@charset "UTF-8";

/* ----------------------------------------------------
	concept
---------------------------------------------------- */
.conceptSection {
	height: 100vh;
}

.conceptInner {
	width: 100%;
	min-height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.conceptBg {
	background-position: center center;
	background-repeat: no-repeat;
	width: 100%;
	height: 100%;
	opacity: 0;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: -1;
	transition: transform 1.5s ease 0s, opacity 1s ease 0.5s, filter 1.5s ease 0s;
	filter: blur(100px) contrast(100%);
}

.show .conceptBg {
	opacity: 1;
	transform: scale(1.2);
	filter: none;
}

.concept__contents {
	width: 56.66275%;
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 10;
}

.concept__contents--title {
	line-height: 1;
	font-weight: 400;
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
}

.concept__contents--title::before {
	width: 30.77955vw;
	border-top: solid 1px rgb(var(--wht));
	position: absolute;
	top: 2.38462vw;
	left: -6.4vw;
	top: 4.8vw;
	left: -8.8vw;
	transform: rotate(315deg);
	transform-origin: right top;
	content: "";
}

.concept__contents--title .jp {
	margin-bottom: 0.5em;
	font-size: 2.66667vw;
	letter-spacing: 0.25em;
	writing-mode: vertical-rl;
	display: inline-block;
}

.concept__contents--title .jp.short {
	letter-spacing: 1em;
}

.concept__contents--title .en {
	line-height: 1.5;
	font-size: 1.33333vw;
	text-align: center;
}

.concept__contents--text {
	padding-top: 18.4vw;
	width: 76%;
	font-size: 1.33333vw;
}

@media screen and (max-width: 768px) {
	.conceptBg {
		transition: transform 2s ease 0s, opacity 1s ease 0.5s, filter 2s ease 0s;
	}

	.concept__contents {
		width: 85%;
		display: flex;
		justify-content: space-between;
		position: relative;
		z-index: 10;
	}

	.concept__contents--title {
		width: 24%;
	}

	.concept__contents--title::before {
		display: none;
	}

	.concept__contents--title .jp {
		font-size: 4.8vw;
	}

	.concept__contents--title .en {
		font-size: 2.93333vw;
	}

	.concept__contents--text {
		padding: 0 0 0 3.2vw;
		font-size: 3.73333vw;
	}
}

/*
	scenery
------------------------------ */
.scenery .conceptBg {
	background-image: url(../img/sceneryBg.webp);
	background-size: cover;
}

@media screen and (max-width: 768px) {
	.scenery .conceptBg {
		background-position: left center;
	}
}

/*
	washoku
------------------------------ */
.washoku .conceptBg {
	background-image: url(../img/washokuBg.webp);
	background-size: cover;
}

@media screen and (max-width: 768px) {
	.washoku .conceptBg {
		background-position: right center;
	}
}

/*
	image
------------------------------ */
.image.conceptSection {
	height: 120vh;
}

.image .conceptBg {
	background-image: url(../img/imageBg.webp);
	background-size: cover;
}

@media screen and (max-width: 768px) {
	.image .conceptBg {
		background-position: center center;
	}
}

/* ----------------------------------------------------
	course
---------------------------------------------------- */
.courseInner {
	padding: 9.33333vw 0;
	width: 100%;
	height: 100% !important;
	position: relative;
	top: 0;
	left: 0;
	z-index: 10;
}

.courseInner__text {
	text-align: center;
}

.courseInner__text .text {
	font-size: 1.33333vw;
}

.courseInner__text .linkBtn {
	margin-top: 2em;
}

.courseInner__text .linkBtn button {
	background: none;
	margin: 0 auto;
	width: 37.92308%;
	height: 5.86667vw;
	color: rgb(var(--wht));
	font-family: var(--inter);
	font-size: 1.33333vw;
	border: solid 1px rgb(var(--wht));
	transition: all 0.5s ease 0s;
	cursor: pointer;
}

.courseInner__text .linkBtn button:hover {
	background: rgba(var(--wht), 0.75);
	color: rgb(var(--bgColor));
	opacity: 1;
	border: solid 1px rgb(var(--wht));
}

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

	.courseInner__text {
		padding: 0 6.4vw;
	}

	.courseInner__text .text {
		font-size: 3.73333vw;
	}

	.courseInner__text .linkBtn {
		padding: 0 6.4vw;
	}

	.courseInner__text .linkBtn button {
		background: none;
		width: 100%;
		height: 13.33333vw;
		font-size: 3.73333vw;
	}
}

