@charset "utf-8";

section{
	margin-bottom: 35px;
	padding-top: 55px;
	margin-top: -55px;
}
section.bt-arrow{
	margin-bottom: 0;
}
section.bt-arrow::after{
	content: "";
	display: block;
	width: 52px;
	height: 48px;
	margin: 10px auto;
	background: url("../img/course_arrow.svg") no-repeat center center /52px 48px;
}
@media only screen and (max-width:640px) {
	#content section:last-child{
		margin-bottom: 0;
	}
}

.course-nav{
	width: 960px;
	margin: 0 auto;
}
.course-nav ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	list-style: none;
}
.course-nav ul li{
	width: 48.75%;
	margin-bottom: 2.5%;
}
.course-nav ul li img{
	width: 100%;
	height: auto;
}
@media only screen and (max-width:640px) {
	.course-nav{
		width: 100%;
	}
	.course-nav ul{
		display: block;
	}
	.course-nav ul li{
		width: 100%;
		margin-bottom: 5px;
	}
}

.icon-tel::before    { background-image: url("../img/spec_icon1.svg"); }
.icon-addr::before   { background-image: url("../img/spec_icon2.svg"); }
.icon-hours::before  { background-image: url("../img/spec_icon3.svg"); }
.icon-close::before  { background-image: url("../img/spec_icon4.svg"); }
.icon-parking::before{ background-image: url("../img/spec_icon5.svg"); }
.icon-fee::before    { background-image: url("../img/spec_icon6.svg"); }

.article-head{
	width: 960px;
	margin: 0 auto 20px;
}
.article-head p.article-header-lead{
	padding: 20px 15px;
}
.article-head div.legends{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 15px;
	background: #fff;
	border: 1px solid #1FB8CE;
}
.article-head div.legends ul{
	width: 420px;
	list-style: none;
	color: #1FB8CE;
	font-size: 15px;
	font-weight: 900;
}
.article-head div.legends ul li{
	display: inline-block;
	margin-right: 20px;
	margin-bottom: 20px;
}
.article-head div.legends ul li::before{
	display: inline-block;
	content: "";
	width: 30px;
	height: 30px;
	margin-right: 10px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 30px 30px;
	vertical-align: -.6em;
}
.recommended-icons{
	display: flex;
	align-items: center;
	width: 335px;
	padding: 5px 10px;
	background: #1FB8CE;
}
.recommended-icons img{
	display: block;
	width: 43px;
	height: 43px;
	margin-right: 7px;
}
.recommended-icons span{
	display: block;
	width: 202px;
	margin-left: auto;
	color: #fff;
	font-size: 18px;
	line-height: 20px;
	font-weight: 900;
}
@media only screen and (min-width:641px) {
	.article-head div.legends ul li:nth-child(n+4){
		margin-bottom: 0;
	}
}
@media only screen and (max-width:640px) {
	.article-head{
		width: 100%;
		margin: 0 auto 15px;
	}
	.article-head p.article-header-lead{
		padding: 10px 4%;
	}
	.article-head div.legends{
		display: block;
		width: 92%;
		margin: 0 auto;
		padding: 10px;
	}
	.article-head div.legends ul{
		width: 100%;
	}
	.article-head div.legends ul li{
		margin-right: 0;
		margin-bottom: 15px;
	}
	.article-head div.legends ul li:nth-child(2n+1){
		width: 55%;
		
	}
	.article-head div.legends ul li::before{
		margin-right: 5px;
		vertical-align: -.6em;
	}
	.recommended-icons{
		width: 100%;
	}
}

