.statement-lead p span,
.statement-header h1 span,
.salons-icon-map,
.salons-list-item a h3{
	font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}
/*noto semibold*/
.plan-price strong,
.news-list .news-date{
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-style: normal;	
}


.loading-logo{
	position: absolute;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background: url(../img/common/logo_br.svg) 0 0 no-repeat;
	background-size: 100% 100%;
}
.kv-movie-wrap{
	position: fixed;
	top: 0;
	left: 0;
	overflow: hidden;
	z-index: 10;
}
.kv-movie-wrap .circle-play{
	display: none;
}
.is-end-kv .kv-movie-wrap .circle-play{
	display: block;
}

.kv-movie{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
}
.kv-movie-box {
	position: absolute;
	left: 50%;
	height: 100%;
	z-index: 1;
	-ms-transform: translate(-50%,0);
	-webkit-transform: translate(-50%,0);
	transform: translate(-50%,0);
}
.kv-movie-inner{
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	padding-bottom: 37.5%;
	-ms-transform: translate(0,-50%);
	-webkit-transform: translate(0,-50%);
	transform: translate(0,-50%);
}
.kv-movie:after{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: 10;
}
#kv-player{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.kv{
	position: relative;
	width: 100%;
	height: 100svh;
	z-index: 20;
}



.main-movie{
	height: 100svh;
}

.main-top .ceremony-bg{
	display: none;
}
.is-end-kv .ceremony-bg{
	display: block;
}

/*statement*/
.statement-img{
	opacity: 0;
}
.statement-img.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

/*fair*/
.main-top .fair-contents .fair-list,
.main-top .fair-contents .btn-link{
	opacity: 0;
}
.main-top .fair-contents .fair-list.on,
.main-top .fair-contents .btn-link.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

/*plan*/
.main-top .plan-contents .plan-list{
	opacity: 0;
}
.main-top .plan-contents .plan-list.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

/*logs*/
.main-top .logs-contents .logs-list,
.main-top .logs-contents .btn-link{
	opacity: 0;
}
.main-top .logs-contents .logs-list.on,
.main-top .logs-contents .btn-link.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

/*hotel*/
.main-top .hotel-kv,
.main-top .hotel-contents .hotel-image-list,
.main-top .hotel-contents .hotel-info,
.main-top .hotel-contents .hotel-map,
.main-top .hotel-gallery-image-list figure{
	opacity: 0;
}


.main-top .hotel-kv.on,
.main-top .hotel-contents .hotel-image-list.on,
.main-top .hotel-contents .hotel-info.on,
.main-top .hotel-contents .hotel-map.on,
.main-top .hotel-gallery-image-list figure.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

/*salon*/
.main-top .salons-contents .salons-list{
	opacity: 0;
}
.main-top .salons-contents .salons-list.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}


/*header*/
.main-top .fair-contents .sec-header,
.main-top .plan-contents .sec-header,
.main-top .logs-contents .sec-header,
.main-top .hotel-contents .sec-header,
.main-top .salons-contents .sec-header{
	opacity: 0;
}
.main-top .fair-contents .sec-header.on,
.main-top .plan-contents .sec-header.on,
.main-top .logs-contents .sec-header.on,
.main-top .hotel-contents .sec-header.on,
.main-top .salons-contents .sec-header.on{
	opacity: 1;
	transition: opacity 1000ms ease;
}

.logs-list-ticker-slide .logs-list-item figure,
.hotel-list-ticker-slide figure{
	position: relative;
}
.logs-list-ticker-slide .logs-list-item figure:after,
.hotel-list-ticker-slide figure:after{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 20;
}

/* popup
==========================================================*/

#popup{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,1);
	z-index: 1000000;
	opacity: 0;
	visibility: hidden;
	transition: opacity 600ms ease,visibility 600ms ease;
}
.popup-viewer{
	position: absolute;
	margin: auto;
	top: 50%;
	left: 50%;
	width: 100%;
	max-width: 1360px;
	transform: translate(-50%,-50%);
	z-index: 50;
}
.popup-viewer figure{
	aspect-ratio: 16/9;
	display: none;
}
.popup-viewer iframe{
	width: 100%;
	height: 100%;
}
.popup-viewer figure.on{
	display: block;
}
.popup-close-layer{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
}
.btn-popup-close{
	z-index: 20;
}


