@charset "utf-8";
/* ===================================================
	Facilities CSS
====================================================== */

/* ---------------------------------------------------
	共通 - sec_layout
------------------------------------------------------ */
.sec_layout { padding-bottom: 95px; }
.sec_layout .cmn_tit01 { margin-bottom: 35px; }
.sec_layout .main_photo { margin-bottom: 25px; }
.sec_layout .main_photo + p { line-height: 2.1; }

@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	.sec_layout { padding-bottom: 55px; }
	.sec_layout .cmn_tit01 { margin-bottom: 25px; }
	.sec_layout .main_photo { margin-bottom: 15px; }
	.sec_layout .main_photo + p { line-height: 1.8; }
}

/* ---------------------------------------------------
	#sec01
------------------------------------------------------ */
#sec01 { padding-top: 130px; position: relative; }
#sec01::before { content: ''; background: url(../img/lead_bg01.png) no-repeat left top/contain; width: 674px; height: 746px; position: absolute; top: -230px; left: -220px; z-index: -1; }

@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	#sec01 { padding-top: 60px; }
	#sec01::before { width: 90vw; height: 95vw; top: -25vw; left: -25vw; }
}

/* ---------------------------------------------------
	#sec04
------------------------------------------------------ */
#sec04 { padding-bottom: 140px; position: relative; }
#sec04::before { content: ''; background: url(../../facilities/img/sec_bg01.png) no-repeat left top/contain; width: 674px; height: 590px; position: absolute; bottom: -170px; right: -285px; z-index: -1; }
@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	#sec04 { padding-bottom: 80px; }
	#sec04::before { width: 90vw; height: 95vw; bottom: -40vw; right: -35vw; }
}


/* ---------------------------------------------------
	#sec05
------------------------------------------------------ */
#sec05 { padding-bottom: 150px; }
#sec05 .main_photo { margin-bottom: 55px; }
#sec05 .cmn_tit01 { margin-bottom: 30px; }
#sec05 .cmn_tit01 + p { text-align: center; line-height: 2.1; margin-bottom: 50px; }
#sec05 .sec05_01 .photo_col { position: relative; margin-bottom: 30px; }
#sec05 .sec05_01 .photo_col p { color: #fff; position: absolute; bottom: 20px; right: 30px; font-size: 16px; text-align: right; letter-spacing: 0.1em; line-height: 1.4; }
#sec05 .sec05_01 .photo_col p span { font-size: 14px; }
#sec05 .sec05_01 h3 { margin-bottom: 10px; font-size: 26px; letter-spacing: 0.1em; }
#sec05 .sec05_01 p { line-height: 2.1; }
#sec05 .sec05_01 .note_col { margin-top: 50px; padding: 40px 55px; background: url(../img/bg02.jpg); }
#sec05 .sec05_01 .note_col div + div { margin-top: 50px; }
#sec05 .sec05_01 .note_col dt { font-size: 22px; margin-bottom: 20px; letter-spacing: 0.05em; }
#sec05 .sec05_01 .note_col dd { font-size: 15px; line-height: 2.4; letter-spacing: 0.03em; }

@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	#sec05 { padding-bottom: 80px; }
	#sec05 .main_photo { height: 50vw; margin-bottom: 30px; }
	#sec05 .cmn_tit01 { margin-bottom: 20px; }
	#sec05 .cmn_tit01 + p { line-height: 1.8; margin-bottom: 30px; text-align: left; }
	#sec05 .sec05_01 .photo_col { margin-bottom: 20px; }
	#sec05 .sec05_01 .photo_col p { bottom: 10px; right: 15px; font-size: 14px; }
	#sec05 .sec05_01 .photo_col p span { font-size: 14px; }
	#sec05 .sec05_01 h3 { font-size: 20px; }
	#sec05 .sec05_01 p { line-height: 1.8; }
	#sec05 .sec05_01 .note_col { margin-top: 30px; padding: 35px 6%; }
	#sec05 .sec05_01 .note_col div + div { margin-top: 30px; }
	#sec05 .sec05_01 .note_col dt { font-size: 17px; margin-bottom: 10px; }
	#sec05 .sec05_01 .note_col dd { font-size: 14px; line-height: 2; }
}


/* ---------------------------------------------------
	#sec06
------------------------------------------------------ */
#sec06 { padding: 95px 0 125px; background: var(--color04); color: #fff; }
#sec06 .cmn_tit01 { margin-bottom: 90px; }
#sec06 .list { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 50px 60px; }
#sec06 .list li { width: calc((100% - 60px) / 2);}
#sec06 .list li p { text-align: center; font-size: 18px; margin-top: 10px; }

@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	#sec06 { padding: 60px 0 70px; }
	#sec06 .cmn_tit01 { margin-bottom: 55px; }
	#sec06 .list { justify-content: center; gap: 30px 20px; }
	#sec06 .list li { width: max(185px, calc((100% - 20px) / 2)); flex-grow: 1;}
	#sec06 .list li p { font-size: 15px; margin-top: 5px; }
}


/* ---------------------------------------------------
	#sec07
------------------------------------------------------ */
#sec07 { padding: 75px 0 110px; }
#sec07 .cmn_tit01 { margin-bottom: 90px; }
#sec07 .table_layout div { font-size: 16px; display: flex; border-bottom: 1px solid #aeaeae; padding-bottom: 15px; margin-bottom: 15px; letter-spacing: 0.1em; line-height: 1.8; }
#sec07 .table_layout div dt { width: 250px; flex-shrink: 0; }
#sec07 .table_layout div dd { flex-grow: 1; }
#sec07 .table_layout div dd a { border-bottom: 1px solid var(--txt_color01); letter-spacing: 0.1em; }

@media screen and (hover: hover) {
}
@media screen and (min-width: 601px) {
}
@media screen and (max-width: 600px) {
	#sec07 { padding: 60px 0; }
	#sec07 .cmn_tit01 { margin-bottom: 40px; }
	#sec07 .table_layout div { font-size: 14px; flex-direction: column; padding: 0 2% 15px; }
	#sec07 .table_layout div dt { width: 100%; padding-bottom: 5px; }
}
