@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');

.sp {
	display: none;
}

main {
	opacity: 1 !important;
}

html {
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	background: #fff;
}
header, footer, main, nav, section, article, figure, figcaption {
	display: block;
}
html, body, header, footer, main, nav, section, article, figure, figcaption,
div, p, ul, ol, dl, li, dt, dd,
h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
}
li {
	list-style: none;
}
i {
	font-style: normal;
}

img {
	vertical-align: bottom;
	border: none;
}

em {
	font-style: normal;
}

::selection {
	color: #fff;
	background: #999;
	opacity: 1;
}

#wrap > footer *::selection {
	color: #000;
	background: #bbb;
}



main {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 120px auto 100px;
	padding: 0 100px;
}


main {
	will-change: opacity;
	opacity: 0;
	transition: opacity 1000ms ease-out 100ms;
}
.loaded main {
	opacity: 1;
}


body {
	line-height: 1;
	color: #1e1e1e;
	font-family: "FP-ヒラギノ角ゴ ProN W4", sans-serif;
	background: #f0f0f0;
}

html:lang(en) body {
	font-family: "UniversLTPro-55Roman", sans-serif;
}


a {
	color: #1e1e1e;
	text-decoration: none;
}
a.disabled {
	pointer-events: none;
	cursor: default;
	opacity: 0.3;
}

.nowrap {
	white-space: nowrap;
}


#menu-button {
	display: none;
}




#wrap > header {
	position: fixed;
	width: 100%;
	height: 80px;
	left: 0;
	top: 0;
	z-index: 1000;
	background: #f0f0f0;
}
#wrap > header .inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	max-width: 1400px;
	height: 80px;
	margin: 0 auto;
	padding: 0 50px;
}


#wrap > header .logo {
	width: 152px;
	height: 36px;
}
#wrap > header .logo img {
	width: 100%;
	height: auto;
}


#wrap > header nav {
	display: flex;
	align-items: center;
}



#wrap > header nav > ul {
	display: flex;
	margin: 0 30px 0 0;
	font-size: 0.875rem;
}
#wrap > header nav ul li {
	position: relative;
}
#wrap > header nav ul li + li {
	margin-left: 40px;
}






#wrap > header a {
	cursor: pointer;
	transition: all 300ms ease-out;
}
#wrap > header a:hover {
	color: #666;
}




#wrap > header .lang {
}
#wrap > header .lang ul {
	display: flex;
}
#wrap > header .lang li {
	position: relative;
}
#wrap > header .lang li * {
	font-size: 0.875rem;
	font-family: "UniversLTPro-55Roman", sans-serif;
}
#wrap > header nav .lang ul li + li {
	margin-left: 24px;
}
#wrap > header .lang li + li::before {
	position: absolute;
	content: "";
	display: block;
	width: 1px;
	height: 14px;
	left: -12.5px;
	top: calc(50% - 8px);
	background: #1e1e1e;
}
#wrap > header .lang li.current a {
	color: #999;
}











#wrap > footer {
	margin: 150px 0 0;
	padding: 64px 0 50px;
	color: #f0f0f0;
	background: #1e1e1e;
}
#wrap > footer a {
	color: #f0f0f0;
	transition: all 300ms ease-out;
}
#wrap > footer a:hover {
	text-decoration: none;
}

#wrap > footer .inner {
	position: relative;
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 120px 0 100px;
}


#wrap > footer .logo {
	position: relative;
	width: 310px;
	top: -10px;
}
#wrap > footer .logo img {
	width: 288px;
	height: auto;
}



#wrap > footer .nav {
	position: relative;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 750px;
}

#wrap > footer .menu {
	display: flex;
	flex-wrap: wrap;
	width: 530px;
}
#wrap > footer .menu > ul {
	width: 50%;
}
#wrap > footer .extra {
	width: 100%;
	margin: 75px 0 0;
}

#wrap > footer .menu > ul li + li {
	margin-top: 24px;
}
#wrap > footer .menu > ul a {
	font-size: 0.875rem;
}
#wrap > footer .menu > ul a:hover {
	color: #999;
}



#wrap > footer .extra ul {
	display: flex;
}
#wrap > footer .extra li + li {
	margin-left: 20px;
}
#wrap > footer .extra a {
	font-size: 0.75rem;
	color: #969696;
}
#wrap > footer .extra a:hover {
	color: #666;
}




#wrap > footer .box {
	width: 220px;
}
#wrap > footer .sns + .sns {
	margin-top: 22px;
}
#wrap > footer .sns strong {
	display: block;
	font-size: 0.75rem;
	font-weight: 400;
	margin: 0 0 10px;
	padding: 0 0 10px;
	border-bottom: 1px solid #646464;
}
#wrap > footer .sns ul {
	display: flex;
}
#wrap > footer .sns li a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 30px;
	height: 30px;
	border-radius: 15px;
	background: #f0f0f0;
}
#wrap > footer .sns li a img {
	width: 14px;
	height: auto;
}
#wrap > footer .sns li + li {
	margin-left: 24px;
}




