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



/****************************************************************************************************
header
****************************************************************************************************/
#logo,
#wakohre/*,
#tel img*/ {
    filter: invert(100%) brightness(500%);
}
#hnavi .outline a {
	color: #FFF;
}
#header::after {
	background-image: linear-gradient(180deg, rgba(0,0,0,.8), rgba(0,0,0,.8));
}
#gNavi > ul > li {
	border-left:1px solid rgba(255,255,255,0.25);
}
#gNavi > ul > li:nth-last-of-type(1) {
	border-right:1px solid rgba(255,255,255,0.25);
}
#gNavi > ul > li > a,
#gNavi > ul > li > span {
	color: #FFF;
}
#gNavi > ul > li.select > a {
	color: #E0D27D;
}
#gNavi > ul > li > a span.small {
	color: #FFF;
}

/*#footer {
	background: #191919;
	border-top: 1px solid rgba(225,211,125,.5);
	color: #FFF;
}
#tel div a {
	color: #FFF;
}*/



/****************************************************************************************************
contents
****************************************************************************************************/
#contents {
	overflow: hidden;
}



/****************************************************************************************************
main
****************************************************************************************************/
#main {
	position: relative;
}
#main::after {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 300px;
	left: 0;
	bottom: 0;
	background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,1));
	z-index: 10;
}
#main figure {
	position: relative;
}
#main figure figcaption {
	position: absolute;
	right: 0.8em;
	bottom: 0.8em;
	color: #FFF;
	font-size: 0.866rem;
	font-weight: bold;
	text-shadow:
		0px 0px 10px rgba(0,0,0,1),
		0px 0px 10px rgba(0,0,0,1);
	z-index: 20;
}
#main img {
	width: 100%;
}
#main1,
#main2,
#main-copy1,
#main-copy2,
#main-copy3,
#main-bukken,
#main-parts1,
#main-parts2 {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
}
#main0,
#main1,
#main2,
#main-copy1,
#main-copy2,
#main-copy3,
#main-bukken,
#main-parts1,
#main-parts2,
#main-light {
	display: none;
}
#main-copy1 {
	transform-origin: 50% 20%;
}
#main-copy2 {
	transform-origin: 50% 25%;
}
#main-copy3 {
	transform-origin: 50% 27%;
}
#main-light {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #FFF;
}
#price {
	position: absolute;
	width: 57.75vw;
	left: 2vw;
	bottom: 150px;
	z-index: 100;
}
#access {
	position: absolute;
	width: 33.625vw;
	right: 2vw;
	bottom: 150px;
	z-index: 100;
}
#price img,
#access img {
	width: 100%;
	height: auto;
}



/****************************************************************************************************
information
****************************************************************************************************/
#information {
	position: relative;
	margin-top: -120px;
	padding: 0 0 100px 0;
	z-index: 10;
}
#info1 div {
	font-size: 2.666rem;
	letter-spacing: 0.1em;
	line-height: 1.4;
}
#info1 h2 {
	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;
	margin-top: 0.2em;
	color: #FFF;
	font-size: 5.466rem;
	font-weight: normal;
	line-height: 1.3;
}
#info1 h2 span.sub {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient:vertical;
    -webkit-box-direction:normal;
    -webkit-flex-direction:column;
    -ms-flex-direction:column;
    flex-direction:column;
	margin: 0 0.2em;
	font-size: 2rem;
	line-height: 1.3;
}
#info1 h2 span.small {
	margin-left: 0.2em;
	font-size: 3.066rem;
	vertical-align: 0.3em;
}
#info1 h2 a {
	color: #E60013;
}
#info1 p {
	margin-top: 1em;
	font-size: 1.6rem;
	line-height: 1.6;
}
#point {
	margin-top: 36px;
}
#present {
	margin-top: 40px;
}
#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: 50px auto 0 auto;
}
.movie-block {
	margin-top: 60px;
}



