@charset "UTF-8";
/*-------------------------
 *
 *
 *
 * Page title
 *
 *
 *
-------------------------*/

.page_ttl {
	margin-bottom: 0;
}

@media (max-width: 960px) {

}

@media (max-width: 768px) {

}

@media (max-width: 560px) {

}

/*-------------------------
 *
 *
 *
 * Flow
 *
 *
 *
-------------------------*/

.page_switch {
	position: relative;
	margin-bottom: -4px;
	z-index: 1;
}

.page_switch > .inner {
	max-width: 1055px;
	display: flex;
	align-items: flex-end;
}

.page_switch_tab {
	width: 50%;
	height: 60px;
	line-height: 60px;
	font-size: 20px;
	color: #999;
	text-align: center;
	position: relative;
	cursor: pointer;
	transition: .3s ease;
}

.page_switch_tab::before {
	display: block;
	content: '';
	width: 100%;
	height: 4px;
	background: #199A42;
	position: absolute;
	bottom: 0;
	left: 0;
	opacity: 0;
}

.page_switch_tab a {
	display: block;
	color: #999;
}

.page_switch_tab a:hover,
.page_switch_tab.current a {
	color: #199a42;
	opacity: 1;
}

.page_switch_tab.current::before {
	opacity: 1;
}

.page_switch_tab br {
	display: none;
}

.flow_body {
	position: relative;
	background: #ffffff;
	padding: 50px 0 50px 0;
}

.flow_list > .inner {
	max-width: 900px;
	display: flex;
	flex-wrap: wrap;
	column-gap: 5%;
	margin-bottom: 0px;
}

.flow_item {
	width: 30%;
	margin-bottom: 40px;
}

.flow_item_thumb {
	margin-bottom: 16px;
}

.flow_item_thumb > .img {
	padding-top: 62.5%;
/*	background-color: #ddd;*/
}

.flow_step {
	width: 56px;
	height: 56px;
	border-radius: 28px;
	overflow: hidden;
	background: #199A42;
	color: #fff;
	line-height: 1;
	position: absolute;
	top: 4px;
	left: 4px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
}

.flow_step_text {
	font-size: 12px;
	margin-top: 3px;
}

.flow_step_num {
	font-size: 32px;
}

.flow_item_hl {
	
	line-height: 1.5;
	margin-bottom: 16px;
}

.flow_text {
	font-size: 14px;
	line-height: 1.6;
}

.flow_item_btn a {
	margin: 16px auto 0;
	font-size: 20px;
	height: 40px;
	line-height: 40px;
	border-radius: 20px;
}

.flow_btns {
	display: flex;
	flex-wrap: wrap;
	margin-top: 20px;
}

.flow_btns .flow_btn a {
	margin: 0 10px 10px 0;
}

@media (max-width: 960px) {

	.flow_item {
		width: 47.5%;
	}

}

@media (max-width: 768px) {

	.flow_body {
		padding-bottom: 0;
	}

	.page_switch_tab {
		height: auto;
		line-height: 1.33;
		font-size: 14px;
		padding: 16px 0;
	}

	.page_switch_tab br {
		display: inline;
	}

}

@media (max-width: 560px) {

	.flow_list > .inner {
		margin-bottom: 20px;
	}

	.flow_item {
		width: 100%;
		margin-bottom: 30px;
	}

}

/*-------------------------
 *
 *
 *
 * CTA
 *
 *
 *
-------------------------*/

#htl_cta > .inner {
	max-width: 1082px;
	background: #FFE7A7;
	color: #644B2D;
	position: relative;
}

.htl_cta_content {
	width: calc( 100% - 406px );
	padding: 20px 0 10px 40px;
}

.htl_cta_hl {
	font-size: 32px;
	line-height: 1.33;
	margin-bottom: 6px;
}

.htl_cta_text {
	font-size: 14px;
	line-height: 1.36;
}

.htl_cta_btns {
	margin-top: 16px;
	display: flex;
	flex-wrap: wrap;
}

.htl_cta_btn a {
	margin: 0 10px 10px 0;
}

.htl_cta_btn_teachers a {
	width: 166px;
}

.htl_cta_img {
	width: 366px;
	height: 206px;
	position: absolute;
	right: 20px;
	bottom: 0;
}

@media (max-width: 960px) {

}

@media (max-width: 768px) {

	#htl_cta > .inner {
		width: 100%;
		display: block;
		flex-direction: column;
	}

	.htl_cta_content {
		width: 100%;
		padding: 20px 30px 10px;
	}

	.htl_cta_img {
		position: relative;
		right: auto;
		bottom: auto;
		margin: 0 5% 0 auto;
	}

}

@media (max-width: 560px) {

	.htl_cta_content {
		padding: 20px 5% 10px;
	}

	.htl_cta_hl {
		font-size: 26px;
	}

	.htl_cta_btns {
		margin-top: 24px;
	}

}

/*-------------------------
 *
 *
 *
 * Schedule
 *
 *
 *
-------------------------*/

#schedule > .inner {
	max-width: 1082px;
	background: #fff;
	position: relative;
	padding: 45px 0 50px;
}

.schedule_hl {
	font-size: 28px;
	text-align: center;
	line-height: 1.33;
	color: #333;
	margin-bottom: 20px;
}

/*-------------------------
 *
 *
 *
 * Recommend
 *
 *
 *
-------------------------*/

#recommend > .inner {
	width: 100%;
	max-width: initial;
	background: #fff;
	position: relative;
	padding: 45px 0 50px;
}

.recommend_hl {
	font-size: 28px;
	text-align: center;
	line-height: 1.33;
	color: #333;
	margin-bottom: 20px;
}

#recommend_slider_wrapper {
	position: relative;
	height: 320px;
}

#recommend_slider {
	width: 2880px;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0);
	padding-bottom: 10px;
}

.teacher_item {
	margin: 0;
}

@media (max-width: 960px) {

}

@media (max-width: 768px) {

	#recommend_slider_wrapper {
		height: 360px;
	}

	#recommend_slider {
		width: 1765px;
	}

	.teacher_item_hl {
		margin-right: 4%;
	}

}

@media (max-width: 560px) {

}

/*-------------------------
 *
 *
 *
 * Schedule
 *
 *
 *
-------------------------*/
.schedule_booked {
	background: #FFDAB9;
}