#wrap > footer .info {
	position: absolute;
	width: 310px;
	left: 100px;
	bottom: 0;
}

#wrap > footer .address {
	margin: 30px 0 0;
	font-size: 0.875rem;
}
#wrap > footer .copyright {
	margin: 15px 0 0;
	font-size: 0.75rem;
	font-family: "UniversLTPro-55Roman", sans-serif;
	color: #969696;
}
#wrap > footer .copyright span {
	position: relative;
	display: inline-block;
	margin: 0 3px;
	transform: scale(1.15);
}





#wrap > footer .lang {
}
#wrap > footer .lang ul {
	display: flex;
}
#wrap > footer .lang li {
	position: relative;
}
#wrap > footer .lang li + li {
	margin-left: 24px;
}
#wrap > footer .lang li * {
	font-size: 1rem;
	font-family: "UniversLTPro-55Roman", sans-serif;
}
#wrap > footer .lang li span {
	cursor: default;
}
#wrap > footer .lang li + li::before {
	position: absolute;
	content: "";
	display: block;
	width: 1px;
	height: 14px;
	left: -13px;
	top: calc(50% - 7px);
	background: #f0f0f0;
}
#wrap > footer li a:hover {
	color: #999;
}











#wrap {
	padding: 80px 0 0;
}










.top-kv {
	position: relative;
	height: calc(100vh - 80px);
}
.top-kv .inner {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10;
	overflow: hidden;
}
.top-kv .inner span {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.top-kv .inner span img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}







.top-intro {
	width: 600px;
	margin: 200px auto 0;
}
.top-intro h1 {
	font-size: 2rem;
}
.top-intro p {
	margin: 50px 0 0 35px;
	font-size: 1.125rem;
	line-height: 2;
}



.top-map {
	margin: 180px 0 0;
}
.top-map img {
	width: 100%;
	height: auto;
}
.top-map .scroll {
	display: none;
}







