@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;
}












#kv {
	position: relative;
	height: calc(100vh - 80px);
	overflow: hidden;
}
#kv .map {
	position: absolute;
	width: 140vw;
	height: calc(100vh + 40vw);
	left: -5vw;
	bottom: 0;
	will-change: transform;
}
#kv .map img {
	width: 140vw;
	height: calc(100vh + 40vw);
	left: 0;
	top: 0;
	opacity: 0;
	object-fit: cover;
	will-change: opacity;
}


#kv .title {
	position: absolute;
	width: 42vw;
	height: 10vw;
	left: 48vw;
	bottom: 23vh;
	z-index: 10;
}
#kv .title img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: contain;
	visibility: hidden;
}
#kv .title img.current {
	visibility: visible;
}
#kv .title img.base {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	visibility: hidden !important;
}


#kv.start .map {
	animation: opening 25000ms forwards ease-out;
}
#kv.start .map img {
	animation: fade 2000ms forwards ease-out;
}

@keyframes opening {
	0% {
		transform: translate(0px, 0px);
	}
	100% {
		transform: translate(-35vw, 40vw);
	}
}

@keyframes fade {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}




#kv	.arrow {
	position: absolute;
	width: 62px;
	height: 60px;
	left: 22vw;
	bottom: 32px;
	z-index: 30;
	transition: all 500ms ease-out;
}
#kv	.arrow a {
	position: relative;
	display: block;
	height: 60px;
	text-align: center;
	color: #1e1e1e;
	font-size: 0.75rem;
	letter-spacing: 2px;
	text-indent: 2px;
	font-family: "UniversLTPro-55Roman", sans-serif;
}
#kv	.arrow a::after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: url(../img/arrow_down.svg) 50% 100% no-repeat;
	background-size: 60px auto;
}



#kv	.arrow {
	opacity: 0;
}
#kv	.arrow.show {
	opacity: 1;
}
#kv .arrow.show a::after {
	animation: loopscroll infinite 2500ms ease-out;
}
@keyframes loopscroll {
	0% {
		transform: translateY(0px);
	}
	70% {
		transform: translateY(0px);
	}
	80% {
		transform: translateY(8px);
	}
	90% {
		transform: translateY(8px);
	}
	100% {
		transform: translateY(0px);
	}
}







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


#intro {
	position: relative;
	height: 860px;
}
#intro .column {
	position: absolute;
	width: 505px;
	right: 90px;
	bottom: 0;
	z-index: 10;
}
#intro .column h1 {
	font-size: 2rem;
}
#intro .column p {
	margin: 50px 0 0 30px; 
	line-height: 2;
	font-size: 1.125rem;
}



#map {
	position: relative;
	width: 594px;
	height: 600px;
	left: 388px;
	top: 0;
	background: url(../img/map.svg) 0 0 no-repeat;
	background-size: 100% auto;
}

#map .label {
	position: absolute;
	width: 375px;
	height: 90px;
	left: -390px;
	top: 226px;
	background: url(../img/logo.svg) 0 0 no-repeat;
	background-size: 100% auto;
}

#map .point {
	position: absolute;
	width: 52px;
	height: 52px;
	left: 23px;
	top: 316px;
}
#map .point em {
	position: absolute;
	display: block;
	width: 30px;
	height: 30px;
	left: calc(50% - 15px);
	top: calc(50% - 15px);
	z-index: 10;
	background: #000;
	border-radius: 15px;
	
	transform: scale(0);
}
#map .point span {
	position: absolute;
	box-sizing: border-box;
	display: block;
	width: 208px;
	height: 208px;
	left: calc(50% - 104px);
	top: calc(50% - 104px);
	z-index: 1;
	background: #f2f2f2;
	border: 8px solid #000;
	border-radius: 104px;
	
	visibility: hidden;
	transform: scale(0.125);
}
#map .point i {
	position: absolute;
	box-sizing: border-box;
	display: block;
	width: 1000px;
	height: 1000px;
	left: calc(50% - 500px);
	top: calc(50% - 500px);
	z-index: 1;
	border: 1px solid #000;
	border-radius: 500px;
	
	visibility: hidden;
	transform: scale(0.05);
}


#map {
	opacity: 0;
	transform: translateY(30px);
	transition: all 500ms ease-out;
}
#map.show {
	opacity: 1;
	transform: translateY(0px);
}


#map .label {
	opacity: 0;
	transition: all 750ms ease-out 1300ms;
}
#map.show .label {
	opacity: 1;
}


#map.show .point em {
	animation: zoom1 500ms forwards ease-out 500ms;
}
#map.show .point span {
	animation: zoom2 300ms forwards ease-out 700ms;
}
#map.show .point i {
	animation: zoom3 900ms forwards linear 1000ms;
}


@keyframes zoom1 {
	0% {
		transform: scale(0);
	}
	75% {
		transform: scale(0.7);
	}
	100% {
		transform: scale(0.4);
	}
}


@keyframes zoom2 {
	0% {
		visibility: hidden;
		border-width: 8px;
		transform: scale(0.125);
	}
	75% {
		visibility: visible;
		border-width: 3px;
		transform: scale(0.3);
	}
	100% {
		visibility: visible;
		border-width: 4px;
		transform: scale(0.25);
	}
}

@keyframes zoom3 {
	0% {
		border-width: 4px;
		transform: scale(0.05);
	}
	100% {
		visibility: visible;
		opacity: 0;
		border-width: 1px;
		transform: scale(1);
	}
}













