@charset "UTF-8";
/* =====================================
駐車場マップ
======================================== */
.wrap_parking_map_contents {
	width: 100vw;
	margin-left: -6.2666666667vw;
	margin-top: 72px;
	background: #EBFAD9;
	border-radius: 4.2666666667vw;
	padding: 48px 0 24px;
	position: relative;
}

.parking_map_label {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 87.2vw;
	height: 48px;
	background: #065A2D;
	color: #fff;
	font-weight: bold;
	text-align: center;
	border-radius: 10.6666666667vw;
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.img_parking_map {
	width: 95.7333333333vw;
	margin: 0 auto;
}

/* ボタン */
.wrap_ul_parking_map {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: 16px;
}

.single_contents .ul_parking_map li {
	padding: 0;
}
.single_contents .ul_parking_map li button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 16px;
	text-align: left;
	padding: 0;
}
.single_contents .ul_parking_map li::before {
	content: none;
}

.parking_name {
	color: #065A2D;
	font-weight: bold;
	font-size: 20px;
	font-size: 2rem;
	text-decoration: underline;
}

.ul_parking_map li button::before {
	content: "";
	display: block;
	min-width: 48px;
	max-height: 48px;
	height: 32px;
	background-repeat: no-repeat;
	background-size: contain;
}

.ul_parking_map li:nth-child(1) button::before {
	background-image: url(../images/parking/icon_p1.svg);
}
.ul_parking_map li:nth-child(2) button::before {
	background-image: url(../images/parking/icon_p2.svg);
}
.ul_parking_map li:nth-child(3) button::before {
	background-image: url(../images/parking/icon_p3.svg);
}
.ul_parking_map li:nth-child(4) button::before {
	background-image: url(../images/parking/icon_p4.svg);
}
.ul_parking_map li:nth-child(5) button::before {
	background-image: url(../images/parking/icon_p5.svg);
}
.ul_parking_map li:nth-child(6) button::before {
	background-image: url(../images/parking/icon_p6.svg);
}
.ul_parking_map li:nth-child(7) button::before {
	background-image: url(../images/parking/icon_p.svg);
}
.ul_parking_map li:nth-child(8) button::before {
	background-image: url(../images/parking/icon_p1w.svg);
}
.ul_parking_map li:nth-child(9) button::before {
	background-image: url(../images/parking/icon_p2w.svg);
}
.ul_parking_map li:nth-child(10) button::before {
	background-image: url(../images/parking/icon_p3w.svg);
}

.parking_map_note {
	width: 87.4666666667vw;
	margin: 16px auto 0;
}

/* ========== モーダル ========== */
.wrap_modal_contents {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	z-index: 1000;
	display: none;
}
.wrap_modal_contents .inner {
	width: 100%;
	height: 100%;
	background: #3D3D43;
}

/* モーダル表示中は背景スクロールさせない */
body.is-modal-open {
	overflow: hidden;
}

.modal_contents {
	width: 95.7333333333vw;
	background: #fff;
	padding: 16px;
	border-radius: 4.2666666667vw;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	z-index: 10;
}
.modal_contents .inner_modal_contents {
	background: #EBFAD9;
	border-radius: 4.2666666667vw;
	padding: 48px 16px;
}

.modal_item:not(:first-child) .ttl_heading04 {
	margin-top: 16px;
}

/* CLOSE */
.btn_modal_close button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 80px;
	height: 48px;
	font-weight: 900;
	color: #fff;
	background: #00853E;
	border-radius: 2.1333333333vw;
	font-size: 16px;
	font-size: 1.6rem;
	position: absolute;
	top: 8px;
	right: 8px;
}
.btn_modal_close button::before {
	content: "";
	display: block;
	width: 32px;
	height: 16px;
	background: url(../images/parking/icon_close.svg) no-repeat;
	background-size: contain;
}

.facility_news {
	background: none;
}

@media (min-width: 769px) {
	.wrap_parking_map_contents {
		width: 100%;
		margin-left: auto;
		margin-top: 48px;
		border-radius: 16px;
		padding: 72px 0 40px;
	}
	.parking_map_label {
		width: min(68.2352941176vw, 928px);
		height: auto;
		padding: 6px 16px;
		border-radius: 40px;
		font-size: 24px;
		font-size: 2.4rem;
	}
	.parking_map_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
		align-items: flex-start;
		gap: min(4.7058823529vw, 64px);
	}
	.img_parking_map {
		width: min(35.2941176471vw, 480px);
		margin: 0;
	}
	.single_contents .img_parking_map {
		margin-bottom: 0;
	}
	/* ボタン */
	.wrap_ul_parking_map {
		width: 361px;
		margin-top: 16px;
	}
	.single_contents .ul_parking_map li {
		padding: 0;
		margin-bottom: 16px;
	}
	.single_contents .ul_parking_map li:last-child {
		margin-bottom: 0;
	}
	.single_contents .ul_parking_map li button {
		gap: 32px;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		cursor: pointer;
	}
	.ul_parking_map li button::before {
		min-width: 64px;
		max-height: 64px;
		height: 48px;
	}
	.parking_name {
		font-size: 24px;
		font-size: 2.4rem;
	}
	.parking_map_note {
		width: 100%;
		text-align: center;
	}
	/* ========== モーダル ========== */
	.modal_contents {
		width: min(95%, 1120px);
		border-radius: 16px;
	}
	.modal_contents .inner_modal_contents {
		border-radius: 16px;
		padding: 48px 80px;
	}
	/* CLOSE */
	.btn_modal_close button {
		border-radius: 8px;
		cursor: pointer;
	}
}