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

.pc {
	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: #000;
	opacity: 1;
}

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


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


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


#wrap > header {
	position: fixed;
	width: 100%;
	height: 75px;
	left: 0;
	top: 0;
	z-index: 1000;
	background: #f2f2f2;
}


#wrap > header nav {
	position: fixed;
	width: 100vw;
	height: 100vh;
	height: 100lvh;
	left: 0;
	top: 75px;
	z-index: 999;
	background: #f2f2f2;
	
	visibility: hidden;
	opacity: 0;
	transition: all 400ms ease-out;
}
body.menu #wrap > header nav {
	visibility: visible;
	opacity: 1;
}
body.menu main {
	visibility: hidden;
	transition: all 400ms ease-out;
}
body.menu footer {
	visibility: hidden;
	transition: all 400ms ease-out;
}



main {
	box-sizing: border-box;
	margin: 100px auto 100px;
	padding: 0 20px;
}






#wrap > header .logo {
	position: absolute;
	width: 152px;
	height: 36px;
	left: 20px;
	top: calc(50% - 18px);
}
#wrap > header .logo img {
	width: 100%;
	height: auto;
}




#wrap > header nav > ul {
	margin: 75px 60px 0;
	font-size: 16px;
	text-align: right;
}
#wrap > header nav > ul li + li {
	margin-top: 30px;
}

#wrap > header .lang {
	margin: 50px 60px 0;
	text-align: right;
}
#wrap > header .lang ul {
	display: flex;
	justify-content: flex-end;
}
#wrap > header .lang li {
	position: relative;
}
#wrap > header .lang li + li {
	margin-left: 24px;
}
#wrap > header .lang li * {
	font-size: 16px;
	font-family: "UniversLTPro-55Roman", sans-serif;
}
#wrap > header .lang li + li::before {
	position: absolute;
	content: "";
	display: block;
	width: 1px;
	height: 18px;
	left: -12.5px;
	top: calc(50% - 11px);
	background: #1e1e1e;
}
#wrap > header .lang li.current a {
	color: #999;
}


#menu-button {
	position: fixed;
	width: 36px;
	height: 36px;
	right: 18px;
	top: 19px;
	z-index: 1001;
}
#menu-button a {
	position: relative;
	display: block;
	height: 36px;
}
#menu-button a i {
	position: absolute;
	width: 28px;
	height: 1px;
	left: 4px;
	top: 50%;
	background: #1e1e1e;
	transition: all 300ms ease-out;
}
#menu-button a i:nth-child(1) {
	margin-top: -7px;
}
#menu-button a i:nth-child(3) {
	margin-top: 7px;
}


body.menu #menu-button a i:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
body.menu #menu-button a i:nth-child(2) {
	opacity: 0;
}
body.menu #menu-button a i:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}










#wrap > footer {
	margin: 70px 0 0;
	padding: 60px 20px 30px;
	color: #f0f0f0;
	background: #1e1e1e;
}
#wrap > footer a {
	color: #f0f0f0;
}
#wrap > footer a:hover,
#wrap > footer a:active {
	text-decoration: none;
}

#wrap > footer .inner {
	position: relative;
}

#wrap > footer .logo {
	position: relative;
}
#wrap > footer .logo img {
	width: 66vw;
	height: auto;
}


#wrap > footer .nav {
	margin: 55px 0 0;
}

#wrap > footer .nav a {
	font-size: 14px;
}


#wrap > footer .menu {
	margin: 60px 0 0;
}
#wrap > footer .menu ul {
	display: inline;
	font-size: 0;
}
#wrap > footer .menu li {
	display: inline-block;
	width: 50%;
	margin: 0 0 24px;
}

#wrap > footer .extra {
	margin: 30px 0 0;
}
#wrap > footer .extra a {
	font-size: 12px;
	color: #969696;
}






#wrap > footer .sns {
	margin: 50px 0 0;
}
#wrap > footer .sns + .sns {
	margin-top: 32px;
}
#wrap > footer .sns strong {
	display: block;
	margin: 0 0 20px;
	padding: 0 0 10px;
	font-size: 12px;
	color: #969696;
	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: 40px;
	height: 40px;
	border-radius: 20px;
	background: #f0f0f0;
}
#wrap > footer .sns li a img {
	width: 18px;
	height: auto;
}
#wrap > footer .sns li + li {
	margin-left: 36px;
}


#wrap > footer .lang {
	margin: 40px 0 0;
}
#wrap > footer .lang ul {
	display: flex;
}
#wrap > footer .lang li {
	position: relative;
}
#wrap > footer .lang li + li {
	margin-left: 16px;
}
#wrap > footer .lang li * {
	font-size: 14px;
	font-family: "UniversLTPro-55Roman", sans-serif;
}
#wrap > footer .lang li + li::before {
	position: absolute;
	content: "";
	display: block;
	width: 1px;
	height: 14px;
	left: -9px;
	top: calc(50% - 7px);
	background: #f0f0f0;
}

#wrap > footer .info {
}
#wrap > footer .address {
	margin: 30px 0 0;
	font-size: 14px;
}

#wrap > footer .copyright {
	margin: 15px 0 0;
	font-size: 12px;
	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 {
	padding: 75px 0 0;
}








