@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;
}
#main figure {
	position: relative;
}
#main img {
	width: 100%;
}
#main2,
#main-plot1,
#main-plot2,
#main-plot3,
#main-plot4,
#main-plot5,
#main-plot6,
#main-plot7,
#main-plot8,
#main-plot9,
#main-flash,
#main-copy {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
}
#main1,
#main2,
#main-plot1,
#main-plot2,
#main-plot3,
#main-plot4,
#main-plot5,
#main-plot6,
#main-plot7,
#main-plot8,
#main-plot9,
#main-flash,
#main-copy {
	display: none;
}
#main figcaption  {
	position: absolute;
	right: 1em;
	bottom: 1em;
	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-plot9 {
	transform-origin: 53% 68%;
}



/****************************************************************************************************
information
****************************************************************************************************/
#information {
	position: relative;
	padding-bottom: 100px;
	background: #000;
}
#info1 {
	position: relative;
	width: 1200px;
	margin: auto;
	z-index: 10;
}
#info1 h3 {
	margin-top: 60px;
	color: #C9BC9C;
	font-size: 4.8rem;
	font-weight: normal;
	line-height: 1.4;
	letter-spacing: 0.05em;
}
#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: #C9BC9C;
}
#info1 h3 a .small {
	margin-left: 0.2em;
	font-size: 2.8rem;
	letter-spacing: 0.05em;
}
#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: 30px;
}
#request-box p {
	margin-top: 1rem;
	font-size: 1.333rem;
	line-height: 1.6;
}



/****************************************************************************************************
mg
****************************************************************************************************/
.information {
	position: relative;
	width: 1200px;
	margin: auto;
	margin-top: 30px;
	z-index: 30;
}
.information > a {
	display: block;
}
.information h3 {
	padding: 0.3em;
	background: #A08E58;
	color: #FFF;
	font-size: 3.733rem;
	font-weight: normal;
	line-height: 1.2;
	letter-spacing: 0.1em;
}
.information h3 span {
	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;
	gap: 0.1em;
}
.information h3 span::after {
	content: "";
	display: inline-block;
	width: 46px;
	height: 46px;
	background: url(../img/top-v2/arrow.png) no-repeat center center;
	background-size: cover;
}
.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;
}



/****************************************************************************************************
index
****************************************************************************************************/
#index {
	position: relative;
	z-index: 2;
}
.index-block {
	border-top: 2px solid rgba(224,213,139,.5);
}
.index-block:nth-last-of-type(1) {
	border-bottom: 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;
	text-align: center;
}
.index-txt {
	display: inline-block;
	min-width: 400px;
	margin: auto;
	text-align: left;
}
.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 {
}

.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;
	}
	#main figcaption  {
		font-size: 0.533rem;
	}
	#main-plot9 {
		transform-origin: 72% 68%;
	}
		
		
		
	/****************************************************************************************************
	information
	****************************************************************************************************/
	#information {
		padding: 0 4vw 10vw 4vw;
	}
	#info1 {
		width: 100%;
	}
	#info1 h3 {
		margin-top: 6vw;
		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%;
	}
	#request-box p {
		margin-top: 1em;
		font-size: 0.866rem;
		text-align: left;
	}
	
	
	
	/****************************************************************************************************
	mg
	****************************************************************************************************/
	.information {
		width: 100%;
		margin-top: 5vw;
	}
	.information h3 {
		padding: 0.4em;
		font-size: 2.0rem;
	}
	.information h3 span::after {
		width: 1.866rem;
		height: 1.866rem;
	}
	.information div {
		font-size: 0.933rem;
	}
	
	
	
	/****************************************************************************************************
	index
	****************************************************************************************************/
	.index-img .img-box img {
		height: 50vw;
	}
	#concept .index-img .img-box img {
		object-position: 32% 0;
	}
	#location .index-img .img-box img {
		object-position: 25% 0;
	}
	#parking .index-img .img-box img {
		object-position: 35% 0;
	}
	#common-space .index-img .img-box img {
		object-position: 45% 0;
	}
	.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;
	}
}

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