/* ----------------------------------------------------
	header
---------------------------------------------------- */
.header {
	background-image: url(../img/header-bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 1.830vw;
	position: relative;
}

.header__content {
	background-color: rgba(var(--blu), 0.85);
	padding: 2.928vw 0;
	width: 43.192vw;
	color: rgb(var(--wht));
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	z-index: 1;
}

.header__content--logo {
	margin-bottom: 2.928vw;
	padding-left: 3.66vw;
	width: 12.811vw;
}

.header__content--title {
	margin-bottom: 1.830vw;
	padding-left: 3.66vw;
	width: 35.652vw;
}

.header__content--date {
	background-color: rgb(var(--sky));
	padding: 0.5rem 3.66vw;
	color: rgb(var(--blu));
	font-size: 1.83vw;
	font-weight: 500;
	display: flex;
	align-items: baseline;
}

.header__content--date i {
	margin-left: 0.25em;
	font-size: 1.464vw;
}

@media screen and (max-width: 768px) {
	.header {
		background: none;
		padding: 0;
		display: flex;
		flex-direction: column-reverse;
	}

	.header__content {
		padding: 5rem 0;
		width: 100%;
		position: static;
		transform: translateY(0);
	}

	.header__content--logo {
		margin: 0 auto 4rem;
		padding-left: 0;
		width: 12.7rem;
	}

	.header__content--title {
		margin: 0 auto 4rem;
		padding-left: 0;
		width: 33.4rem;
	}

	.header__content--date {
		padding-left: 0;
		font-size: 1.6rem;
		justify-content: center;
	}

	.header__content--date i {
		font-size: 1.4rem;
	}
}

/* ----------------------------------------------------
	about
---------------------------------------------------- */
.about {
	padding: 12rem 0;
	text-align: center;
}

.about__lead {
	margin-bottom: 10rem;
	font-size: 3rem;
}

.about__nav {
	margin: 0 auto;
	width: 110.6rem;
}

.about__nav--list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.about__nav--item {
	width: 25.2rem;
}

.about__nav--link {
	box-shadow: 0 0.4rem 1rem rgba(var(--blk), 0.25);
	display: block;
}

.about__nav--link figure {
	position: relative;
}

.about__nav--link figcaption {
	background-color: rgb(var(--blu));
	width: 100%;
	height: 8rem;
	line-height: 1;
	color: rgb(var(--wht));
	font-size: 2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 0;
	left: 0;
}

.about__nav--link figcaption span {
	margin-bottom: 0.5rem;
	height: 5rem;
	display: flex;
	justify-content: center;
	align-items: center;
}

.about__nav--link figcaption svg {
	width: 1.5rem;
	height: auto;
}

@media screen and (max-width: 768px) {
	.about {
		padding: 6rem 0;
	}

	.about__lead {
		margin-bottom: 4rem;
		font-size: 1.8rem;
	}

	.about__nav {
		width: 34.5rem;
	}

	.about__nav--item {
		margin-bottom: 1rem;
		width: 16.7rem;
	}

	.about__nav--link figcaption {
		height: 6.5rem;
		font-size: 1.6rem;
	}

	.about__nav--link figcaption span {
		height: 3.6rem;
	}

	.about__nav--link figcaption svg {
		width: 0.9rem;
	}
}

/* ----------------------------------------------------
	menu
---------------------------------------------------- */
.menu {
	padding: 12rem 0;
}

.menu__title {
	margin: 0 auto 3rem;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.menu {
		padding: 6rem 0;
	}

	.menu__title {
		margin-bottom: 4rem;
	}
}

/*
	menu__list
------------------------------ */
.menu__list {
	margin: 0 auto;
	width: 106.4rem;
}

.menu__list--item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}

.menu__shop-name {
	margin-bottom: 5rem;
	width: 100%;
	font-size: 3.2rem;
	font-weight: 600;
	text-align: center;
}

.menu__shop-name small {
	color: rgb(var(--blu));
	font-size: 2rem;
	display: block;
}

.menu__list--item:nth-child(even) {
	flex-direction: row-reverse;
}

.menu__list--item:not(:last-of-type) {
	margin-bottom: 12rem;
}