.is-show-popup #popup{
	opacity: 1;
	visibility: visible;
}



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


	.main-upper,
	.main-lower{
		position: relative;
		background-image: url(../img/common/bg_tex3.jpg);
		background-position: 50% 0;
		background-repeat: repeat;
		z-index: 20;
		background-size: 100% auto;
	}

	/* kv
	==========================================================*/


	.kv-catch{
		position: absolute;
		bottom: 80px;
		width: 100%;
		text-align: center;
		color: #fff;
		z-index: 50;
	}
	.kv-logo{
		margin: auto;
		max-width: 632px;
	}
	.kv-catch p{
		margin: 20px 0 0;
		font-size: 26px;
		font-weight: 600;
	}



	/* statement
	==========================================================*/

	#statement{
		position: relative;
		z-index: 15;
		overflow: hidden;
	}
	.statement-contents{
		position: relative;
		padding: 290px 0 480px;
		text-align: center;
		color: #fff;
	}
	.statement-bg{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	.statement-bg img{
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: 50% 100%;
	}
	.is-fix-statement .statement-bg{
		position: fixed;
	}


	.statement-header h1{
		font-weight: 600;
		line-height: calc(50/22);
		letter-spacing: 0.02em;
	}
	.statement-lead{
		margin: 185px 0 0;
	}
	.statement-lead p{
		font-size: 18px;
		font-weight: 600;
		line-height: calc(32/18);
	}
	.statement-lead p + p{
		margin-top: 45px;
	}
	.statement-img{
		position: absolute;
	}
	.statement-img1{
		top: 76px;
		right: 50%;
		margin-right: -586px;
		width: 180px;
	}
	.statement-img2{
		top: 156px;
		left: 50%;
		margin-left: -555px;
		width: 145px;
	}
	.statement-img3{
		top: 400px;
		left: 50%;
		margin-left: -640px;
		width: 270px;
	}
	.statement-img4{
		top: 454px;
		right: 50%;
		margin-right: -630px;
		width: 387px;
	}
	.statement-img5{
		top: 750px;
		left: 50%;
		margin-left: -510px;
		width: 294px;
	}


	/* news
	==========================================================*/

	#news .news-contents{
		padding: 50px 0;
		background: url(../img/common/bg_tex.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	.news-contents-inner{
		padding: 0 70px;
		display: flex;
		margin: auto;
		max-width: 1120px;
	}
	.news-header h2{
		width: 155px;
	}
	.news-list{
		padding: 0 0 0 110px;
		width: calc(100% - 155px);
	}
	.news-list a{
		position: relative;
		display: block;
		padding: 0 0 30px 5px;
		width: 100%;
	}
	.news-list a .line-link-txt{
		position: relative;
		display: flex;
		width: 100%;
		padding: 0 50px 0 10px;
	}
	.news-list p{
		line-height: 1.5;
	}
	.news-list .link-line{
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
	}
	.news-list a .line-link-txt:after{
		right: 30px;
	}
	.news-list a .line-link-txt:after{
		content: "";
		position: absolute;
		margin: auto;
		top: 0;
		right: 30px;
		bottom: 0;
		display: block;
		width: 12px;
		background: url(../img/common/arrow_r_br.svg) 50% 50% no-repeat;
		background-size: 100% 100%;
	}


	.news-list a[target="_blank"] .line-link-txt:after{
		content: "";
		position: absolute;
		margin: auto;
		top: 0;
		right: 30px;
		bottom: 0;
		display: block;
		width: 14px;
		height: 12px;
		background: url(../img/common/icon_blank_br.svg) 50% 50% no-repeat;
		background-size: 100% 100%;
	}
	.news-list .news-date{
		margin: 0 20px 0 0;
		line-height: 1.5;
	}
	.news-list-item + .news-list-item{
		padding-top: 30px;
	}



	/* chapel
	==========================================================*/

	.chapel-contents{
		padding: 45px 0;
		background: url(../img/common/bg_tex2.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	.chapel-contents .sec-header{
		text-align: center;

	}
	.chapel-contents .sec-header h2{
		margin: auto;
		width: 590px;
	}
	#chapel figure img{ 
		width: 100%;
		height: auto;
	}





	/* hotel
	==========================================================*/
	#hotel figure img{
		width: 100%;
	}
	.hotel-contents{
		margin: auto;
		padding: 0 0 100px;
	}

	.hotel-contents .sec-header h2{
		margin: auto;
		width: 200px;
	}
	.hotel-contents .sec-header{
		margin-top: -20px;
		position: relative;
		text-align: center;
		z-index: 100;
	}

	.hotel-image-list{
		margin: 60px 0 0;
	}
	.hotel-list-ticker-slide{
		position: relative;
		overflow: hidden;
	}
	.hotel-list-ticker{
		display: flex;
	}


	.hotel-info{
		margin: 60px auto 0;
		max-width: 565px;
	}
	.hotel-info dl{
		display: flex;
	}
	.hotel-info dl + dl{
		margin-top: 10px;
	}
	.hotel-info dl dt{
		width: 140px;
		line-height: 1.5;
	}
	.hotel-info dl dd{
		width: calc(100% - 140px);
		line-height: 1.5;
	}
	.hotel-map{
		margin: 60px auto 0;
		padding: 0 20px;
		max-width: 1100px;
	}
	.hotel-map iframe{ 
		width: 100%;
		height: 300px;
	}
	.hotel-gallery-image{
		padding: 60px;
		background: url(../img/common/bg_tex.jpg) 0 0 repeat;
		background-size: 100%;
	}
	.hotel-gallery-image-list{
		display: flex;
		flex-wrap: wrap;
		margin: 0 -6px;	
	}
	.hotel-gallery-image-list figure{
		padding: 0 6px;
		width: calc(100% / 6);
	}
	.hotel-gallery-image-list figure:nth-child(n+7){
		margin-top: 12px;
	}




}



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


	.main-upper,
	.main-lower{
		position: relative;
		background-image: url(../img/common/bg_tex3_sp.jpg);
		background-position: 50% 0;
		background-repeat: repeat;
		z-index: 20;
		background-size: 100% auto;
	}



	/* loading
	==========================================================*/

	.loading{
		background: url(../img/common/bg_loading_sp.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	.loading-logo{
		width: 250px;
		height: 43px;
	}

	/* kv
	==========================================================*/

	.kv{
		width: 100%;
		height: 100svh;
	}
	.kv-catch{
		position: absolute;
		bottom: 50%;
		margin: 0 0 -150px;
		width: 100%;
		text-align: center;
		color: #fff;
	}
	.kv-logo{
		margin: auto;
		max-width: 340px;
	}
	.kv-catch p{
		margin: 15px 0 0;
		font-size: 18px;
		font-weight: 600;
	}

	/* statement
	==========================================================*/

	#statement{
		position: relative;
		z-index: 15;
	}
	.statement-contents{
		position: relative;
		padding: calc(4000% / 375) 0 calc(45600% / 375);
		text-align: center;
		color: #fff;
	}
	.statement-bg{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	.statement-bg img{
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: 50% 100%;
	}


	.is-fix-statement .statement-bg{
		position: fixed;
	}

	.statement-header{
		margin: 30px 0 0;
	}
	.statement-header h1{
		font-weight: 600;
		font-size: 16px;
		line-height: calc(26/16);
		letter-spacing: 0.02em;
	}
	.statement-lead{
		margin: 25px 0 0;
	}
	.statement-lead p{
		font-weight: 600;
		line-height: calc(24/14);
	}
	.statement-lead p + p{
		margin-top: 25px;
	}
	.statement-img-box1{
		display: flex;
		flex-direction: row-reverse;
	}
	.statement-img1{
		padding: 0 calc(1500% / 375) 0 0;
		width: calc(10600% / 375);
	}
	.statement-img2{
		padding: calc(5800% / 375) calc(1300% / 375) 0 calc(5000% / 375);
		width: calc(13400% / 375);
	}
	.statement-img3{
		padding: calc(11000% / 375) 0 0 0 ;
		width: calc(13500% / 375);
	}

	.statement-img-box2{
		margin: 40px 0 0;
		display: flex;
		flex-direction: row-reverse;
	}
	.statement-img4{
		padding: 0 calc(2700% / 375) 0 calc(800% / 375);
		width: 50%;
	}
	.statement-img5{
		padding: calc(10500% / 375) calc(800% / 375) 0 calc(2700% / 375);
		width: 50%;
	}


	/* news
	==========================================================*/

	#news .news-contents{
		padding: 50px 0 80px;
		background: url(../img/common/bg_tex.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	.news-contents-inner{
		padding: 0 23px;
	}
	.news-header h2{
		width: 102px;
	}

	.news-list{
		margin: 40px 0 0;
	}
	.news-list a{
		position: relative;
		display: block;
		padding: 0 0 20px 5px;
		width: 100%;
	}
	.news-list a .line-link-txt{
		position: relative;
		width: 100%;
		padding: 0 45px 0 5px;
	}
	.news-list p{
		margin: 10px 0 0;
		line-height: 1.5;
	}
	.news-list .link-line{
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
	}
	.news-list a .line-link-txt:after{
		content: "";
		position: absolute;
		margin: auto;
		top: 0;
		right: 10px;
		bottom: 0;
		display: block;
		width: 12px;
		background: url(../img/common/arrow_r_br.svg) 50% 50% no-repeat;
		background-size: 100% 100%;
	}


	.news-list a[target="_blank"] .line-link-txt:after{
		content: "";
		position: absolute;
		margin: auto;
		top: 0;
		right: 10px;
		bottom: 0;
		display: block;
		width: 14px;
		height: 12px;
		background: url(../img/common/icon_blank_br.svg) 50% 50% no-repeat;
		background-size: 100% 100%;
	}
	.news-list .news-date{
		margin: 0 20px 0 0;
		line-height: 1.5;
		font-size: 16px;
	}
	.news-list-item + .news-list-item{
		padding-top: 20px;
	}



	/* chapel
	==========================================================*/

	.chapel-contents{
		padding: 45px 0;
		background: url(../img/common/bg_tex2.jpg) 50% 50% no-repeat;
		background-size: cover;
	}
	.chapel-contents .sec-header{
		text-align: center;

	}
	.chapel-contents .sec-header h2{
		margin: auto;
		width: 300px;
	}
	#chapel figure img{ 
		width: 100%;
		height: auto;
	}





	/* hotel
	==========================================================*/
	#hotel figure img{
		width: 100%;
	}
	.hotel-contents{
		margin: auto;
		padding: 0 0 50px;
	}

	.hotel-contents .sec-header h2{
		margin: auto;
		width: 103px;
	}
	.hotel-contents .sec-header{
		margin-top: -10px;
		position: relative;
		text-align: center;
		z-index: 100;
	}
	.hotel-contents .sec-header h2 + p{
		margin-top: 20px;
	}
	.hotel-image-list{
		margin: 35px 0 0;
	}
	.hotel-list-ticker-slide{
		position: relative;
		overflow: hidden;
	}
	.hotel-list-ticker{
		display: flex;
	}
	.hotel-list-ticker img{
		width: 100%;
	}

	.hotel-info{
		margin: 40px 0 0;
		padding: 0 30px;
	}

	.hotel-info dl + dl{
		margin-top: 20px;
	}
	.hotel-info dl dt{
		line-height: 1.5;
	}
	.hotel-info dl dd{
		margin-top: 10px;
		line-height: 1.5;
	}
	.hotel-map{
		margin: 30px auto 0;
		padding: 0 30px;
	}
	.hotel-map iframe{ 
		width: 100%;
		height: 180px;
	}
	.hotel-gallery-image{
		padding: 40px 10px;
		background: url(../img/common/bg_tex.jpg) 0 0 repeat;
		background-size: 100%;
	}
	.hotel-gallery-image-list{
		display: flex;
		flex-wrap: wrap;
		margin: 0 -5px;	
	}
	.hotel-gallery-image-list figure{
		padding: 0 5px;
		width: calc(100% / 3);
	}
	.hotel-gallery-image-list figure:nth-child(n+4){
		margin-top: 10px;
	}


}


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


}




