/* bootstrap 5 fix */
@media (prefers-reduced-motion: no-preference) {
	:root {scroll-behavior: auto;}
}
*{
	position: relative;
	box-sizing: border-box;
}
body{
	margin: 0;
	font-family: 'Noto Sans TC', sans-serif;
	padding-top: 80px;
}
img{
	position: relative;
	display: block;
	max-width: 100%;
}
a{display: inline-block;}
a, a:hover, a:focus{text-decoration: none;}
a:focus{outline: none;}
section{
	position: relative;
	overflow: hidden;
}
.flex{
	display: flex;
	flex-wrap: wrap;
}
.flex-row{
	display: flex;
	flex-wrap: wrap;
	margin-left: -12px;
	margin-right: -12px;
}
.flex-1{flex: 1;}
.center{
	margin-left: auto;
	margin-right: auto;
}
.t-center{text-align: center;}
.t-right{text-align: right;}
.v-center{
	top: 50%;
	transform: translateY(-50%);
}
.flex-center{justify-content: center;}
.flex-v-center{align-items: center;}
.show-xl, .show-lg, .show-md, .show-sm, .hide{
	display: none;
}
.container, .container-fluid, .container-xxl{
	padding-left: 15px;
	padding-right: 15px;
}
.row-p15{
	margin-left: -15px;
	margin-right: -15px;
}
.row-p15 > *{
	padding-left: 15px;
	padding-right: 15px;
}
.p15{
	padding-left: 15px;
	padding-right: 15px;
}
.fh{height: 100%;}
.full-img{
	max-width: none;
	width: 100%;
}
.wow{
	visibility: hidden;
	animation-duration: 1.5s;
}

/* header */
header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 80px;
	z-index: 9999;
}
.header_bg{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	transition: opacity 0.5s;
	box-shadow: 0 1px 2px #ccc;
	opacity: 0.95;
}
.menu{
	height: 100%;
	padding-top: 23px;
	padding-left: 300px;
	padding-right: 360px;
}
.menu_row{
	height: 100%;
	justify-content: center
}
.menu_item{
	height: 100%;
	padding-left: 7px;
	padding-right: 7px;
}
.menu_btn{
	display: block;
	font-size: 16px;
	color: #000;
	padding: 10px 20px;
	border-radius: 22px;
}
.menu_btn:hover{
	color: #fff;
	background-color: #FF6767;
}
.menu_item.active .menu_btn, .menu_btn.active{
	color: #fff;
	background-color: #FF6767;
}
.menu2{
	position: fixed;
	top: 80px;
	left: 0;
	width: 100%;
	height: 70px;
	background-color: #555555dd;
	display: none;
}
.menu2_row{
	justify-content: center;
}
.menu2_item{
	padding-left: 7px;
	padding-right: 7px;
	padding-top: 13px;
}
.menu2_btn{
	display: block;
	font-size: 16px;
	color: #fff;
	padding: 10px 20px;
	border-radius: 22px;
}
.menu2_btn:hover{
	color: #fff;
	background-color: #FF6767;
}
.menu2_item.active .menu2_btn, .menu2_btn.active{
	color: #fff;
	background-color: #FF6767;
}
.menu_right{
	position: absolute;
	top: 30px;
	right: 0;
	padding-right: 20px;
}
.menur_row{
	align-items: center;
}
.menur_item{
	padding-left: 5px;
	padding-right: 5px;
}
.menur_ibtn{
	display: block;
	width: 30px;
	height: 30px;
	padding-top: 6px;
	border-radius: 50%;
	background-color: #eee;
	overflow: hidden;
}
.menur_ibtn img{
	width: 18px;
	margin-left: auto;
	margin-right: auto;
}
.menur_ibtn:hover{
	background-color: #FF6767;
}
.menur_item2{
	padding-left: 30px;
}
.menur_btn{
	display: block;
	font-size: 16px;
	color: #fff;
	background-color: #FF6767;
	border-radius: 30px;
	padding: 10px 30px;
}
.menur_btn > img{
	display: inline-block;
	top: -1px;
	margin-right: 10px;
}
.menur_btn:hover{
	background-color: #ff3636;
}
.menu_right2{
	position: absolute;
	top: 2px;
	right: 0;
	padding-right: 20px;
}
.menur2_item{
	padding-left: 10px;
	padding-right: 10px;
}
.menur2_item:nth-child(n+2)::before{
	position: absolute;
	content: "";
	top: 8px;
	left: 0;
	width: 1px;
	height: 13px;
	background-color: #333;
}
.menur2_btn{
	font-size: 13px;
	color: #000;
	letter-spacing: 0.5px;
}
.menur2_btn:hover{
	color: #FF6767;
}
.header_logo{
	position: absolute;
	top: 22px;
	left: 30px;
	width: 210px;
}
.mobile_btn{
	position: absolute;
	top: 17px;
	right: 20px;
	cursor: pointer;
	display: none;
}
.body_top{
	height: 80px;
}

