@charset "UTF-8";

/* ------------------------------------
					facilities
--------------------------------------*/
/*------- facilities pgs -------*/
.pgs h2 {
	color: var(--basegr);
	font-size: 32px;
	font-weight: 700;
	text-align: left;
	margin-bottom: 30px;
}

.pgs h3 {
	color: var(--basegr);
	font-size: 24px;
	font-weight: 700;
	text-align: left;
	margin: 43px 0 30px;
}

/*------- facilitiesIndex -------*/
.facilities01 {
	display: block;
	margin-bottom: 65px;
	align-items: center;
}

.facilities01 figure {
	position: relative;
}

.facilities01 figure .badge {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 5;
	display: inline-block;
	padding: 5px 10px;
	font-weight: bold;
	line-height: 1;
	color: #fff;
	background: #E40038;
}

.facilities01 h2 {
	color: #008383;
	font-size: 36px !important;
	font-weight: 700;
	margin-bottom: 15px;
}

.facilities01 h2 .num {
	display: block;
	font-size: 16px;
	font-weight: 500;
	padding-bottom: 20px;
}

.facilities01 p {
	margin-bottom: 50px;
}

.facilities01 .btnMore {
	border: 1px var(--basebl) solid;
	color: var(--basebl);
	margin-left: auto;
}

.facilities01 .btnMore::after {
	background: var(--basebl);
}

.facilities01:hover .btnMore {
	color: #fff;
}

.btnMore::after {
	background: #fff;
}

.facilities01:hover .btnMore::before {
	width: 100%;
}

.facilities01:hover .btnMore::after {
	background: #fff;
}

.facilitiesIndex ul {
	max-width: 940px;
}

.facilitiesIndex ul li {
	background: #fff;
	box-shadow: 0px 0px 20px 20px rgba(0, 0, 0, 0.05);
	margin-bottom: 60px;
	position: relative;
	text-align: right;
	border-bottom: 3px solid transparent;
}

.facilitiesIndex ul li:hover {
	border-bottom: 3px solid var(--basebl);
}

.facilitiesIndex ul li .num {
	background: var(--basebl);
	color: #fff;
	display: inline-block;
	font-family: 'Barlow Condensed', sans-serif;
	font-size: 16px;
	font-weight: 500;
	font-style: italic;
	letter-spacing: 0.08em;
	padding: 7px 67px 0 20px;
	text-align: center;
	position: relative;
	z-index: 10;
	height: 47px;
}

.facilitiesIndex ul li .num::after {
	content: "";
	background: #fff;
	width: 50px;
	height: 1px;
	position: absolute;
	top: 50%;
	right: 0;
}

.facilitiesIndex ul li figure {
	aspect-ratio: 100 / 56.82;
	margin-top: -47px;
	margin-bottom: 0 !important;
	position: relative;
	z-index: 1;
	overflow: hidden;
}

.facilitiesIndex ul li figure>img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.facilitiesIndex ul li div {
	position: relative;
	padding: 20px 60px 20px 20px;
}

.facilitiesIndex ul li div::before {
	content: "";
	background: var(--basebl);
	border: 1px solid var(--basebl);
	display: inline-block;
	width: 22px;
	height: 22px;
	border-radius: 12px;
	position: absolute;
	top: calc(50% - 12px);
	right: 25px;
}

.facilitiesIndex ul li:hover div::before {
	background: #fff;
	border: 1px solid var(--basebl);
}

.facilitiesIndex ul li div::after {
	content: "";
	position: absolute;
	top: calc(50% - 4px);
	right: 35px;
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
}

.facilitiesIndex ul li:hover div::after {
	border-top: 1px solid var(--basebl);
	border-right: 1px solid var(--basebl);
}

.facilitiesIndex ul li h2 {
	color: var(--basebl) !important;
	font-size: 18px !important;
	margin-bottom: 0 !important;
	text-align: left;
}

.facilitiesIndex ul li h2 span {
	display: block;
	position: relative;
}

.facilitiesIndex ul li p {
	margin-top: 10px;
	font-size: 14px;
}

.facilitiesIndex ul li p span {
	display: block;
}

@media screen and (min-width: 769px) {
	.facilities01 .pcFlex {
		align-items: center;
	}

	.facilities01 .pcFlex.--align_first {
		align-items: start;
	}

	.facilities01 .txt {
		/*padding-top: 130px;*/
		width: 45.6%;
		max-width: 465px;
	}

	.facilities01 figure {
		width: 50%;
		max-width: 510px;
	}

	.facilitiesIndex ul li {
		width: 46.8%;
		max-width: 440px;
	}
}

