@charset "UTF-8";

/*main
----------------------------------------*/
.space main {
	background: #F5F5F5;
}
.space .ttl_page {
	background: #f8f9f8;
}

/*intro
----------------------------------------*/
.space .intro {
	padding: 13rem 2rem 9.9rem;
	border-radius: 0 0 27rem;
	background: #f8f9f8;
	z-index: 3;
}
.space .intro::after {
	content: '';
	display: block;
	width: 66.4rem;
	position: absolute;
	right: 24.8rem;
	top: 0;
	bottom: 0;
	border-radius: 33.2rem 33.2rem 0 0;
	background: #718E5E;
	opacity: .06;
}
.space .intro::before {
	content: '';
	display: block;
	width: 66.4rem;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	border-radius: 0 0 27rem 27rem;
	background: #F2F2F2 url(../../img/common/intro_img_01.png) no-repeat right bottom / 30.7rem auto;
}
.space .intro_txt {
	max-width: 93rem;
	margin: 0 auto;
	z-index: 2;
}
.space .intro_txt h2 {
	font-weight: 400;
	font-size: 2.8rem;
	color: #7AA160;
	line-height: 1.4286;
	letter-spacing: .1em;
	margin-bottom: 2.1rem;
}
.space .intro_txt p {
	font-size: 1.5rem;
	line-height: 2.1333;
	letter-spacing: .1em;
}
@media only screen and (max-width: 768px) {
	.space .intro {
		padding: 5.2rem 4rem 6.3rem;
		border-radius: 0 0 12rem;
	}
	.space .intro::after {
		width: 36.9rem;
		right: 12.5rem;
		height: 28.5rem;
		top: auto;
		border-radius: 18.45rem 18.45rem 0 0;
	}
	.space .intro::before {
		width: 25rem;
		border-radius: 0 0 12rem 12rem;
		background: #F2F2F2 url(../../img/common/intro_img_01-sp.png) no-repeat right bottom / 12.4rem auto;
	}
	.space .intro_txt {
		margin: 0;
	}
	.space .intro_txt h2 {
		font-size: 2.2rem;
		margin-bottom: 1.7rem;
	}
	.space .intro_txt p {
		font-size: 1.3rem;
		line-height: 1.6923;
		letter-spacing: .05em;
	}
}

