@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Marcellus+SC&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');

/* リセット
---------------------------------------------------------- */
html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h2, h3, h4, h5, h6,
pre, form, fieldset, input, textarea, p, table, th, td, button, a, span {
	margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
ol,
ul {
	list-style: none;
}
h1, h2, h2, h3, h4, h5, h6, strong {
	font-weight: 700;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
address {
	font-style: normal;
}
button {
	font-family: inherit;
	color: inherit;
	outline: none;
}

/* レイアウト
----------------------------------------*/
html {
	font-size: 1rem;
	font-size: 10px;
	height: 100%;
}
body {
	color: #333;
	font-family: "Noto Sans JP", sans-serif;
	background: #fff;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.5;
	height: 100%;
	-webkit-text-size-adjust: 100%;
}
body.open,
body.modal_open,
body.js-loading:not(.js-loading-exit) {
	width: 100%;
	height: 100%;
	position: fixed;
	overflow-y: scroll;
}
img {
	image-rendering: -webkit-optimize-contrast;
	display: block;
}
a,
button {
	text-decoration: none;
	color: inherit;
	transition: opacity .3s;
}
table,
tbody,
thead,
tr,
th,
td {
	position: static;
}
main {
	overflow: clip;
}
@media (hover:hover) {
	a:hover,
	button:hover {
		opacity: .6;
	}
}
@media only screen and (max-width: 1350px) {
	html {
		font-size: .7408vw;
	}
}
@media only screen and (min-width: 769px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
}
@media only screen and (max-width: 768px) {
	img {
		width: 100%;
	}
	html {
		font-size: 2.5641vw;
	}
}

/* font
----------------------------------------*/
.en {
	font-family: "Marcellus SC", serif;
}
.mincho {
	font-family: "Noto Serif JP", serif;
}

/* img
----------------------------------------*/
img {
	max-width: 100%;
	height: auto;
}

/*表示
----------------------------------------*/
@media only screen and (min-width: 769px) {
	.sp {
		display: none !important;
	}
}

@media only screen and (max-width: 768px) {
	.pc {
		display: none !important;
	}
}

/*loading
----------------------------------------*/
body::before {
	content: '';
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(69, 102, 118, .2);
	z-index: 2001;
	opacity: 0;
	pointer-events: none;
	transition: opacity 3.2s cubic-bezier(.4, 0, .2, 1);
	will-change: opacity;
}
body.js-loading::before {
	opacity: 1;
}
body.js-loading.js-loading-exit::before {
	opacity: 0;
}
.loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #fff;
	z-index: 3000;
	-webkit-mask-image: linear-gradient(#000, #000), url(../img/logo.svg);
	mask-image: linear-gradient(#000, #000), url(../img/logo.svg);
	-webkit-mask-type: alpha;
	mask-type: alpha;
	-webkit-mask-size: 100% 100%, 50rem auto;
	mask-size: 100% 100%, 50rem auto;
	-webkit-mask-repeat: no-repeat, no-repeat;
	mask-repeat: no-repeat, no-repeat;
	-webkit-mask-position: center, center;
	mask-position: center, center;
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 3.2s cubic-bezier(.4, 0, .2, 1), visibility 0s linear 3.2s;
	will-change: opacity;
}
body.js-loading .loading {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}
body.js-loading.js-loading-exit .loading {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}
@media only screen and (max-width: 768px) {
	.loading {
		-webkit-mask-size: 100% 100%, 28rem auto;
		mask-size: 100% 100%, 28rem auto;
	}
}

/*header
----------------------------------------*/
.header {
	position: fixed;
	top: 4rem;
	left: 0;
	right: 0;
	z-index: 1000;
}
.header_btn {
	display: none;
}
@media only screen and (max-width: 768px) {
	.header {
		top: 0;
	}
	.header_btn {
		position: absolute;
		top: 1.5rem;
		right: 1.6rem;
		appearance: none;
		padding: 0;
		border: 0;
		display: block;
		width: 5rem;
		height: 5rem;
		border-radius: 50%;
		background: rgba(255, 255, 255, .85);
		z-index: 10;
		transition: background .3s;

		-webkit-backdrop-filter: blur(.4rem);
		backdrop-filter: blur(.4rem);

		@supports (-webkit-app-region: inherit) and ((backdrop-filter: url(#glass-distortion)) or (-webkit-backdrop-filter: url(#glass-distortion))) {
			-webkit-backdrop-filter: url(#glass-distortion) blur(.2rem);
			backdrop-filter: url(#glass-distortion) blur(.2rem);
		}
	}
	.open .header_btn {
		background: rgba(137, 145, 162, 0.1);
	}
	.header_btn::before,
	.header_btn::after {
		content: '';
		display: block;
		width: 2.2rem;
		height: .2rem;
		background: #333;
		position: absolute;
		top: 2rem;
		right: 1.4rem;
		transition: transform .3s, background .3s;
	}
	.header_btn::after {
		width: 1.8rem;
		top: 2.8rem;
	}
	.open .header_btn::before,
	.open .header_btn::after {
		background: #fff;
		width: 2.4rem;
		top: 2.4rem;
		right: 1.2rem;
		transform: rotate(20deg);
	}
	.open .header_btn::after {
		background: #fff;
		transform: rotate(-20deg);
	}
}

/* gnav
----------------------------------------*/
.gnav ul {
	display: flex;
	justify-content: center;
	gap: 1.5rem;
}
@media only screen and (min-width: 769px) {
	.gnav ul a {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 16.5rem;
		height: 4rem;
		border-radius: 2rem;
		padding-top: .2rem;
		background: rgba(255, 255, 255, .85);
		font-size: 1.3rem;
		letter-spacing: .35rem;
		padding-left: .35rem;
		-webkit-backdrop-filter: blur(.6rem);
		backdrop-filter: blur(.6rem);

		@supports (-webkit-app-region: inherit) and ((backdrop-filter: url(#glass-distortion)) or (-webkit-backdrop-filter: url(#glass-distortion))) {
			-webkit-backdrop-filter: url(#glass-distortion) blur(.2rem);
			backdrop-filter: url(#glass-distortion) blur(.2rem);
		}
	}
}
@media only screen and (max-width: 768px) {
	.gnav {
		background: rgba(27, 58, 92, 0.2);
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		opacity: 0;
		pointer-events: none;
		transition: opacity .5s;
		-webkit-backdrop-filter: blur(.7rem);
		backdrop-filter: blur(.7rem);

		@supports (-webkit-app-region: inherit) and ((backdrop-filter: url(#glass-distortion)) or (-webkit-backdrop-filter: url(#glass-distortion))) {
			-webkit-backdrop-filter: url(#glass-distortion) blur(.3rem);
			backdrop-filter: url(#glass-distortion) blur(.3rem);
		}
	}
	.open .gnav {
		opacity: 1;
		pointer-events: all;
	}
	.gnav_inner {
		width: 34rem;
		height: 100%;
		overflow: auto;
		margin: 0 0 0 auto;
		padding: 10.5rem 0 2.9rem 4.5rem;
		background: url(../img/gnav_bg_01.jpg) no-repeat center center / cover;
		transition: transform .3s;
		transform: translateX(100%);
	}
	.open .gnav_inner {
		transform: none;
	}
	.gnav ul {
		display: block;
		padding-bottom: 6rem;
	}
	.gnav ul li {
		border-bottom: .1rem solid rgba(255, 255, 255, .5);
	}
	.gnav ul li + li {
		margin-top: 3rem;
	}
	.gnav ul a {
		display: block;
		color: #fff;
		font-size: 1.4rem;
		letter-spacing: .35rem;
		padding: 0 0 2.5rem 1.6rem;
	}
	.gnav ul a::before {
		content: '';
		display: block;
		width: .5rem;
		height: .5rem;
		background: #F67F34;
		border-radius: 50%;
		position: absolute;
		left: 0;
		top: .8rem;
	}
	.gnav_box {
		min-height: 100%;
		padding-bottom: 6rem;
	}
	.gnav_instagram {
		display: flex;
		align-items: center;
		gap: 1.7rem;
		color: #fff;
		position: absolute;
		right: 2rem;
		bottom: 0;
	}
	.gnav_instagram dt {
		font-size: 1.3rem;
		letter-spacing: .3rem;
	}
	.gnav_instagram dd {
		display: flex;
		align-items: center;
		gap: .9rem;
	}
	.gnav_instagram .sns_icon {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 4rem;
		height: 4rem;
		border-radius: 50%;
		border: .1rem solid #fff;
	}
	.gnav_instagram .sns_icon img {
		width: 1.7rem;
	}
	.gnav_instagram .sns_comingsoon {
		font-size: 1rem;
		letter-spacing: .14rem;
		white-space: nowrap;
	}
}

/*mv_ttl
----------------------------------------*/
.mv {
	height: 100vh;
	margin-bottom: 10rem;
}
.mv_img {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	isolation: isolate;
	pointer-events: none;
}
.mv_img::after {
	content: '';
	position: absolute;
	inset: 0;
	background: #333;
	mix-blend-mode: multiply;
	opacity: .15;
	z-index: 0;
}
.mv_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mv_ttl {
	max-width: 110.2rem;
	margin: 0 auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 7rem;
}
.mv_ttl img {
	width: 45.5rem;
	margin: 0 0 0 auto;
}
@media only screen and (max-width: 768px) {
	    .p-wedding .mv-sec .page-title {
        width: calc(100% - 100px);
    }
	.mv {
		margin-bottom: 5rem;
	}
	.mv_ttl {
		max-width: 25.6rem;
		height: 12.733rem;
		margin: auto 0;
		left: auto;
		right: 1.1rem;
		top: 7.5rem;
		bottom: 0;
	}
	.mv_ttl img {
		width: 100%;
	}
	.mv_period {
		width: 16rem;
		position: absolute;
		left: 2.5rem;
		bottom: 6.1rem;
	}
}

/*intro
----------------------------------------*/
.intro {
	text-align: center;
	font-size: 2.6rem;
	line-height: 2.2308;
	color: #fff;
	margin-bottom: 16.2rem;
}
.intro_bg {
	min-width: 100vw;
	min-height: 100vw;
	width: 262.3rem;
	height: 262.3rem;
	border-radius: 50%;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
.intro_box {
	z-index: 10;
	padding: 20.9rem 0 0;
	font-weight: 500;
	letter-spacing: .5rem;
}
@media only screen and (max-width: 768px) {
	.intro {
		font-size: 1.8rem;
		line-height: 2;
		margin-bottom: 11rem;
	}
	.intro_bg {
		width: 118.6rem;
		height: 227.4rem;
	}
	.intro_box {
		padding: 12.6rem 0 0 .5rem;
	}
}

/*time
----------------------------------------*/
.time {
	max-width: 120rem;
	margin: 0 auto 5rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	z-index: 10;
}
.time_item {
	display: block;
	border: .1rem solid #8FA4B4;
	padding: 5.6rem 4.9rem 3.4rem;
	color: inherit;
	text-decoration: none;
}
.time_item:nth-child(1) {
	background: #F4F1EC;
	border-radius: 1rem 0 0 1rem;
	border-right: 0;
}
.time_item:nth-child(2) {
	background: linear-gradient(to bottom, #faefe4 0%,#efebe3 50%,#ebe6d9 100%);
	border-radius: 0 1rem 1rem 0;
}
.time_item h2 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 2rem;
}
.time_item p.mincho {
    margin-top: 20px;
    text-align: center;
    font-weight: 700;
    letter-spacing: .2rem;
    font-size: 1.5rem;
    color: #1B3A5C;
}
.time_item h2 img:nth-child(1) {
	width: 35.9rem;
	margin: 1.6rem 0 0 .1rem;
}
.time_item h2 img:nth-child(2) {
	width: 8.6rem;
}
.time_item:nth-child(2) h2 img:nth-child(1) {
	width: 33.9rem;
	margin: .7rem 0 0 .1rem;
}
.time_item figure {
	width: 50rem;
	margin: 0 auto;
	border-radius: 1rem;
	overflow: hidden;
}
.time_item dl {
	border-top: .1rem solid rgba(143, 164, 180, .5);
	margin-top: 2.8rem;
	display: grid;
	grid-template-columns: 10.2rem auto;
	padding: 2.6rem 0 0;
}
.time_item dl dt {
	font-size: 1.2rem;
	color: #8FA4B4;
	letter-spacing: .3rem;
}
.time_item dl dd {
	color: #1B3A5C;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: .3rem;
}
.time_item dl dd span {
	display: block;
	font-size: 2rem;
	font-weight: 600;
	letter-spacing: .64rem;
	line-height: 1;
	margin: -.1rem 0 .9rem;
}
@media only screen and (max-width: 768px) {
	.time_item p.mincho {
    font-size: 1.3rem;
}
	.time {
		margin: 0 1rem 2rem;
		display: block;
	}
	.time_item {
		border: .1rem solid #8FA4B4;
		padding: 1.9rem 2.9rem 2.4rem;
	}
	.time_item:nth-child(1) {
		border-radius: .5rem .5rem 0 0;
		border-bottom: 0;
	}
	.time_item:nth-child(2) {
		border-radius: 0 0 .5rem .5rem;
		padding-top: 2rem;
	}
	.time_item h2 img:nth-child(1) {
		width: 22.7rem;
		margin: 1rem 0 0 .1rem;
	}
	.time_item h2 img:nth-child(2) {
		width: 6rem;
	}
	.time_item:nth-child(2) h2 img:nth-child(1) {
		width: 22.59rem;
	}
	.time_item figure {
		width: auto;
		border-radius: .5rem;
	}
	.time_item dl {
		margin-top: 2rem;
		grid-template-columns: 12.2rem auto;
		padding: 1.8rem 0 0;
	}
	.time_item dl dt {
		margin-top: -.1rem;
	}
	.time_item dl dd {
		font-size: 1.3rem;
	}
	.time_item dl dd span {
		font-size: 1.6rem;
		letter-spacing: .62rem;
		margin: 0 -1rem .8rem 0;
	}
}

/*important
----------------------------------------*/
.important {
	background: #F8F8F5;
	max-width: 110rem;
	margin: 0 auto 15rem;
	border-radius: 1rem;
	padding: 6rem 5rem 5.1rem;
	z-index: 10;
	display: grid;
	grid-template-columns: 36.8rem auto;
}
.important h2 {
	font-size: 1.8rem;
	font-weight: 600;
	color: #1B3A5C;
	line-height: 2;
	letter-spacing: .3rem;
	margin-top: -.9rem;
}
.important h2 span {
	display: block;
	font-size: 1.4rem;
	color: #F67F34;
	font-weight: 400;
	margin-bottom: .8rem;
}
.important_box p {
	font-size: 1.3rem;
	font-weight: 500;
	letter-spacing: .3rem;
	line-height: 2;
}
.important_box ul {
	background: #F4F1EC;
	border-radius: .5rem;
	padding: 2.2rem 3.1rem;
	font-size: 1.3rem;
	line-height: 2;
	font-weight: 500;
	letter-spacing: .3rem;
	margin: 1.3rem 0 2.2rem;
}
.important_box ul li {
	padding-left: 2.3rem;
}
.important_box ul li::before {
	content: '';
	display: block;
	width: .7rem;
	height: .7rem;
	border-radius: 50%;
	background: #F67F34;
	position: absolute;
	top: .9rem;
	left: 0;
}
@media only screen and (max-width: 768px) {
	.important {
		max-width: 35rem;
		margin: 0 auto 9.1rem;
		border-radius: .5rem;
		padding: 5.2rem 2rem 4.3rem;
		display: block;
	}
	.important h2 {
		text-align: center;
		font-size: 1.6rem;
		margin: 0 0 2.2rem;
	}
	.important h2 span {
		font-size: 1.3rem;
		margin-bottom: 1.7rem;
	}
	.important_box p {
		text-align: center;
	}
	.important_box ul {
		padding: 1.8rem 1.5rem 1.5rem;
		margin: 2.2rem 0 3.1rem;
	}
	.important_box ul li {
		padding-left: 2.4rem;
	}
	.important_box ul li::before {
		left: .3rem;
	}
}

/*daytime
----------------------------------------*/
.daytime {
	z-index: 9;
	padding: 2.8rem 0 0;
	margin-bottom: 0;
}
.daytime::before {
	content: '';
	display: block;
	width: 100%;
	position: absolute;
	left: 0;
	top: -28.5rem;
	bottom: 0;
	background: linear-gradient(to bottom, rgba(244,241,236,0),rgba(244,241,236,1) 38.4rem);
	z-index: 9;
}
.daytime#evening {
	padding-bottom: 0;
	margin-bottom: 0;
}
.daytime.hide {
	display: none;
}
.daytime#evening::before {
	top: -26.5rem;
	background: linear-gradient(to bottom, rgba(244, 241, 236, 0), rgba(27, 58, 92, 0.3) 15rem, rgba(27, 58, 92, 1) 30rem);
}
.daytime + .daytime {
	margin-top: 30rem;
}
#daytime + #evening::before {
	top: -30rem;
	background: linear-gradient(to bottom, rgba(244, 241, 236, 1), rgba(27, 58, 92, 1) 30rem);
}
#evening + #daytime::before {
	top: -30rem;
	background: linear-gradient(to bottom, rgba(27, 58, 92, 1), rgba(244, 241, 236, 1) 30rem);
}
.daytime_inner {
	max-width: 120rem;
	margin: 0 auto;
	z-index: 12;
}
.daytime h2 {
	width: 71.8rem;
	margin-left: .3rem;
}
.daytime h2::before {
	content: '';
	display: block;
	background: url(../img/icon_daytime.svg) no-repeat left top / 100% auto;
	width: 4rem;
	height: 4rem;
	position: absolute;
	top: 1rem;
	right: -4.5rem;
}
.daytime h2 img {
	width: 100%;
}
.daytime#evening h2 {
	width: 67.72rem;
}
.daytime#evening h2::before {
	background-image: url(../img/icon_evening.svg);
	width: 2.2rem;
	height: 3.3rem;
	right: -5.2rem;
	top: .9rem;
}
.daytime#evening h2 img {
	filter: brightness(0) invert(1);
}
.daynavi {
	width: 41rem;
	height: 6rem;
	border-radius: 3rem;
	padding: .5rem;
	background: #F4F1EC;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	box-shadow: .3rem .3rem 1rem rgba(0, 0, 0, .08);
	position: absolute;
	top: 2.2rem;
	right: 0;
}
.daynavi a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 20rem;
	height: 5rem;
	border-radius: 2.5rem;
	font-size: 1.3rem;
	letter-spacing: .6rem;
	color: #1B3A5C;
	padding-bottom: .1rem;
}
.daynavi a::before {
	content: '';
	display: block;
	background: url(../img/icon_daytime.svg) no-repeat left top / 100% auto;
	width: 1.8rem;
	height: 1.8rem;
	margin-right: 1.2rem;
}
.daynavi a[href="#evening"]::before {
    background-image: url(../img/icon_evening.svg);
    width: 1rem;
    height: 2rem;
    margin: .7rem 1.4rem 0 .2rem;
}
.daynavi a.current {
	background: #1B3A5C;
	color: #fff;
}
.daynavi a.current::before {
	filter: brightness(0) invert(1);
}
.daynavi a .en {
	margin-right: .1rem;
}
.daytime_head {
display: flex;
    justify-content: space-between;
    margin: 3.3rem 0 8.7rem;
    flex-direction: column-reverse;
}
#evening .daytime_head {
	margin-top: 5.1rem;
}
#evening .daytime_head p {
    color: #fff;
    line-height: 1.55;
    letter-spacing: .12rem;
    font-size: 1.3rem;
}
.daytime_time {
	text-align: left;
	order: 2;
	color: #8FA4B4;
	font-size: 1.8rem;
	letter-spacing: .3rem;
	margin: .2rem -.2rem 2rem 0;
}
.daytime_time > span {
	display: block;
	font-size: 3rem;
	letter-spacing: .6rem;
	color: #1B3A5C;
	margin-right: -.3rem;
}
.daytime_time > span span {
	font-size: 2.4rem;
	font-family: "Noto Sans JP", sans-serif;
}
.daytime_head h3 {
	font-size: 1.8rem;
	letter-spacing: .3rem;
	font-weight: 600;
	line-height: 2.2222;
	color: #1B3A5C;
}
#evening .daytime_time > span,
#evening .daytime_head h3 {
	color: #fff;
}
.daytime_list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8rem 4.5rem;
}
.daytime_list li {
	display: flex;
}
.daytime_list a {
	display: flex;
	flex-direction: column;
	width: 100%;
}
.daytime_list a::after {
	content: '';
	display: block;
	width: 2.5rem;
	height: 2.5rem;
	background: #F67F34 url(../img/icon_plus.svg) no-repeat center center / 1.1rem auto;
	position: absolute;
	right: 3.1rem;
	bottom: 1.8rem;
	border-radius: .3rem;
}
.daytime_list figure {
	overflow: hidden;
	border-radius: .5rem .5rem 0 0;
}
.daytime_list figure img {
	width: 100%;
	aspect-ratio: 37 / 44;
	object-fit: cover;
}
.daytime_list_box {
	background: #F8F8F5;
	box-shadow: .3rem .4rem 2rem rgba(0, 0, 0, .05);
	border-radius: .5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	margin-top: -.5rem;
	padding: 2.7rem 2.8rem 1.6rem;
}
.daytime_list_box h3 {
	font-size: 1.6rem;
	color: #1B3A5C;
	line-height: 1.5882;
	letter-spacing: .3rem;
	font-weight: 700;
	margin-bottom: 1.2rem;
	overflow-wrap: anywhere;
}
.daytime_list_box h3 span {
	display: block;
}
.daytime_list_box h3.has-drink {
	margin-bottom: .4rem;
}
.daytime_list_drink {
    font-size: 1.3rem;
    line-height: 1.5;
    letter-spacing: .15rem;
    color: #1B3A5C;
    margin-bottom: 1.4rem;
	font-weight: 600;
    overflow-wrap: anywhere;
}
#evening .daytime_list_menu {
	min-height: 8rem;
	margin-bottom: 1.6rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#evening .daytime_list_drink {
	margin-bottom: 0;
}
.daytime_list .daytime_list_edited {
	margin-bottom: 3.8rem;
}
.daytime_list_edited dt {
	font-size: 1.2rem;
	color: #8FA4B4;
	letter-spacing: .3rem;
	margin-bottom: 1rem;
}
.daytime_list_edited dd {
	display: flex;
	align-items: center;
}
.daytime_list_img {
	display: flex;
	gap: 1rem;
	margin-left: -.1rem;
}
.daytime_list_img figure {
	width: 8rem;
	border-radius: .3rem;
	overflow: hidden;
}
.daytime_list_img figure img {
	width: 100%;
	aspect-ratio: 1;
}
.daytime_list_edited h4 {
	flex: 1;
	padding-left: 3rem;
	color: #1B3A5C;
	font-weight: 600;
	letter-spacing: 0.1rem;
	overflow-wrap: anywhere;
}
.daytime_list_edited h4 span {
	display: block;
	letter-spacing: .15rem;
	margin-bottom: .7rem;
	overflow-wrap: anywhere;
}
.daytime_list_price {
	border-top: .1rem solid #E3E3E3;
	font-size: 1.2rem;
	color: #8FA4B4;
	letter-spacing: .2rem;
	font-weight: 700;
	margin: 3.8rem 0 0;
	padding-top: 1.3rem;
}
.daytime_list .daytime_list_price {
	margin-top: auto;
}
.daytime_list_price .en {
	font-size: 2rem;
	color: #1B3A5C;
	font-weight: 400;
	margin-right: .4rem;
}
@media only screen and (max-width: 768px) {
	#evening .daytime_head p {
    font-size: 1.2rem;
}
	.daytime_list_drink {
    text-align: center;
	font-size: 1.1rem;
}
	#evening .daytime_list_menu {
		min-height: 8.8rem;
		margin-bottom: 1.2rem;
	}
	.daytime_list .daytime_list_edited {
		margin-bottom: 1.8rem;
	}
	.daytime {
		padding: 2rem 0 0;
		margin-bottom: 0;
	}
	.daytime#evening {
		padding-bottom: 0;
		margin-bottom: 0;
	}
	.daytime::before {
		top: -10rem;
		background: linear-gradient(to bottom, rgba(224,241,246, 0), rgba(244,241,236, 1.3) 15rem, rgba(244,241,236, 1) 42.3rem);
	}
	.daytime#evening::before {
		top: -10rem;
		background: linear-gradient(to bottom, rgba(244, 241, 236, 0), rgba(27, 58, 92, 1.3) 15rem, rgba(27, 58, 92, 1) 42.3rem);
	}
	.daytime + .daytime {
		margin-top: 22rem;
	}
	#daytime + #evening::before {
		top: -22rem;
		background: linear-gradient(to bottom, rgba(244, 241, 236, 1), rgba(27, 58, 92, 1) 22rem);
	}
	#evening + #daytime::before {
		top: -22rem;
		background: linear-gradient(to bottom, rgba(27, 58, 92, 1), rgba(244, 241, 236, 1) 22rem);
	}
	.daytime_inner {
		max-width: 35rem;
	}
	.daytime h2 {
		width: 31.042rem;
		margin-left: .2rem;
	}
	.daytime h2::before {
		width: 3rem;
		height: 3rem;
		top: -.3rem;
		right: -3.8rem;
	}
	.daytime#evening h2 {
		width: 30.5rem;
	}
	.daytime#evening h2::before {
		width: 1.75rem;
		height: 2.7rem;
		right: -3.5rem;
		top: .6rem;
	}
	.daynavi {
		width: 35rem;
		position: relative;
		top: auto;
		right: auto;
		margin: 0 auto 6.3rem;
	}
	.daynavi a {
		width: 17rem;
		font-size: 1.2rem;
		letter-spacing: .5rem;
		padding-top: .1rem;
	}
	.daynavi a::before {
		width: 1.2rem;
		height: 1.2rem;
		margin-right: .8rem;
	}
	.daynavi a[href="#evening"]::before {
		width: .7rem;
		height: 1.1rem;
		margin: -.1rem 1.2rem 0 .8rem;
	}
	.daytime_head {
		display: block;
		margin: 2rem 0 4.8rem;
	}
	#evening .daytime_head {
		margin: 2.7rem 0 3.8rem;
	}
	.daytime_time {
		font-size: 1.6rem;
		margin-bottom: 2rem;
	}
	.daytime_time > span {
		font-size: 2rem;
		margin-bottom: .7rem;
	}
	.daytime_time > span span {
		font-size: 2rem;
	}
	.daytime_head h3 {
		font-size: 1.6rem;
		line-height: 2.25;
		margin-left: 1.1rem;
	}
	.daytime_list {
		grid-template-columns: repeat(2, 1fr);
		gap: 4rem 1rem;
	}
	.daytime_list a::after {
		width: 2rem;
		height: 2rem;
		background-size: .851rem auto;
		right: 1.5rem;
		bottom: 1.5rem;
	}
	.daytime_list figure img {
		aspect-ratio: 17 / 20.2;
	}
	.daytime_list_box {
		margin-top: -.4rem;
		padding: 1.9rem 1rem 1.4rem;
	}
	.daytime_list_box h3 {
		font-size: 1.2rem;
		line-height: 1.55;
		letter-spacing: .12rem;
		text-align: center;
		margin-bottom: 1.1rem;
	}
	.daytime_list_box h3.has-drink {
		margin-bottom: .6rem;
	}
	.daytime_list_edited dt {
		font-size: 1rem;
		margin-bottom: 1.2rem;
	}
	.daytime .daytime_list_edited dt {
		font-size: 1rem;
		text-align: center;
		margin-bottom: .8rem;
	}
	.daytime .daytime_list_edited dd {
		display: block;
	}
	.daytime_list_img {
		gap: .8rem;
	}
	.daytime .daytime_list_img {
		justify-content: center;
		gap: .8rem;
		margin: 0 0 1.5rem;
	}
	.daytime_list_img figure {
		width: 6.2rem;
	}
	.daytime .daytime_list_img figure {
		width: 5.4rem;
	}
	.daytime .daytime_list_img figure img {
		width: 100%;
		aspect-ratio: 1;
	}
	.daytime_list_edited h4 {
		padding-left: 2.4rem;
	}
	.daytime .daytime_list_edited h4 {
		padding-left: 0;
		text-align: center;
		font-size: 1.3rem;
	}
	.daytime .daytime_list_edited h4 span {
		font-size: 1.2rem;
		font-weight: 500;
		letter-spacing: .2rem;
		margin-bottom: .3rem;
	}
	.daytime_list_price {
		font-size: 1.1rem;
		margin: 1.8rem 0 0;
		padding-top: 1rem;
	}
	.daytime_list .daytime_list_price {
		margin-top: auto;
	}
	.daytime_list_price .en {
		font-size: 1.4rem;
	}
}