/*-PC only-*/
@media screen and (max-width: 768px) {

	/*SP*/
	.facilities01 {
		margin-bottom: 35px;
	}

	.facilities01 h2 {
		margin-bottom: 30px;
	}

	.facilities01 .btnMore {
		margin-left: 0;
		margin-bottom: 30px;
	}

	.facilitiesIndex ul li {
		margin-bottom: 30px;
	}
}

/*-SP only-*/




.facilitiesDeta {
	margin-bottom: 60px;
}

.facilitiesDeta .address {
	flex-wrap: wrap;
}

.facilitiesDeta .address dt {
	font-size: 18px;
	font-weight: 700;
	padding-bottom: 10px;
	width: 78px;
}

.facilitiesDeta .address dd {
	font-size: 18px;
	padding-bottom: 10px;
	width: calc(100% - 78px);
}

.facilitiesDetail {
	margin-bottom: 100px;
}

.facilitiesDetail *,
.facilitiesMap * {
	letter-spacing: 0;
}

.facilitiesDetail h4 {
	color: #222 !important;
	font-size: 20px !important;
	font-weight: 700;
	text-align: left;
	margin: 20px 0;
}

.facilitiesDetail ul li {
	margin-bottom: 50px;
}

.facilitiesDetail ul li figure {
	margin-bottom: 15px;
}

.facilitiesDetail_media>div+div {
	margin-top: 50px;
}

.facilitiesMap>div {
	width: 100%;
	max-width: 1020px;
	height: 478px;
}

.facilitiesArea .pcFlex {
	gap: 25px 4%;
}

.facilitiesArea1,
.facilitiesArea2 {
	flex: 1;
}

.dataTable.flex,
.dataTable dd.pcFlex {
	flex-wrap: wrap;
}

.dataTable dt {
	border-bottom: 3px solid #E4E6EC;
	font-weight: 700;
	padding: 20px 0;
	width: 135px;
}

.dataTable dd {
	border-bottom: 1px solid #E4E6EC;
	padding: 20px 0 20px 7.3%;
	width: calc(100% - 135px);
}

.facilitiesDeta figure {
	position: relative;
}

.facilitiesDeta figure .badge {
	position: absolute;
	top: 0;
	right: 0;
	display: inline-block;
	padding: 5px 10px;
	font-weight: bold;
	line-height: 1;
	color: #fff;
	background: #E40038;
}

@media screen and (min-width: 769px) {
	.facilitiesDeta .txt {
		width: 39.2%;
		max-width: 400px;
	}

	.facilitiesDeta h2 {
		margin-bottom: 50px !important;
	}

	.facilitiesDeta figure {
		width: 47%;
		max-width: 480px;

	}

	.facilitiesDetail_title_l {
		margin-bottom: 30px;
		font-size: 32px;
		color: var(--basegr);
	}

	.facilitiesDetail_title_l.is-center {
		text-align: center;
	}

	.facilitiesDetail_text {
		margin-bottom: 45px;
		font-size: 24px;
		text-align: center;
		line-height: 1.7;
	}

	.facilitiesDetail_title_m {
		margin: 0 0 25px !important;
		font-size: 24px !important;
		color: var(--basegr);
	}

	.dataTable dd .pcFlex li:nth-child(odd) {
		width: 57%;
		justify-content: flex-start;
	}

	.dataTable dd .pcFlex li:nth-child(even) {
		width: 43%;
	}

	.dataTable dd .pcFlex+p {
		padding-left: 57%;
	}

	.facilitiesDetail ul {
		display: flex;
		flex-wrap: wrap;
		gap: 30px;
	}

	.facilitiesDetail ul li {
		width: 31.4%;
		max-width: 320px;
	}

	.facilitiesDetail ul li:nth-child(3n) {
		margin-right: 0;
	}

	.facilitiesDetail_media .pcFlex {
		align-items: center;
		gap: 6%;
	}

	.facilitiesDetail_media .pcFlex:nth-child(even) {
		flex-direction: row-reverse;
	}

	.facilitiesDetail_media .pcFlex>* {
		width: 47%;
	}

	.facilitiesOutline {
		margin-bottom: 50px;
	}

}

/*-PC only-*/