/*venue
----------------------------------------*/
.space .venue {
	background: #fff;
	margin: -29rem 0 0;
	padding: 37.8rem 0 28.8rem;
	border-radius: 0 0 0 21rem;
	overflow: hidden;
	z-index: 2;
}
.space .venue + .venue {
	background: none;
	padding: .1rem 0 10rem;
	margin-top: -20rem;
	border-radius: 0;
}
.space .venue_main {
	width: calc(50% + 54.3rem);
	margin: 0 0 5rem auto;
	border-radius: 10rem 0 0;
	overflow: hidden;
}
.space .venue_main figure {
	width: 108.8rem;
	float: left;
}
.space .venue_info {
	max-width: 108.8rem;
	margin: 0 auto 6rem;
	display: flex;
}
.space .venue_info h2 {
	width: 18.7rem;
	font-size: 1.3rem;
	color: #7AA160;
	font-weight: 400;
	line-height: 1.45;
	letter-spacing: .15em;
}
.space .venue_info h2 .en {
	display: block;
	font-size: 2.8rem;
	letter-spacing: .15em;
}
.space .venue_info_txt {
	width: 59.9rem;
}
.space .venue_info_txt::after {
	content: '';
	display: block;
	width: .1rem;
	background: #C3CDBD;
	position: absolute;
	right: 0;
	top: .3rem;
	bottom: 1.5rem;
}
.space .venue_info h3 {
	font-size: 2rem;
	letter-spacing: .1em;
	line-height: 1.45;
	font-weight: 400;
	margin-bottom: 1.1rem;
}
.space .venue_info_txt p {
	font-size: 1.3rem;
	letter-spacing: .1em;
	line-height: 2.2308;
}
.space .venue_info_spec {
	padding-left: 3.7rem;
}
.space .venue_info_spec dt {
	font-size: 1.3rem;
	color: #7AA160;
	letter-spacing: .15em;
	margin-bottom: .7rem;
}
.space .venue_info_spec dd {
	font-size: 1.3rem;
	letter-spacing: .1em;
	line-height: 2.2308;
}
.space .venue_list {
	max-width: 108.8rem;
	margin: 0 auto 8.5rem;
	display: flex;
	gap: 1.4rem;
}
.space .venue_list li {
	flex: 1;
}
.space .venue_list figure {
	border-radius: 1rem;
	overflow: hidden;
	margin-bottom: 1.5rem;
}
.space .venue_list h4 {
	font-size: 2.2rem;
	font-weight: 400;
	color: #7AA160;
	letter-spacing: .15em;
	margin-bottom: 1rem;
	margin-top: 2rem;
}
.space .venue_list p {
	font-size: 1.3rem;
	letter-spacing: .06em;
	line-height: 1.7692;
}
.space .venue_slider {
	width: 61.1rem;
	margin: 0 auto;
	position: static;
}
.space .venue_slider .slick-list::after,
.space .venue_slider::after {
	content: '';
	display: block;
	clear: both;
}
.space .venue_slider figure {
	float: left;
	margin: 0 .1rem;
	width: 60.9rem;
}
.space .venue_slider .slick-prev,
.space .venue_slider .slick-next {
	content: '';
	display: block;
	appearance: none;
	outline: none;
	border: 0;
	width: 3.6rem;
	height: 3.6rem;
	overflow: hidden;
	text-indent: -99rem;
	background: url(../../img/common/icon_arrow_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 16.6rem;
	right: 6.9rem;
	z-index: 10;
	cursor: pointer;
}
.space .venue_slider .slick-prev {
	transform: scale(-1, 1);
	left: 6.9rem;
	right: auto;
}
.space .venue_slider .slick-dots {
	display: flex;
	gap: .8rem;
	justify-content: center;
	margin-top: 1.6rem;
	z-index: 2;
}
.space .venue_slider .slick-dots li {
	width: .6rem;
	height: .6rem;
}
.space .venue_slider .slick-dots button {
	display: block;
	appearance: none;
	width: .6rem;
	height: .6rem;
	border-radius: 50%;
	background: #D9D9D9;
	overflow: hidden;
	text-indent: -99rem;
	border: 0;
}
.space .venue_slider .slick-dots .slick-active button {
	background: #7AA160;
}
.space .venue_btn {
	display: block;
	width: 25.3rem;
	background: #7AA160;
	color: #fff;
	font-size: 1.3rem;
	letter-spacing: .01em;
	border-radius: 2.1rem;
	padding: 1.2rem 2.2rem;
	margin: 3.8rem auto 0;
}
.space .venue_btn::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .5rem 0 .5rem .8rem;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 1.6rem;
	margin: auto 0;
	transition: transform .3s;
}
@media (hover:hover) {
	.space .venue_btn:hover::after {
		transform: translateX(.5rem);
	}
}
@media only screen and (max-width: 768px) {
	.space .venue {
		margin: -10rem 0 0;
		padding: 24.2rem 0 6.9rem;
		border-radius: 0 0 0 8rem;
	}
	.space .venue + .venue {
		padding: 14.3rem 0 6.2rem;
		margin-top: 0;
	}
	.space .venue_main {
		width: 35.4rem;
		margin: 0 0 2.3rem auto;
	}
	.space .venue_main figure {
		width: 33.5rem;
		margin-right: .3rem;
	}
	.space .venue_info {
		max-width: 29.5rem;
		margin: 0 auto 5.3rem;
		display: block;
		position: static;
	}
	.space .venue_info h2 {
		width: auto;
		position: absolute;
		left: 0;
		right: 0;
		top: -7.8rem;
		text-align: center;
		line-height: 1.38;
	}
	.space .venue_info h2 .en {
		font-size: 2.6rem;
	}
	.space .venue_info_txt {
		width: auto;
		padding-bottom: 2.3rem;
		border-bottom: .1rem solid #C3CDBD;
	}
	.space .venue_info_txt::after {
		display: none;
	}
	.space .venue_info h3 {
		font-size: 1.8rem;
		line-height: 1.6111;
		margin: 0 -.5rem .5rem 0;
	}
	.space .venue_info_txt p {
		letter-spacing: .05em;
		line-height: 1.6923;
	}
	.space .venue_info_spec {
		padding: 2.4rem 0 0;
	}
	.space .venue_info_spec dt {
		font-size: 1.6rem;
	}
	.space .venue_info_spec dd {
		letter-spacing: .05em;
		line-height: 1.6923;
	}
	.space .venue_list {
		max-width: 29.5rem;
		margin: 0 auto 5.3rem;
		display: block;
	}
	.space .venue_list li + li {
		margin-top: 3.3rem;
	}
	.space .venue_list figure {
		margin-bottom: 1.3rem;
	}
	.space .venue_list h4 {
		font-size: 1.8rem;
		margin-bottom: .6rem;
	}
	.space .venue_list p {
		letter-spacing: .05em;
		line-height: 1.6923;
	}
	.space .venue_slider {
		width: 33.7rem;
	}
	.space .venue_slider figure {
		width: 33.5rem;
	}
	.space .venue_slider figure img {
		height: 24.5rem;
		object-fit: cover;
	}
	.space .venue_slider .slick-prev,
	.space .venue_slider .slick-next {
		width: 2.8rem;
		height: 2.8rem;
		top: 10.8rem;
		right: 1.3rem;
		filter: brightness(0) invert(1);
	}
	.space .venue_slider .slick-prev {
		left: 1.3rem;
		right: auto;
	}
	.space .venue_slider .slick-dots {
		gap: .5rem;
		margin-top: 1rem;
	}
	.space .venue_slider .slick-dots li {
		width: .4rem;
		height: .4rem;
	}
	.space .venue_slider .slick-dots button {
		width: .4rem;
		height: .4rem;
	}
	.space .venue_btn {
		width: 29.5rem;
		font-size: 1.4rem;
		letter-spacing: .1em;
		border-radius: 2.4rem;
		padding: 1.35rem 3rem;
		margin: 3.3rem auto 0;
	}
}