/*
	courseSlide
------------------------------ */
.courseSlide .slick-slide img {
	margin-bottom: 4.26667vw;
}

.courseSlide .slick-slide img {
	width: 100%;
	height: auto;
	transform: scale(0.8);
	transition: transform 1.5s ease;
}

.courseSlide .slick-slide.slick-center img {
	opacity: 1;
	transform: scale(1);
}

@media screen and (max-width: 768px) {
	.courseSlide .slick-slide img {
		margin-bottom: 8vw;
	}

	.courseSlide .slick-slide img {
		transform: scale(0.85);
	}
}

/*
	story
------------------------------ */
.story {
	background: rgb(var(--bgColor));
	padding: 15.2vw 0;
}

.story__title {
	margin-bottom: 0.25em;
	padding-bottom: 4.26667vw;
	font-family: var(--inter);
	font-size: 1.6vw;
	font-weight: 400;
	text-align: center;
}

.story__title .big {
	font-family: var(--big);
	font-size: 3.2vw;
	display: block;
}

.story__title .logo {
	margin-top: 2em;
	display: block;
}

.story__lead {
	margin-bottom: 7.46667vw;
	font-size: 1.33333vw;
	text-align: center;
}

.story__lead .text {
	margin-bottom: 0;
}

.story__list {
	margin: 0 auto 14.4vw;
	width: 100%;
	overflow: hidden;
	display: flex;
	justify-content: space-between;
}