.portal-column {
	position: relative;
}
.portal-column .box {
	position: absolute;
	width: 500px;
	left: 50%;
	bottom: 0;
}
.portal-column .box h2 {
	font-size: 1.75rem;
}
.portal-column .box p {
	margin: 40px 0 0 35px;
	font-size: 1em;
	line-height: 2;
}
.portal-column .box nav {
	margin: 30px 0 0 35px;
}
.portal-column nav a {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	width: 386px;
	height: 60px;
	padding: 0 50px;
	font-size: 1.125rem;
	text-decoration: none;
	color: #fff;
	background: #1e1e1e;
}
.portal-column nav a em {
	position: absolute;
	display: block;
	width: 82px;
	height: 8px;
	right: 30px;
	top: calc(50% - 4px);
	background: url(../img/arrow_white.svg) 50% 50% no-repeat;
	background-size: 100% auto;
}
.portal-column nav a:hover em {
	transform: translateX(5px) !important;
}
.portal-column nav a.show em {
	transition: transform 300ms ease-out 0ms !important;
}


.portal-column .photo1 span,
.portal-column .photo2 span {
	position: relative;
	display: block;
	overflow: hidden;
	will-change: transform;
}

.portal-column .photo1 img,
.portal-column .photo2 img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.portal-column .logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}




.portal-museum {
	height: 60vw;
	margin: 240px 0 0;	
}

.portal-museum .photo1 span {
	position: absolute;
	width: 17vw;
	height: 17vw;
	right: 7vw;
	top: 0;
}
.portal-museum .photo2 span {
	position: absolute;
	width: 39vw;
	height: 25vw;
	left: 0;
	bottom: 7vw;
}
.portal-museum .logo {
	position: absolute;
	width: 35.5vw;
	height: 14vw;
	left: 7vw;
	top: 5vw;
}





.portal-villa {
	height: 66vw;
	margin: 400px 0 0;	
}

.portal-villa .photo1 span {
	position: absolute;
	width: 42.8vw;
	height: 26vw;
	right: 0;
	top: 0;
}
.portal-villa .photo2 span {
	position: absolute;
	width: 32vw;
	height: 23vw;
	left: 0;
	bottom: 3.5vw;
}
.portal-villa .logo {
	position: absolute;
	width: 35.5vw;
	height: 19.5vw;
	left: 7vw;
	top: 9.2vw;
}






.portal-restaurant {
	height: 61.5vw;
	margin: 280px 0;	
}

.portal-restaurant .photo1 span {
	position: absolute;
	width: 23vw;
	height: 23vw;
	right: 7vw;
	top: 0;
}
.portal-restaurant .photo2 span {
	position: absolute;
	width: 34.8vw;
	height: 24.2vw;
	left: 0;
	bottom: -0.5vw;
}
.portal-restaurant .logo {
	position: absolute;
	width: 39.2vw;
	height: 20vw;
	left: 7vw;
	top: 6.8vw;
}





.portal-architecture {
	height: 64vw;
	margin: 270px 0 0;	
}

.portal-architecture .photo1 span {
	position: absolute;
	width: 57vw;
	height: 34.6vw;
	left: 0;
	top: 0;
}




#intro .column h1 {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 1800ms;
}
#intro .column p {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 2200ms;
}
#intro #map.show + .column h1,
#intro #map.show + .column p {
	opacity: 1;
	transform: translateY(0);
}


.portal-column .logo img {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out;
}
.portal-column .logo.show img {
	opacity: 1;
	transform: translateY(0);
}

.portal-column .photo1 img,
.portal-column .photo2 img {
	opacity: 0;
	transform: scale(1.2);
	transition: all 800ms ease-out;
}
.portal-column .photo2 img {
	transition-delay: 400ms;
}
.portal-column .photo2 img {
	transition-delay: 1200ms;
}
.portal-column .photo1.show img,
.portal-column .photo2.show img {
	opacity: 1;
	transform: scale(1.0);
}


.portal-column .box h2,
.portal-column .box p {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out;
}
.portal-column .box p {
	transition-delay: 500ms;
}
.portal-column .box.show h2,
.portal-column .box.show p {
	opacity: 1;
	transform: translateY(0);
}

.portal-column .box nav {
	opacity: 0;
	transition: all 800ms ease-out 1200ms;
}
.portal-column .box.show nav {
	opacity: 1;
}

.portal-column .box nav a em {
	transform: translateX(-30px);
	transition: transform 800ms ease-out 1200ms;
}
.portal-column .box.show nav a em {
	transform: translateX(0);
}









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

html:lang(en) #intro .column h1 {
	font-weight: normal;
	font-family: "UniversLTPro-65Bold", sans-serif;
}

html:lang(en) .portal-column .box h2 {
	line-height: 1.4;
	font-weight: normal;
	font-family: "UniversLTPro-65Bold", sans-serif;
}


html:lang(en) #map {
	width: 652px;
	height: 600px;
	left: 330px;
	background: url(../img/map_en.svg) 0 0 no-repeat;
	background-size: 100% auto;
}

html:lang(en) #map .point {
	left: 81px;
	top: 340px;
}



html:lang(en) .portal-architecture {
	height: auto;
	margin: 270px 0 0;	
}
html:lang(en) .portal-architecture .photo1 span {
	position: absolute;
	width: 57vw;
	height: 34.6vw;
	left: 0;
	top: 0;
}
html:lang(en) .portal-column .box {
	position: relative;
	width: 500px;
	left: 50%;
	padding-top: calc(34.6vw + 60px);
	bottom: auto;
}




