@charset "UTF-8";
/* CSS Document */


/* ボタン　================================================== */
.btn_wrap{
	display: block;
	width: 270px;
	margin: 30px auto;
}

.btn01{
	display: inline-block;
	text-align: center;
	width: 100%;
	background: rgba(255,255,255,1);
	color: #333;
	border: solid 3px #52a633;
	padding: 1em;
	position: relative;
	border-radius: 30px;
	box-shadow: 6px 6px rgba(0,0,0,0.1);
	font-size: 1em;
	font-weight: 700;
	transition: .5s;
}
.btn01::after{
	font-family: 'Font Awesome 6 Free';
	font-weight: 900;
	content: "\f105";
	position: absolute;
	color: #d9304f;
	top: 50%;
	transform: translateY(-50%);
	right: 15px;
	transition: .3s;
}
.btn01:hover{
	box-shadow: 1px 1px rgba(0,0,0,0.1);
	transform: translate(3px, 3px);
	transition: .3s;
}
.btn01:hover::after{
	right: 10px;
}
.bg_img01 .btn01{
	background: rgba(0,0,0,0);
	color: #fff;
	border: solid 1px #fff;
}
/* Table List　================================================== */
.line02 table {
    border-spacing:0;
    margin: 0 auto;
    padding: 0;
    width:100%;
	line-height: 1.5;
}
.line02 table th{
	border-bottom: solid 2px #52a633;
	padding: 1em;
	width: 25%;
	min-width: 9em;
	font-weight: 700;
}
.line02 table td{
	border-bottom: solid 2px #ccc;
	padding: 1em;
}
.line02 table td i{
	color: #52a633;
	padding-left: 1em;
}
.line02 dl{
	margin-bottom: 0.5em;
	font-size: 0.9rem;
	display: flex;
}
.line02 dl dt{
	width: 11em;
}

.line02 ul li{
	padding-left: 1em;
	text-indent: -1em;
	margin-bottom: 0.5em;
	line-height: 1.5;
}
.p_02 .line02 table th{
	border-bottom: solid 2px #cc3f9d;
}
.p_04 .line02 table th{
	border-bottom: solid 2px #3380a6;
}
.p_05 .line02 table th{
	border-bottom: solid 2px #ccb53f;
}
@media (max-width: 768px){
	.line02 table th{
		display: block;
		width: 100%;
		border-bottom: none;
		text-align: left;
		padding-bottom: 0;
	}
	.line02 table td{
		display: block;
		width: 100%;
		border-bottom: solid 2px #52a633;
	}
	.line02 dl{
		flex-direction: column;
		align-self: flex-start;
		justify-content: flex-start;
	}
	.p_02 .line02 table th,
	.p_04 .line02 table th,
	.p_05 .line02 table th{
		border-bottom: none;
	}
	.p_02 .line02 table td{
		border-bottom: solid 2px #cc3f9d;
	}
	.p_04 .line02 table td{
		border-bottom: solid 2px #3380a6;
	}
	.p_05 .line02 table td{
		border-bottom: solid 2px #ccb53f;
	}
}
.simple01 table {
	border-collapse: collapse;
    border-spacing: 5px;
    margin: 0 auto;
    padding: 0;
    width:100%;
	line-height: 1.5;
}
.simple01 table tr{
	border-bottom: solid 1px #ccc;
}
.simple01 table th,.simple01 table td{
	padding: 1.5em 1em;
	text-align: left;
	vertical-align: top;
}
.simple01 table th{
	font-weight: 700;
	width: 20%;
	min-width: 6em;
}
.simple01 table td i{
	color: #52a633;
}
.simple01 dl{
	margin-bottom: 0.5rem;
}
.simple01 dl dt{
	font-weight:700; 
}
@media (max-width: 960px){
	.simple01 table{
		font-size: 0.9rem;
	}
	.simple01 table th,.simple01 table td{
		display: block;
		width: 100%;
	}
	.simple01 table th{
		padding-bottom: 0;
	}
	
}
.simple02 table {
	border-collapse: collapse;
    border-spacing: 5px;
    padding: 0;
    width:100%;
	line-height: 1.5;
	text-align: center;
}
.simple02 table tr{
	border-bottom: solid 1px #ccc;
}
.simple02 table th,.simple02 table td{
	padding: 1.5em 1em;
	text-align: left;
	vertical-align: top;
	border-right: solid 1px #ccc;
}
.simple02 table th{
	min-width: 7em;
	font-weight: 700;
}
.simple02 table th:last-child,
.simple02 table td:last-child{
	border-right: none;
}
.simple02 dl{
	margin-bottom: 0.5rem;
}
.simple02 dl dt{
	font-weight:700; 
}
.table_wrap .comment{
	display: none;
}
@media (max-width: 960px){
	.simple02 table {
		min-width: 900px;
		font-size: 0.9rem;
	}
	.table_wrap{
		overflow: auto;
	}
	.table_wrap::-webkit-scrollbar{
		width: 2px;
		height: 2px;
	}
	.table_wrap .comment{
		display: inline-block;
		font-size: 0.8rem;
		padding: 15px 0;
	}
}