.menu__image {
	width: 60rem;
}

.menu__image .slick-dots {
	bottom: -2rem;
}

.menu__list--item:nth-child(odd) .menu__image .slick-dots {
	justify-content: flex-end;
}

.menu__content {
	width: 40rem;
}

.menu__content--detail {
	height: calc(100% - 8rem);
	display: flex;
	align-items: center;
}

.menu__content--name {
	line-height: normal;
	font-size: 2.4rem;
}

.menu__content--name small {
	font-size: 1.3rem;
	display: block;
}

.menu__content .link-button {
	margin-top: auto;
	width: 100%;
}

@media screen and (max-width: 768px) {
	.menu__list {
		width: 33rem;
	}

	.menu__list--item {
		display: block;
	}

	.menu__shop-name {
		margin-bottom: 3rem;
		font-size: 2.5rem;
	}

	.menu__shop-name small {
		font-size: 1.4rem;
	}

	.menu__list--item:not(:last-of-type) {
		margin-bottom: 5rem;
	}

	.menu__image {
		margin-bottom: 3rem;
		width: 100%;
	}

	.menu__list--item .menu__image .slick-dots {
		justify-content: flex-end;
	}

	.menu__content {
		width: 100%;
	}

	.menu__content--detail {
		margin-bottom: 3rem;
		height: auto;
		display: block
	}

	.menu__content--name {
		line-height: normal;
		font-size: 2rem;
		letter-spacing: -0.005em;
	}
}

/*
	chinese
------------------------------ */
.chinese {
	overflow: hidden;
}

.chinese .menu__title {
	width: 30.6rem;
}

.chinese .menu__list {
	width: 100%;
}

.chinese .menu__list--item {
	display: block;
}

.chinese__shop--title {
	margin: 0 auto 3rem;
	width: 106.4rem;
	font-weight: 600;
	font-size: 3rem;
}

.chinese__shop--title span,
.chinese__shop--title small {
	display: block;
}

.chinese__shop--title span {
	position: relative;
}

.chinese__shop--title span::before {
	background-color: rgb(var(--blk));
	width: 100vw;
	height: 2px;
	position: absolute;
	top: 50%;
	left: 30rem;
	transform: translateY(-50%);
	content: "";
}

.chinese__shop--title small {
	font-size: 1.5rem;
}

.chinese__shop--content {
	display: flex;
}

.chinese__shop--content.rev {
	flex-direction: row-reverse;
}

.chinese__shop--content .menu__image {
	margin-right: 6.4vw;
	width: 51.098vw;
}

.chinese__shop--content.rev .menu__image {
	margin-right: 0;
	margin-left: 6.4vw;
}

@media screen and (max-width: 768px) {
	.chinese .menu__title {
		width: 21.3rem;
	}

	.chinese .menu__list--item {
		display: block;
	}

	.chinese .menu__list--item:not(:last-of-type) {
		margin-bottom: 5rem;
	}

	.chinese__shop--title {
		margin-bottom: 2.4rem;
		padding-left: 1.5rem;
		width: 100%;
		font-size: 2.4rem;
	}

	.chinese__shop--title span::before {
		left: 25rem;
	}

	.chinese__shop--content {
		display: block;
	}

	.chinese__shop--content .menu__image,
	.chinese__shop--content.rev .menu__image {
		margin: 0 0 3rem;
		width: 100%;
	}

	.chinese__shop--content .menu__image .slick-dots {
		padding-right: 1.5rem;
	}

	.menu__content {
		padding: 0 1.5rem;
	}
}

/*
	japanese
------------------------------ */
.japanese .menu__title {
	width: 44.9rem;
}

.jp-obj01 {
	background-image: url(../img/obj-jp01.webp);
	width: 27.1rem;
	height: 27.1rem;
	top: 4.1rem;
	right: -5.6rem;
}

.jp-obj02 {
	background-image: url(../img/obj-jp02.webp);
	width: 26.9rem;
	height: 29.4rem;
	top: -7.9rem;
	left: 0;
}

@media screen and (max-width: 768px) {
	.japanese .menu__title {
		width: 30.9rem;
	}
}