/* footer */
footer{
	padding-top: 30px;
	padding-bottom: 20px;
	background-color: #362D2D;
}
.footer_con{
	max-width: 1800px;
	padding-left: 15px;
	padding-right: 15px;
	margin-left: auto;
	margin-right: auto;
}
.footer_row{
	margin-bottom: 40px;
}
.footer_left{
	flex: 1;
}
.footer_logo_div{
	height: 55px;
	border-bottom: 1px solid #4b4747;
}
.footer_logo{
	width: 240px;
}
.footer_social{
	padding-top: 20px;
	margin-left: -5px;
	margin-right: -5px;
}
.footer_item{
	width: 180px;
}
.footm_title_div{
	height: 55px;
	border-bottom: 1px solid #4b4747;
}
.footer_abtn_t{
	display: block;
	color: #fff;
}
.footer_abtn_t:hover{
	color: #FF6767;
}
.footer_abtn_t > img{
	display: inline-block;
	margin-right: 7px;
}
.footm_list{
	padding-top: 20px;
}
.footer_abtn{
	display: block;
	font-size: 15px;
	color: #fff;
	margin-bottom: 5px;
}
.footer_abtn:hover{
	color: #FF6767;
}
.footer_info{
	font-size: 14px;
	color: #fff;
	line-height: 1.6em;
}
.copyright{
	position: absolute;
	bottom: 0;
	right: 15px;
	font-size: 14px;
	color: #fff;
	text-align: right;
}

