#sp_navi ul .select
{
	background-color: transparent;
}

#sp_navi
{
	display: none;
}


#sp_navi
{
	color: #fff;
	background: rgba(240, 240, 240, 0.9);
	position: fixed;
	z-index: 1000;
	left: 0px;
	width: 100%;
	height: 100%;
	display: none;
	padding-top: 0px;
	top: 0px;
}



#sp_navi .sp_navi_body
{
	width: 100%;
	height: 100%;
	padding-top: 100px;
	display: block;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
	background-color: transparent;
	position: static;
	top: auto;
}


#sp_navi .sp_head .sp_title img
{
	width:auto;
	height:auto;
}


#sp_navi .sp_navi_menu
{
	padding-right: 20px;
	padding-left: 20px;
}

#sp_navi .sp_navi_menu > ul
{
	text-align: justify;
	margin: 0px;
	padding: 0px;
}

#sp_navi .sp_navi_menu > ul > li
{
	list-style-type: none;
	border: 1px solid var(--base-color01);
	padding: 10px;
	margin-bottom: 10px;
	background-color: #FFF;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}


#sp_navi .sp_navi_menu > ul > li > a
{
	color: var(--base-color01) !important;
	display: block;
	padding-top: 4px;
	padding-bottom: 4px;
	font-size: 20px;
	line-height: 1;
	padding-left: 40px;
	position: relative;
}

#sp_navi .sp_navi_menu > ul > li > a:before
{
	font-family: "Font Awesome 6 Free";
	content: '\f101';
	font-weight: 900;
	margin-right: 10px;
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 10px;
}

#sp_navi .sp_navi_menu > ul > li > ul
{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 10px; /* 横のスペース */
	row-gap: 10px; /* 縦のスペース */
	align-items: stretch;
	padding: 0px;
	grid-auto-rows: 1fr;
	margin-top: 10px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}

#sp_navi .sp_navi_menu > ul > li > ul > li
{
	margin: 0px;
	padding: 0px;
	list-style-type: none;

}

#sp_navi .sp_navi_menu > ul > li > ul > li > a
{
	color: #FFF;
	display: block;
	padding: 6px;
	height: 100%;
	background-color: var(--point-color);
	font-size: 18px;
	line-height: 1.2;
}

#sp_navi .sp_navi_menu > ul > li > ul > li > a:before
{
	font-family: "Font Awesome 6 Free";
	content: '\f068';
	font-weight: 900;
	margin-right: 10px;
}

#sp_navi .sp_contact_btn
{
	text-align: center;
	margin-bottom: 30px;
}

#sp_navi .sp_contact_btn a
{
	background: rgba(14, 172, 102, 0.9);
	display: inline-block;
	font-size: 20px;
	line-height: 1;
	color: #FFF;
	padding-top: 10px;
	padding-right: 40px;
	padding-bottom: 10px;
	padding-left: 40px;
}

#sp_navi .sp_tel
{
	text-align: center;
	margin-bottom: 20px;
	color: var(--point-color);

}

#sp_navi .sp_tel a
{
	font-size: 30px;
	line-height: 1px;
	color: var(--point-color);
	font-weight: bold;
	text-align: center;
	display: block;
	margin-bottom: 4px;
}

#sp_navi .sp_tel a:before
{
	font-family: "Font Awesome 6 Free";
	content: '\f095';
	font-weight: 900;
	margin-right: 10px;
}


#sp_navi h3
{
	color: var(--font-color);
	padding-top: 0px;
	padding-bottom: 8px;
}




#sp_navi .sp_navi_body .hlef_menu
{
display: flex;
justify-content: space-between;
align-items: flex-start;
flex-wrap: wrap;
}

#sp_navi .sp_navi_body .hlef_menu li
{
	width: 48%;
}


#sp_navi .sp_navi_body > ul
{
	display: block;
	width: auto;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 2em;
	margin-left: 0px;
	padding-top: 0px;
	padding-right: 8%;
	padding-bottom: 0px;
	padding-left: 8%;
}

#sp_navi .sp_navi_body > ul > li
{
	display: block;
	width: auto;
	padding-left: 0px;
	list-style-type: none;
	text-align: center;
	padding: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 10px;
	margin-left: 0px;
}


#sp_navi .sp_navi_body > ul > li > a
{
	color: #FFF !important;
	text-align: center !important;
	position: relative;
	text-decoration: none;
	display: block;
	padding-top: 1em;
	padding-right: 10px;
	padding-bottom: 1em;
	padding-left: 10px;
	font-size: 16px;
	line-height: 140%;
	background-color: var(--point-color) !important;

}

#sp_navi .sp_navi_body > ul > li:last-child > a
{
	background-color: #615245 !important;
}


#sp_navi .sp_navi_body > ul > li > a > small
{
	display: block;
	text-align: center;
	font-size: 14px;
	color: #007971;
	padding-top: 4px;
}



#sp_navi .sp_navi_body > ul > li > a:before
{

}


#sp_navi .sp_navi_body > ul > li > a small
{
	margin-left: 10px;
}


#sp_navi .sp_navi_body > ul > li > a span,
#sp_navi .sp_navi_body > ul > li > a:hover span
{
	background-image: none;
	margin: 0px;
	padding: 0px;
}


#sp_navi .sp_navi_body > ul > li > a:hover
{
	background-color: transparent;
}



#sp_navi .contact
{
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 30px;
	padding-left: 30px;
}

#sp_navi .contact a
{
	font-size: 18px;
	color: #fff;
	display: block;
	background-color: #615245;
	padding: 10px;
}

#sp_navi .contact a:before
{
	font-family: "Font Awesome 6 Free";
	content: '\f0e0';
	font-weight: 400;
	margin-right: 10px;
}






#sp_navi .sub_menu
{
	display: block;
}

#sp_navi .sp_box
{
	_zoom: 1;
	overflow: hidden;
	margin-bottom: 1em;	
}







#sp_navi .sp_navi_body .sub_menu
{
	padding-top: 0em;
	padding-right: 10px;
	padding-bottom: 100px;
	padding-left: 10px;
	text-align: center;
}

#sp_navi .sp_navi_body .sub_menu p
{
	text-align: center;
}

#sp_navi .sp_navi_body .sub_menu a
{
	font-weight: bold;
	color: #333;
	text-decoration: none;
	padding-right: 2px;
	padding-left: 2px;
	font-size: 16px;
	line-height: 120%;
}


#sp_navi .sp_navi_body .close_btn
{
	text-align: center;
	margin-bottom: 6em;
	padding-top: 20px;
}

#sp_navi .sp_navi_body .close_btn span
{
	display: inline-block;
	width: auto;
	margin-right: auto;
	margin-left: auto;
	text-align: left;
	-ms-background-size: auto 100%;
	-o-background-size: auto 100%;
	-webkit-background-size: auto 100%;
	-moz-background-size: auto 100%;
	background-size: auto 100%;
	border-radius: 20px;
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	color: #fff;
	padding-top: 4px;
	padding-right: 20px;
	padding-bottom: 4px;
	padding-left: 40px;
	background-color: var(--base-color01);
	position: relative; 
}

#sp_navi .sp_navi_body .close_btn span:before
{
	font-family: "Font Awesome 5 Free";
	content: '\f00d';
	font-weight: 900;
	margin-right: 10px;

	position: absolute;
	top: 50%;
	left: -14px; /* h2 からはみ出させる */
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: #ffff;
	border: 3px solid var(--base-color01);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--base-color01);

}