.story__list--item {
	width: calc(100% / 3);
	height: 40.23077vw;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

.story__list--item .icon-new {
	width: 6.25vw;
	height: 6.25vw;
	position: absolute;
	top: 3.125vw;
	left: 1.563vw;
	z-index: 2;
}

.story__list--item.part1 {
	background: url(../img/story-stella.webp) center no-repeat;
	background-size: cover;
}

.story__list--item.part2 {
	background: url(../img/story-japonism.webp) center no-repeat;
	background-size: cover;
}

.story__list--item.part3 {
	background: url(../img/story-fantasia.webp) center no-repeat;
	background-size: cover;
}

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

.story__list--item a::before {
	background: rgba(var(--blk), 0.5);
	width: 100%;
	height: 100%;
	display: block;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	transition: all 0.5s ease 0s;
	content: "";
}

.story__list--item a:hover,
.story__list--item a:hover::before {
	opacity: 1;
}

.story__list--item .contents {
	text-align: center;
	position: relative;
	z-index: 2;
}

.story__list--item .contents__title {
	margin-bottom: 2em;
}

.story__list--item.part1 .contents__title img {
	width: auto;
	height: 9.308vw;
}

.story__list--item.part2 .contents__title img {
	width: auto;
	height: 9.769vw;
}

.story__list--item.part3 .contents__title img {
	width: auto;
	height: 9.615vw;
}

.story__list--item .contents__details .text {
	margin-bottom: 0;
	font-size: 1.33333vw;
}

.story .profile {
	margin: 5.33333vw auto 0;
	width: 75.53846%;
	display: flex;
	justify-content: space-between;
}

.story .profile__images {
	width: 26.37475%
}

.story .profile__details {
	width: 69.24644%;
}

.story .profile__name {
	margin-bottom: 1em;
	line-height: 1;
	font-size: 1.86667vw;
	display: flex;
	align-items: baseline;
}

.story .profile__name .en {
	margin-left: 1em;
	font-size: 1.33333vw;
}

.story .profile__text .profileText {
	font-size: 1.33333vw;
}

.story .profile__text .text {
	font-size: 1.07692vw;
}

@media screen and (max-width: 768px) {
	.story {
		/* padding: 13.33333vw 6.4vw; */
		padding: 13.33333vw 0;
	}

	.story__title {
		font-size: 4.8vw;
	}

	.story__title .big {
		font-size: 8vw;
	}

	.story__lead {
		font-size: 3.73333vw;
	}

	.story__lead .text {
		margin-bottom: 0;
	}

	.story__list {
		margin: 0 auto 13.33333vw;
		width: 100%;
		display: block;
	}

	.story__list--item {
		width: 100%;
		height: 87.2vw;
	}

	.story__list--item.part1 {
		background: url(../img/story-stella_sp.webp) center no-repeat;
		background-size: cover;
	}

	.story__list--item.part2 {
		background: url(../img/story-japonism_sp.webp) center no-repeat;
		background-size: cover;
	}

	.story__list--item.part3 {
		background: url(../img/story-fantasia_sp.webp) center no-repeat;
		background-size: cover;
	}

	/* .story__list--item:not(:last-of-type) {
		margin-bottom: 1em;
	} */

	.story__list--item.part1 .contents__title img {
		height: 29.333vw;
	}

	.story__list--item.part2 .contents__title img {
		height: 31.467vw;
	}

	.story__list--item.part3 .contents__title img {
		height: 30.133vw;
	}

	.story__list--item .contents__details .text {
		margin-bottom: 0;
		font-size: 3.73333vw;
	}

	.story .profile {
		padding: 0 6.4vw;
		width: 100%;
		display: block;
	}

	.story .profile__images {
		margin-bottom: 1em;
		width: 100%;
		text-align: center;
	}

	.story .profile__images img {
		width: 50%
	}

	.story .profile__details {
		width: 100%;
	}

	.story .profile__name {
		font-size: 4.8vw;
	}

	.story .profile__name .en,
	.story .profile__text .profileText,
	.story .profile__text .text {
		font-size: 3.73333vw;
	}
}

/*
	japonism
------------------------------ */
.japonism {
	min-height: 100vh;
	height: auto;
}

.japonism .story__title .logo img {
	width: 30.04830vw;
}

@media screen and (max-width: 768px) {
	.japonism {
		min-height: auto;
	}

	.japonism .story__title .logo img {
		width: 60.6%;
	}
}

/*
	stella
------------------------------ */
.stella {
	min-height: 100vh;
	height: auto;
}

.stella .story__title .logo img {
	width: 24.04323vw;
}

@media screen and (max-width: 768px) {
	.stella {
		min-height: auto;
	}

	.stella .story__title .logo img {
		width: 51%;
	}
}

/*
	fantasia
------------------------------ */
.fantasia {
	min-height: 100vh;
	height: auto;
}

.fantasia .story__title .logo img {
	width: 28.846vw;
}

@media screen and (max-width: 768px) {
	.fantasia {
		min-height: auto;
	}

	.fantasia .story__title .logo img {
		width: 51%;
	}
}

/*
	modal
------------------------------ */
body.modal-open {
	overflow: hidden;
}

.modal {
	max-width: 660px;
	width: 95%;
	height: 90%;
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1000;
}

.modal-content {
	background: #C4CED1;
	padding: 60px 0;
	width: 100%;
	height: 100%;
	color: rgb(var(--blk));
	text-align: center;
	overflow-y: auto;
	position: relative;
	z-index: 1001;
}

.overlay {
	background: rgba(var(--blk), 0.5);
	width: 100%;
	height: 100%;
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
}

.closeModal {
	background-color: transparent;
	margin-bottom: 10px;
	padding-right: 10px;
	width: 100%;
	text-align: right;
	border: none;
	position: fixed;
	top: 10px;
	right: 0;
}

.closeModal .close {
	margin-left: auto;
	width: 40px;
	height: 40px;
	display: block;
	position: relative;
	cursor: pointer;
}

.closeModal .close::before,
.closeModal .close::after {
	background: rgba(var(--blk), 0.25);
	width: 100%;
	height: 2px;
	position: absolute;
	top: 50%;
	left: 0;
	content: "";
}

.closeModal .close::before {
	transform: translateY(-50%) rotate(45deg);
}

.closeModal .close::after {
	transform: translateY(-50%) rotate(-45deg);
}

.modal-content .modal__title {
	margin-bottom: 32px;
}

.modal-content .modal__title span {
	font-size: 16px;
	font-weight: normal;
	display: block;
}

#modal1 .modal-content .modal__title svg {
	width: 40.06480%;
	height: auto;
}