/*
	western
------------------------------ */
.western .menu__title {
	width: 49.5rem;
}

.western .menu__image,
.western .menu__content {
	z-index: 1;
}

.we-obj01 {
	background-image: url(../img/obj-we01.webp);
	width: 35rem;
	height: 35rem;
	top: -10rem;
	left: -12.9rem;
}

.we-obj02 {
	background-image: url(../img/obj-we02.webp);
	width: 35rem;
	height: 35rem;
	top: -14rem;
	right: -12.9rem;
}

.we-obj03 {
	background-image: url(../img/obj-we03.webp);
	width: 35rem;
	height: 35rem;
	top: -10rem;
	left: -12.9rem;
}

@media screen and (max-width: 768px) {
	.western .menu__title {
		width: 32.1rem;
	}
}

/*
	cocktail
------------------------------ */
.cocktail {
	margin: 15rem auto 0;
	width: 111.4rem;
}

.cocktail__title {
	margin-bottom: 5rem;
	width: 27.1rem;
	position: relative;
	left: -8rem;
}

.cocktail__list {
	display: flex;
	justify-content: space-between;
}

.cocktail__list--item {
	width: 52rem;
}

.cocktail__list--title {
	margin-bottom: 3rem;
	font-size: 2.4rem;
	font-weight: 600;
}

.cocktail__list--title small {
	font-size: 1.6rem;
}

.cocktail__slide .slick-dots {
	justify-content: flex-end;
	bottom: -2rem;
}

.cocktail__content--list {
	margin: 4rem 0;
	text-align: center;
}

.cocktail__content--item {
	line-height: 1.5;
	font-size: 2.4rem;
	font-weight: 600;
}

.cocktail__content--item small {
	font-size: 1.4rem;
	display: block;
}

.cocktail .link-button {
	margin: 0 auto;
}

@media screen and (max-width: 768px) {
	.cocktail {
		margin-top: 10rem;
		width: 32rem;
	}

	.cocktail__title {
		margin-bottom: 0;
		width: 19rem;
		left: -2.2rem;
	}

	.cocktail__list {
		display: block;
	}

	.cocktail__list--item {
		width: 100%;
	}

	.cocktail__list--item:not(:last-of-type) {
		margin-bottom: 6rem;
	}

	.cocktail__list--title {
		line-height: normal;
		text-align: center;
	}

	.cocktail__list--title small {
		font-size: 1.4rem;
	}

	.cocktail__slide {
		margin: 0 auto;
		width: 28.6rem;
	}

	.cocktail__content--list {
		margin: 3rem 0;
	}

	.cocktail__content--item {
		font-size: 2rem;
	}

	.cocktail__content--item small {
		font-size: 1.3rem;
	}

	.cocktail .link-button {
		width: 100%;
	}
}

/* ----------------------------------------------------
	gift
---------------------------------------------------- */
.gift {
	padding: 12rem 0;
}

.gift .menu__title {
	width: 33rem;
}

.gift__title {
	margin-bottom: 6rem;
	font-size: 3.2rem;
	font-weight: 600;
	text-align: center;
}

.gift__content {
	margin: 0 auto;
	width: 111rem;
}

.gift__list {
	margin-bottom: 10rem;
	display: flex;
	justify-content: space-between;
}

.gift__list--item {
	width: 52rem;
}

.gift__list--image {
	margin-bottom: 5rem;
}

.gift__list--image figcaption {
	margin-top: 4rem;
	font-size: 2.8rem;
	text-align: center;
}

.gift__list--image figcaption small {
	font-size: 1.4rem;
	display: block;
}

.gift__list--item .link-button {
	margin: 0 auto;
}

