@charset "UTF-8";

.inview05 {
	opacity: 0;
	transform: translateY(100px);
}
.inview05.show {
	animation-fill-mode: forwards;
	animation-duration: 1.6s;
	animation-name: movey;
	filter: blur(0);
}
@keyframes movey {
	0% {
		opacity: 0;
		transform: translateY(100px);
		/* filter: blur(5px); */
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		/* filter: blur(0); */
	}
}
/* main_copy
----------------------------------------*/
.main_copy {
	padding: 8rem 10.6rem;
	text-align: center;
}
.main_copy h3 {
	max-width: 73.6rem;
	margin: 0 auto;
}
.main_copy h4 {
	font-size: 3rem;
	margin-top: 4rem;
	letter-spacing: 0.05em;
}
.main_copy p {
	font-size: 1.4rem;
	margin-top: 4.1rem;
	line-height: 2.28;
	letter-spacing: 0.1em;
}
@media only screen and (max-width: 768px) {
	.main_copy {
		padding: 2rem 1.5rem;
	}
	.main_copy h3 {
		max-width: 100%;
		margin-top: 5rem;
	}
	.main_copy h4 {
		font-size: 2.2rem;
		text-align: left;
	}
	.main_copy p {
		text-align: left;
		margin-top: 1rem;
		line-height: 2;
	}
}

/* bg_block
----------------------------------------*/
.bg_block {
	background: url("../img/location/bg-access.jpg");
	background-repeat: no-repeat;
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	padding: 10rem 0 30rem 0;
}
.block_inner {
	width: 98rem;
  margin: 0 auto 8rem;
}
.bg_block .block_inner p {
	font-size: 1.1rem;
	text-indent: -1em;
	padding-left: 1em;
}

/* @media only screen and (max-width: 1366px)  {
	.bg_block {
		background-attachment: scroll;
		background-position: bottom;
		background-size: cover;
		margin: 0 0 40px 0;
	}
} */

@media only screen and (max-width: 768px) {
	.bg_block {
		background: url("../img/location/bg-access.jpg");
		background-repeat: no-repeat;
		background-attachment: scroll;
		background-position: bottom;
		background-size: cover;
		padding: 2rem 0 6rem 0;
	}
	.block_inner {
		width: 100%;
		margin: 0 0 5rem 0;
		padding: 0 2rem 0 2rem;
	}
}
@media only screen and (max-width: 736px) {

}

/* gallery
----------------------------------------*/
.gallery {
	padding-top: 5rem;
	position: relative;
}
.gallery::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: calc(100vw - 33.8rem);
	height: 122%;
	background: url(../img/location/bg_gallery.png);
	z-index: -5;
}
.gallery_list {
	max-width: 120rem;
	margin: 0 auto;
	padding-top: 3rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 3.8rem 3.5rem;
}
.gallery_list_item {
	display: block;
  overflow: hidden;
}
.gallery_list_item img {
	width: 100%;
	height: auto;
	object-fit: cover;
}
.gallery_list_item p {
	font-size: 1.4rem;
	margin-top: .5rem;
	letter-spacing: 0.05em;
}
.gallery_list_item p a {
	text-decoration: underline;
}
.gallery_list_item p a:hover {
	opacity: .6;
}
@media only screen and (max-width: 768px) {
	.gallery {
		padding-top: 3rem;
	}
	.gallery::after {
		width: calc(100vw - 6.8rem);
		height: 103%;
	}
	.gallery_list {
		padding-top: 0;
	}
	.gallery_list_item {
		margin-bottom: 1rem;
	}
	.gallery_list_item p {
		margin-top: 1rem;
		margin-bottom: .8rem;
	}
}
@media only screen and (max-width: 736px) {
	.gallery_list {
		max-width: 100%;
		display: block;
		margin-top: 0;
	}
}

/* map
----------------------------------------*/
.map_wrapper {
	margin-bottom: 3rem;
	display: flex;
	justify-content: center;
	gap: 5.2rem;
}
.map_btn {
	width: 100%;
}
.map_btn a {
	display: block;
	text-decoration: none !important;
	text-align: center;
	padding: 2.5rem 0 2.4rem;
	font-size: 1.8rem;
	-webkit-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
	position: relative;
	color: #fff;
	background: linear-gradient(to right, #63B795, #63B69B, #5FAEDA);
	border-radius: .8rem;
	position: relative;
	letter-spacing: 0.05em;
}
.map_btn a::after {
	content: "";
	position: absolute;
	background-image: url("../img/location/ico_arrow.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
	width: .9rem;
	height: .8rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 3rem;
}
.map_btn a:hover {
	opacity: .6;
}

@media only screen and (max-width: 768px) {
	.map_wrapper {
		width: 100%;
		margin-bottom: 1.5rem;
		flex-direction: column;
		gap: 1rem;
	}
	.map_btn a {
		padding: 1.5rem 0 1.4rem;
	}
}

/* info
----------------------------------------*/
.info h2 {
	margin: 0 auto;
	max-width: 38.9rem;
	width: 100%;
}
.info h3 {
	font-size: 1.35rem;
	background: #4A98BF;
	padding: 1rem 1.9rem .9rem;
	color: #fff;
	font-weight: bold;
	margin-bottom: 1.4rem;
	letter-spacing: 0.2em;
}
.info_wrapper {
	display: flex;
	gap: 4rem;
	margin-top: 4.6rem;
}
.info_item {
	width: 100%;
}
.info table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
}
.info table th,
.info table td {
	padding-top: .8rem;
}
.info table th {
	width: 31rem;
	overflow: hidden;
	color: #000;
	font-weight: normal;
	text-align: left;
}
.info table a {
	color: #1b658f !important;
	text-decoration: underline;
	letter-spacing: 0.05em;
}
.info table a:hover {
	opacity: .6;
}
@media only screen and (max-width: 768px) {
	.info h2 {
		margin: 0 auto;
		max-width: 33.5rem;
		width: 100%;
	}
	.info table {
		font-size: 1.2rem;
	}
	.info table th {
		width: 18rem;
	}
}
@media only screen and (max-width: 736px) {
	.info_wrapper {
		flex-direction: column;
		gap: 3rem;
		margin-top: 2.8rem;
	}
}