/*facility
----------------------------------------*/
.space .facility {
	background: url(../../img/space/facility_bg_01.png) no-repeat left top / 70rem 100%;
	margin-top: -9.3rem;
	padding: 28.1rem 0 9.2rem;
}
.space .facility::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: -.1rem;
	right: 0;
	height: 19.2rem;
	border-radius: 0 0 0 21rem;
	background: #F5F5F5;
	pointer-events: none;
}
.space .facility_inner {
	max-width: 108.9rem;
	margin: 0 auto;
}
.space .facility h2 {
	font-weight: 400;
	font-size: 1.3rem;
	letter-spacing: .15em;
	color: #7AA160;
	margin-bottom: 3.5rem;
}
.space .facility h2 .en {
	font-size: 3.3rem;
	letter-spacing: .15em;
	display: block;
}
.space .facility_box {
	display: flex;
	gap: 1.6rem;
}
.space .facility_item {
	flex: 1;
}
.space .facility_item figure {
	border-radius: 1rem;
	overflow: hidden;
}
.space .facility h3 {
	font-size: 1.8rem;
	letter-spacing: .15em;
	font-weight: 400;
	color: #7AA160;
	margin: 1.1rem 0 .8rem;
}
.space .facility_item p {
	font-size: 1.3rem;
	letter-spacing: .06em;
	line-height: 1.7692;
}
@media only screen and (max-width: 768px) {
	.space .facility {
		background: url(../../img/space/facility_bg_01-sp.png) no-repeat left top / 24.1rem 100%;
		margin-top: 0;
		padding: 14.2rem 0 6.3rem;
	}
	.space .facility::before {
		height: 8.1rem;
		border-radius: 0 0 0 8rem;
	}
	.space .facility_inner {
		max-width: 29.5rem;
	}
	.space .facility h2 {
		text-align: center;
		line-height: 1.4;
		margin-bottom: 2.6rem;
	}
	.space .facility h2 .en {
		font-size: 2.6rem;
	}
	.space .facility_box {
		display: block;
	}
	.space .facility_item + .facility_item {
		margin-top: 3.3rem;
	}
	.space .facility h3 {
		font-size: 1.6rem;
		margin: 1.2rem 0 .8rem;
	}
	.space .facility_item p {
		letter-spacing: .05em;
		line-height: 1.6923;
	}
}