@media screen and (max-width: 768px) {
	.gift {
		padding: 6rem 0;
	}

	.gift .menu__title {
		width: 24.7rem;
	}

	.gift__title {
		margin-bottom: 3rem;
		line-height: normal;
		font-size: 2.5rem;
	}

	.gift__content {
		width: 33rem;
	}

	.gift__list {
		margin-bottom: 0;
		display: block;
	}

	.gift__list--item {
		margin-bottom: 5rem;
		width: 100%;
	}

	.gift__list--image {
		margin: 0 auto 3rem;
		width: 100%;
		text-align: center;
	}

	.gift__list--image img {
		width: 28.6rem;
	}

	.gift__list--image figcaption {
		margin-top: 3rem;
		font-size: 2rem;
	}

	.gift__list--image figcaption small {
		font-size: 1.3rem;
	}

	.gift__list--item .link-button {
		width: 100%;
	}
}

/*
	takeout
------------------------------ */
.takeout {
	background: linear-gradient(to bottom, #FFFAE7 0%, #FFF 100%);
	margin: 0 auto;
	padding-bottom: 4rem;
	width: 111rem;
	position: relative;
}

.takeout__title {
	width: 30.6rem;
	position: absolute;
	top: -0.5rem;
	left: 1.3rem;
}

.takeout__content {
	padding: 10rem 6.5rem 8rem;
	border-bottom: solid 1rem rgba(222, 210, 119, 1);
	display: flex;
	justify-content: space-between;
}

.takeout__content--detail {
	padding-top: 9rem;
	width: 40rem;
}

.takeout__list {
	margin-bottom: 4rem;
}

.takeout__list--item {
	line-height: 1.5;
	font-size: 2.8rem;
}

.takeout__list--item small {
	font-size: 1.4rem;
	display: block;
}

.takeout__slide {
	width: 50.2rem;
}

.takeout__slide .slick-dots {
	bottom: -2rem;
}

@media screen and (max-width: 768px) {
	.takeout {
		padding-bottom: 2rem;
		width: 100%;
	}

	.takeout__title {
		width: 24.3rem;
		top: 0;
		left: 2rem;
	}

	.takeout__content {
		padding: 17rem 2.2rem 3rem;
		flex-direction: column-reverse;
	}

	.takeout__content--detail {
		padding-top: 3rem;
		width: 100%;
	}

	.takeout__list {
		margin-bottom: 3rem;
		text-align: center;
	}

	.takeout__list--item {
		font-size: 2rem;
	}

	.takeout__list--item small {
		font-size: 1.3rem;
	}

	.takeout__slide {
		width: 100%;
	}

	.takeout__slide .slick-dots {
		justify-content: flex-end;
	}
}

/* ----------------------------------------------------
	page-note
---------------------------------------------------- */
.page-note {
	padding-top: 12rem;
}

.page-note .note {
	margin: 0 auto;
	width: 113rem;
	font-family: var(--gothic);
}

@media screen and (max-width: 768px) {
	.page-note {
		padding-top: 6rem;
	}

	.page-note .note {
		width: 34.5rem;
	}
}

/* ----------------------------------------------------
	hotels
---------------------------------------------------- */
.hotels {
	margin: 0 auto;
	padding-top: 5rem;
	width: 113rem;
	font-family: var(--gothic);
	text-align: center;
}

.hotels__line {
	margin: 0 auto 4rem;
	padding: 2rem 3.5rem;
	width: 69rem;
	border: solid 1px rgb(var(--blk));
	border-radius: 1rem;
}

.hotels__line--title {
	margin-bottom: 1rem;
	padding-bottom: 0.5rem;
	color: rgb(var(--line));
	font-size: 1.8rem;
	font-weight: 500;
	border-bottom: solid 1px rgb(var(--blk));
}

.hotels__line--content {
	margin-bottom: 1.5rem;
	display: flex;
}

.hotels__line--logo {
	margin: 2rem 3rem 0 0;
	color: rgb(var(--line));
	font-size: 1.2rem;
	flex-shrink: 0;
}

.hotels__line--logo img {
	width: 6.6rem;
}

.hotels__line--detail {
	text-align: left;
}

.hotels__line--detail .title {
	margin-bottom: 0.5rem;
	line-height: normal;
	font-size: 2rem;
}

.hotels__line--detail .title .marker {
	background: linear-gradient(transparent 60%, rgba(253, 225, 70, 1) 60%);
	padding: 0 0.2em;
	font-size: 2.5rem;
	font-weight: 500;
	display: inline-block;
}

.hotels__line .link-button {
	background: rgb(var(--line));
	margin: 0 auto;
	width: 39rem;
	height: 5rem;
	color: rgb(var(--wht));
	font-size: 1.8rem;
}

.hotels__line .link-button svg {
	top: 50%;
	right: 2rem;
	transform: translateY(-50%);
}

.hotels__contact {
	margin-bottom: 4rem;
	line-height: normal;
}

.hotels__contact--title {
	font-size: 2rem;
}

.hotels__contact--detail .tel,
.hotels__contact--detail .memo {
	display: block;
}

.hotels__contact--detail .tel {
	font-size: 4rem;
	font-weight: 600;
}

.hotels__contact--detail .memo {
	font-size: 1.6rem;
}

.hotels__logo {
	margin: 0 auto 4rem;
	width: 18.7rem;
}

.hotels__name {
	margin-bottom: 0.6rem;
	font-size: 2rem;
	font-weight: 500;
}

.hotels__address,
.hotels__tel {
	font-size: 1.6rem;
}

.hotels__memo {
	margin-bottom: 4rem;
	font-size: 1.5rem;
}

.hotels__sns {
	margin-bottom: 5rem;
	display: flex;
	justify-content: center;
}

.hotels__sns--item {
	margin: 0 3.5rem;
	width: 5rem;
}

.hotels__map iframe {
	width: 100%;
	height: 36.3rem;
}

@media screen and (max-width: 768px) {
	.hotels {
		padding-top: 6rem;
		width: 100%;
	}

	.hotels__line {
		padding: 2rem 1.2rem;
		width: 34.5rem;
	}

	.hotels__line--title {
		margin: 0 auto 2rem;
		font-size: 1.6rem;
	}

	.hotels__line--content {
		margin: 0 auto 2rem;
		width: 25rem;
		display: block;
	}

	.hotels__line--logo {
		margin: 0 auto 2rem;
		font-size: 1.1rem;
	}

	.hotels__line--logo img {
		width: 6rem;
	}

	.hotels__line--detail .title {
		font-size: 1.8rem;
	}

	.hotels__line--detail .title .marker {
		font-size: 2.2rem;
	}

	.hotels__line--detail .note {
		font-size: 2.2rem;
	}

	.hotels__line .link-button {
		width: 20rem;
		height: 4.5rem;
		font-size: 1.6rem;
	}

	.hotels__line .link-button svg {
		width: 1.3rem;
		right: 1rem;
	}

	.hotels__contact {
		margin-bottom: 2rem;
	}

	.hotels__contact--title {
		font-size: 1.6rem;
	}

	.hotels__contact--detail .tel {
		font-size: 2.4rem;
	}

	.hotels__contact--detail .memo {
		font-size: 1.5rem;
	}

	.hotels__logo {
		margin-bottom: 2rem;
		width: 18.4rem;
	}

	.hotels__name {
		font-size: 1.6rem;
	}

	.hotels__memo {
		margin: 0 auto 3rem;
		width: 34.5rem;
	}

	.hotels__sns--item {
		margin: 0 3rem;
		width: 4.4rem;
	}

	.hotels__map iframe {
		width: 100%;
		height: 36.3rem;
	}
}

/* ----------------------------------------------------
	xxx
---------------------------------------------------- */
.xxx {}

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

/* ----------------------------------------------------
	footer
---------------------------------------------------- */
.footer {
	padding: 5rem 0;
	font-family: var(--gothic);
}

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

/* 
	hotel-nav 
------------------------------ */
.footer .hotel-nav {
	line-height: 1;
	font-size: 1.6rem;
	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 1em;
	text-decoration: none;
}

@media screen and (max-width: 768px) {
	.footer .hotel-nav {
		font-size: 1.4rem;
		text-align: center;
		display: block;
	}

	.footer .hotel-nav::before {
		content: "";
	}

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

	.footer .hotel-nav__item:not(:last-of-type) {
		margin-bottom: 1em;
	}

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

/* 
	copy
------------------------------ */
.footer .copy {
	margin-top: 2em;
	line-height: normal;
	font-size: 1.1rem;
	text-align: center;
}

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