section.map iframe{
	width: 100%;
}

section div.route{
	display: flex;
	margin-bottom:3rem;
	align-items: center;
}


section div.toschool{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}

section div.toschool{
}

section div.toschool > div{
	width: 33%;
}

section div.toschool > div:before{
	content: "\f239";
	width: 6rem;
	height: 6rem;
	background: #3874bd;
	color: #fff;
	font-size:3rem;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 2rem;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	border-radius: 100%;
	margin: 0 auto 2.5rem;
}

section div.toschool > div{
	padding: 1.5rem;
	border-top: 1px solid #e7e7e7;
	border-bottom: 1px solid #e7e7e7;
	box-sizing: border-box;
}

section div.toschool > div:nth-child(2){
	border: 1px solid #e7e7e7;
}

section div.toschool div div.tl{
	text-align: center;
	color: #3874bd;
	font-size:1.2rem;
	font-weight: 600;
	height: 4rem;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1.5;
}

section div.toschool div p.first:before{
	content:"";
	margin: 1rem auto 2rem;
	width: 4rem;
	background: #3874bd;
	height: 1px;
	display: block;
}
section div.toschool div div.photo_txt p.first:before{
	display: none;
}
section div.toschool div div.photo_txt:before{
	content:"";
	margin: 1rem auto 2rem;
	width: 4rem;
	background: #3874bd;
	height: 1px;
	display: block;
}
section div.toschool div div.photo_txt img {
	vertical-align: bottom;
	margin-bottom: 1rem;
}
section div.toschool div p{
	margin: 0;
	text-align: center;
	font-size:1rem;
	font-weight: 500;
}
section div.toschool div p:after{
	content: "\f063";
	margin: 0.5rem 0;
	display: block;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
}

section div.toschool div p:last-child:after{
	content: "";
	margin: 0;
}

@media (max-width: 673px) {
	section.map iframe{
		height: 350px;
	}
	section div.toschool{
		flex-wrap: wrap;
	}
	
	section div.toschool > div{
		border-top: 1px solid #e7e7e7;
		width: 100%;
	}
	section div.toschool > div:nth-child(2){
		border-left:none;
		border-right: none;
	}
	section div.toschool > div:nth-child(3){
		border-bottom: 1px solid #e7e7e7;
	}
	section div.route{
		flex-wrap: wrap;
		margin-bottom:0;
		align-items: flex-start;
	}
	
	section div.route img:first-child{
		margin-bottom: 1rem;
	}
	section div.toschool div p.first:before{
		margin: 1rem auto;
	}
    section div.toschool div div.photo_txt:before{
		margin: 1rem auto;
	}
	section div.toschool div p:after{
		margin: 0;
	}
	section div.toschool > div:before{
		margin-bottom: 1rem;
	}
	section div.toschool div div.tl{
		height: auto;
		font-size: 1.1rem;
	}
}
@media screen and (min-width:673px) and ( max-width:1165px) {
section div.toschool div div.tl{
	font-size:1rem;
}}

section div.toschool div div.tlvi{
	height: 6.8rem;
}