.bg {
	background-image: url(../images/top/bg_main.jpg);
	background-size: 100%;
}

.p-slider {
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	max-height: 100vh;
	overflow: hidden;
}
.p-slider .slide {
	height: 100vh;
}
.p-slider .slide img {
	width: 100%;
	height: 100%;
	display: block;
	-o-object-fit: cover;
	   object-fit: cover;
}
@media screen and (max-width: 767px) {
	.p-slider {
		width: 100vw;
	}
	.p-slider .slide {
		width: 100vw;
		height: 250vh;
	}
	.p-slider .slide img {
		width: 100%;
		height: 100%;
		display: block;
		-o-object-fit: cover;
		   object-fit: cover;
	}
}
.p-slider .p-mv__slider {
	width: 100%;
	overflow-x: hidden;
}
.p-slider .p-mv__slider .slick-list {
	width: 100%;
	overflow: hidden;
}

.p-mask {
	width: 100vw;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background-color: rgba(0, 0, 0, 0.45);
	opacity: 0;
	-webkit-transition: 0.5s opacity;
	transition: 0.5s opacity;
}
.p-mask.is-show {
	opacity: 1;
}

.p-mv {
	position: relative;
}
.p-mv__content {
	height: 100vh;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
	position: relative;
	padding: 0 15rem 0 0;
}
@media screen and (max-width: 767px) {
	.p-mv__content {
		height: auto;
		padding: 32vw 0 0;
	}
}
.p-mv__content .bnr {
	width: 10.8rem;
	position: absolute;
	top: 4.2rem;
	right: 7.5rem;
}
@media screen and (max-width: 767px) {
	.p-mv__content .bnr {
		width: 26.6666666667vw;
		top: 5.3333333333vw;
		right: 0;
	}
}
.p-mv__content .title {
	width: 65.9rem;
	max-width: 100%;
}
@media screen and (max-width: 767px) {
	.p-mv__content .title {
		width: 80vw;
	}
}

.p-intro {
	padding-top: 8rem;
	padding-bottom: 15rem;
	position: relative;
}
@media screen and (max-width: 767px) {
	.p-intro {
		padding-top: 16vw;
		padding-bottom: 16vw;
	}
}
.p-intro .l-content-inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	    -ms-flex-pack: end;
	        justify-content: flex-end;
}
.p-intro__title {
	color: #ffffff;
	font-size: 3.4rem;
	font-weight: 300;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
	.p-intro__title {
		font-size: 5.3333333333vw;
	}
}
.p-intro__text {
	color: #ffffff;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	margin-top: 1.4rem;
}
@media screen and (max-width: 767px) {
	.p-intro__text {
		font-size: 4vw;
	}
}
.p-intro__text p + p {
	margin-top: 2.4rem;
}
.p-intro .en {
	margin-top: 6rem;
}
@media screen and (max-width: 767px) {
	.p-intro .en {
		margin-top: 8vw;
	}
}
.p-intro .en .p-intro__title {
	font-size: 3.2rem;
	line-height: 1.3;
}
@media screen and (max-width: 767px) {
	.p-intro .en .p-intro__title {
		font-size: 5.3333333333vw;
	}
}
.p-intro .en .p-intro__text {
	line-height: 1.6;
}

.p-main {
	position: relative;
	padding-top: 15rem;
}
@media screen and (max-width: 767px) {
	.p-main {
		padding-top: 16vw;
	}
}

.p-item {
	padding-top: 15rem;
	padding-bottom: 15rem;
}
@media screen and (max-width: 767px) {
	.p-item {
		padding-top: 16vw;
		padding-bottom: 16vw;
	}
	.p-item .l-content-inner {
		padding: 0;
	}
}
.p-item .title {
	margin-right: 0;
	margin-left: auto;
	position: relative;
	z-index: 1;
	bottom: -0.2rem;
}
@media screen and (max-width: 767px) {
	.p-item .title {
		padding: 0 0 0 5.3333333333vw;
	}
}
.p-item .title img {
	display: block;
}
@media screen and (max-width: 767px) {
	.p-item .title img {
		height: 12vw;
		width: auto;
	}
}
.p-item .img {
	position: relative;
}
.p-item .img img {
	display: block;
}
.p-item .cnt {
	width: 15rem;
	position: absolute;
	top: 4.5rem;
	right: 7.5rem;
}
@media screen and (max-width: 767px) {
	.p-item .cnt {
		width: 100%;
		top: 0;
		right: 0;
		position: static;
	}
}
.p-item .link-btn {
	width: 15rem;
}
@media screen and (max-width: 767px) {
	.p-item .link-btn {
		width: 32vw;
		margin-right: 0;
		margin-left: auto;
		position: absolute;
		right: 6.6666666667vw;
		top: 6.6666666667vw;
	}
}
.p-item .link-btn .inn {
	display: block;
	width: 100%;
	text-align: center;
	padding: 0.2em 1em;
	border-radius: 100vh;
	font-size: 1.3rem;
	letter-spacing: 0.2em;
	background-color: #ffffff;
	color: #002b38;
	font-weight: 500;
}
@media screen and (max-width: 767px) {
	.p-item .link-btn .inn {
		font-size: 2.6666666667vw;
	}
}
.p-item .link-btn.green .inn {
	background-color: #002b38;
	color: #ffffff;
}
.p-item .link-btn.yellow .inn {
	background-color: #afa747;
	color: #ffffff;
}
.p-item .link-list {
	margin-top: 3rem;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 1.8rem;
}
@media screen and (max-width: 767px) {
	.p-item .link-list {
		margin-top: 0;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
		gap: 5.3333333333vw;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: normal;
		    -ms-flex-direction: row;
		        flex-direction: row;
		background-color: #000000;
		padding: 6.6666666667vw;
	}
}
@media screen and (max-width: 767px) {
	.p-item .link-list .item {
		width: calc((100% - 10.6666666667vw) / 3);
	}
}
.p-item .link-list .item a,
.p-item .link-list .item img {
	display: block;
}

.p-restaurants .title {
	width: 48.3rem;
}
@media screen and (max-width: 767px) {
	.p-restaurants .title {
		width: 100%;
	}
}

.p-cake .title {
	width: 64.1rem;
}
@media screen and (max-width: 767px) {
	.p-cake .title {
		width: 100%;
	}
}

.p-stay .title {
	width: 40.7rem;
	bottom: -2.4rem;
}
@media screen and (max-width: 767px) {
	.p-stay .title {
		width: 100%;
		bottom: -2.6666666667vw;
	}
	.p-stay .title img {
		height: 14.6666666667vw;
	}
}

.p-dinner {
	padding-bottom: 0;
}
.p-dinner .title {
	width: 59.1rem;
}
@media screen and (max-width: 767px) {
	.p-dinner .title {
		width: 100%;
	}
}