#modal2 .modal-content .modal__title svg {
	width: 31.65424%;
	height: auto;
}

#modal3 .modal-content .modal__title svg {
	width: 31.65424%;
	height: auto;
}

.modal-content .modal__list {
	font-size: 16px;
}

.modal-content .modal__list--item:not(:last-of-type) {
	margin-bottom: 2.5em;
}

.modal-content .menuContents__title {
	margin-bottom: 1em;
	line-height: 1;
	color: #4f80ac;
}

.modal-content .menuContents__contents--title {
	margin-bottom: 1em;
}

.modal-content .menuContents__contents--details {
	font-size: 13px;
}

@media screen and (max-width: 768px) {
	.modal {
		max-width: 100%;
		width: 100%;
		height: 100%;
	}

	.modal-content {
		padding: 13.33333vw 4.8vw;
	}

	.modal-content .modal__title {
		margin-bottom: 2em;
	}

	.modal-content .modal__title span {
		font-size: 4.26667vw;
	}

	#modal1 .modal-content .modal__title svg {
		width: 60.06480%;
	}

	#modal2 .modal-content .modal__title svg {
		width: 51.65424%;
	}

	.modal-content .modal__list {
		font-size: 4.26667vw;
	}

	.modal-content .menuContents__contents--details {
		font-size: 3.73333vw;
	}
}

/* ----------------------------------------------------
	reservation
---------------------------------------------------- */
.reservation {
	background: rgb(var(--bgColor));
	padding: 9.33333vw 0 0;
	text-align: center;
}

.reservation__title {
	margin-bottom: 7.46667vw;
	font-family: var(--inter);
	font-size: 1.6vw;
	font-weight: 400;
}

.reservation__title .jp {
	display: block;
}

.reservation .price {
	margin-bottom: 4em;
}

.reservation .price__title {
	margin-bottom: 1em;
	font-size: 1.6vw;
	font-weight: 400;
}

.reservation .price__contents--title {
	font-size: 1.33333vw;
}

.reservation .price__contents--details {
	margin-bottom: 1em;
	font-family: var(--inter);
	font-size: 1.86667vw;
}

.reservation .plans {
	margin: 0 auto 4em;
	width: 72.70513%;
	display: flex;
	flex-wrap: wrap;
	/* justify-content: space-between; */
	justify-content: center;
}

.reservation .plans__item {
	padding: 2.5em;
	width: 46.99011%;
	border: solid 1px rgb(var(--wht));
}

.reservation .plans__item:nth-child(1) {
	margin: 0 10% 50px;
}

.reservation .plans__item:nth-child(2) {
	margin-right: calc(100% - (46.99011% * 2));
}

.reservation .plans__item .plans__logo {
	margin-bottom: 2em;
}

.reservation .plans__item.part1 .plans__logo img {
	width: 56%;
}

.reservation .plans__item.part2 .plans__logo img {
	width: 48%;
}

.reservation .plans__item .linkBtn a {
	background: #3C5D8C;
	padding: 1em 0;
	line-height: 1.2;
	color: rgb(var(--wht));
	font-size: 1.33333vw;
	border: solid 2px #3C5D8C;
	border-radius: 0.53333vw;
	flex-direction: column;
}

