/* bootstrap 5 fix */
@media (prefers-reduced-motion: no-preference) {
	:root {scroll-behavior: auto;}
}
:root{
	--ch2: "Noto Serif TC", serif;
}
*{
	position: relative;
	box-sizing: border-box;
}
body{
	margin: 0;
	font-family: 'Noto Sans TC', sans-serif;
	background-color: #f4f4f4;
	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;}
.ch2{
	font-family: "Noto Serif TC", serif;
}

/* 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: #15655c;
	transition: opacity 0.5s;
	opacity: 0.95;
}
.menu{
	height: 100%;
	padding-left: 200px;
	padding-right: 200px;
}
.menu_row{
	height: 100%;
	justify-content: center;
}
.menu_item{
	height: 100%;
	padding-left: 30px;
	padding-right: 30px;
}
.menu_btn{
	display: block;
	height: 100%;
	font-size: 18px;
	color: #fff;
	padding-top: 26px;
}
.menu_btn:hover{
	color: #fbe887;
}
.menu_right{
	position: absolute;
	top: 0;
	right: 0;
	padding-top: 20px;
	padding-right: 25px;
}
.menur_row{
	align-items: center;
}
.menur_item{
	padding-left: 7px;
	padding-right: 7px;
}
.menur_ibtn{
	display: block;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: #ddd;
	overflow: hidden;
}
.menur_ibtn img{
	width: 20px;
	height: 20px;
	top: 50%;
	transform: translateY(-50%);
	margin-left: auto;
	margin-right: auto;
}
.menur_ibtn:hover{
	background-color: #0866ff;
}
.menur_ibtn:hover img{
	left: -1000px;
    filter: drop-shadow(1000px 0 #fff);
}
.menur_btn{
	display: block;
	width: 110px;
	font-size: 17px;
	color: #000;
	text-align: center;
	background-color: #fbe887;
	border-radius: 30px;
	padding: 6px 0 5px;
}
.menur_btn:hover{
	color: #000;
	background-color: #fff;
}
.header_logo{
	position: absolute;
	top: 23px;
	left: 20px;
	width: 150px;
}
.mobile_btn{
	position: absolute;
	top: 17px;
	right: 20px;
	cursor: pointer;
	display: none;
}

/* index */
.kv{
	height: 700px;
}
.kv_op{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.kv_idle{
	height: 100%;
	display: none;
}
.kv_bg{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.kv_title_div{
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	transform: translateY(-50%);
}
.kv_title{
	margin-left: auto;
	margin-right: auto;
}
.sec_menu{
	padding-top: 20px;
	padding-bottom: 20px;
}
.main_sec{
	padding-top: 50px;
	padding-bottom: 50px;
}
.sec_title_div{
	text-align: center;
	margin-bottom: 40px;
}
.sec_title{
	display: inline-block;
	font-size: 30px;
	color: #2B9B8E;
	font-weight: 500;
	padding-bottom: 12px;
	border-bottom: 4px solid #2B9B8E;
}
.main_text{
	line-height: 1.8em;
}
.about_text{
	font-size: 18px;
	text-align: center;
	letter-spacing: 1px;
}
.about_text .ec{
	color: #15655c;
	font-weight: bold;
}
.title2{
	font-size: 22px;
	color: #cc9785;
	font-weight: 600;
	letter-spacing: 1px;
	text-align: center;
	margin-bottom: 20px;
}
.title3{
	font-size: 22px;
	color: #064039;
	font-weight: 500;
	text-align: center;
	margin-bottom: 15px;
}
.bg_info{
	background-image: url(../img/bg_info.jpg);
	background-repeat: repeat-x;
	background-position: top center;
}
.theme_sub{
	font-size: 18px;
	text-align: center;
	margin-bottom: 30px;
}
.theme_con{
	max-width: 896px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
}
.theme_item{
	margin-bottom: 30px;
}
.theme_icon{
	width: 200px;
	border-radius: 30px;
	box-shadow: 2px 2px 8px #ccc;
	margin-left: auto;
	margin-right: auto;
}
.theme_title{
	position: absolute;
	bottom: 10px;
	left: 0;
	width: 100%;
	font-size: 22px;
	color: #fff;
	font-weight: bold;
	text-align: center;
	margin-bottom: 5px;
}
.theme_text{
	padding-top: 10px;
	text-align: center;
}
.group_con{
	max-width: 896px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
}
.group_row{
	justify-content: space-between;
}
.group_item{
	margin-bottom: 24px;
}
.group_icon{
	width: 200px;
	height: 200px;
	border-radius: 30px;
	background: linear-gradient(#217e70, #2b9b8f);
	box-shadow: 2px 2px 8px #ccc;
	padding-top: 50px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
}
.group_icon img{
	width: 100px;
	margin-left: auto;
	margin-right: auto;
}
.group_title{
	font-size: 22px;
	color: #064039;
	font-weight: 500;
	text-align: center;
}
.groupb_form{
	font-size: 17px;
	color: #a27464;
	font-weight: 500;
	text-align: center;
	margin-bottom: 20px;
}
.groupb_sub{
	font-weight: 500;
	text-align: center;
	margin-bottom: 10px;
}
.groupb_text{
	height: 120px;
	color: #15655c;
	line-height: 1.7em;
	margin-bottom: 20px;
}
.group_scope_row{
	margin-left: -2px;
	margin-right: -2px;
}
.gbs_item{
	width: 33.33%;
	padding-left: 2px;
	padding-right: 2px;
	margin-bottom: 4px;
}
.gbs_item > div{
	font-size: 14px;
	padding: 4px;
	border-radius: 5px;
	background-color: #eec870;
}
.main_ul{
	padding-left: 25px;
}
.rule_con{
	max-width: 560px;
	margin-left: auto;
	margin-right: auto;
}
.w860{
	max-width: 860px;
	margin-left: auto;
	margin-right: auto;
}
.w920{
	max-width: 920px;
	margin-left: auto;
	margin-right: auto;
}
.score_box{
	height: 100%;
	border-radius: 10px;
	border: 1px solid #cc9785;
	background-color: #fff;
	padding: 20px 15px;
	box-shadow: 2px 2px 8px #ccc;
}
.score_img{
	width: 400px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px;
}
.group_cate_row{
	margin-left: -5px;
	margin-right: -5px;
}
.group_cate{
	width: calc(50% - 10px);
	font-size: 15px;
	color: #fff;
	padding: 5px 7px 5px 10px;
	border-radius: 10px;
	margin-left: 5px;
	margin-right: 5px;
	margin-bottom: 10px;
}
.group_cate_text{
	align-items: center;
	top: 50%;
	transform: translateY(-50%);
}
.group_cate_num{
	width: 36px;
	text-align: right;
}
.group_cate.t1{
	background-color: #fb2f84;
}
.group_cate.t2{
	background-color: #478ffd;
}
.group_cate.t3{
	background-color: #2b9b8d;
}
.group_cate.t4{
	background-color: #cc9785;
}
.award_row{
	justify-content: center;
	margin-top: 40px;
	margin-bottom: 50px;
}
.award_item{
	margin-bottom: 30px;
}
.award_box{
	height: 100%;
	border-radius: 10px;
	border: 1px solid #2B9B8E;
	background-color: #fff;
	padding: 20px 15px;
	box-shadow: 2px 2px 8px #ccc;
}
.award_icon{
	width: 50px;
	height: 50px;
	border-radius: 50%;
	padding-top: 10px;
	box-shadow: 2px 2px 6px #ccc;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
	overflow: hidden;
}
.award_icon img{
	width: 32px;
	margin-left: auto;
	margin-right: auto;
}
.award_icon.t1{
	background: linear-gradient(135deg, #ffdd67, #ffa800);
}
.award_icon.t2{
	background: linear-gradient(135deg, #dedede, #9b9b9b);
}
.award_icon.t3{
	background: linear-gradient(135deg, #deb88c, #a06520);
}
.award_icon.t4{
	background: linear-gradient(135deg, #74ecde, #23c1af);
}
.award_icon.t5{
	background: linear-gradient(135deg, #f493ca, #e0439d);
}
.award_ul{
	list-style-type: none;
	padding-left: 18px;
}
.award_ul li::before{
	position: absolute;
	content: "";
	top: 10px;
	left: -18px;
	width: 12px;
	height: 12px;
	background-image: url(../img/ul_arrow.png);
	background-repeat: no-repeat;
	background-size: contain;
}
.notice_box{
	border: 1px solid #ccc;
	border-radius: 10px;
	background-color: #fff;
	overflow: hidden;
}
.notice_con{
	height: 400px;
	padding: 15px;
	overflow-y: auto;
}
.date_frame{
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}
.date_item{
	border-radius: 10px;
	margin-bottom: 20px;
	overflow: hidden;
}
.date_date{
	width: 190px;
	font-size: 18px;
	color: #fff;
	background-color: #cc9785;
	padding: 15px;
}
.date_text{
	flex: 1;
	font-size: 18px;
	background-color: #fff;
	padding: 15px;
}
.sign_box{
	padding: 30px;
	background-color: #fff;
	border-radius: 20px;
	border: 1px solid #2B9B8E;
	box-shadow: 2px 2px 8px #ccc;
}
.sign_sub{
	font-size: 18px;
	color: #2B9B8E;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
}
.sign_row{
	max-width: 420px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
}
.sign_btn{
	display: block;
	width: 240px;
	font-size: 18px;
	color: #fff;
	text-align: center;
	background-color: #2B9B8E;
	padding: 13px 0;
	border-radius: 40px;
	border: 1px solid #2B9B8E;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px;
}
.sign_btn:hover{
	color: #2B9B8E;
	background-color: #fff;
}
.consent_btn{
	display: block;
	width: 240px;
	font-size: 18px;
	color: #fff;
	text-align: center;
	background-color: #cc9785;
	padding: 13px 0;
	border-radius: 40px;
	border: 1px solid #cc9785;
	margin-left: auto;
	margin-right: auto;
}
.consent_btn:hover{
	color: #cc9785;
	background-color: #fff;
}
.popu_item{
	margin-bottom: 40px;
}
.popu_row.show_3 .popu_item:nth-child(n+4){
	display: none;
}
.popu_box{
	display: block;
	height: 100%;
	color: #000;
	border-radius: 10px;
	border: 1px solid #2B9B8E;
	background-color: #fff;
	box-shadow: 2px 2px 8px #ccc;
	overflow: hidden;
}
.popu_img{
	padding-bottom: 56%;
	overflow: hidden;
}
.popu_img > img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}
.popu_view{
	position: absolute;
	bottom: 0;
	right: 0;
	font-size: 14px;
	color: #fff;
	padding: 5px 10px;
	background-color: #222;
	border-radius: 5px;
}
.popu_con{
	padding: 15px;
}
.popu_award{
	font-size: 15px;
	color: #a27464;
	font-weight: 500;
	margin-bottom: 5px;
}
.popu_name{
	font-size: 15px;
	color: #064039;
	font-weight: 500;
	margin-bottom: 10px;
}
.popu_title{
	font-size: 18px;
	font-weight: 500;
}
.popu_box:hover{
	color: #064039;
}
.popu_box:hover .popu_img > img{
	transform: scale(1.05);
}
.more_btn{
	display: inline-block;
	font-size: 15px;
	color: #000;
	letter-spacing: 0.5px;
	padding: 14px 36px;
	background-color: #fff;
	border-radius: 40px;
	border: 1px solid #ddd;
}
.more_icon{
	display: inline-block;
	width: 30px;
	height: 16px;
	top: 2px;
	border-radius: 20px;
	background-color: #2B9B8E;
	overflow: hidden;
	margin-left: 15px;
}
.more_btn:hover .more_icon{
	background-color: #212121;
}
.logos_row{
	justify-content: center;
}
.logos_item{
	width: 220px;
	padding-left: 12px;
	padding-right: 12px;
}
.logos_btn{
	display: block;
	width: 150px;
	margin-left: auto;
	margin-right: auto;
}
.logos_btn img{
	transition: transform 0.3s;
}
.logos_btn:hover img{
	transform: scale(1.05);
}
footer{
	padding: 20px 0;
	background-color: #69686d;
}
.footer_info{
	color: #fff;
	text-align: center;
	line-height: 2em;
}
.gotop{
	position: fixed;
	bottom: 90px;
	right: 26px;
	width: 40px;
	font-size: 16px;
	text-align: center;
	cursor: pointer;
	z-index: 9990;
}
.gotop > img{
	top: 7px;
}
.side_sign{
	position: fixed;
	bottom: 15px;
	right: 15px;
	width: 60px;
	height: 60px;
	font-size: 16px;
	color: #fff;
	text-align: center;
	letter-spacing: 1px;
	line-height: 1.2em;
	background-color: #2B9B8E;
	border: 1px solid #2B9B8E;
	border-radius: 10px;
	padding-top: 10px;
	cursor: pointer;
	z-index: 9990;
}
.side_sign:hover{
	color: #2B9B8E;
	background-color: #fff;
}
.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%;
}

/* setting */
.white{color: #fff;}
.red{color: #f00;}
.green{color: #15655c;}
.bg_white{background-color: #fff;}
.bg_gray{background-color: #EBF1F0;}
.mb-10{margin-bottom: 10px;}
.mb-20{margin-bottom: 20px;}
.mb-30{margin-bottom: 30px;}
.mb-40{margin-bottom: 40px;}

@media (max-width: 1400px){
	.kv{
		height: 500px;
	}
	.groupb_text{
		height: 140px;
	}
	.gbs_item{
		width: 50%;
	}
}

/* xl */
@media (max-width: 1199px){
	.show-xl{display: block;}
	.hide-xl{display: none;}
	.menu_item{
		padding-left: 20px;
		padding-right: 20px;
	}
	.kv_title{
		width: 500px;
	}
}

/* lg */
@media (max-width: 991px){
	.show-lg{display: block;}
	.hide-lg{display: none;}
	body{
		padding-top: 60px;
	}
	
	/* header */
	header{
		height: 60px;
	}
	.menu{
		position: absolute;
		top: 60px;
		left: 0;
		width: 100%;
		height: calc(100vh - 60px);
		padding: 20px 0;
		background-color: #15655c;
		overflow-y: auto;
		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 15px;
		text-align: center;
	}
	.menu_right{
		position: relative;
		padding-top: 40px;
		padding-right: 0;
	}
	.menur_row{
		justify-content: center;
	}
	.menur_btn{
		margin-left: auto;
		margin-right: auto;
	}
	.header_logo{
		width: 120px;
		top: 15px;
		left: 15px;
	}
	.mobile_btn{
		display: block;
	}
	
	.kv{
		height: 400px;
	}
	.theme_icon{
		border-radius: 20px;
	}
	.theme_title{
		font-size: 20px;
	}
	.group_icon{
		width: 150px;
		height: 150px;
		padding-top: 37px;
	}
	.group_icon img{
		width: 80px;
	}
	.group_title{
		font-size: 18px;
	}
	.groupb_text{
		height: auto;
	}
}

/* md */
@media (max-width: 767px){
	.show-md{display: block;}
	.hide-md{display: none;}
	.kv{
		height: 300px;
	}
	.kv_title{
		width: 220px;
	}
	.main_sec{
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.sec_title{
		font-size: 24px;
		padding-bottom: 10px;
	}
	.title2{
		font-size: 20px;
	}
	.title3{
		font-size: 20px;
	}
	.theme_sub{
		font-size: 16px;
		text-align: left;
	}
	.group_icon{
		width: 100px;
		height: 100px;
		border-radius: 15px;
		padding-top: 22px;
	}
	.group_icon img{
		width: 60px;
	}
	.group_title{
		font-size: 16px;
	}
	.notice_con{
		height: 360px;
		padding: 15px 10px;
	}
	.date_item{
		border-radius: 0;
	}
	.date_date{
		width: 160px;
		font-size: 16px;
		padding: 10px;
	}
	.date_text{
		flex: 0 0 auto;
		width: 100%;
		font-size: 16px;
		padding: 10px;
	}
	.gotop{
		bottom: 75px;
		right: 20px;
	}
	.sign_box{
		padding: 30px 15px;
	}
	.side_sign{
		width: 50px;
		height: 50px;
		font-size: 15px;
		padding-top: 6px;
	}
}

/* sm */
@media (max-width: 575px){
	.show-sm{display: block;}
	.hide-sm{display: none;}
	.logos_row{
		justify-content: flex-start;
	}
	.logos_item{
		width: 50%;
		margin-bottom: 10px;
	}
}