/*sidemenu
----------------------------------------*/
.sidemenu {
	padding: 25.6rem 0 24.1rem;
	overflow: clip;
	z-index: 2;
}
.sidemenu::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 30rem;
	background: linear-gradient(to bottom, rgba(27, 58, 92, 1),rgba(27, 58, 92, 0));
}
.daytime.hide#evening ~ .sidemenu::after,
.sidemenu.is-after-daytime::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 30rem;
	background: linear-gradient(to bottom, rgba(244, 241, 236, 1),rgba(244, 241, 236, 0));
}
.sidemenu::before {
	content: '';
	display: block;
	width: 315.5rem;
	height: 315.5rem;
	min-width: 100vw;
	min-height: 100vw;
	border-radius: 50%;
	background: #F0F8FB;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	box-shadow: .4rem .4rem 4.4rem rgba(0, 0, 0, .05);
}
.sidemenu_inner {
	max-width: 120rem;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 42rem auto;
	z-index: 10;
}
.sidemenu_head {
	padding-left: .1rem;
}
.sidemenu_head h2 {
	width: 30.4rem;
	margin: 0 0 4.6rem .2rem;
}
.sidemenu_head p {
	font-size: 1.8rem;
	font-weight: 600;
	letter-spacing: .3rem;
	line-height: 2.1111;
	color: #1B3A5C;
}
.sidemenu_box ul {
	columns: 2;
	column-gap: 2rem;
	color: #1B3A5C;
	margin: .7rem -3.4rem 0 0;
}
.sidemenu_box ul li {
	padding: 0 0 4.4rem 2rem;
}
.sidemenu_box ul h3 {
	font-size: 1.6rem;
	letter-spacing: .4rem;
	font-weight: 700;
}
.sidemenu_box ul li::before {
	content: '';
	display: block;
	width: .7rem;
	height: .7rem;
	background: #F67F34;
	border-radius: 50%;
	position: absolute;
	top: .9rem;
	left: 0;
}
.sidemenu_box ul li:last-of-type:before {
	display: none;
}
.sidemenu_price {
	font-size: 1.2rem;
	color: #8FA4B4;
	font-weight: 700;
	letter-spacing: .2rem;
	margin-top: .8rem;
}
.sidemenu_price .en {
	font-size: 2rem;
	color: #1B3A5C;
	font-weight: 400;
	margin-right: .6rem;
}
.sidemenu_price .mincho {
	font-size: 1.4rem;
	color: #1B3A5C;
	margin: 0 .5rem 0 1.3rem;
	letter-spacing: .4rem;
}
.sidemenu_card {
	width: 74rem;
	margin: 1.7rem auto 0;
}
.sidemenu_card a {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	background: #F8F8F5;
}
.sidemenu_card a::after {
	content: '';
	display: block;
	width: 2.5rem;
	height: 2.5rem;
	background: #F67F34 url(../img/icon_plus.svg) no-repeat center center / 1.1rem auto;
	position: absolute;
	right: 3rem;
	bottom: 3rem;
	border-radius: .3rem;
}
.sidemenu_card a > figure {
	border-radius: .5rem 0 0 .5rem;
	overflow: hidden;
}
.sidemenu_card a.kids > figure::before,
.modal_item.kids > figure::before {
	content: '';
	display: block;
	width: 8rem;
	height: 8rem;
	background: url(../img/icon_kids.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 1.5rem;
	left: 1.5rem;
}
.sidemenu_card_box {
	box-shadow: .3rem .4rem 1rem rgba(0, 0, 0, .05);
	display: flex;
	align-items: flex-end;
}
.sidemenu_card_box h3 {
	font-size: 1.7rem;
	line-height: 1.5882;
	color: #1B3A5C;
	font-weight: 700;
	letter-spacing: .3rem;
	margin: 0 0 1.2rem;
}
.sidemenu_card_box_inner {
	padding: 3rem 3rem 2.8rem;
	margin: auto 0 0;
	height: fit-content;
	width: 100%;
}
.sidemenu_card .daytime_list_price {
	padding-top: 2.3rem;
	margin-top: 6.5rem;
}
.sidemenu_btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22rem;
	height: 5rem;
	border-radius: 2.5rem;
	font-size: 1.3rem;
	letter-spacing: .5rem;
	color: #1B3A5C;
	border: .1rem solid #1B3A5C;
	margin: 4.4rem 0 0;
	padding: .2rem 1.1rem 0 0;
	box-shadow: .4rem .4rem 1.4rem rgba(0, 0, 0, .15);
}
.sidemenu_btn::after {
	content: '';
	display: block;
	width: 1.4rem;
	height: 1.4rem;
	background: url(../img/icon_external.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 2.2rem;
	margin: auto 0;
}
@media only screen and (max-width: 768px) {
	.sidemenu {
		padding: 12.6rem 0 12rem;
		overflow: visible;
	}
	.sidemenu::after {
		height: 25rem;
		background: linear-gradient(to bottom, rgba(27, 58, 92, 1), rgba(27, 58, 92, .4) 40%, rgba(240, 248, 251, 90%));
	}
	.daytime.hide#evening ~ .sidemenu::after,
	.sidemenu.is-after-daytime::after {
		background: linear-gradient(to bottom, rgba(244, 241, 236, 1), rgba(244, 241, 236, .4) 40%, rgba(240, 248, 251, 90%));
	}
	.sidemenu::before {
		width: 165rem;
		height: 165rem;
		border-radius: 0 0 50% 50%;
		top: 0;
	}
	.sidemenu_inner {
		margin: 0 3.1rem;
		padding-bottom: 10rem;
		display: block;
	}
	.sidemenu_head {
		position: static;
	}
	.sidemenu_head h2 {
		width: 22.7rem;
		margin: 0 0 4.5rem -.4rem;
	}
	.sidemenu_head p {
		font-size: 1.6rem;
		line-height: 2.125;
	}
	.sidemenu_box ul {
		columns: 1;
		margin: 6.1rem 0 0;
	}
	.sidemenu_box ul li {
		padding: 0 0 2.6rem 2rem;
	}
	.sidemenu_box ul h3 {
		line-height: 1.6875;
	}
	.sidemenu_box ul li::before {
		top: 1.1rem;
	}
	.sidemenu_price {
		margin-top: .6rem;
	}
	.sidemenu_price .en {
		font-size: 1.6rem;
		margin-right: .5rem;
	}
	.sidemenu_price .mincho {
		font-size: 1.2rem;
		margin: 0 .2rem 0 .3rem;
	}
	.sidemenu_card {
		width: auto;
		margin: 2.8rem auto 0;
	}
	.sidemenu_card a {
		display: block;
	}
	.sidemenu_card a::after {
		right: 2rem;
		bottom: 2rem;
	}
	.sidemenu_card a > figure {
		border-radius: .5rem .5rem 0 0;
	}
	.sidemenu_card a.kids > figure::before,
	.modal_item.kids > figure::before {
		width: 7rem;
		height: 7rem;
		top: 1.1rem;
		left: 1rem;
	}
	.sidemenu_card_box {
		margin-top: -.4rem;
		background: #F8F8F5;
		border-radius: .5rem .5rem 0 0;
	}
	.sidemenu_card_box h3 {
		margin: 0 0 1.4rem;
	}
	.sidemenu_card_box_inner {
		padding: 1.7rem 2rem 2.1rem;
	}
	.sidemenu_card .daytime_list_price {
		padding-top: 1.3rem;
		margin-top: 1.4rem;
		font-size: 1.2rem;
	}
	.sidemenu_card .daytime_list_price span {
		font-size: 1.8rem;
		vertical-align: -.1rem;
	}
	.sidemenu_btn {
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		margin: 0 auto;
		width: 29rem;
	}
	.sidemenu_btn::after {
		right: 5.7rem;
	}
}

/*super
----------------------------------------*/
.super {
	margin-top: -21rem;
	padding-bottom: 25.8rem;
	color: #fff;
}
.super::before {
	content: '';
	position: sticky;
	top: 0;
	left: 0;
	display: block;
	height: 100vh;
	width: 100%;
	background: url(../img/super_bg_01.jpg) no-repeat center center / cover;
	margin-bottom: -100vh;
}
.super h2 {
	width: 108.9rem;
	margin: 0 auto 7.3rem;
	padding: 34rem 0 0;
}
.super_inner {
	max-width: 110rem;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 55rem auto;
}
.super_inner h3 {
	font-size: 3rem;
	letter-spacing: 1rem;
	line-height: 1.9333;
}
.super_box {
	padding-top: .8rem;
}
.super_box > p {
	font-size: 1.4rem;
	letter-spacing: .3rem;
	line-height: 2.2857;
	font-weight: 700;
}
.super_prpfile {
	display: flex;
	align-items: flex-start;
	margin: 4.9rem 0 0;
}
.super_prpfile figure {
	width: 13rem;
	height: 13rem;
	border-radius: .5rem;
	overflow: hidden;
}
.super_prpfile_box {
	flex: 1;
	padding-left: 2.3rem;
}
.super_prpfile_box h4 {
	display: flex;
	align-items: center;
	font-size: 1.3rem;
	letter-spacing: .3rem;
	margin: .5rem 0 1.5rem;
}
.super_prpfile_box h4 .mincho {
	font-size: 2.4rem;
	letter-spacing: .4rem;
	font-weight: 700;
	margin: -.6rem 0 0 1.3rem;
}
.super_prpfile_box h4 a {
	width: 3rem;
	display: block;
	margin: -.3rem 0 0 1.3rem;
}
.super_prpfile_box p {
	font-size: 1.3rem;
	font-weight: 500;
	letter-spacing: .2rem;
	line-height: 1.9231;
}
@media only screen and (min-width: 1366px) {
	.super {
		margin-top: clamp(calc(-21rem - 32vw), calc(-21rem - (100vw - 1366px) * 1.5), -21rem);
	}
	.super h2 {
		padding-top: clamp(34rem, calc(34rem + (100vw - 1366px) * 1.5), calc(34rem + 32vw));
	}
}
@media only screen and (max-width: 768px) {
	.super_prpfile_box h4 a {
	width: 2.2rem;
}
	.super {
		padding-bottom: 20rem;
	}
	.super::before {
		background-image: url(../img/super_bg_01-sp.jpg);
	}
	.super h2 {
		width: 34.2rem;
		margin: 0 0 3.9rem 2.2rem;
		padding: 31rem 0 0;
	}
	.super_inner {
		margin: 0 3rem;
		display: block;
	}
	.super_inner h3 {
		font-size: 2.2rem;
		letter-spacing: .8rem;
		margin-right: -.5rem;
		line-height: 1.9091;
	}
	.super_box {
		padding-top: 2rem;
	}
	.super_box > p {
		font-size: 1.3rem;
		line-height: 2.30769;
		margin-right: -1rem;
	}
	.super_prpfile {
		margin: 7rem 0 0;
	}
	.super_prpfile figure {
		width: 10rem;
		height: 10rem;
	}
	.super_prpfile_box h4 {
		display: block;
		margin: -.5rem 0 1.5rem;
	}
	.super_prpfile_box h4 .mincho {
		display: block;
		font-size: 1.8rem;
		margin: .6rem 0 0;
	}
	.super_prpfile_box h4 a {
		position: absolute;
		right: 0;
		bottom: 2px;
		margin: 0;
	}
	.super_prpfile_box p {
		margin-right: -.5rem;
	}
}

/*info
----------------------------------------*/
.info {
	margin-top: -12.7rem;
	padding: 14.2rem 0 18rem;
	color: #1B3A5C;
	overflow: clip;
}
.info::before {
	content: '';
	display: block;
	width: 378.3rem;
	height: 378.3rem;
	min-width: 100vw;
	min-height: 100vw;
	border-radius: 50%;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	background: linear-gradient(to right, #e9e8de 0%,#dcdfd6 50%,#d9e3de 100%);
}
.info h2 {
	width: 29.6rem;
	margin: 0 auto 4.4rem;
}
.info_txt {
	text-align: center;
	font-size: 2rem;
	font-weight: 600;
	letter-spacing: .4rem;
	margin-bottom: 1.9rem;
}
.info_period {
	text-align: center;
}
.info_period > span:nth-child(1) {
	font-size: 2.8rem;
	letter-spacing: .6rem;
	vertical-align: .5rem;
	margin-right: 1.2rem;
}
.info_period > span:nth-child(2),
.info_period > span:nth-child(4) {
	font-size: 5rem;
	letter-spacing: .1rem;
}
.info_period > span:nth-child(3),
.info_period > span:nth-child(5) {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 4.3rem;
	height: 4.3rem;
	background: #F4F1EC;
	border-radius: 50%;
	font-size: 1.2rem;
	letter-spacing: .2rem;
	vertical-align: 1.2rem;
	margin-left: .9rem;
}
.info_period > span:nth-child(4) {
	margin-left: 6rem;
}
.info_period > span:nth-child(4)::before {
	content: '';
	display: block;
	width: 2.7rem;
	height: .1rem;
	background: #1B3A5C;
	position: absolute;
	left: -4.3rem;
	top: 3.3rem;
}
.info_address {
	text-align: center;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: .2rem;
	margin: 2.6rem 0 0;
}
.info_address_gap {
	display: inline-block;
	width: .7em;
}
.info_address::before {
	content: '';
	display: inline-block;
	background: url(../img/icon_map.svg) no-repeat left top / 100% auto;
	width: 1.5rem;
	height: 2rem;
	margin-right: 1rem;
	vertical-align: -.5rem;
}
@media only screen and (max-width: 768px) {
	.info {
		padding: 12rem 0 11.7rem;
		z-index: 3;
	}
	.info::before {
		width: 165rem;
		height: 189.3rem;
		background: linear-gradient(to right, #dce6e4 35%,#e2e6e0 50%,#e7e5d9 65%);
	}
	.info h2 {
		width: 18.8rem;
		margin: 0 auto 3.4rem;
	}
	.info_txt {
		font-size: 1.6rem;
		line-height: 2.125;
		padding-left: 1rem;
		margin-bottom: 3rem;
	}
	.info_period > span:nth-child(1) {
		font-size: 1.6rem;
		letter-spacing: .4rem;
		margin-right: .5rem;
	}
	.info_period > span:nth-child(2),
	.info_period > span:nth-child(4) {
		font-size: 3.6rem;
	}
	.info_period > span:nth-child(3),
	.info_period > span:nth-child(5) {
		width: 3.5rem;
		height: 3.5rem;
		font-size: .9rem;
		vertical-align: 1rem;
		padding-top: .2rem;
		margin-left: .7rem;
	}
	.info_period > span:nth-child(4) {
		margin-left: 4.5rem;
	}
	.info_period > span:nth-child(4)::before {
		width: 2.2rem;
		left: -3.3rem;
		top: 2.3rem;
	}
	.info_address {
		width: 23.6rem;
		text-align: left;
		font-size: 1.5rem;
		line-height: 1.88;
		margin: 1.4rem auto 0;
		left: 1.2rem;
	}
	.info_address::before {
		display: block;
		position: absolute;
		top: .5rem;
		left: -2.6rem;
	}
}

/*access
----------------------------------------*/
.access {
	background: #F4F1EC;
	color: #1B3A5C;
	padding: 10.3rem 0 11.2rem;
	z-index: 2;
}
.access h2 {
	width: 57rem;
	position: absolute;
	left: 0;
	right: .4rem;
	top: -8rem;
	padding-top: 4rem;
	margin: 0 auto;
}
.access_address {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: .3rem;
}
.access_map {
	display: block;
	width: fit-content;
	margin: 2.2rem auto 10.2rem;
	padding: 0 0 1.2rem 3rem;
	font-size: 1.3rem;
	font-weight: 600;
	letter-spacing: .13em;
	border-bottom: .1rem solid #8FA4B4;
}
.access_map::before {
	content: '';
	display: block;
	background: url(../img/icon_map_orange.svg) no-repeat left top / 100% auto;
	width: 1.5rem;
	height: 2rem;
	position: absolute;
	top: .1rem;
	left: 0;
}
.access_route {
	max-width: 130rem;
	background: #F8F8F5;
	margin: 0 auto;
	border-radius: .5rem;
	padding: 3rem 0 8.3rem;
	display: flex;
	align-items: center;
}
.access_route h3 {
	width: 33.95rem;
	position: absolute;
	top: -3.6rem;
	left: 5.3rem;
}
.access_route h3 img {
	width: 100%;
}
.access_route_txt {
	padding: 15.2rem 0 0 10rem;
	flex: 1;
}
.access_route_txt h4 {
	font-size: 2.4rem;
	line-height: 1.6667;
	letter-spacing: .5rem;
	margin-bottom: 2.2rem;
}
.access_route_txt p {
	font-size: 1.4rem;
	font-weight: 600;
	line-height: 2;
	letter-spacing: .2rem;
}
.access_route figure {
	width: 68.7rem;
	margin: 0 5rem 0 0;
}
.access_traffic {
	max-width: 119.9rem;
	margin: 7.5rem auto 0;
	display: flex;
}
.access_traffic h4 {
	font-weight: 400;
	color: #F67F34;
	font-size: 1.3rem;
	letter-spacing: .3rem;
	margin-bottom: .8rem;
}
.access_traffic dt {
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: .4rem;
	color: #1B3A5C;
	margin-bottom: .3rem;
	line-height: 2;
}
.access_traffic dd {
	font-size: 1.3rem;
	line-height: 2;
	letter-spacing: .3rem;
	font-weight: 500;
	color: #333;
}
.access_traffic dd + dt {
	margin-top: 2rem;
}
.access_traffic dl + h4 {
	margin-top: 2.5rem;
}
.access_traffic_item:nth-child(1) {
	width: 41.6rem;
	padding-right: 3.8rem;
}
.access_traffic_item:nth-child(2) {
	width: 42.7rem;
	padding: 0 3rem 0 4rem;
	border-left: .1rem solid rgba(143, 164, 180, .5);
}
.access_traffic_item:nth-child(3) {
	padding-left: 3.8rem;
	border-left: .1rem solid rgba(143, 164, 180, .5);
	flex: 1;
}
@media only screen and (max-width: 768px) {
	.access {
		padding: 5.8rem 0 9.2rem;
		background: none;
		z-index: 3;
	}
	.access::after {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 80rem;
		background: #F4F1EC;
	}
	.access::before {
		content: '';
		display: block;
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		background: #F4F1EC;
		width: 186.9rem;
		height: 186.9rem;
		border-radius: 50%;
	}
	.access h2 {
		width: 34.2rem;
		right: .5rem;
		top: -2.6rem;
		padding: 0;
		z-index: 2;
	}
	.access_address {
		font-size: 1.4rem;
		line-height: 2.1429;
		z-index: 2;
	}
	.access_map {
		margin: 2.1rem auto 9rem;
		z-index: 2;
	}
	.access_route {
		padding: 3rem 0 7.3rem;
		display: block;
		z-index: 2;
	}
	.access_route h3 {
		width: 16.942rem;
		top: -1.4rem;
		left: 3.116rem;
	}
	.access_route_txt {
		padding: 7.8rem 5rem 0;
	}
	.access_route_txt h4 {
		font-size: 2rem;
		line-height: 1.8;
		margin-bottom: 1rem;
	}
	.access_route_txt p {
		font-size: 1.3rem;
	}
	.access_route figure {
		width: 37rem;
		margin: 2.1rem auto 0;
	}
	.access_traffic {
		max-width: 33rem;
		margin: 5.5rem auto 0;
		display: block;
		z-index: 2;
	}
	.access_traffic_item:nth-child(1) {
		width: auto;
		padding-right: 0;
	}
	.access_traffic_item:nth-child(2) {
		width: auto;
		padding: 2rem 0 0;
		margin-top: 3.1rem;
		border: 0;
		border-top: .1rem solid rgba(143, 164, 180, .5);
	}
	.access_traffic_item:nth-child(3) {
		padding: 2rem 0 0;
		margin-top: 3.1rem;
		border: 0;
		border-top: .1rem solid rgba(143, 164, 180, .5);
	}
	.access_traffic_item:nth-child(3) h4:nth-of-type(2) {
		border-top: .1rem solid rgba(143, 164, 180, .5);
		padding: 2rem 0 0;
		margin-top: 3.1rem;
	}
}

/*faq
----------------------------------------*/
.faq {
	overflow: clip;
	padding: 14.5rem 0 19rem;
	z-index: 2;
}
.faq::before {
	content: '';
	display: block;
	width: 378.3rem;
	height: 378.3rem;
	min-width: 100vw;
	min-height: 100vw;
	border-radius: 50%;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	background: linear-gradient(to right, #e9e8df 0%,#dcded6 50%,#d9e1dd 100%);
}
.faq_inner {
	max-width: 110rem;
	margin: 0 auto;
	display: flex;
}
.faq h2 {
	width: 27.3rem;
	margin: 0 0 3.6rem .4rem;
}
.faq_txt {
	width: 42.5rem;
}
.faq_txt p {
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 2.1429;
	letter-spacing: .3rem;
	color: #1B3A5C;
}
.faq_list {
	flex: 1;
	margin-top: -.2rem;
}
.faq_list dt {
	background: #F8F8F5;
	font-size: 1.6rem;
	letter-spacing: .3rem;
	font-weight: 600;
	border-radius: .5rem;
	padding: 2.4rem 4rem 2.2rem 6.7rem;
	cursor: pointer;
	transition: .1s;
	transition-delay: .35s;
}
.faq_list dt.open {
	border-radius: .5rem .5rem 0 0;
	transition-delay: 0s;
}
.faq_list dt::after {
	content: '';
	display: block;
	width: 2.5rem;
	height: 2.5rem;
	background: url(../img/icon_plus.svg) no-repeat center center / 1.1rem auto, url(../img/icon_minus.svg) no-repeat -1rem -1rem, #F67F34;
	position: absolute;
	right: 2.1rem;
	top: 2.3rem;
	border-radius: .3rem;
}
.faq_list dt::before {
	content: '';
	display: block;
	height: .1rem;
	position: absolute;
	left: 2.1rem;
	right: 2.2rem;
	bottom: 0;
	background: rgba(143, 164, 180, .5);
	opacity: 0;
	transition: .1s;
	transition-delay: .35s;
}
.faq_list dt.open::before {
	opacity: 1;
	transition-delay: 0s;
}
.faq_list dt.open::after {
	background-image: url(../img/icon_minus.svg);
}
.faq_list dt .en {
	position: absolute;
	top: 1.6rem;
	left: 2.2rem;
	font-size: 2.4rem;
	color: #1B3A5C;
	font-weight: 400;
}
.faq_list dd {
	background: #F8F8F5;
	border-radius: 0 0 .5rem .5rem;
	padding: 1.3rem 4rem 2.1rem 6.7rem;
	line-height: 2;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: .2rem;
	display: none;
}
.faq_list dd a {
color: #1B3A5C;
    text-decoration: underline;
}
.faq_list dd .en {
	position: absolute;
	top: .6rem;
	left: 2.2rem;
	font-size: 2.4rem;
	color: #F67F34;
	font-weight: 400;
}
.faq_list dd + dt {
	margin-top: 2rem;
}
@media only screen and (max-width: 768px) {
	.faq {
		overflow: visible;
		padding: 8.5rem 0 12.8rem;
	}
	.faq::before {
		width: 186.9rem;
		height: 186.9rem;
		background: linear-gradient(45deg, #dde7e4 15%,#dddfd6 50%,#d8d9cd 75%);
	}
	.faq_inner {
		max-width: 33rem;
		display: block;
	}
	.faq h2 {
		width: 16.4rem;
		margin: 0 0 3.8rem .2rem;
	}
	.faq_txt {
		width: auto;
	}
	.faq_txt p {
		font-size: 1.3rem;
		line-height: 2;
	}
	.faq_list {
		margin-top: 4.2rem;
	}
	.faq_list dt {
		font-size: 1.3rem;
		line-height: 2.1538;
		padding: 1.4rem 4rem 1.62rem 4.6rem;
	}
	.faq_list dt::after {
		width: 2rem;
		height: 2rem;
		background: url(../img/icon_plus.svg) no-repeat center center / .85rem auto, url(../img/icon_minus.svg) no-repeat -1rem -1rem, #F67F34;
		right: 1.9rem;
		top: 1.9rem;
	}
	.faq_list dt::before {
		bottom: .3rem;
	}
	.faq_list dt .en {
		top: .8rem;
		left: 2.1rem;
		font-size: 1.8rem;
	}
	.faq_list dd {
		padding: .9rem 4rem 2.9rem 4.6rem;
		font-size: 1.3rem;
	}
	.faq_list dd .en {
		left: 2.1rem;
		font-size: 1.8rem;
	}
	.faq_list dd + dt {
		margin-top: 1rem;
	}
}

/*modal
----------------------------------------*/
.modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	backdrop-filter: blur(1.4rem);
	background: rgba(137, 145, 162, 0.2);
	z-index: 2000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity .5s;
}
.modal_open .modal {
	opacity: 1;
	pointer-events: all;
}
.modal_inner {
	max-height: 100%;
	width: 100%;
	overflow: auto;
	padding: 6rem 0;
}
.modal_box {
	max-width: 120rem;
	background: #F8F8F5;
	border-radius: .5rem;
	margin: 0 auto;
}
.modal_close {
	appearance: none;
	border: 0;
	outline: none;
	width: 5rem;
	height: 5rem;
	background: #F8F8F5;
	border-radius: 50%;
	position: absolute;
	top: 2rem;
	right: 2rem;
	box-shadow: .2rem .2rem 1.4rem rgba(0, 0, 0, .08), .3rem .3rem 1.4rem rgba(0, 0, 0, .08);
	cursor: pointer;
	z-index: 10;
}
.modal_close::before,
.modal_close::after {
	content: '';
	display: block;
	width: .1rem;
	height: 1.3rem;
	background: #1B3A5C;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	transform: rotate(45deg);
}
.modal_close::after {
	transform: rotate(-45deg);
}
.modal_item {
	display: flex;
	align-items: center;
	padding: 5rem;
}
.modal_item > figure {
	width: 37rem;
	border-radius: .5rem;
	overflow: hidden;
}
.modal_contents {
	flex: 1;
	padding: 3.5rem 0 0 5rem;
}
.modal_item h2 {
	font-size: 2.2rem;
	line-height: 1.125;
	color: #1B3A5C;
	letter-spacing: .3rem;
	margin-bottom: 1.9rem;
	overflow-wrap: anywhere;
}
.modal_drink {
	font-size: 1rem;
	line-height: 1.5;
	letter-spacing: .15rem;
	color: #8FA4B4;
	font-weight: 700;
	margin: -1rem 0 2rem;
	overflow-wrap: anywhere;
}
.modal_evening_menu h2 {
	margin-bottom: 1.2rem;
}
.modal_evening_menu h3 {
	font-size: 1.8rem;
	line-height: 1.35;
	color: #1B3A5C;
	letter-spacing: .3rem;
	font-weight: 700;
	margin: 1.6rem 0 .7rem;
	overflow-wrap: anywhere;
}
.modal_evening_menu .modal_price {
	margin-bottom: 1.2rem;
}
.modal_evening_menu .modal_price .en {
	font-size: 1.6rem;
}
.modal_evening_menu .modal_evening_drink_price {
	margin-bottom: 1.3rem;
}
.modal_evening_set {
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .2rem;
    color: #8FA4B4;
}
.modal_evening_set .en {
	font-size: 1.5rem;
	color: #1B3A5C;
	font-weight: 400;
	margin-right: .5rem;
}
.modal_price {
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: .2rem;
	color: #8FA4B4;
	margin-bottom: 2.7rem;
}
.modal_price .en {
	font-size: 2rem;
	font-weight: 400;
	color: #1B3A5C;
	margin-right: .4rem;
}
.modal_evening_menu .pea {
	font-size: 1.3rem;
	line-height: 1.5;
	letter-spacing: .2rem;
	color: #1B3A5C;
	font-weight: 700;
	margin-bottom: 0.5rem;
}
.modal_evening_menu. {
	margin-bottom: 2rem;
}
.modal_txt {
	font-size: 1.3rem;
	font-weight: 500;
	letter-spacing: .2rem;
	line-height: 1.9231;
	margin-bottom: 4rem;
    margin-top: 2rem;
}
.modal_contents_inner {
	display: grid;
    grid-template-columns: 32.5rem auto;
    gap: 3rem;
}
.modal_contents_item p {
	font-size: 1.3rem;
	letter-spacing: .2rem;
	line-height: 1.7692;
	margin-top: 1.9rem;
}
.modal .daytime_list_edited {
	margin-right: -.2rem;
}
@media only screen and (max-width: 768px) {
	.modal_box {
		max-width: 35rem;
	}
	.modal_close {
		width: 4rem;
		height: 4rem;
		top: 1rem;
		right: 1rem;
	}
	.modal_close::before,
	.modal_close::after {
		height: 1rem;
	}
	.modal_item {
		display: block;
		padding: 6.6rem 2rem 5.1rem;
	}
	.modal_item > figure {
		width: auto;
	}
	.modal_contents {
		padding: 2.2rem 0 0;
	}
	.modal_item h2 {
		font-size: 1.6rem;
		margin-bottom: .7rem;
	}
	.modal_drink {
		margin: -.1rem 0 1.8rem;
	}
	.modal_evening_menu {
		margin-bottom: 2.4rem;
	}
	.modal_evening_menu h2 {
		line-height: 1.45;
		letter-spacing: .12rem;
		margin-bottom: .5rem;
	}
	.modal_evening_menu h3 {
		font-size: 1.4rem;
		line-height: 1.45;
		letter-spacing: .12rem;
		margin: 1.3rem 0 .5rem;
	}
		.modal_evening_menu .pea {
        font-size: 1.25rem;
        letter-spacing: .12rem;
        margin-bottom: 0;
		color: #1B3A5C;
    font-weight: 700;
	line-height: 1.5;
	display: contents;
	}
	.modal_evening_menu .modal_price {
		margin-bottom: 1rem;
	}
	.modal_evening_menu .modal_price .en {
		font-size: 1.4rem;
	}
	.modal_evening_set {
		font-size: 1.1rem;
        font-weight: 600;
        letter-spacing: .12rem;
        color: #8FA4B4;
		display: contents;
	}
	.modal_evening_set .en {
		font-size: 1.3rem;
		margin-left: 1.4rem;
		margin-right: .5rem;
	}
	.modal_price {
		font-size: 1.1rem;
		font-weight: 600;
		margin-bottom: 2.4rem;
	}
	.modal_price .en {
		font-size: 1.4rem;
		margin-right: .5rem;
	}
	.modal_txt {
		margin-bottom: 3.8rem;
		margin-top: 0rem;
	}
	.modal_contents_inner {
		display: block;
	}
	.modal_contents_item + .modal_contents_item {
		margin-top: 3.8rem;
	}
	.modal .daytime_list_edited dt {
		font-size: 1.2rem;
		margin-bottom: 1rem;
	}
	.modal .daytime_list_img {
		gap: 1rem;
	}
	.modal .daytime_list_img figure {
		width: 7.6rem;
	}
	.modal .daytime_list_edited h4 {
		font-size: 1.3rem;
		padding-left: 3rem;
	}
	.modal .daytime_list_edited h4 span {
		font-size: 1.2rem;
		letter-spacing: .2rem;
		margin-bottom: .5rem;
	}
}

/*footer
----------------------------------------*/
.footer_bg {
	position: sticky;
	top: 0;
	left: 0;
	margin: -100vh 0;
}
.footer_bg img {
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
.footer h2 {
	margin: 100vh 0 0;
	padding: 25.3rem 0 33.9rem;
}
.footer h2 img {
	width: 79.9rem;
	margin: 0 auto;
}
.footer_inner {
	background: #1B3A5C;
	color: #fff;
	padding: 13rem 0 15.4rem;
}
.footer_sns {
	text-align: center;
}
.footer_sns dt {
	font-size: 1.6rem;
	padding-left: .3rem;
	letter-spacing: .3rem;
	margin-bottom: 5.2rem;
}
.footer_sns dd {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    flex-direction: column;
}
.footer_sns .sns_icon {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 7rem;
	height: 7rem;
	border-radius: 50%;
	border: .1rem solid #fff;
}
.footer_sns .sns_icon img {
	width: 2.956rem;
}
.footer_sns .sns_comingsoon {
	font-size: 1.2rem;
	letter-spacing: .18rem;
	white-space: nowrap;
}
.footer .copyright {
	display: block;
	font-size: 1.3rem;
	letter-spacing: .3rem;
	text-align: center;
	margin-top: 4.9rem;
}
@media only screen and (max-width: 768px) {
	.footer h2 {
		padding: 21.355rem 0 23.875rem;
	}
	.footer h2 img {
		width: 35.774rem;
	}
	.footer_inner {
		padding: 11.3rem 0 12.5rem;
	}
	.footer_sns dt {
		margin-bottom: 2.4rem;
	}
	.footer_sns .sns_icon {
		width: 6rem;
		height: 6rem;
	}
	.footer_sns .sns_icon img {
		width: 2.533rem;
	}
	.footer_sns .sns_comingsoon {
		font-size: 1.1rem;
	}
	.footer .copyright {
		font-size: 1.1rem;
		margin-top: 4.6rem;
	}
}

/*inview
----------------------------------------*/
.js-inview {
	opacity: 0;
	transform: translateY(2rem);
	transition: opacity 1s, transform 1s;
	transition-timing-function: ease-out;
}
.js-inview.show {
	opacity: 1;
	transform: none;
}
