@charset "UTF-8";
/* CSS Document */



/****************************************************************************************************
contents
****************************************************************************************************/
html,body{
	background: #000 url(../img/top/contents-bg.jpg) no-repeat center top;
	background-attachment: fixed;
}
#contents {
	color: #FFF;
	overflow: hidden;
}



/****************************************************************************************************
main
****************************************************************************************************/
#main {
	position: relative;
	background: #000;
	border-bottom: 1px solid rgba(224,213,139,.25);
}
#main figure {
	position: relative;
}
#main img {
	width: 100%;
}
#main2,
#main3,
#main4,
#main5,
#main6,
#main7,
#main8,
#main9,
#main10,
#main11,
#main12,
#main13 {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
}
#main1,
#main2,
#main3,
#main4,
#main5,
#main6,
#main7,
#main8,
#main9,
#main10,
#main11,
#main12,
#main13 {
	display: none;
}
#main6 {
	transform-origin: 20% 20%;
}
#main8 {
	transform-origin: 50% 95%;
}
#main7 figcaption  {
	position: absolute;
	left: 2.1vw;
	bottom: 6.4vw;
	color: #FFF;
	font-size: 0.733rem;
	font-weight: bold;
	text-shadow:
		0px 0px 10px rgba(0,0,0,1),
		0px 0px 10px rgba(0,0,0,1);
	z-index: 20;
}



/****************************************************************************************************
information
****************************************************************************************************/
#information {
	background: #000;
}
#info1 {
	width: 1200px;
	margin: auto;
	padding: 100px 0 0 0;
}
#info1 h2 {
	font-size: 1.733rem;
	font-weight: normal;
	line-height: 1.4;
}
#info1 h2 strong {
	color: #DFD28D;
}
#info1 h2 sup {
	font-size: 50%;
	vertical-align: top;
}
#info1 h3 {
	margin-top: 0.1em;
	color: #DFD38E;
	font-size: 5.466rem;
	font-weight: normal;
	line-height: 1.4;
}
#info1 h3 a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	color: #DFD38E;
}
#info1 h3 a .small {
	margin-left: 0.2em;
	font-size: 3.466rem;
}
#info1 p {
	margin-top: 0.2em;
	font-size: 1.333rem;
	line-height: 1.6;
}
#request-box {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-lines: multiple;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	gap: 10px;
	max-width: 1200px;
	margin: 0 auto 0 auto;
	margin-top: 60px;
}



/****************************************************************************************************
mg
****************************************************************************************************/
.information {
	position: relative;
	width: 1200px;
	margin: auto;
	margin-top: 30px;
	margin-bottom: 40px;
	z-index: 30;
}
.information > a {
	display: block;
}
.information h3 {
	padding: 1.2em;
	background: #A08E58;
	color: #FFF;
	font-size: 1.266rem;
	line-height: 1.8;
}
.information div {
	padding: 1.2em;
	background: rgba(255,255,255,.9);
	border: 1px solid #CCCCCC;
	color: #111;
	font-size: 1.266rem;
	line-height: 1.8;
}



/****************************************************************************************************
concept
****************************************************************************************************/
#concept {
	position: relative;
	padding: 200px 0 200px 0;
	background: url(../img/top/concept-bg.png) no-repeat center top;
}
#concept-movie-block {
	width: 1200px;
	margin: auto;
	margin-top: 100px;
}
#concept-movie-block h3 {
	font-size: 1.6rem;
	line-height: 1.4;
	letter-spacing: 0.05em;
	text-shadow: 0 0 10px rgba(0,0,0,1);
}
.movie-box {
	margin-top: 1.5rem;
}
.movie-box a {
	display: inline-block;
	box-shadow: 0 0 15px rgba(0,0,0,.45);
}
#concept-block2 {
	width: 1200px;
	margin: auto;
	margin-top: 100px;
	/*margin-top: 80px;
	padding-top: 80px;
	border-top: 1px solid rgba(255,255,255,.25);*/
}
#concept-block1 h3,
#concept-block2 h3 {
	margin-top: 1em;
	font-size: 2rem;
	line-height: 1.4;
	letter-spacing: 0.05em;
	text-shadow: 0 0 10px rgba(0,0,0,1);
}
#concept-block1 p,
#concept-block2 p {
	margin-top: 3em;
	font-size: 1.333rem;
	line-height: 2.8;
	letter-spacing: 0.1em;
	text-shadow: 0 0 10px rgba(0,0,0,1);
}
#concept-block2 p {
	margin-top: 1.5em;
	margin-bottom: 40px;
	line-height: 1.8;
	letter-spacing: 0;
}
.flex-block {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	gap: 30px;
}
.img-box {
	display: inline-block;
}
.img-box figcaption {
	text-align: right;
	margin-top: 0.8em;
	font-size: 0.866rem;
	line-height: 1.4;
}
.request-repeat {
	margin-top: 100px;
}
.request-repeat p {
	margin-top: 2rem;
	font-size: 1.333rem;
	line-height: 1.6;
}



