@charset "UTF-8";

.sitemap_container {
	display: flex;
	max-width: 1145px;
	margin: 0 auto;
	column-gap: 10px;
	justify-content: space-between;

	row-gap: 25px;
}

.sitemap_nav-maxwide {
	display: flex;
	width: 100%;
	flex-direction: column;
}
.sitemap_nav-minwide .sitemap_nav-list {
	height: 100%;
}

.sitemap_nav-list {
	display: flex;
	width: 100%;
	flex-direction: column;
}
.sitemap_nav-item > a {
	display: flex;
	padding-left: clamp(0.313rem, -0.143rem + 0.95vw, 0.625rem);
	border-left: clamp(0.313rem, -0.143rem + 0.95vw, 0.625rem) solid #d8231a;
	color: #d8231a;
	font-weight: bold;
	font-size: clamp(1rem, -0.093rem + 2.28vw, 1.75rem);
	letter-spacing: 0.05em;
	transition: all 0.3s;
}
.sitemap_nav-item > a:hover {
	border-left-color: #2970cc;
	color: #2970cc;
}
.sitemap_nav-item > a span {
	position: relative;
}
.sitemap_nav-item > a span::after {
	position: absolute;
	bottom: 3px;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #d8231a;
	content: "";
	transition: all 0.3s;
}
.sitemap_nav-item > a:hover span::after {
	background-color: #2970cc;
}

.sitemap_nav-item p {
	max-width: 310px;
	width: 100%;
	margin-top: 20px;
	padding-left: clamp(0rem, -1.822rem + 3.8vw, 1.25rem);
	font-weight: normal;
	font-size: clamp(0.875rem, 0.511rem + 0.76vw, 1.125rem);
	text-align: justify;
}
.sitemap_subnav-list {
	display: flex;
	margin-top: 20px;
	padding-left: clamp(0rem, -1.822rem + 3.8vw, 1.25rem);
	font-weight: normal;
	font-size: clamp(0.813rem, 0.357rem + 0.95vw, 1.125rem);
	letter-spacing: 0.05em;
	text-decoration: underline;
	flex-direction: column;
}
.sitemap_subnav-list a {
	transition: all 0.3s;
}
.sitemap_subnav-list a:hover {
	color: #2970cc;
}

.main_img-bg {
	display: flex;
	visibility: hidden;
	position: absolute;
	bottom: -2.3437vw;
	left: 50%;
	z-index: -1;
	transform: translateX(-50%);
	max-width: 2010px;
	width: 104.6875%;
	opacity: 0.1;
	justify-content: flex-end;
}

.main_img-bg img {
	visibility: visible;
	max-width: 970px;
	min-width: 550px;
	width: 48.25871%;
}
.sitemap_nav-minlist {
	display: flex;
	padding-top: 25px;
	padding-left: clamp(0rem, -1.822rem + 3.8vw, 1.25rem);
	border-top: 1px solid #dddddd;
	font-weight: 500;
	font-size: 15px;
	letter-spacing: 0.05em;
	text-decoration: underline;
	flex-direction: column;

	row-gap: 35px;
}
.sitemap_nav-minlist a {
	transition: all 0.3s;
}
.sitemap_nav-minlist a:hover {
	color: #2970cc;
}
@media screen and (min-width: 768px) {
	.main_container {
		padding-top: 120px;
		padding-bottom: 105px;
	}
	.title_container {
		margin-bottom: 70px;
	}
	.sitemap_container {
		width: 95%;
	}
	.sitemap_nav-minwide#sitemap_top {
		max-width: 270px;
	}
	.sitemap_nav-minwide#sitemap_clinic {
		max-width: 300px;
	}
	.sitemap_nav-maxwide {
		max-width: 350px;
		min-width: 250px;
		width: clamp(15.625rem, 4.666rem + 22.83vw, 21.875rem);
	}
	.sitemap_nav-list {
		row-gap: 50px;
	}
	.sitemap_nav-maxwide {
		row-gap: 60px;
	}.sitemap_subnav-list br {
		display: none;
	}
	.sitemap_subnav-list {
		row-gap: 15px;
	}
	.sitemap_nav-minlist {
		row-gap: 35px;
	}
}

@media screen and (max-width: 767px) {
	.main_container {
		padding-top: 70px;
		padding-bottom: 50px;
	}
	.title_container {
		margin-bottom: 30px;
	}
	.sitemap_container {
		width: 100%;
		padding: 0 20px;
		flex-direction: column;
		flex-wrap: wrap;
	}
	.sitemap_nav-minwide {
		max-width: 540px;
		width: 100%;
		margin: 0 auto;
	}
	.sitemap_nav-maxwide {
		max-width: 540px;
		width: 100%;
		margin: 0 auto;

		row-gap: 25px;
	}
	.sitemap_subnav-list {
		column-gap: 10px;

		row-gap: 25px;
	}
	@media screen and (max-width: 400px) {
	}
	@media screen and (max-width: 374px) {
		.sitemap_subnav-list {
			column-gap: 10px;
		}
	}
	.sitemap_nav-item {
		padding: 0 10px;
		padding-top: 25px;
		border-top: 1px solid #dddddd;
	}
	.sitemap_nav-list {
		row-gap: 25px;
	}


	#sitemap_top
	.sitemap_nav-item {
		padding-top: 0;
		border-top: none;
	}
	#sitemap_top .sitemap_subnav-list {
		max-height: 365px;
		height: 100%;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#sitemap_clinic .sitemap_subnav-list {
		max-height: 110px;
		height: 100%;
		flex-wrap: wrap;
	}
	.sitemap_nav-minlist {
		padding-right: 10px;
		padding-left: 10px;

		row-gap: 25px;
	}
	.main_img-bg {
		display: none;
	}
}

/*@media screen and (min-width: 768px) {
	.sitemap_nav-item a br {
		display: none;
	}
}*/

@media screen and (max-width: 374px) {
	#sitemap_clinic .sitemap_subnav-list.mb-flex {
		max-height: initial;
		flex-direction: row;
	}
}