ul.t_indent li{
	padding-left: 1em;
	text-indent: -1em;
	margin-bottom: 0.5em;
	line-height: 1.5;
}
.border01 li{
	font-size: 1.1rem;
	line-height: 1.5;
	border-bottom: dotted 8px rgba(82,166,51,0.2);
	margin-bottom: 1em;
	padding-left: 1em;
	text-indent: -1em;
}
.p_02 .border01 li{
	border-bottom: dotted 8px rgba(204,63,157,0.2);
}
.p_04 .border01 li{
	border-bottom: dotted 8px rgba(51,128,166,0.2);
}
.p_05 .border01 li{
	border-bottom: dotted 8px rgba(204,181,63,0.2);
}
@media (max-width: 750px){
	.border01 li{
		font-size: 1rem;
	}
}
.link_list{
	margin-left: 1rem;
}
.link_list li{
	font-size: 0.9rem;
	line-height: 1.5;
	margin-bottom: 1em;
	border-bottom: dashed 1px #ccc;
	text-indent: -1.5em;
	padding-left: 1.5em;
}
.link_list li i{
	color: #d9304f;
	padding-right: 0.5em;
	display: inline;
}
.link_list li a{
	color: #1a1a1a;
	transition: .5s;
}
.link_list li a:hover{
	color: #52a633;
}
/* カルーセル============================================================ */
.carousel_wrap{
	width: 100%;
	margin: auto;
}
.carousel {
	width:calc(100% - 40px);
	padding: 0;
	margin: auto;
}
.carousel .inner {
	overflow: hidden;
	margin: 20px;
	border-radius: 30px;
	box-shadow: 2px 2px 5px rgba(0,0,0,0.1);
}
.carousel .inner img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}
.carousel .slick-next {
	right: -20px;
	z-index: 50;
}
.carousel .slick-prev {
	left: -20px;
	z-index: 50;
}
/* 施設一覧　============================================================ */
.item_wrap{
	padding: 30px;
}
.item_wrap .in_flex{
	display: flex;
	justify-content: center;
	align-items: stretch;
	gap:15px;
}
.item_wrap dl{
	margin-bottom: 0.5em;
	font-size: 0.9rem;
	display: flex;
	border-bottom: dashed 1px #ccc;
	line-height: 1.5;
}
.item_wrap dl dt{
	width: 7em;
}
.item_wrap .in_flex .img{
	width: 100%;

}
.item_wrap .in_flex .img img{
	width: 100%;
	height: 350px;
	object-fit: cover;
	vertical-align: middle;
}
@media (max-width: 960px){
	.item_wrap .in_flex{
		flex-wrap: wrap;
	}
}
@media (max-width: 750px){
	.item_wrap dl{
		flex-direction: column;
		justify-content: flex-start;
		align-items: flex-start;
	}
}


/* Map ============================================================ */
.map{
	width: 100%;
}
.map iframe{
	width: 100%;
	vertical-align: middle;
}

/* ページ内リンク ======================================== */
.sticky_wrap{
	position: sticky;
	top: 30px;
	width: 100%;
	max-width: 300px;
	z-index: 10;
}
.sticky_wrap.pc_link{
	top: 120px;
}
.sticky_wrap ul li{
	margin-bottom: 0.5em;
	font-size: 0.8em;
	
}
.sticky_wrap ul li a{
	display: block;
	width: 100%;
	background:#e2efdc;
	color: #333;
	white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
	padding: 0.5rem 1rem;
	border-radius: 30px;
	transition: .5s;
}
.sticky_wrap ul li a i{
	color: #fff;
}
.sticky_wrap ul li a:hover{
	color: #999;
}
.sticky_wrap h3{
	margin: 15px 0 5px;
	font-size: 1.1rem;
	font-weight: 600;
}


.card003_space{
	display: flex;
	justify-content: center;
	align-content: center;
	padding: 20px 0;
	position: relative;
}
 .card003_space .space{
	width: 350px;
	 position: relative;
}
.card003_space .space.news_cat{
	width: 250px;
}
.card003_space .c_wrap{
	width: calc(100% - 300px);
	padding: 10px;
	flex: 1;
}
.card003_space .c_wrap .inner{
	width: 100%;
	max-width: 960px;
	margin: 70px auto 0;
	padding: 15px;
}