@media screen and (max-width: 768px) {

	/*SP*/
	.facilitiesDeta .address {
		margin-bottom: 24px !important;
	}

	.facilitiesDetail h3 {
		margin: 22px 0 15px !important;
	}

	.facilitiesDetail h4 {
		margin: 10px 0;
	}

	.facilitiesDetail ul li {
		margin-bottom: 30px;
	}

	.facilitiesDetail_media {
		margin-top: 50px;
	}

	.facilitiesDetail_title_m {
		font-size: 20px;
		margin-bottom: 15px;
	}

	.facilitiesIndex ul li h2 span {
		line-height: 1.7;
		padding-right: 10.5%;
	}

	.dataTable dt {
		width: 25%;
	}

	.dataTable dd {
		width: 75%;
	}

	.facilitiesOutline {
		margin-bottom: 30px;
	}
}



/*井上追加分*/


.facilities01_addContet {
	background: #fff;
	box-shadow: 0px 0px 20px 20px rgba(0, 0, 0, 0.05);
	position: relative;
	text-align: right;
	border-bottom: 3px solid transparent;
	width: 50%;
	max-width: 510px;
}

.facilities01_addContet:hover {
	border-bottom: 3px solid var(--basebl);
}

.facilities01 p.facilities01_addContet-text {
	padding: 40px;
	text-align: left;
	margin: 0;
	position: relative;
	overflow: hidden;
	background: none;
	color: #222222;
	z-index: 1;
}

.facilities01 p.facilities01_addContet-text::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url(../images/facilities/add_bg.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	transition: transform 0.3s ease-in-out;
	z-index: -1;
}


.facilities01 p.facilities01_addContet-text:hover::before {
	transform: scale(1.2);
}

.facilities01 h2.facilities01_addContet-container-text {
	color: var(--basebl) !important;
	font-size: 18px !important;
	margin-bottom: 0 !important;
	text-align: left;
}

.facilities01_addContet-container {
	position: relative;
	padding: 20px 60px 20px 20px;
}

.facilities01_addContet-container::before {
	content: "";
	background: var(--basebl);
	border: 1px solid var(--basebl);
	display: inline-block;
	width: 22px;
	height: 22px;
	border-radius: 12px;
	position: absolute;
	top: calc(50% - 12px);
	right: 25px;
}

.facilities01_addContet:hover .facilities01_addContet-container::before {
	background: #fff;
	border: 1px solid var(--basebl);
}

.facilities01_addContet-container::after {
	content: "";
	position: absolute;
	top: calc(50% - 4px);
	right: 35px;
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
}

.facilities01_addContet:hover .facilities01_addContet-container::after {
	border-top: 1px solid var(--basebl);
	border-right: 1px solid var(--basebl);
}

.facilities01_addContet-container-text span {
	display: block;
	position: relative;
}

@media screen and (max-width: 768px) {

	.facilities01_addContet {
		width: 100%;
	}
}



/*main_equipment.php*/

/*page-equipment__index01*/

.pgs h2.page-equipment__index01-ttl {
	text-align: center;
	margin: 0;
}

.page-equipment__index01-text {
	text-align: center;
	margin-top: 40px;
}

.pgs h3.page-equipment__index01-subttl {
	text-align: center;
	margin: 0;
	margin-top: 40px;
}

.pgs h3.page-equipment__index01-subttl span {
	display: block;
	font-size: 12px;
	color: #222222;
	margin-top: 5px;
}

.page-equipment__index01-list {
	display: flex;
	margin-top: 40px;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px 0;
}

.page-equipment__index01-list-item {
	width: 24%;
	font-size: 18px;
	text-align: center;
	background: var(--basegr);
	color: #fff;
}

.page-equipment__index01-list::after {
	display: block;
	content: "";
	width: 24%;
}

.page-equipment__index01-image {
	margin-top: 40px;
}

.page-equipment__index01-image img {
	width: 100%;
}

.page-equipment__index01-text02 {
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	margin-top: 40px;
}

.page-equipment__index01-list02 {
	margin-top: 40px;
	display: flex;
	gap: 20px;
}

.page-equipment__index01-list02-item-text{
	font-size: 14px;
	text-align: center;
	margin-top: 20px;
}

@media screen and (max-width: 768px) {
	.page-equipment__index01-list-item{
		width: 48%;
		padding: 10px;
		font-size: 16px;
	}

	.page-equipment__index01-text02{
		font-size: 18px;
	}

	.page-equipment__index01-list02{
		flex-wrap: wrap;
	}

	.page-equipment__index01-list02-item{
		width: 47%;
	}
}


/*page-equipment__index02*/

.page-equipment__index02 {
	padding: 80px 0 40px 0;
	text-align: center;
}

.pgs h2.page-equipment__index02-ttl {
	text-align: center;
	margin: 0;
}