#sp_navi .contact_menu 
{
	margin-bottom: 20px;
	padding-right: 20px;
	padding-left: 20px;
	padding-top: 20px;
}


#sp_navi .contact_menu ul
{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 0px; /* 横のスペース */
	row-gap: 0px; /* 縦のスペース */
	align-items: stretch; /* 子要素をセルの高さに合わせて引き伸ばす */
	margin: 0px;
	padding: 0px;
}

#sp_navi .contact_menu ul li
{
	margin: 0px;
	padding: 0px;
	list-style-type: none;
}

#sp_navi .contact_menu ul li a
{
	background-color: rgba(237, 84, 158, 0.9);
	display: block;
	padding-top: 10px;
	font-weight: bold;
	color: #FFF;
}

#sp_navi .contact_menu ul li:last-child a
{
	background: rgba(63, 169, 245, 0.9);
}

#sp_navi .contact_menu ul li a:before
{
	font-family: "Font Awesome 6 Free";
	content: '\e4dd';
	font-weight: 900;
	margin-right: 10px;
}

#sp_navi .contact_menu ul li:last-child a:before{	content: '\f0e0';}




/* PCのみ設定  768 以上*/
@media screen and (min-width:1200px)
{


}

@media (max-width: 1199px) 
{




}


/* タブレットレイアウト : 768 px 〜 959 px*/
@media screen and (min-width:768px) and (max-width:1199px)
{


#sp_navi .sp_navi_menu 
{
	margin-bottom: 20px;
}

#sp_navi .sp_navi_menu > ul
{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 20px; /* 横のスペース */
	row-gap: 20px; /* 縦のスペース */
	align-items: stretch; /* 子要素をセルの高さに合わせて引き伸ばす */
	margin: 0px;
	padding: 0px;

}


#sp_navi .sp_navi_menu > ul > li
{
	margin-bottom: 0px;
}


#sp_navi .sp_navi_menu > ul > li > ul
{
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	column-gap: 10px; /* 横のスペース */
	row-gap: 10px; /* 縦のスペース */
	align-items: stretch;
	padding: 0px;
	grid-auto-rows: 1fr;
	margin-top: 10px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}



}

/* スマホ設定  768 以下*/
@media screen and (max-width:767px)
{



}

/* スマホ設定  599 以下*/
@media screen and (max-width:599px)
{

#sp_navi .sp_navi_body
{
	padding-top: 80px;
}


#sp_navi .sp_navi_menu ul
{
	width: auto;
}

#sp_navi .sp_navi_menu > ul > li > ul > li > a
{
	font-size: 16px;
	padding-top: 10px;
	padding-bottom: 10px;
}

#sp_navi .sp_navi_menu > ul > li > ul
{
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	column-gap: 10px; /* 横のスペース */
	row-gap: 10px; /* 縦のスペース */
	align-items: stretch;
	padding: 0px;
	grid-auto-rows: 1fr;
	margin-top: 10px;
	margin-right: 0px;
	margin-bottom: 0px;
	margin-left: 0px;
}


}