@media (max-width: 1200px){
	.pc_link{
		display: none;
	}
	.card003_space{
		flex-direction: column;
	}
	.card003_space .c_wrap{
		width: 100%;
	}
	.sticky_wrap{
		top: 80px;
		max-width: none;
		padding-top: 10px;
	}
	.sticky_wrap ul{
		display: flex;
		flex-wrap: wrap;
		gap:10px;
		margin: 10px 0;
	}
	.sticky_wrap ul li{
		margin: 0;
		width: calc(100% / 3 - 10px);
	}
	.sticky_wrap ul li a{
		padding: 0.2rem 1rem;
		width: 100%;
		white-space: nowrap;
    	overflow: hidden;
    	text-overflow: ellipsis;
	}
}
@media (max-width: 750px){
	.sticky_wrap{
		padding-top: 1px;
	}
	.sticky_wrap ul li{
		width: calc(50% - 5px);
	}
	
}
@media (max-width: 450px){
	.card003_space .c_wrap{
		padding: 0;
	}
	.sticky_wrap ul li{
		font-size: 0.7em;
		max-width: 50%;
	}
	
	.sticky_wrap ul{
		gap:5px;
	}
	.mb_link ul{
		display: none;
	}
}

.flow_arrow{
	font-size: 2.5em;
	text-align: center;
	color:#52a633;
	line-height: 1;
}
.p_02 .flow_arrow {
	color: #cc3f9d;
}
.p_04 .flow_arrow {
	color: #3f9dcc;
}
.p_05 .flow_arrow {
	color: #ccb53f;
}


/* QA ============================================================ */
.qa-list dl {
    position: relative;
    margin: 0;
    padding: 28px 80px 28px 30px;
    cursor: pointer;
    border-bottom: 1px solid #ccc;
}
.qa-list dl:first-child {
    border-top: 1px solid #ccc;
}
.qa-list dl::before {
    position: absolute;
    top: 35px;
    right: 35px;
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 2px solid #8a9898;
    border-right: 2px solid #8a9898;
}
.qa-list .open::before {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
    padding: 0 0 0 50px;
    font-weight: bold;
    font-size: 1.2rem;
}
.qa-list dl dt::before {
    font-size: 30px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: 'Q.';
    color:#8a9898;
}
.qa-list dl dd::before {
    font-size: 30px;
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 2px;
    display: block;
    content: 'A.';
    color: #e65912;
}
.qa-list dl dd {
    position: relative;
    display: none;
    height: auto;
    margin: 20px 0 0;
    padding: 0 0 0 50px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}


@media (max-width: 750px){
	.qa-list dl{
		 padding: 28px 30px 28px 15px;
	}
	.qa-list dl::before{
		right: 15px;
	}
	.qa-list dl dt{
		padding: 0 0 0 40px;
	}
}

/* タイムライン ============================================================ */
.timeline{
	position: relative;
	width: calc(100% - 30px);
	margin-inline:auto;
}
.timeline .timeline_inner{
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	margin-bottom: 30px;
	position: relative;
}
.timeline .timeline_inner::before{
	position: absolute;
    content: "";
    height: 125%;
    width: 8px;
    top: 25px;
    left: 40px;
    background: #f2ede4;
}
.timeline .timeline_inner:last-child::before{
	height: 5%;
	background-color: transparent;
}
.timeline .timeline_inner dt{
	width: 90px;
    height: 90px;
    line-height: 90px;
    background: #ef94bb;
	color: #fff;
    border-radius: 50%;
    text-align: center;
    font-size: 0.95rem;
    font-weight: 700;
    position: relative;
    z-index: 4;
    letter-spacing: 0.05em;
}
.timeline .timeline_inner dd{
	flex: 1;
	line-height: 1.5;
    position: relative;
    left: 20px;
    margin-top: 10px;
    padding: 15px 10px 15px 30px;
    z-index: 2;
    background: #f2ede4;
    box-shadow: 2px 2px 3px rgba(0,0,0,0.1);
	border-left: solid 5px #f2ede4;
}
.timeline .timeline_inner dd::after{
	border: solid transparent;
	content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    border-color: rgba(255, 255, 255, 0);
    border-top-width:10px;
    border-bottom-width:10px;
    border-left-width:20px;
    border-right-width:20px;
    margin-top: -8px;
    border-right-color:#f2ede4;
    right:100%;
    top:2rem;
}
.timeline .timeline_inner dd span{
	font-size: 80%;
}
.timeline_inner h4{
	font-size: 1.1rem;
	font-weight: 700;
}
.timeline_inner p{
	font-size: 0.9rem;
	line-height: 1.8;
}
@media (max-width: 1200px){
	.timeline{
		width: 100%;
	}
}