.course-head h2{
	display: flex;
	align-items: center;
	background: #1FB8CE;
	color: #fff;
	font-size: 24px;
	line-height: 1;
	font-weight: 900;
}
#course-map .course-head h2{
	height: 50px;
	justify-content: center;
}
.course-head h2 span.num{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 50px;
	margin-right: 10px;
	background: #FFE45E;
	color: #4C4949;
	font-size: 41px;
	line-height: 1;
}
.course-head h2 span.num img.icon-moon{
	width: 30px;
	height: 30px;
}
.course-head h2 span.num img.icon-star{
	width: 26px;
	height: 26px;
}
.course-summary{
	padding: 10px 15px;
	background: #fff;
}
.course-summary h3{
	margin-bottom: 10px;
	color: #4C4949;
	font-size: 28px;
	line-height: 34px;
	font-weight: 900;
}
.course-summary p{
	color: #1FB8CE;
	font-size: 18px;
	line-height: 22px;
	font-weight: 900;
}
.course-summary ul.course-summary-icons{
	margin-top: 10px;
	list-style: none;
	overflow: hidden;
}
.course-summary ul.course-summary-icons li{
	float: left;
	margin-right: 13px;
}
.course-summary ul.course-summary-icons li img{
	width: 50px;
	height: 50px;
}
.course-outline{
	display: flex;
	background: #fff;
}
.course-outline > figure{
	position: relative;
	flex-shrink: 0;
	width: 550px;
}
.course-outline > figure img{
	width: 100%;
	height: auto;
}
.course-outline > figure span{
	position: absolute;
	right: 20px;
	bottom: 25px;
}
.course-outline > figure span img{
	display: inline-block;
	width: 70px;
	height: 70px;
	margin-left: 15px;
}
.course-outline > div{
	width: 100%;
	padding: 0 15px;
}
.course-info{
	padding: 12px 15px;
	background: #E8F9FC;
	color: #0995BF;
	font-size: 15px;
}
.course-info ul{
	list-style: none;
}
.course-info ul li + li{
	margin-top: 6px;
}
.course-info ul li::before{
	display: inline-block;
	content: "";
	width: 25px;
	height: 25px;
	margin-right: 10px;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 25px 25px;
	vertical-align: -.5em;
}
.course-info ul + .course-info-btn{
	margin-top: 30px;
}
.course-info .course-info-btn{
	display: flex;
	justify-content: center;
}
.course-info .course-info-btn a{
	display: inline-block;
	margin: 0 10px;
	padding: 10px 20px;
	background: #1FB8CE;
	border-radius: 8px;
	color: #fff;
	font-size: 22px;
	font-weight: 900;
	line-height: 1;
}
#course-map .map-img img{
	width: 100%;
	height: auto;
}
	.course-cat-ttl{
		position: relative;
		width: 92%;
		margin: 0 auto 10px;
		padding-bottom: 18px;
		color: #1FB8CE;
		font-size: 34px;
		line-height: 40px;
		font-weight: 900;
		text-align: center;
	}
	.course-cat-ttl::after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 6px;
		background: #1FB8CE;
		border-radius: 3px;
	}
@media only screen and (max-width:640px) {
	.course-head h2{
		font-size: 20px;
	}
	#course-map .course-head h2{
		height: 50px;
		justify-content: center;
	}
	.course-head h2 span.num{
		width: 48px;
		height: 48px;
		margin-right: 17px;
		font-size: 34px;
	}
	.course-summary{
		padding: 5px 4% 10px;
		background: #fff;
	}
	.course-summary h3{
		margin-bottom: 5px;
		font-size: 26px;
		line-height: 32px;
	}
	.course-summary p{
		font-size: 15px;
		line-height: 18px;
	}
	.course-summary ul.course-summary-icons{
		margin-top: 10px;
	}
	.course-summary ul.course-summary-icons li{
		margin-right: 7px;
	}
	.course-summary ul.course-summary-icons li img{
		width: 40px;
		height: 40px;
	}
	.course-outline{
		display: block;
	}
	.course-outline > figure{
		width: 100%;
	}
	.course-outline > figure span{
		right: 15px;
		bottom: 10px;
	}
	.course-outline > figure span img{
		width: 50px;
		height: 50px;
		margin-left: 10px;
	}
	.course-outline > div{
		width: 100%;
		padding: 10px 4%;
	}
	.course-info{
		padding: 10px 4%;
		font-size: 12px;
		line-height: 1.33;
	}
	.course-info ul li{
		padding-left: 20px;
		text-indent: -20px;
	}
	.course-info ul li + li{
		margin-top: 4px;
	}
	.course-info ul li::before{
		width: 16px;
		height: 16px;
		margin-right: 5px;
		background-size: 16px 16px;
		vertical-align: -.25em;
	}
	.course-info ul + .course-info-btn{
		margin-top: 10px;
	}
	#course-map .map-img{
		position: relative;
		width: 100%;
		height: 132vw;
		overflow-x: scroll;
		-webkit-overflow-scrolling: touch;
	}
	#course-map .map-img.map-height-s{
		height: 103.93vw;
	}
	#course-map .map-img img{
		height: 100%;
		width: auto;
	}
	.course-cat-ttl{
		position: relative;
		width: 92%;
		margin: 0 auto 10px;
		padding-bottom: 18px;
		color: #1FB8CE;
		font-size: 34px;
		line-height: 40px;
		font-weight: 900;
		text-align: center;
	}
	.course-cat-ttl::after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 6px;
		background: #1FB8CE;
		border-radius: 3px;
	}
}
