@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%;
	width: 100vw;
	background: #fff;
	overflow-x: hidden;
}
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 {
	width: 100vw;
	overflow-x: hidden;
}


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

#wrap > header li a:active {
	text-decoration: underline;
}



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







#kv {
	position: relative;
	height: calc(var(--doc-height) - 75px);
	overflow: hidden;
}
#kv .map {
	position: absolute;
	width: calc((var(--doc-height) + 20vw) / 2100 * 3000);
	height: calc(var(--doc-height) + 20vw);
	left: -10vw;
	bottom: 0;
	will-change: transform;
}
#kv .map img {
	width: calc((var(--doc-height) + 20vw) / 2100 * 3000);
	height: calc(var(--doc-height) + 20vw);
	left: 0;
	bottom: 0;
	opacity: 0;
	object-fit: cover;
	will-change: opacity;
}



#kv .title {
	position: absolute;
	width: 86vw;
	height: 30vw;
	left: 10vw;
	bottom: 42vw;
	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;
	object-fit: contain;
	visibility: hidden !important;
}


#kv	.arrow {
	position: absolute;
	width: 72vw;
	height: 48px;
	left: 14vw;
	bottom: 30px;
	z-index: 30;
	transition: all 500ms ease-out;
}
#kv	.arrow a {
	position: relative;
	display: block;
	width: 48px;
	height: 48px;
	text-align: center;
	color: #1e1e1e;
	font-size: 11px;
	font-family: "UniversLTPro-55Roman", sans-serif;
	letter-spacing: 1px;
	text-indent: -1px;
}
#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: 46px auto;
}



#kv	.arrow {
	opacity: 0;
}
#kv	.arrow.show {
	opacity: 1;
}
#kv .arrow.show a::after {
	animation: loopscroll infinite 2500ms ease-out;
}





#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(calc(-100% + 120vw), calc(20vw + 75px));
	}
}

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




@keyframes loopscroll {
	0% {
		transform: translateY(0px);
	}
	70% {
		transform: translateY(0px);
	}
	80% {
		transform: translateY(8px);
	}
	90% {
		transform: translateY(8px);
	}
	100% {
		transform: translateY(0px);
	}
}









#intro {
	position: relative;
	margin-top: 75px;
}


#map {
	position: relative;
	width: 90vw;
	height: 91.6vw;
	left: 22vw;
	margin: 10px 0 0;
	background: url(../img/map.svg) 0 0 no-repeat;
	background-size: 100% auto;
}
#map .label {
	position: absolute;
	width: 27vw;
	height: 7vw;
	left: -18vw;
	top: 40vw;
	background: url(../img/logo.svg) 0 0 no-repeat;
	background-size: 100% auto;
}
#map .point {
	position: absolute;
	width: 8vw;
	height: 8vw;
	left: 3.1vw;
	top: 51.5vw;
}
#map .point em {
	position: absolute;
	display: block;
	width: 8vw;
	height: 8vw;
	left: calc(50% - 4vw);
	top: calc(50% - 4vw);
	z-index: 10;
	background: #000;
	border-radius: 4vw;
	
	transform: scale(0);
}
#map .point span {
	position: absolute;
	box-sizing: border-box;
	display: block;
	width: 80vw;
	height: 80vw;
	left: calc(50% - 40vw);
	top: calc(50% - 40vw);
	z-index: 1;
	background: #f2f2f2;
	border: 8px solid #000;
	border-radius: 40vw;
	
	visibility: hidden;
	transform: scale(0.125);
}
#map .point i {
	position: absolute;
	box-sizing: border-box;
	display: block;
	width: 150vw;
	height: 150vw;
	left: calc(50% - 75vw);
	top: calc(50% - 75vw);
	z-index: 1;
	border: 1px solid #000;
	border-radius: 75vw;
	
	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.6);
	}
	100% {
		transform: scale(0.3);
	}
}


@keyframes zoom2 {
	0% {
		visibility: hidden;
		border-width: 1px;
		transform: scale(0.025);
	}
	75% {
		visibility: visible;
		border-width: 5px;
		transform: scale(0.1.5);
	}
	100% {
		visibility: visible;
		border-width: 4px;
		transform: scale(0.1);
	}
}

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









#intro .column {
	position: relative;
	width: 270px;
	margin: 75px auto 0;
}
#intro .column h1 {
	font-size: 22px;
}
#intro .column p {
	margin: 30px 0 0 30px;
	font-size: 14px;
	line-height: 2;
}









.portal-column {
	position: relative;
}
.portal-column .box {
	position: relative;
	width: 305px;
	margin: 60px auto 0;
	left: 15px;
}
.portal-column .box h2 {
	margin-right: -20px;
	font-size: 22px;
	line-height: 1.6;
}
.portal-column .box p {
	margin: 20px 0 0 30px;
	font-size: 14px;
	line-height: 2;
}
.portal-column .box nav {
	margin: 20px 0 0 30px;
}
.portal-column nav a {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	width: 250px;
	height: 50px;
	padding: 0 28px;
	font-size: 14px;
	text-decoration: none;
	color: #fff;
	background: #1e1e1e;
}
.portal-column nav a em {
	position: absolute;
	display: block;
	width: 52px;
	height: 6px;
	right: 18px;
	top: calc(50% - 3px);
	background: url(../img/arrow_white.svg) 50% 50% no-repeat;
	background-size: 100% auto;
}




.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 {
	margin: 110px 0 0;	
}

.portal-museum .photo1 span {
	width: 33vw;
	height: 33vw;
	margin-left: calc(67vw - 20px);
}
.portal-museum .logo {
	width: 72vw;
	margin: 75px 0 0 20px;
}
.portal-museum .photo2 span {
	width: 60vw;
	height: 46.4vw;
	margin: 60px 0 0;
}




.portal-villa {
	margin: 100px 0 0;	
}

.portal-villa .photo1 span {
	width: 88vw;
	height: 54.6vw;
	margin-left: 12vw;
}
.portal-villa .logo {
	width: 72vw;
	height: 39vw;
	margin: 80px 0 0 20px;
}
.portal-villa .photo2 span {
	width: 53.8vw;
	height: 38vw;
	margin: 50px 0 0;
}







.portal-restaurant {
	margin: 90px 0;	
}

.portal-restaurant .photo1 span {
	width: 48vw;
	height: 48vw;
}
.portal-restaurant .logo {
	width: 80vw;
	height: 43.8vw;
	margin: 80px 0 0 20px;
}
.portal-restaurant .photo2 span {
	width: 78vw;
	height: 55vw;
	margin: 55px 0 0 22vw;
}






.portal-architecture {
	margin: 90px 0 0;	
}

.portal-architecture .photo1 span {
	width: 100vw;
	height: 58.4vw;
}











#intro .column h1 {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 0ms;
}
#intro .column p {
	opacity: 0;
	transform: translateY(30px);
	transition: all 800ms ease-out 500ms;
}
#intro .column.show h1,
#intro .column.show 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: 400ms;
}
.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;
}





#map .point {
	left: 81px;
	top: 340px;
}




html:lang(en) #map {
	width: 90vw;
	height: 82.82vw;
	left: 20vw;
	margin: 10px 0 0;
	background: url(../img/map_en.svg) 0 0 no-repeat;
	background-size: 90% auto;
}
html:lang(en) #map .point {
	left: 10.0vw;
	top: 38.0vw;
}
html:lang(en) #map .label {
	left: -16vw;
	top: 29vw;
}



html:lang(en) #intro .column p br {
	display: none;
}