/****************************************************************************************************
link
****************************************************************************************************/
#link {
	position: relative;
	z-index: 30;
	overflow: hidden;
}
.link-block {
	border-top: 2px solid rgba(225,211,125,.5);
}
.link-block > a,
.link-block > span {
	position: relative;
	display: block;
}
.link-block > span {
	opacity: .3;
}
.link-block a:hover {
	opacity: 0.75;
}
.title-box {
	position: absolute;
	left: 60px;
	top: 60px;
	text-align: left;
	z-index: 50;
}
.title-box h2 {
	color: #D3D1A9;
	font-size: 5.333rem;
	text-shadow: 0 0 20px rgba(0,0,0,1);
}
.title-box p {
	position: relative;
	display: inline-block;
	margin-top: 0.4em;
	color: #FFF;
	font-size: 2.133rem;
	text-shadow: 0 0 20px rgba(0,0,0,1);
}
.title-box p::after {
	position: absolute;
	display: block;
	top: 50%;
	right: -10px;
	content: "";
	width: 100px;
	height: 1px;
	background: #FFF;
	opacity: .5;
	-webkit-transform: translate(100%, -1px);
	transform: translate(100%, -1px);
}
.btn-box {
	position: absolute;
	display: block;
	left: 40px;
	bottom: 40px;
	padding: 0.6em 2em;
	background: #000;
	border: 1px solid rgba(205,194,163,0.5);
	color: #D3D1A9;
	font-size: 1.333rem;
	z-index: 40;
}
.img-box {
	position: relative;
	overflow: hidden;
}
.img-box img {
	object-fit: cover;
	width: 100%;
	height: 600px;
}
.img-box .bg img {
	-webkit-transition: transform 300ms ease-out;
	-moz-transition: transform 300ms ease-out;
	transition: transform 300ms ease-out;
}
.link-block a:hover .img-box .bg img {
	-webkit-transform: scale(1.02);
	transform: scale(1.02);
}
/*.img-box .bg::before {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: url(../img/top/shadow.png);
	opacity: .75;
	z-index: 10;
}*/
.img-box .bg::after {
	position: absolute;
	display: block;
	content: "";
	width: 50%;
	height: 100%;
	left: 0;
	top: 0;
	background-image: linear-gradient(90deg, rgba(0,0,0,.5), rgba(0,0,0,0));
	opacity: .75;
	z-index: 10;
}
.img-box figcaption {
	position: absolute;
	right: 1em;
	bottom: 1em;
	color: #FFF;
	font-size: 0.866rem;
	text-shadow:
		0 0 10px rgba(0,0,0,1),
		0 0 10px rgba(0,0,0,1),
		0 0 10px rgba(0,0,0,1);
	z-index: 30;
}
.link-block:nth-of-type(odd) .title-box {
	left: auto;
	right: 60px;
	top: 60px;
	text-align: right;
}
.link-block:nth-of-type(odd) .title-box p::after {
	position: absolute;
	display: block;
	top: 50%;
	right: auto;
	left: -10px;
	content: "";
	width: 100px;
	height: 1px;
	background: #FFF;
	opacity: .5;
	-webkit-transform: translate(-100%, -1px);
	transform: translate(-100%, -1px);
}
.link-block:nth-of-type(odd) .btn-box {
	left: auto;
	right: 40px;
}
.link-block:nth-of-type(odd) .img-box .bg::after {
	left: auto;
	right: 0;
	background-image: linear-gradient(270deg, rgba(0,0,0,.5), rgba(0,0,0,0));
}
.link-block:nth-of-type(odd) .img-box figcaption {
	right: auto;
	left: 1em;
}




@media screen and (max-width: 767px),
screen and (max-width: 960px) and (orientation: landscape) {
	#tel div a {
		color: #FFF;
	}
	
	
	
	/****************************************************************************************************
	main
	****************************************************************************************************/
	#main {
	}
	#main::after {
		height: 30vw;
	}
	#main figure figcaption {
		font-size: 0.4rem;
	}
	#main img {
		width: 140%;
		margin-left: -20%;
	}
	#price {
		width: 92.4vw;
		left: 11vw;
		bottom: 8vw;
	}
	#access {
		width: 53.8vw;
		right: auto;
		left: 7.1vw;
		bottom: 19.5vw;
	}
	#main #price img {
		width: 100%;
	}
	#main #access img {
		width: 100%;
	}
		
		
		
	/****************************************************************************************************
	information
	****************************************************************************************************/
	#information {
		margin-top: -6vw;
		padding: 0 4vw 10vw 4vw;
	}
	#info1 div {
		font-size: 1.533rem;
		line-height: 1.4;
	}
	#info1 h2 {
		font-size: 2.133rem;
	}
	#info1 h2 span.sub {
		margin: 0 0.2em;
		font-size: 0.866rem;
	}
	#info1 h2 span.small {
		display: block;
		margin-left: 0;
		font-size: 1.4rem;
		vertical-align: 0;
		line-height: 1.4;
	}
	#info1 p {
		padding: 0.8em 0em;
		font-size: 1.0rem;
	}
	#point {
		margin-top: 4vw;
	}
	#present {
		margin-top: 5vw;
	}
	#request-box {
		gap: 1vw;
		min-width: initial;
		min-width: auto;
		margin: 5vw 0 0 0;
	}
	#request-box > div {
		width: 100%;
	}
	#request-box > div img {
		width: 100%;
	}
	.movie-block {
		margin-top: 4vw;
	}
	
	
	
	/****************************************************************************************************
	link
	****************************************************************************************************/
	.link-block + .link-block {
		margin-top: 0;
	}
	.title-box {
		position: static;
		padding: 4vw;
	}
	.title-box h2 {
		font-size: 2rem;
	}
	.title-box p {
		margin-top: 0.4em;
		font-size: 1.2rem;
	}
	.title-box p::after {
		right: -2vw;
		width: 100vw;
		opacity: .25;
	}
	.btn-box {
		left: 2vw;
		bottom: 2vw;
		font-size: 1.0rem;
	}
	.img-box .color {
		opacity: 0.25;
	}
	.img-box .color::before {
		opacity: .75;
	}
	.img-box img {
		height: 50vw;
	}
	.img-box figcaption {
		font-size: 0.533rem;
	}
	.link-block .img-box .bg::after {
		display: none;
	}
	.link-block:nth-of-type(odd) .title-box {
		left: auto;
		right: 6vw;
		top: 6vw;
	}
	.link-block:nth-of-type(odd) .title-box p::after {
		right: auto;
		left: -2vw;
		width: 100vw;
		opacity: .25;
	}
	.link-block:nth-of-type(odd) .btn-box {
		right: 2vw;
		left: auto;
	}
}

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