.top-architecture {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.top-architecture + .top-architecture {
	margin-top: 50px;
}

.top-architecture .header {
	padding: 0 0 20px;
	border-bottom: 1px solid #969696;
}
.top-architecture h2 {
	font-size: 1.25rem;
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}

.top-architecture li {
	border-bottom: 1px solid #969696;
}

.top-architecture li a {
	position: relative;
	display: flex;
	align-items: center;
	padding: 28px 0;
	cursor: pointer;
	transition: all 300ms ease-out;
}
.top-architecture .number {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 26px;
	height: 26px;
	margin: 0 20px 0 0;
	padding: 3px 0 0;
	font-size: 0.9125rem;
	font-family: "UniversLTPro-55Roman", sans-serif;
	color: #fff;
	background: #000;
	border-radius: 13px;
}
.top-architecture li strong {
	font-size: 1.75rem;
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-architecture li em {
	position: relative;
	top: 3px;
	margin-left: 22px;
	font-size: 1rem;
	font-family: "UniversLTPro-55Roman", sans-serif;
	vertical-align: bottom;
}

.top-architecture li a:hover {
	opacity: 0.7;
}

.top-architecture li a i {
	position: absolute;
	display: block;
	width: 40px;
	height: 40px;
	right: 40px;
	top: calc(50% - 20px);
	transition: all 300ms ease-out;
}
.top-architecture li a i::before,
.top-architecture li a i::after {
	position: absolute;
	display: block;
	content: "";
	width: 100%;
	height: 1px;
	left: 0;
	top: calc(50% - 0.5px);
	background: #646464;
}
.top-architecture li a i::after {
	transform: rotate(90deg);
}

.top-architecture li.opened a i {
	transform: rotate(-45deg);
}




.top-architecture li .extra {
	position: relative;
	height: 0;
	overflow: hidden;
	transition: all 400ms ease-out;
}

.top-architecture li .box {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	background: #e6e6e6;
}
.top-architecture li .box .text {
	box-sizing: border-box;
	width: 50%;
	padding: 40px 50px;
}
.top-architecture li .box .text p {
	font-size: 0.875rem;
	line-height: 2;
}
.top-architecture li .box figure {
	box-sizing: border-box;
	width: 50%;
}
.top-architecture li .box figure img {
	width: 100%;
	height: auto;
}








.top-profile {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.top-profile .inner {
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	padding: 80px 80px 50px;
	background: #e6e6e6;
}
.top-profile .box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: calc(100% - 218px - 80px);
}
.top-profile .label {
	font-size: 0.875rem;
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-profile dl {
	margin: 100px 0 0;
}
.top-profile dt {
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-profile dt strong {
	font-size: 1.5rem;
}
.top-profile dt span {
	font-size: 0.875rem;
}
.top-profile dd {
	margin: 25px 0 0;
	font-size: 1rem;
	line-height: 2;
}

.top-profile figure {
	width: 218px;
}
.top-profile img {
	width: 100%;
	height: auto;
}







.top-list {
	box-sizing: border-box;
	max-width: 1400px;
	margin: 150px auto 0;
	padding: 0 100px;
}
.top-list + .top-list {
	margin-top: 200px;
}
.top-list .box + .box {
	margin-top: 80px;
}

.top-list .box {
	position: relative;
}

.top-list.top-pickup .box {
	min-height: 450px;
}

@media screen and (max-width:1399px) {
	.top-list.top-pickup .box {
		min-height: calc((100vw - 200px) * 0.75 / 900 * 450);
	}
}




.top-list .box .gallery {
	position: absolute;
	width: 75%;
	height: 450px;
	right: 0;
	top: 0;
	z-index: 1;
	overflow: hidden;
}
.top-list .box .gallery-inner {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.top-list .box .gallery span {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}
.top-list .box .gallery img {
	width: 100%;
	height: auto;
}
.top-list .box .gallery span.hidden {
	opacity: 0;
}
.top-list .box .gallery span.ready {
	transition: all 800ms ease-out;
}



.top-list .box {
	background: #f0f0f0
}

.top-list .box ul {
	position: relative;
	z-index: 100;
	padding: 35px 0 0;
	mix-blend-mode: exclusion;
}
.top-list .box li {
	position: relative;
	padding: 0 0 45px;
}
.top-list .box li + li {
	margin-top: 45px;
}
.top-list .box li::after {
	position: absolute;
	content: "";
	display: block;
	width: 486px;
	height: 1px;
	left: 0;
	bottom: 0;
	z-index: 10;
	background: #c8c8c8;
	filter: invert(1);
	will-change: opacity;
}

.top-list .box dt {
	color: #fff;
	letter-spacing: 5px;
	line-height: 1.5;
	font-size: 2.25rem;
	font-family: "UniversNextPro-Thin", sans-serif;
}
.top-list .box dd {
	margin: 50px 0 0 100px;
	filter: invert(1);
}

.top-list .box dd span {
	position: relative;
	display: inline-block;
	padding: 0 75px 0 0;
	font-size: 0.875rem;
}
.top-list .box dd span em {
	position: absolute;
	display: block;
	width: 68px;
	height: 10px;
	right: 0;
	top: calc(50% - 5px);
	background: url(../img/arrow_long.svg) 50% 50% no-repeat;
	background-size: 100% auto;
	transition: all 300ms ease-out;
}
.top-list .box a:hover dd span em {
	transform: translateX(5px);
}















.top-kv .inner img {
	opacity: 0;
	transform: scale(1.1);
	transition: all 1500ms ease-out;
}
.top-kv.show .inner img {
	opacity: 1;
	transform: scale(1);
}






.top-intro h1 {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 300ms;
}
.top-intro  p {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 800ms;
}
.top-intro.show h1,
.top-intro.show p {
	opacity: 1;
	transform: translateY(0);
}




.top-map .map {
	opacity: 0;
	transition: all 800ms ease-out 0ms;
}
.top-map.show .map {
	opacity: 1;
}




.top-architecture .header {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 0ms;
}
.top-architecture.show .header {
	opacity: 1;
	transform: translateY(0);
}

.top-architecture li {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 0ms;
}
.top-architecture.show li {
	opacity: 1;
	transform: translateY(0);
}
.top-architecture li:nth-child(1) {
	transition-delay:  300ms;
}
.top-architecture li:nth-child(2) {
	transition-delay:  500ms;
}
.top-architecture li:nth-child(3) {
	transition-delay:  700ms;
}
.top-architecture li:nth-child(4) {
	transition-delay:  900ms;
}
.top-architecture li:nth-child(5) {
	transition-delay:  1100ms;
}
.top-architecture li:nth-child(6) {
	transition-delay:  1300ms;
}






.top-profile {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 0ms;
}
.top-profile.show {
	opacity: 1;
	transform: translateY(0);
}






.top-list h2 {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 0ms;
}
.top-list.show h2 {
	opacity: 1;
	transform: translateY(0);
}

.top-list li {
	opacity: 0;
	transition: all 1000ms ease-out 0ms;
}
.top-list li.show {
	opacity: 1;
	transform: translateY(0);
}

.top-list .box .gallery-inner {
	opacity: 0;
	transform: scale(1.1);
	transition: all 1000ms ease-out 300ms;
}
.top-list .box .gallery-inner.show {
	opacity: 1;
	transform: scale(1);
}









/* ---------- */
/* English */

html:lang(en) .top-intro h1 {
	font-weight: normal;
	font-family: "UniversLTPro-65Bold", sans-serif;
}
html:lang(en) .top-architecture h2 {
	font-weight: normal;
	font-family: "UniversLTPro-65Bold", sans-serif;
}
html:lang(en) .top-architecture li strong {
	position: relative;
	top: 3px;
	font-weight: normal;
	font-family: "UniversLTPro-55Roman", sans-serif;
}


html:lang(en) .top-profile dt {
	font-weight: normal;
	font-family: "UniversLTPro-55Roman", sans-serif;
}


html:lang(en) .top-list .box dd span {
	font-size: 1rem;
}


html:lang(en) .top-intro p {
	font-size: 1rem;
	line-height: 2;
}
html:lang(en) .top-architecture li .box .text p,
html:lang(en) .top-profile dd {
	line-height: 1.8;
}































