.reservation .plans__item .linkBtn a:hover {
	background: rgb(var(--wht));
	color: #3C5D8C;
	opacity: 1;
}

.reservation .plans+.note {
	margin: 0 auto;
	padding-bottom: 6em;
	width: 72.70513%;
	text-align: left;
}

.reservation__images {
	height: 48.38702vw;
	overflow: hidden;
}

.reservation__images .tmb {
	width: 100%;
}

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

	.reservation__title {
		font-size: 4.8vw;
	}

	.reservation .price {
		padding: 0 6.4vw;
	}

	.reservation .price__title {
		font-size: 4.26667vw;
	}

	.reservation .price__contents--title {
		font-size: 3.73333vw;
	}

	.reservation .price__contents--details {
		font-size: 4.8vw;
	}

	.reservation .plans {
		padding: 0 6.4vw;
		width: 100%;
		flex-direction: column;
	}

	.reservation .plans__item {
		padding: 2.5em;
		width: 100%;
	}

	.reservation .plans__item:nth-child(1),
	.reservation .plans__item:nth-child(2) {
		margin: 0;
	}

	.reservation .plans__item:not(:last-of-type) {
		margin-bottom: 1em;
	}

	.reservation .plans__item .plans__logo {
		margin-bottom: 2em;
	}

	.reservation .plans__item.part1 .plans__logo img {
		width: 80%;
	}

	.reservation .plans__item.part2 .plans__logo img {
		width: 72%;
	}

	.reservation .plans__item .linkBtn a {
		font-size: 3.73333vw;
	}

	.reservation .plans+.note {
		padding: 0 6.4vw 13.33333vw;
		width: 100%;
	}
}

/* ----------------------------------------------------
	movieArea
---------------------------------------------------- */
.movieArea {
	height: 48.38702vw;
}

@media screen and (max-width: 768px) {
	.movieArea {
		height: 50vh;
	}
}

/* ----------------------------------------------------
	access
---------------------------------------------------- */
.access {
	background: rgb(var(--bgColor));
	padding: 9.33333vw 0;
	text-align: center;
}

.access__title {
	margin-bottom: 7.46667vw;
	font-family: var(--inter);
	font-size: 1.6vw;
	font-weight: 400;
}

.access .location__hotelsName {
	font-size: 1.6vw;
}

.access .location__hallName {
	margin-bottom: 1em;
	font-size: 1.6vw;
}

.access .location__address .address {
	margin-bottom: 2em;
	font-size: 1.33333vw;
}

.access .location__address .map {
	margin: 0 auto 2em;
	width: 67.84615%;
	height: 33.46154vw;
}

.access .location__address .map iframe {
	width: 100%;
	height: 100%;
}

.access .location__access.linkBtn a {
	margin: 0 auto;
	width: 37.92308%;
	height: 5.86667vw;
	color: rgb(var(--wht));
	font-size: 1.33333vw;
	border: solid 1px rgb(var(--wht));
}

.access .location__access.linkBtn a:hover {
	background: rgba(var(--wht), 0.75);
	color: rgb(var(--bgColor));
	opacity: 1;
}

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

	.access__title {
		font-size: 4.8vw;
	}

	.access .location__hotelsName {
		font-size: 4.8vw;
	}

	.access .location__hallName {
		font-size: 3.73333vw;
	}

	.access .location__address .address {
		font-size: 3.73333vw;
	}

	.access .location__address .map {
		margin: 0 auto 2em;
		width: 100%;
		height: 45vh;
	}

	.access .location__access {
		padding: 0 6.4vw;
	}

	.access .location__access.linkBtn a {
		width: 100%;
		height: 13.33333vw;
		font-size: 3.73333vw;
	}

	.access .location__access.linkBtn a:hover {
		background: rgba(var(--wht), 0.75);
		color: rgb(var(--bgColor));
		opacity: 1;
	}
}