/****************************************************************************************************
index
****************************************************************************************************/
#index {
	position: relative;
	z-index: 2;
}
.index-block {
	border-top: 2px solid rgba(224,213,139,.5);
}
.index-block,
.index-block > a {
	position: relative;
	display: block;
	width: 100%;
}
.index-img {
	width: 100%;
	overflow: hidden;
}
.index-img .img-box {
	position: relative;
	display: inline-block;
	width: 100%;
	background: #000;
}
.index-img .img-box img {
	object-fit: cover;
	object-position: right center;
	width: 100%;
	height: 600px;
	transition: all 500ms;
}
.index-img .img-box figcaption.in {
	position: absolute;
	left: 1em;
	bottom: 1em;
	font-size: 0.666rem;
}
.index-img .img-box figcaption.in.white {
	color: #FFF;
	font-weight: bold;
	text-shadow:
		0 0 5px rgba(0,0,0,1),
		0 0 5px rgba(0,0,0,1),
		0 0 5px rgba(0,0,0,1);
}
.index-text {
	position: absolute;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	right: 0;
	top: 0;
	width: 40%;
	height: 600px;
	padding-left: 60px;
	text-align: left;
}
.index-txt {
	display: inline-block;
	min-width: 400px;
}
.index-txt h3 {
	margin-bottom: 36px;
	color: #DFD48B;
	font-family: "Cormorant Infant", serif;
	font-weight: 500;
	font-style: normal;
	font-size: 2.8rem;
	letter-spacing: 0.05em;
	transition: all 500ms;
}
.index-txt h4 {
	color: #FFF;
	font-size: 1.733rem;
	line-height: 1.6;
	letter-spacing: 0.05em;
	white-space: nowrap;
	transition: all 500ms;
}
.index-txt h4 .small {
	font-size: 1.2rem;
}
.index-btn {
	position: relative;
	display: inline-block;
	min-width: 200px;
	margin-top: 4.5em;
	padding-bottom: 0.4em;
	color: #FFF;
	font-size: 1.033rem;
	font-family: Futura, 'Century Gothic';
	transition: all 500ms;
}
.index-btn::after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 15px;
	right: 0;
	bottom: 0;
	border-right: 1px solid rgba(255,255,255,.5);
	border-bottom: 1px solid rgba(255,255,255,.5);
	transform: skew(45deg, 0);
	transform-origin: 100% 100%;
}

.index-block:nth-of-type(odd) .index-img {
	-webkit-box-ordinal-group:3;
	-webkit-order:2;
	-ms-flex-order:2;
	order:2;
}
.index-block:nth-of-type(odd) .index-img .img-box img {
	object-position: right center;
}
.index-block:nth-of-type(odd) .index-img .img-box figcaption.in {
	left: auto;
	right: 1em;
}
.index-block:nth-of-type(odd) .index-text {
    -webkit-box-pack:end;
    -webkit-justify-content:flex-end;
    -ms-flex-pack:end;
    justify-content:flex-end;
	right: auto;
	left: 0;
	padding-left: 0;
	padding-right: 60px;
}
.index-block:nth-of-type(odd) .index-text .index-txt {
	text-align: left;
}