/* index */
.kv_bg{
	height: 760px;
	background-image: url(../img/index/kv.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: bottom center;
}
.kv_con{
	position: absolute;
	top: 250px;
	left: 0;
	width: 100%;
}
.con-1600{
	max-width: 1630px;
	padding-left: 15px;
	padding-right: 15px;
	margin-left: auto;
	margin-right: auto;
}
.kv_con_in{
	position: absolute;
	top: 0;
	right: 30px;
	width: 580px;
}
.kv_icon_01{
	position: absolute;
	top: -35px;
	left: -25px;
}
.kv_icon_02{
	position: absolute;
	top: 50px;
	right: -20px;
}
.kv_title{
	font-size: 60px;
	color: #3EAA4C;
	font-weight: bold;
	letter-spacing: 1px;
	margin-bottom: 30px;
}
.kv_text{
	width: 489px;
	margin-left: auto;
	margin-right: auto;
}
.kv_btn_div{
	transform: translateY(-50px);
}
.kv_item{
	width: 12.5%;
	padding-left: 7px;
	padding-right: 7px;
}
.kv_btn{
	display: block;
}
.kv_btn_img{
	width: 160px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
}
.kv_btn_title{
	font-size: 18px;
	color: #000;
	font-weight: 500;
	letter-spacing: 1px;
	text-align: center;
}
.kv_btn:hover::before{
	position: absolute;
	content: "";
	bottom: -10px;
	left: calc(50% - 44px);
	width: 88px;
	height: 22px;
	background-image: url(../img/index/btn_hover.png);
	background-repeat: none;
}
.main_sec{
	padding-top: 50px;
	padding-bottom: 50px;
}
.index_banner{
	padding-top: 40px;
	padding-bottom: 120px;
}
.con-1440{
	max-width: 1470px;
	padding-left: 15px;
	padding-right: 15px;
	margin-left: auto;
	margin-right: auto;
}
.index_title{
	font-size: 36px;
	font-weight: bold;
	letter-spacing: 1px;
	text-align: center;
	margin-bottom: 30px;
}
.index_sitem{
	border-radius: 60px;
	overflow: hidden;
	display: none;
}
.index_sitem:first-child{
	display: block;
}
.index_sitem img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.banner_sp_01{
	position: absolute;
	top: -100px;
	right: 50px;
}
.banner_sp_02{
	position: absolute;
	bottom: -100px;
	left: -50px;
}
.banner_sp_03{
	position: absolute;
	bottom: -130px;
	right: -75px;
}
.sec_title{
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 1px;
	text-align: center;
	margin-bottom: 2px;
}
.sec_title_en{
	font-family: "Arial";
	font-size: 18px;
	color: #3EAA4C;
	font-weight: bold;
	letter-spacing: 3px;
	text-align: center;
	margin-bottom: 40px;
}
.news_row{
	margin-left: -15px;
	margin-right: -15px;
	margin-bottom: 30px;
}
.news_item{
	padding: 0 50px;
	margin-bottom: 30px;
}
.news_box{
	display: block;
	color: #222;
	padding-bottom: 12px;
	border-bottom: 1px solid #eee;
}
.news_box:hover{
	color: #FF6767;
}
.news_date{
	font-size: 12px;
	color: #B7B7B7;
	margin-bottom: 7px;
}
.news_date .category{
	font-size: 14px;
	color: #3EAA4C;
	top: 1px;
}
.news_title{
	font-size: 18px;
	font-weight: 500;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	height: 54px;
}
.more_btn{
	display: block;
	width: 160px;
	font-size: 17px;
	color: #000;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-align: center;
	padding: 12px 0;
	background-color: #FFB829;
	border-radius: 35px;
	margin-left: auto;
	margin-right: auto;
}
.more_btn::after{
	position: absolute;
	content: "";
	top: 19px;
	right: 20px;
	width: 14px;
	height: 14px;
	background-image: url(../img/icon_more.png);
	background-repeat: no-repeat;
}
.more_btn:hover{
	color: #fff;
	background-color: #FF6767;
}
.index_course{
	min-height: 880px;
	padding-top: 100px;
	padding-bottom: 100px;
	background-image: url(../img/index/sec_bg_01.jpg);
	background-repeat: no-repeat;
	background-position: center;
}
.course_row{
	margin-left: -15px;
	margin-right: -15px;
	margin-bottom: 30px;
}
.course_item{
	padding: 0 50px;
	margin-bottom: 40px;
}
.course_box{
	display: block;
	color: #222;
}
.course_img{
	padding-bottom: 66%;
	border-radius: 30px;
	margin-bottom: 15px;
	overflow: hidden;
}
.course_img img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}
.course_info{
	font-size: 14px;
	color: #5E5E5E;
	margin-top: 3px;
}
.course_box:hover{
	color: #FF6767;
}
.course_box:hover .course_img img{
	transform: scale(1.05);
}
.index_record{
	padding-top: 50px;
	padding-bottom: 90px;
}
.record_div{
	height: 500px;
	margin-top: 60px;
}
.record_box{
	position: absolute;
	border: 3px solid #AAE29D;
	border-radius: 50%;
	background-color: #fff;
	box-shadow: 10px 10px 0 #AAE29D;
}
.record_con{
	top: 50%;
	transform: translateY(-50%);
	text-align: center;
}
.record_num{
	font-family: "Arial";
	font-size: 50px;
	color: #FF6767;
	font-weight: bold;
	letter-spacing: 1px;
	line-height: 1.1em;
}
.record_num.big{font-size: 70px;}
.record_num.small{font-size: 44px;}
.record_unit{
	font-size: 17px;
	font-weight: 500;
	margin-left: 5px;
}
.record_box.t1{
	top: 20px;
	left: 60px;
	width: 220px;
	height: 220px;
}
.record_box.t2{
	top: 225px;
	left: 130px;
	width: 190px;
	height: 190px;
}
.record_box.t3{
	top: 50px;
	left: 410px;
	width: 280px;
	height: 280px;
}
.record_box.t4{
	top: 305px;
	left: 390px;
	width: 167px;
	height: 167px;
}
.record_box.t5{
	top: 0;
	left: 740px;
	width: 190px;
	height: 190px;
}
.record_box.t6{
	top: 230px;
	left: 720px;
	width: 167px;
	height: 167px;
}
.record_box.t7{
	top: 100px;
	left: 1010px;
	width: 200px;
	height: 200px;
}
.record_sp_01{
	position: absolute;
	top: 300px;
	left: -80px;
}
.record_sp_02{
	position: absolute;
	top: 250px;
	right: -70px;
}
.record_sp_03{
	position: absolute;
	top: 0;
	left: 0;
}
.record_sp_04{
	position: absolute;
	top: 0;
	left: 615px;
}
.record_sp_05{
	position: absolute;
	top: -10px;
	left: 870px;
}
.record_sp_06{
	position: absolute;
	top: 480px;
	left: 220px;
}
.record_sp_07{
	position: absolute;
	top: 350px;
	right: 280px;
}
.index_donation{
	padding-top: 60px;
	padding-bottom: 60px;
	background-image: url(../img/index/sec_bg_02.jpg);
	background-repeat: no-repeat;
	background-position: top center;
}
.donation_left{
	padding-top: 120px;
}
.donation_title{
	font-size: 40px;
	font-weight: bold;
	letter-spacing: 2px;
	line-height: 1.4em;
	margin-bottom: 50px;
}
.donation_title span{
	font-size: 56px;
	color: #FF6767;
}
.donation_text{
	margin-bottom: 30px;
}
.donation_btn{
	display: block;
	width: 160px;
	font-size: 17px;
	color: #fff;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-align: center;
	padding: 12px 0;
	background-color: #FF6767;
	border-radius: 35px;
}
.donation_btn::before{
	position: absolute;
	content: "";
	top: 19px;
	left: 20px;
	width: 14px;
	height: 13px;
	background-image: url(../img/btn_icon_01.png);
	background-repeat: no-repeat;
}
.donation_btn:hover{
	color: #000;
}
.donation_pic{
	max-width: none;
}

