@charset "UTF-8";

/* ============================================================
	ビジュアル
============================================================ */
#visual {
	position: relative;
}
#visual .photo {
	position: relative;
	max-width: 1920px;
	height: 640px;
	margin: 0 auto;
}
#visual .photo-img {
	width: 100%;
	height: 640px;
	background: no-repeat center / cover;
	-webkit-mask-image: url(../images-common/visual-mask-pc.svg);
	mask-image: url(../images-common/visual-mask-pc.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	mask-size: cover;
	-webkit-mask-position: center;
	mask-position: center;
}
#visual .photo::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 640px;
	background: rgba(0, 0, 0, .2);
	-webkit-mask-image: url(../images-common/visual-mask-pc.svg);
	mask-image: url(../images-common/visual-mask-pc.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	mask-size: cover;
	-webkit-mask-position: center;
	mask-position: center;
}
#visual .headline {
	position: absolute;
	top: 200px;
	left: 0;
	right: 0;
	width: 1200px;
	margin: 0 auto;
	color: #fff;
}
#visual .headline-sub {
	font-family: 'Cinzel', serif;
	font-size: 80px;
	letter-spacing: .05em;
}
#visual .headline-main {
	margin-top: 10px;
	font-size: 16px;
	letter-spacing: .2em;
}


/* ============================================================
	アクセス
============================================================ */
#access {
	padding-top: 120px;
}
#access .message {
	width: 1200px;
	margin: 0 auto;
}
#access .message-text {
	text-align: center;
	letter-spacing: .2em;
	line-height: 2;
}
#access .map {
	margin-top: 120px;
}
#access .map-iframe {
	width: 100%;
	height: 640px;
	vertical-align: bottom;
	-webkit-filter: saturate(60%);
	filter: saturate(60%);
}

/* ============================================================
	ガイド
============================================================ */
#guide {
	padding-top: 120px;
	background: #e6ecec;
}
#guide .about {
	width: 1160px;
	margin: 0 auto;
}
#guide .about-figure {
	float: left;
}
#guide .about-figure-photo {
	width: 600px;
}
#guide .about-figure-photo-img {
	width: 600px;
	height: 400px;
}
#guide .about-figure-name {
	width: 540px;
	margin: -28px auto 0;
}
#guide .about-figure-name-sub {
	font-family: 'Cinzel', serif;
	color: #006699;
	font-size: 72px;
	letter-spacing: .05em;
}
#guide .about-figure-name-main {
	margin-top: 10px;
	letter-spacing: .2em;
}
#guide .about-data {
	float: right;
}
#guide .about-data-ul {
	width: 480px;
	margin: 0 auto;
}
#guide .about-data-li:not(:first-of-type) {
	margin-top: 60px;
}
#guide .about-data-title {
	padding: 20px 0;
	border-bottom: solid 1px #999;
	letter-spacing: .2em;
}
#guide .about-data-text {
	margin-top: 20px;
	letter-spacing: .2em;
	line-height: 2;
}
#guide .about-data-button {
	margin-top: 20px;
}
#guide .about-data-button-a {
	position: relative;
	display: block;
	width: 240px;
	height: 60px;
	line-height: 60px;
	background: #fff;
	text-align: center;
	text-indent: .2em;
	letter-spacing: .2em;
}
#guide .route {
	margin-top: 150px;
}
#guide .route-ul {
	width: 1160px;
	margin: 0 auto;
}
#guide .route-li {
	float: left;
}
#guide .route-li:not(:first-of-type) {
	margin-left: 60px;
}
#guide .route-title {
	float: left;
	width: 150px;
}
#guide .route-title-icon {
	width: 72px;
	height: 80px;
	margin: 0 auto;
}
#guide .route-title-icon-img {
	width: 72px;
	height: 72px;
}
#guide .route-title-text {
	position: relative;
	margin: 0 auto;
	font-size: 32px;
	letter-spacing: .2em;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
}
#guide .route-desc {
	position: relative;
	float: right;
	width: 400px;
}
#guide .route-desc-cover {
	position: absolute;
	width: 400px;
	height: 200px;
	background: rgba(0, 0, 0, .5);
	cursor: pointer;
	text-align: center;
	color: #fff;
	font-size: 20px;
	letter-spacing: .1em;
	text-indent: .1em;
	line-height: 250px;
}
#guide .route-desc-cover::before {
	content: '';
	display: block;
	position: absolute;
	top: 70px;
	right: 0;
	left: 0;
	margin: 0 auto;
	width: 0;
	height: 0;
	border-top: solid 14px transparent;
	border-bottom: solid 14px transparent;
	border-left: solid 24px #fff;
}
#guide .route-desc-movie {
	width: 400px;
}
#guide .route-desc-movie-img {
	width: 400px;
	height: 200px;
}
#guide .route-desc-text {
	margin-top: 20px;
	letter-spacing: .2em;
	line-height: 2;
}
#guide .route-message {
	width: 1200px;
	margin: 100px auto 0;
}
#guide .route-message-text {
	text-align: center;
	letter-spacing: .2em;
	line-height: 2;
}
#guide .photo {
	position: relative;
	max-width: 1920px;
	height: 640px;
	margin: 160px auto 0;
}
#guide .photo-img {
	width: 100%;
	height: 640px;
	background: no-repeat center / cover;
	-webkit-mask-image: url(../images-common/photo-mask-pc.svg);
	mask-image: url(../images-common/photo-mask-pc.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	mask-size: cover;
	-webkit-mask-position: center;
	mask-position: center;
}


/* ============================================================
	ポップアップ・経路動画
============================================================ */
#popup-route {
}
#popup-route .popup-route {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	padding: 60px 0 100px;
	z-index: 600;
	overflow-y: scroll;
	overflow-x: hidden;
	box-sizing: border-box;
}
#popup-route .background {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .5);
	z-index: 1;
}
#popup-route .card {
	position: relative;
	width: 720px;
	margin: 0 auto;
	padding: 80px 100px;
	background: #fff;
	z-index: 2;
}
#popup-route .card-close {
	position: absolute;
	top: 20px;
	right: 20px;
	z-index: 3;
}
#popup-route .card-close-span {
	display: block;
	width: 50px;
	height: 50px;
	background: #e6ecec;
	border-radius: 50%;
	cursor: pointer;
}
#popup-route .card-close-span::before,
#popup-route .card-close-span::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 22px;
	height: 3px;
	margin: auto;
	background: #999;
}
#popup-route .card-close-span::before {
	transform: rotate(45deg);
}
#popup-route .card-close-span::after {
	transform: rotate(-45deg);
}
#popup-route .card-movie {
	text-align: center;
}
#popup-route .card-movie-video {
	width: 460px;
	height: 818px;
}
#popup-route .card-button {
	margin-top: 70px;
}
#popup-route .card-button-span {
	position: relative;
	display: block;
	width: 240px;
	height: 60px;
	margin: 0 auto;
	line-height: 58px;
	border: solid 1px #666;
	text-align: center;
	text-indent: .2em;
	letter-spacing: .2em;
	cursor: pointer;
}