.index-text::before {
	content: "";
	display: block;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	height: 600px;
	background: rgba(0,0,0,.8);
	transition: all 500ms;
}
.index-block > a:hover {
	opacity: 1;
}
.index-block > a:hover .index-text::before {
	right: -100%;
}
.index-block:nth-of-type(odd) > a:hover .index-text::before {
	right: 100%;
}
.index-block > a:hover .index-img .img-box img {
	opacity: 0.5;
}
.index-block > a:hover .index-txt h3,
.index-block > a:hover .index-txt h4,
.index-block > a:hover .index-txt p,
.index-block > a:hover .index-txt .index-btn {
	border-color: rgba(255,255,255,.5);
	color: #FFF;
}




@media screen and (max-width: 767px),
screen and (max-width: 960px) and (orientation: landscape) {
	html,body{
		background: #000 url(../img/top/contents-bg.jpg) no-repeat center top;
		background-attachment: fixed;
		background-size: 200vw 100vh;
	}
	
	.spLeft {
		text-align: left;
	}
	
	
	/****************************************************************************************************
	main
	****************************************************************************************************/
	#main {
		position: relative;
		width: 100%;
		height: auto;
		left: 0;
		top: 0;
		padding-bottom: 4vw;
		z-index:10;
	}
	#main img {
		width: 140vw;
		margin-left: -15vw;
	}
	#main6 img {
		width: 130vw;
		margin-left: 0;
	}
	#main7 {
		top: auto;
		bottom: 4vw;
	}
	#main7 img {
		width: 130vw;
		margin-left: 0;
	}
	#main8 {
		top: auto;
		bottom: 0;
	}
	#main8 img {
		width: 120vw;
		margin-left: -10vw;
	}
	#main6 {
		transform-origin: 20% 20%;
	}
	#main8 {
		transform-origin: 50% 95%;
	}
	#main7 figcaption  {
		left: 2.1vw;
		bottom: 6.4vw;
		font-size: 0.533rem;
	}
		
		
		
	/****************************************************************************************************
	information
	****************************************************************************************************/
	#information {
		padding: 0 4vw 0 4vw;
	}
	#info1 {
		width: 100%;
		padding: 6vw 0 0 0;
	}
	#info1 h2 {
		font-size: 1.0rem;
		font-weight: normal;
		line-height: 1.6;
	}
	#info1 h3 {
		font-size: 2.4rem;
	}
	#info1 h3 a {
		-webkit-box-lines: multiple;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	#info1 h3 a .small {
		margin-left: 0;
		font-size: 2rem;
	}
	#info1 p {
		font-size: 0.866rem;
		text-align: left;
	}
	#request-box {
		-webkit-box-lines: multiple;
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		gap: 1vw;
		min-width: initial;
		min-width: auto;
		width: 92vw;
		margin: auto;
		margin-top: 4vw;
	}
	#request-box > div {
		width: 100%;
	}
	#request-box > div img {
		width: 100%;
	}
	
	
	
	/****************************************************************************************************
	mg
	****************************************************************************************************/
	.information {
		width: 100%;
		margin-top: 5vw;
		margin-bottom: 5vw;
	}
	.information h3 {
		font-size: 0.933rem;
	}
	.information div {
		font-size: 0.933rem;
	}
	
	
	
	/****************************************************************************************************
	concept
	****************************************************************************************************/
	#concept {
		padding: 15vw 0 10vw 0;
		background-size: 170vw auto;
	}
	#concept-movie-block {
		width: 92vw;
		margin: auto;
		margin-top: 10vw;
	}
	#concept-movie-block h3 {
		font-size: 1.2rem;
		letter-spacing: 0;
		line-height: 1.6;
	}
	.movie-box {
		margin-top: 1.0rem;
	}
	#concept-block2 {
		width: 92vw;
		margin: auto;
		margin-top: 10vw;
		/*margin-top: 8vw;
		padding-top: 8vw;*/
	}
	#concept-block1 h2 {
		width: 70vw;
		margin: auto;
	}
	#concept-block1 h3,
	#concept-block2 h3 {
		font-size: 1.5rem;
		letter-spacing: 0;
	}
	#concept-block1 p,
	#concept-block2 p {
		margin-top: 2em;
		font-size: 0.866rem;
		line-height: 2.4;
		letter-spacing: 0;
	}
	#concept-block2 p {
		margin-top: 1.2em;
		margin-bottom: 4vw;
		line-height: 1.8;
		letter-spacing: 0;
	}
	.flex-block {
		gap: 2vw;
	}
	.img-box figcaption {
		font-size: 0.533rem;
	}
	.request-repeat {
		margin-top: 10vw;
	}
	.request-repeat p {
		width: 92vw;
		margin: auto;
		margin-top: 1rem;
		font-size: 0.866rem;
		line-height: 1.6;
		text-align: left;
	}
	
	
	
	/****************************************************************************************************
	index
	****************************************************************************************************/
	.index-img .img-box img {
		height: 50vw;
	}
	.index-img .img-box figcaption.in {
		left: auto;
		right: 1em;
		font-size: 0.533rem;
	}
	.index-text {
		position: static;
		width: 100%;
		height: auto;
		padding: 10vw 10vw 10vw 10vw;
		background: rgba(0,0,0,.5);
	}
	.index-txt {
		width: 80vw;
		min-width: initial;
		min-width: auto;
	}
	.index-txt h3 {
		margin-bottom: 6vw;
		font-size: 2.4rem;
	}
	.index-txt h4 {
		font-size: 1.333rem;
	}
	.index-txt h4 .small {
		font-size: 1.0rem;
	}
	.index-btn {
		min-width: 40vw;
		margin-top: 3em;
		font-size: 0.933rem;
	}
	.index-btn::after {
		height: 3vw;
	}
	
	.index-block:nth-of-type(odd) .index-img {
		-webkit-box-ordinal-group:1;
		-webkit-order:0;
		-ms-flex-order:0;
		order:0;
	}
	.index-block:nth-of-type(odd) .index-text {
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		padding: 10vw 10vw 10vw 10vw;
	}
	
	.index-text::before {
		display: none;
	}
	.position-text h3 {
		font-size: 1.333rem;
	}
	.position-text p {
		font-size: 0.933rem;
	}
	.location-img-block {
		gap: 4vw 2vw;
		margin-top: 6vw;
		margin-bottom: 10vw;
	}
	.location-img-block > .img-box {
		width: 45vw;
	}
	.location-img-block.spLarge > .img-box {
		width: 100%;
	}
	.location-img-block + .location-img-block.v2 {
		margin-top: 4vw;
	}
	.location-img-block.v2 {
		gap: 2vw;
	}
	.location-facility-box {
		width: 100%;
		padding: 4vw 6vw;
	}
	.location-facility-box h4 {
		margin-bottom: 0.6em;
		padding-bottom: 0.6em;
		font-size: 0.866rem;
	}
	.location-facility-box ul {
		font-size: 0.866rem;
	}
	figure.facility-img {
		position: relative;
	}
	figure.facility-img figcaption {
		font-size: 0.866rem;
	}
	.access-block {
		margin-top: 6vw;
	}
	#ashiya-block {
		width: 100%;
		margin-top: 6vw;
		padding: 8vw 6vw 6vw 6vw;
	}
	#ashiya-topics {
		left: 1px;
		top: 1px;
		padding: 0.3em 0.6em;
		font-size: 0.866rem;
	}
	#ashiya-block::after {
		width: calc(100% - 2vw);
		height: calc(100% - 2vw);
		left: 1vw;
		top: 1vw;
	}
	#ashiya-block h3 {
		font-size: 1.4rem;
		line-height: 1.4;
	}
	#ashiya-block p {
		margin-top: 1rem;
		padding-top: 1rem;
		font-size: 1.0rem;
		line-height: 1.6;
	}
	#ashiya-block p.small {
		font-size: 0.666rem;
	}
}

@media screen and (max-width: 960px) and (orientation: landscape) {
}