/* other */
.edit_area img{
	height: auto !important;
	margin-left: auto;
	margin-right: auto;
}
.edit_area iframe{
	width: 100%;
}
.video_frame{
    position: relative;
    padding-bottom: 56.25%;
    overflow: hidden;
}
.video_frame iframe, .video_frame video{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* news */
.page_kv{
	height: 500px;
	overflow: visible;
}
.page_kv_img{
	position: absolute;
	top: 0;
	left: 0;
	max-width: none;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: bottom center;
}
.kv_icon{
	position: absolute;
	bottom: 0;
	right: 0;
}
.news_kv_icon{
	bottom: -100px;
	right: 60px;
}
.page_kv_con{
	padding-top: 220px;
	padding-bottom: 65px;
}
.page_kv_title_div{
	display: inline-block;
}
.kv_title_icon{
	position: absolute;
	top: -40px;
	right: -45px;
}
.page_kv_title{
	font-size: 40px;
	color: #fff;
	font-weight: 500;
	letter-spacing: 2px;
	margin-bottom: 15px;
}
.page_kv_title_en{
	font-family: "Arial";
	font-size: 30px;
	color: #fff;
	font-weight: bold;
	letter-spacing: 6px;
}
.page_kv_text{
	position: absolute;
	bottom: 0;
	right: 15px;
	width: 474px;
}
.news{
	padding-top: 100px;
	padding-bottom: 100px;
}
.sort_row{
	justify-content: center;
	border-bottom: 1px solid #ddd;
	margin-bottom: 80px;
}
.sort_btn{
	display: block;
	width: 12.5%;
	color: #000;
	text-align: center;
	padding: 15px 0;
	border-bottom: 4px solid transparent;
}
.sort_btn:hover, .sort_btn.active{
	border-color: #FFB829;
}
.navigation_div{
	padding-top: 10px;
}
.pagination{
	justify-content: center;
}
.page-link{
	color: #232222;
	border: none;
	background: none;
	border-radius: 5px;
}
.page-link:focus{
	color: #232222;
	box-shadow: none;
	background: none;
}
.page-item.active .page-link{
	color: #fff;
	background-color: #3EAA4C;
}
.page-item:hover .page-link{
	color: #fff;
	background-color: #3EAA4C;
}
.newsp_title_div{
	padding-left: 20px;
	border-left: 6px solid #3EAA4C;
	margin-bottom: 30px;
}
.newsp_title{
	font-size: 30px;
	letter-spacing: 0.5px;
	line-height: 1.5em;
	margin-top: 15px;
}
.news_con{
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
.newsp_img{
	margin-bottom: 10px;
}
.newsp_img img{
	border-radius: 60px;
	margin-left: auto;
	margin-right: auto;
}
.news_text{
	line-height: 1.8em;
	padding-bottom: 80px;
	border-bottom: 1px solid #eee;
}
.news_share{
	padding-top: 40px;
}
.news_share_row{
	align-items: center;
	justify-content: flex-end;
}
.icon_share_item{
	padding-right: 12px;
}
.icon_share_item img{
	width: 14px;
}

/* course */
.course_sel_div{
	justify-content: center;
	margin-left: -15px;
	margin-right: -15px;
	margin-bottom: 60px;
}
.course_sel_item{
	width: 300px;
	padding-left: 15px;
	padding-right: 15px;
}
input:focus{
	outline: none;
}
select:focus{
	outline: none;
}
.course_sel{
	width: 100%;
	padding: 9px 15px;
	border: none;
	border-radius: 20px;
	background-color: #f3f3f3;
}
.course_search{
	width: 100%;
	padding: 10px 35px 10px 15px;
	border: none;
	border-radius: 20px;
	background-color: #f3f3f3;
}
.icon_search{
	position: absolute;
	top: 12px;
	right: 12px;
}

/* about */
.about_kv_icon{
	bottom: -200px;
	right: 60px;
}
.about_title{
	font-size: 30px;
	font-weight: 500;
	line-height: 1.2em;
	letter-spacing: 0.5px;
	padding-left: 20px;
	border-left: 6px solid #3EAA4C;
	margin-bottom: 40px;
}
.about1_left{
	padding-right: 50px;
}
.main_text{
	line-height: 1.8em;
}
.main_text p{
	margin-bottom: 30px;
}
.main_text .ec{
	font-weight: bold;
	background-color: #FFE229;
}
.about_pic{
	width: 420px;
	border-radius: 50%;
}
.bhr{
	margin-top: 60px;
	border-bottom: 1px solid #eee;
}
.about_mark{
	min-height: 542px;
	padding-top: 15px;
	padding-bottom: 15px;
	background-image: url(../img/about/about_bg.jpg);
	background-repeat: no-repeat;
	background-position: center;
	margin-top: 50px;
	margin-bottom: 50px;
}
.about_logo{
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
}
.about_mark_text{
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 1px;
	text-align: center;
	margin-bottom: 7px;
}
.about_mark_text .ec_red{
	font-size: 25px;
	color: #FF6767;
	font-weight: bold;
}
.about_mark_text .ec_green{
	font-size: 25px;
	color: #3EAA4C;
	font-weight: bold;
}

/* location */
.loc_sec{
	padding-top: 50px;
	padding-bottom: 1px;
}
.loc_title{
	display: inline-block;
	font-size: 18px;
	color: #3EAA4C;
	font-weight: 500;
	padding: 6px 17px;
	border: 3px solid #AAE29D;
	border-radius: 20px;
	box-shadow: 4px 4px 0 #AAE29D;
}
.loc_text{
	font-size: 15px;
	margin-bottom: 30px;
}
.loc_text p{
	margin-bottom: 10px;
}
.loc_text span{
	color: #ddd;
	margin-left: 7px;
	margin-right: 7px;
}
.loc_btn_row{
	margin-left: -5px;
	margin-right: -5px;
}
.loc_item{
	margin-bottom: 60px;
}
.loc_btn{
	width: 30px;
	height: 30px;
	margin-left: 5px;
	margin-right: 5px;
	overflow: hidden;
}
.loc_btn:hover img{
	top: -30px;
}
.loc_btn2{
	width: 72px;
	height: 30px;
	margin-left: 5px;
	margin-right: 5px;
	overflow: hidden;
}
.loc_btn2:hover img{
	top: -30px;
}
.loc_bhr{
	margin-top: 40px;
	border-bottom: 1px solid #eee;
}
@media (min-width: 768px){
	.loc_item:nth-child(odd){
		padding-right: 40px;
	}
	.loc_item:nth-child(even){
		padding-left: 40px;
	}
}

/* award */
.award{
	padding-top: 80px;
	padding-bottom: 100px;
}
.award_line{
	position: absolute;
	top: 0;
	left: 50%;
	width: 1px;
	height: calc(100% - 100px);
	background-color: #ddd;
}
.award_row{
	padding-bottom: 200px;
	margin-bottom: 40px;
}
.award_item{
	width: 50%;
	margin-bottom: 80px;
}
.award_year{
	font-size: 36px;
	color: #3EAA4C;
	font-weight: bold;
	letter-spacing: 1px;
	line-height: 1.1em;
	padding-left: 20px;
	border-left: 6px solid #3EAA4C;
	margin-bottom: 40px;
}
.award_year span{
	font-size: 32px;
	color: #333;
	margin-left: 7px;
}
.award_point{
	position: absolute;
	top: 12px;
}
.award_text{
	font-size: 15px;
}
.award_text p{
	margin-bottom: 10px;
}
.award_item:nth-child(odd){
	padding-right: 60px;
}
.award_item:nth-child(odd) .award_point{
	right: -9px;
}
.award_item:nth-child(even){
	top: 250px;
	padding-left: 60px;
}
.award_item:nth-child(even) .award_point{
	left: -8px;
}
.award_more_btn::after{
	background-image: url(../img/icon_open.png);
}

/* service */
.service_slogan_sec{
	padding-top: 80px;
	padding-bottom: 50px;
}
.service_slogan{
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 2em;
	text-align: center;
}
.service_slogan .ec_red{
	font-size: 25px;
	color: #FF6767;
	font-weight: bold;
}
.service_slogan .ec_green{
	font-size: 25px;
	color: #3EAA4C;
	font-weight: bold;
}
.ser_item{
	margin-bottom: 80px;
}
@media (min-width: 768px){
	.ser_item:nth-child(odd){
		padding-right: 50px;
	}
	.ser_item:nth-child(even){
		padding-left: 50px;
	}
}
.ser_box{
	height: 100%;
	border-bottom: 1px solid #eee;
	padding-bottom: 70px;
}
.serb_title_row{
	margin-bottom: 20px;
}
.serb_title{
	font-size: 21px;
	font-weight: bold;
	letter-spacing: 1px;
	padding-top: 20px;
	padding-right: 20px;
}
.serb_icon{
	width: 55px;
}
.serb_text{
	font-size: 15px;
	line-height: 1.8em;
	letter-spacing: 0.5px;
}
.serb_abtn{
	position: absolute;
	bottom: 15px;
	right: 0;
	font-size: 17px;
	color: #3EAA4C;
	font-weight: 500;
	letter-spacing: 0.5px;
}
.serb_abtn:hover{
	color: #FF6767;
}
.service_pic{
	width: 360px;
	border-radius: 50%;
}
.main_ul li{
	margin-bottom: 3px;
}
.main_ul li::marker{
	color: #3EAA4C;
}
.cst_row{
	margin-top: 70px;
}
.process_row{
	justify-content: center;
	margin-top: 80px;
}
.process_item{
	width: 160px;
}
.process_ball{
	width: 160px;
	height: 160px;
	border-radius: 50%;
	padding-top: 25px;
	margin-bottom: 20px;
}
.process_ball.t1{background-color: #FF9161;}
.process_ball.t2{background-color: #FFC258;}
.process_ball.t3{background-color: #47D899;}
.process_ball.t4{background-color: #2AD9B7;}
.process_icon{
	width: 50px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
}
.process_title{
	font-size: 21px;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 1.1em;
	text-align: center;
}
.process_text{
	font-size: 15px;
	line-height: 1.7em;
	text-align: center;
}
.process_arrow_div{
	width: 80px;
	padding-top: 65px;
}
.process_arrow{
	margin-left: auto;
	margin-right: auto;
}
.price_frame{
	max-width: 1200px;
	padding: 40px 60px;
	border: 2px solid #AFE3A3;
	border-radius: 30px;
}
.price_item{
	width: 50%;
	padding: 25px;
	font-size: 17px;
	border-bottom: 1px solid #eee;
}
.price_row:last-child .price_item{
	border-bottom: none;
}
.cst_sitem{
	width: 33.33%;
	padding-left: 20px;
	padding-right: 20px;
	display: none;
}
.cst_sitem:first-child{
	display: block;
}
.cst_simg{
	padding-bottom: 67.5%;
	border-radius: 60px;
	overflow: hidden;
}
.cst_simg img{
	position: absolute;
	top: 0;
	left: 0;
	max-width: none;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.sloc_item{
	margin-bottom: 60px;
}
.sloc_img{
	padding-bottom: 66%;
	border-radius: 30px;
	margin-bottom: 20px;
	overflow: hidden;
}
.sloc_img img{
	position: absolute;
	top: 0;
	left: 0;
	max-width: none;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.sloc_abtn{
	position: absolute;
	bottom: 2px;
	right: 0;
	font-size: 17px;
	color: #3EAA4C;
	font-weight: 500;
}
.sloc_abtn:hover{
	color: #FF6767;
}

/* psychotherapist */
.psy_sort_sec{
	padding-top: 80px;
	padding-bottom: 60px;
}
.psy_banner{
	padding-top: 70px;
	padding-bottom: 70px;
	background-color: #F1E6DD;
}
.psyb_title_div{
	width: 350px;
	padding-right: 20px;
}
.psyb_title{
	font-size: 30px;
	font-weight: 500;
	letter-spacing: 0.5px;
	line-height: 1.3em;
	padding-left: 20px;
	border-left: 6px solid #3EAA4C;
}
.psyb_info{
	flex: 1;
}
.psyb_btn_div{
	width: 300px;
	padding-left: 20px;
}
.psyb_abtn{
	top: 2px;
	bottom: auto;
}
.member_item{
	margin-bottom: 80px;
}
.member_box{
	max-width: 360px;
	margin-left: auto;
	margin-right: auto;
}
.member_job{
	font-size: 16px;
	font-weight: 400;
}
.member_img{
	width: 300px;
	height: 360px;
	border-radius: 180px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
	overflow: hidden;
}
.member_img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.member_title{
	font-size: 15px;
	font-weight: bold;
	letter-spacing: 0.5px;
	margin-bottom: 10px;
}
.member_title span{
	color: #ddd;
	font-weight: 400px;
	margin-left: 10px;
}
.member_text{
	font-size: 15px;
	color: #5E5E5E;
	letter-spacing: 0.5px;
	line-height: 1.7em;
}
.member_text hr{
	border-color: #eee;
	opacity: 1;
}


/* setting */
.white{color: #fff;}
.red{color: #f00;}
.red2{color: #FF6767;}
.green{color: #3EAA4C;}
.mb-10{margin-bottom: 10px;}
.mb-20{margin-bottom: 20px;}
.mb-30{margin-bottom: 30px;}

@media (max-width: 1440px){
	.kv_bg{
		height: 600px;
	}
	.kv_con{
		top: 170px;
	}
	.kv_row{
		margin-left: -7px;
		margin-right: -7px;
	}
	.kv_btn_title{
		font-size: 16px;
		letter-spacing: 0;
	}
	.footer_left{
		flex: 0 0 auto;
		width: 100%;
		padding-bottom: 40px;
	}
	.footer_logo_div{
		border: none;
	}
	.footer_right{
		width: 100%;
	}
	.footer_item{
		width: 16.66%;
	}
}

@media (max-width: 1320px){
	.menu{
		padding-left: 250px;
	}
	.menu_item{
		padding-left: 2px;
		padding-right: 2px;
	}
	.record_box.t1{
		left: 150px;
	}
	.record_box.t2{
		left: 210px;
	}
	.record_box.t5{
		left: 700px;
	}
	.record_box.t6{
		left: 680px;
	}
	.record_box.t7{
		left: 850px;
	}
	.donation_left{
		padding-top: 40px;
	}
	.donation_title{
		font-size: 30px;
		letter-spacing: 1px;
	}
	.donation_title span{
		font-size: 40px;
	}
	.donation_pic{
		max-width: 100%;
		left: 30px;
	}
}

/* xl */
@media (max-width: 1199px){
	.show-xl{display: block;}
	.hide-xl{display: none;}
	
	/* header */
	body{
		padding-top: 60px;
	}
	header{
		height: 60px;
	}
	.menu{
		position: absolute;
		top: 60px;
		left: 0;
		width: 100%;
		height: calc(100vh - 60px);
		padding: 20px 0;
		background-color: #fff;
		overflow-y: auto;
		border-top: 1px solid #ddd;
		display: none;
	}
	.menu_row{
		height: auto;
	}
	.menu_item{
		width: 100%;
		height: auto;
		padding: 0;
	}
	.menu_item.active::after{
		display: none;
	}
	.menu_btn{
		height: auto;
		padding: 15px;
		text-align: center;
		border-radius: 0;
	}
	.menu2{
		position: relative;
		top: 0;
		height: auto;
	}
	.menu2_item{
		width: 100%;
		padding: 0;
	}
	.menu2_item{
		padding: 0;
	}
	.menu2_btn{
		height: auto;
		padding: 15px;
		text-align: center;
		border-radius: 0;
	}
	
	.menu_right{
		position: relative;
		top: 0;
		padding-top: 20px;
		padding-right: 0;
	}
	.menur_row{
		justify-content: center;
	}
	.menur_item2{
		width: 100%;
		padding-top: 30px;
		padding-left: 0;
	}
	.menur_btn{
		width: 160px;
		padding: 10px 0;
		text-align: center;
		margin-left: auto;
		margin-right: auto;
	}
	.menu_right2{
		position: relative;
		top: 0;
		padding: 20px 0;
	}
	.menu_right2 > .flex{
		justify-content: center;
	}
	.header_logo{
		width: 190px;
		top: 15px;
		left: 15px;
	}
	.mobile_btn{
		display: block;
	}
	
	.news_item{
		padding-left: 15px;
		padding-right: 15px;
	}
	.course_item{
		padding-left: 15px;
		padding-right: 15px;
	}
	.index_record{
		padding-bottom: 50px;
	}
	.record_div{
		max-width: 375px;
		height: 800px;
		margin-top: 30px;
		margin-left: auto;
		margin-right: auto;
	}
	.record_num{
		font-size: 36px;
	}
	.record_num.big{
		font-size: 50px;
	}
	.record_num.small{
		font-size: 36px;
	}
	.record_box.t1{
		top: 0;
		left: 0;
		width: 200px;
		height: 200px;
	}
	.record_box.t2{
		top: 90px;
		left: auto;
		right: 0;
		width: 170px;
		height: 170px;
	}
	.record_box.t3{
		top: 230px;
		left: 55px;
		width: 240px;
		height: 240px;
	}
	.record_box.t4{
		top: 430px;
		left: 0;
		width: 150px;
		height: 150px;
	}
	.record_box.t5{
		top: 450px;
		left: auto;
		right: 0;
		width: 170px;
		height: 170px;
	}
	.record_box.t6{
		top: 600px;
		left: auto;
		right: 0;
		width: 150px;
		height: 150px;
	}
	.record_box.t7{
		top: 570px;
		left: 0;
	}
	.record_sp_03{
		top: -10px;
		left: -10px;
		width: 40px;
	}
	.record_sp_04{
		left: auto;
		right: 0;
		width: 100px;
	}
	.record_sp_06{
		top: 770px;
		left: 0;
		width: 50px;
	}
	.record_sp_07{
		top: 780px;
		right: 0;
		width: 35px;
	}
	.donation_title{
		font-size: 30px;
		letter-spacing: 1px;
	}
}

/* lg */
@media (max-width: 991px){
	.show-lg{display: block;}
	.hide-lg{display: none;}
	
	.kv_bg{
		height: 500px;
	}
	.kv_con{
		top: 100px;
	}
	.kv_btn_title{
		font-size: 14px;
	}
	.index_banner{
		padding-bottom: 50px;
	}
	.index_course{
		min-height: 0;
		padding-top: 50px;
		padding-bottom: 50px;
	}
	.footer_item{
		width: 33.33%;
		margin-bottom: 40px;
	}
	.copyright{
		position: relative;
		right: 0;
		text-align: center;
		margin-top: 40px;
	}
	.kv_icon{
		display: none;
	}
	.sort_row{
		justify-content: flex-start;
	}
	.sort_btn{
		width: 25%;
		padding: 10px 0;
	}
	.newsp_title_div{
		padding-left: 15px;
	}
	.newsp_title{
		font-size: 20px;
	}
	.about1_left{
		padding-right: 0;
		padding-bottom: 30px;
	}
	.about_pic{
		margin-left: auto;
		margin-right: auto;
	}
	.service_pic{
		margin-left: auto;
		margin-right: auto;
	}
	.process_arrow_div{
		width: 30px;
	}
	.process_item{
		width: 140px;
	}
	.process_ball{
		width: 140px;
		height: 140px;
		padding-top: 15px;
	}
	.psy_banner{
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.psyb_title_div{
		width: 100%;
		padding-right: 0;
		margin-bottom: 30px;
	}
	.psyb_info{
		flex: 0 0 auto;
		width: 100%;
		margin-bottom: 30px;
	}
	.psyb_btn_div{
		width: 100%;
		padding-left: 0;
	}
}

/* md */
@media (max-width: 767px){
	.show-md{display: block;}
	.hide-md{display: none;}
	
	/* index */
	.kv_bg{
		height: 400px;
	}
	.kv_con{
		top: 90px;
	}
	.kv_con_in{
		position: relative;
		width: 100%;
		right: 0;
	}
	.kv_title{
		font-size: 32px;
		text-align: center;
	}
	.kv_icon_01{
		top: -30px;
		left: 0;
		width: 40px;
	}
	.kv_icon_02{
		top: 20px;
		right: -10px;
		width: 26px;
	}
	.kv_row{
		justify-content: center;
		margin-left: -10px;
		margin-right: -10px;
	}
	.kv_item{
		width: 33.33%;
		padding-left: 10px;
		padding-right: 10px;
		margin-bottom: 20px;
	}
	.index_banner{
		padding-top: 10px;
	}
	.index_title{
		font-size: 18px;
		letter-spacing: 0;
		margin-bottom: 20px;
	}
	.index_banner{
		padding-bottom: 30px;
	}
	.main_sec{
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.sec_title_en{
		margin-bottom: 30px;
	}
	.news_row{
		margin-bottom: 0;
	}
	.index_course{
		background: none;
		background-color: #f9f4ee;
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.course_row{
		margin-bottom: 0;
	}
	.index_donation{
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.donation_left{
		padding-top: 0;
		padding-bottom: 30px;
	}
	.donation_title{
		font-size: 24px;
		margin-bottom: 30px;
	}
	.donation_title span{
		font-size: 32px;
	}
	.footer_logo_div{
		height: auto;
		margin-bottom: 10px;
	}
	.footer_logo{
		width: 190px;
	}
	.footer_item{
		width: 50%;
	}
	.footm_title_div{
		height: 45px;
	}
	
	/* news */
	.page_kv{
		height: 300px;
		overflow: hidden;
	}
	.page_kv_con{
		padding-top: 80px;
		padding-bottom: 0;
	}
	.sort_btn{
		width: 33.33%;
	}
	.kv_title_icon{
		width: 30px;
		top: -30px;
		right: -35px;
	}
	.page_kv_title{
		font-size: 30px;
	}
	.page_kv_title_en{
		font-size: 22px;
		letter-spacing: 2px;
	}
	.page_kv_text{
		position: relative;
		right: 0;
		margin-top: 30px;
		margin-left: auto;
		margin-right: auto;
	}
	.news{
		padding-top: 30px;
		padding-bottom: 50px;
	}
	.sort_row{
		margin-bottom: 50px;
	}
	.sort_btn{
		font-size: 15px;
	}
	.news_text{
		padding-bottom: 50px;
	}
	
	/* course */
	.course_sel_div{
		margin-bottom: 30px;
	}
	.course_sel_item{
		width: 50%;
	}
	.course_sel{
		font-size: 15px;
		padding: 9px 12px
	}
	.course_search{
		font-size: 15px;
		padding: 9px 25px 9px 12px;
	}
	.icon_search{
		top: 10px;
		right: 6px;
	}
	
	/* about */
	.about_title{
		font-size: 22px;
		margin-bottom: 30px;
	}
	.about_mark{
		background: none;
		background-color: #f9f4ee;
		padding-top: 30px;
		padding-bottom: 30px;
		margin-top: 20px;
		margin-bottom: 0;
	}
	.about_logo{
		width: 200px;
	}
	.loc_sec{
		padding-top: 30px;
	}
	.loc_item{
		margin-bottom: 20px;
	}
	.award{
		padding-top: 40px;
		padding-bottom: 60px;
	}
	.award_row{
		padding-bottom: 0;
		margin-bottom: 20px;
	}
	.award_line{
		left: 15px;
	}
	.award_item{
		width: 100%;
		margin-bottom: 40px;
	}
	.award_item:nth-child(odd){
		padding-left: 25px;
		padding-right: 0;
	}
	.award_item:nth-child(odd) .award_point{
		left: -8px;
		right: auto;
	}
	.award_item:nth-child(even){
		top: 0;
		padding-left: 25px;
	}
	.award_point{
		top: 6px;
	}
	.award_year{
		font-size: 26px;
		margin-bottom: 20px;
	}
	.award_year span{
		font-size: 22px;
	}
	
	/* service */
	.service_slogan_sec{
		padding-top: 50px;
		padding-bottom: 40px;
	}
	.service_slogan{
		font-size: 17px;
	}
	.service_slogan .ec_green{
		font-size: 21px;
	}
	.service_slogan .ec_red{
		font-size: 21px;
	}
	.ser_item{
		margin-bottom: 50px;
	}
	.process_row{
		margin-top: 30px;
	}
	.process_item{
		width: 100%;
	}
	.process_ball{
		width: 160px;
		height: 160px;
		padding-top: 25px;
		margin-left: auto;
		margin-right: auto;
	}
	.process_arrow_div{
		width: 100%;
		padding: 25px 0;
	}
	.process_arrow{
		transform: rotate(90deg);
	}
	.price_frame{
		padding: 10px;
	}
	.price_item{
		padding: 15px;
	}
	.cst_sitem{
		padding-left: 15px;
		padding-right: 15px;
	}
	.cst_simg{
		border-radius: 30px;
	}
	.sloc_item{
		margin-bottom: 40px;
	}
	.psy_sort_sec{
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.psyb_title{
		font-size: 22px;
	}
}

/* sm */
@media (max-width: 575px){
	.show-sm{display: block;}
	.hide-sm{display: none;}
}