.page-equipment__index02-list {
	display: flex;
	margin-top: 40px;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
}

.page-equipment__index02-list-item {
	width: 24%;
	font-size: 18px;
	text-align: center;
	background: var(--basegr);
	color: #fff;
}

.page-equipment__index02-text {
	margin-top: 40px;
}

.page-equipment__index02-flexbox {
	display: flex;
	margin-top: 40px;
	gap: 40px;
}

.page-equipment__index02-flexbox img {
	width: 100%;
}

.page-equipment__index02-flexbox figure {
	width: 50%;
}

@media screen and (max-width: 768px) {
	.page-equipment__index02-list-item{
		width: 47%;
        padding: 10px;
        font-size: 16px;
	}
	.page-equipment__index02-list-item::after {
		display: block;
		content: "";
		width: 47%;
	}

	.page-equipment__index02-flexbox{
		flex-direction: column;
		grid-area: 20px;
	}

	.page-equipment__index02-flexbox figure {
		width: 100%;
	}
}

/*page-equipment__index03*/

.page-equipment__index03 {
	padding: 40px 0 0 0;
}

.pgs h2.page-equipment__index03-ttl {
	margin: 0;
}

.pgs h2.page-equipment__index03-ttl:not(:first-of-type) {
	margin-top: 40px;
}

.page-equipment__index03-ttl span {
	font-size: 16px;
	display: block;
}

.page-equipment__index03-list {
	margin-top: 20px;
	display: flex;
	gap: 20px;
}

.page-equipment__index03-list-item {
	width: 32%;
}

.page-equipment__index03-list-item figure {
	width: 100%;
}

.page-equipment__index03-list-item img {
	width: 100%;
}

@media screen and (max-width: 768px) {
	.pgs h2.page-equipment__index03-ttl{
		font-size: 24px;
	}

	.page-equipment__index03-ttl span{
		font-size: 12px;
	}
}


/*equipment01.php*/

/*page-equipment01__index01*/

.pgs h2.page-equipment01__index01-ttl {
	text-align: center;
	margin: 0;
}

.page-equipment01__index01-text {
	margin-top: 20px;
	text-align: center;
	font-size: 24px;
}

.page-equipment01__index01-text.--left {
	text-align: left;
}

.page-equipment01__index01-flexbox {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin-top: 20px;
}

.page-equipment01__index01-flexbox figure {
	width: 40%;
}

.page-equipment01__index01-flexbox img {
	width: 100%;
}

.pgs h3.page-equipment01__index01-subttl {
	margin: 0;
	margin-top: 80px;
}

.pgs h3.page-equipment01__index01-subttl:not(:first-of-type) {
	margin: 0;
	margin-top: 40px;
}

.page-equipment01__index01-text02 {
	margin-top: 20px;
	font-size: 18px;
}

.page-equipment01__index01-text03 {
	margin-top: 20px;
	font-size: 18px;
}

.page-equipment01__index01-faq-container {
	margin-top: 20px;
}

.page-equipment01__index01-faq-container-text01{
	font-size: 18px;
}

.page-equipment01__index01-faq-container-text02{
	font-size: 18px;
}



/*equipment02.php*/

/*page-equipment02__index01*/

.pgs h2.page-equipment02__index01-ttl {
	text-align: center;
	margin: 0;
}

.page-equipment02__index01-subttl {
	font-size: 24px;
	text-align: center;
	margin-top: 20px;
	font-weight: bold;
}

.page-equipment02__index01-text {
	text-align: center;
	margin-top: 20px;
	font-size: 20px;
}

.page-equipment02__index01-flexbox {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin-top: 20px;
}

.page-equipment02__index01-flexbox figure {
	width: 40%;
}

.page-equipment02__index01-flexbox img {
	width: 100%;
}

.page-equipment02__index01-text02{
	margin-top: 40px;
	font-size: 18px;
}

/*page-equipment02__index02*/

.page-equipment02__index02{
	padding: 80px 0 0 0;
}

.pgs h2.page-equipment02__index02-ttl {
	text-align: center;
	margin: 0;
}

.page-equipment02__index02-text{
	margin-top: 40px;
	text-align: center;
	font-size: 18px;
}

.page-equipment02__index02-image{
	margin-top: 20px;
}

.page-equipment02__index02-image figure{
	width: 40%;
    margin: auto;
}

.page-equipment02__index02-image img{
	width: 100%;
}

.page-equipment02__index02-text02{
	margin-top: 20px;
	text-align: center;
	font-size: 18px;
}