.top-kv {
	position: relative;
	height: calc(100vw);
}
.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 {
	margin: 90px 20px 0 50px;
}
.top-intro h1 {
	font-size: 22px;
}
.top-intro p {
	margin: 35px 0 0 30px;
	font-size: 14px;
	line-height: 2;
}






.top-map {
	position: relative;
	margin: 90px 0 0;
}
.top-map .map {
	position: relative;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
}
.top-map .map img {
	width: 540px;
}

.top-map .scroll {
	position: absolute;
	width: 86px;
	right: 0;
	top: 30px;
	z-index: 10;
	color: #1e1e1e;
	font-size: 10px;
}
.top-map .scroll::after {
	position: absolute;
	content: "";
	display: block;
	width: 52px;
	height: 1px;
	right: 0;
	top: 5px;
	background: #1e1e1e;
}







.top-architecture {
	box-sizing: border-box;
	margin: 100px 20px 0;
}
.top-architecture + .top-architecture {
	margin-top: 80px;
}

.top-architecture .header {
	padding: 0 0 15px;
	border-bottom: 1px solid #969696;
}
.top-architecture h2 {
	font-size: 14px;
	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: 14px 0;
	cursor: pointer;
	transition: all 300ms ease-out;
}
.top-architecture .number {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 18px;
	height: 18px;
	margin: 0 10px 0 0;
	padding: 2px 0 0;
	font-size: 8px;
	font-family: "UniversLTPro-55Roman", sans-serif;
	color: #fff;
	background: #000;
	border-radius: 10px;
}
.top-architecture li strong {
	font-size: 16px;
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-architecture li em {
	position: relative;
	top: 2px;
	margin-left: 12px;
	font-size: 12px;
	font-family: "UniversLTPro-55Roman", sans-serif;
	vertical-align: bottom;
}


.top-architecture li a i {
	position: absolute;
	display: block;
	width: 16px;
	height: 16px;
	right: 12px;
	top: calc(50% - 8px);
	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;
	flex-direction: column-reverse;
	background: #e6e6e6;
}
.top-architecture li .box .text {
	box-sizing: border-box;
	padding: 30px 20px;
}
.top-architecture li .box .text p {
	font-size: 12px;
	line-height: 2;
}
.top-architecture li .box figure {
	box-sizing: border-box;
}
.top-architecture li .box figure img {
	width: 100%;
	height: auto;
}








.top-profile {
	box-sizing: border-box;
	margin: 80px 20px 0;
}
.top-profile .inner {
	position: relative;
	box-sizing: border-box;
	display: flex;
	flex-direction: column-reverse;
	padding: 30px 20px 20px;
	background: #e6e6e6;
}
.top-profile .box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.top-profile .label {
	position: absolute;
	left: 20px;
	top: 30px;
	font-size: 12px;
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-profile dl {
	margin: 30px 0 0;
}
.top-profile dt {
	font-family: "FP-ヒラギノ角ゴ ProN W6", sans-serif;
}
.top-profile dt strong {
	font-size: 18px;
}
.top-profile dt span {
	font-size: 12px;
}
.top-profile dd {
	margin: 25px 0 0;
	font-size: 14px;
	line-height: 2;
}

.top-profile figure {
	text-align: right;
}
.top-profile img {
	width: 138px;
	height: auto;
}






.top-list {
	box-sizing: border-box;
	margin: 120px auto 0;
	padding: 0 20px;
}
.top-list h2 {
	margin: 0 0 30px;
	letter-spacing: 3px;
	font-size: 20px;
	font-family: "UniversNextPro-Thin", sans-serif;
}

.top-list + .top-list {
	margin-top: 100px;
}
.top-list .box + .box {
	margin-top: 40px;
}

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





.top-list .box .image {
	display: block;
	overflow: hidden;
}
.top-list .box .image img {
	width: 100%;
	height: auto;
}



.top-list .box ul {
}
.top-list .box li {
	position: relative;
	padding: 0 0 30px;
}
.top-list .box li + li {
	margin-top: 30px;
}
.top-list .box li::after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	left: 0;
	bottom: 0;
	z-index: 10;
	background: #c8c8c8;
}
.top-list .box dl {
	margin: 25px 0 0;
}
.top-list .box dt {
	letter-spacing: 4px;
	line-height: 1.5;
	font-size: 28px;
	font-family: "UniversNextPro-Thin", sans-serif;
}
.top-list .box dd {
	margin: 5px 0 0;
	text-align: right;
}
.top-list .box dd span {
	position: relative;
	display: inline-block;
	padding: 0 48px 0 0;
	font-size: 12px;
}
.top-list .box dd span em {
	position: absolute;
	display: block;
	width: 42px;
	height: 6px;
	right: 0;
	top: calc(50% - 4px);
	background: url(../img/arrow_long.svg) 50% 50% no-repeat;
	background-size: 100% auto;
}













.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,
.top-map .scroll {
	opacity: 0;
	transition: all 800ms ease-out 0ms;
}
.top-map .scroll {
	transition-delay: 500ms;
}
.top-map.show .map,
.top-map.show .scroll {
	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 .image img {
	opacity: 0;
	transform: scale(1.1);
	transition: all 1000ms ease-out 0ms;
}
.top-list .box .image.show img {
	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: 2px;
	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: 14px;
}




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














































