@charset "UTF-8";
/*Noto Sans TC-黑體*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700;900&display=swap');

body {
	margin: 0;
	padding: 0;
}

#social_area img {
	vertical-align: middle;
	border-style: none;
}

#social_area {
	font-family: 'Noto Sans TC', sans-serif !important;
	font-weight: 400;
	overflow: hidden;
}

#social_area * {
	box-sizing: border-box;
}

/* #social_area ul{	padding: 0;	list-style: none !important;} */

a,
a:focus,
a:hover {
	text-decoration: none;
	outline: none;
}

a.toggle {
	cursor: pointer !important;
}

.middle {
	display: -ms-flexbox !important;
	display: flex !important;
	-ms-flex-align: center !important;
	align-items: center !important;
	-ms-flex-pack: center !important;
	justify-content: center !important;
}

@media screen and (min-width: 576px) {
	.type_ph {
		display: none !important;
	}
}

@media screen and (max-width: 575px) {
	.type_pc {
		display: none !important;
	}
}

/*桌機板*/
.head{ width:100%; padding:1%; height:auto;
		text-align:center;	font-weight:bold;
	background-color:#000000;  }


.head a{  padding:1%; 
		font-size:24px;text-decoration:none;
		text-align:center;	font-weight:bold;
 color:#FFFFFF;}

.head a:hover{ 
    transform:translate(0,5px); color:#EDDB5F;
    box-shadow:1px 1px 15px rgba(20%,20%,40%,0.5);
	}

/*圖片切換*/
.head .pic{
	width:100%;
	margin:0 auto;
	max-width: 1200px;
	padding:0;
	text-align:center;}
	
.head .pic-m{
	width:0;
	height:0;
	overflow:hidden;}


/*按鈕*/
/************************************/
section#social_area {
	padding: 0 !important;
	margin: 0 !important;
}

#socail_icon_box {
	position: absolute;
	left: 0.5em;
	left: 0.5em;
	top: 12.5em;
	display: -ms-flexbox !important;
	display: flex !important;
	-ms-flex-align: start !important;
	align-items: flex-start !important;
	-ms-flex-direction: column !important;
	flex-direction: column !important;
	z-index: 2500;
	-o-transition: top 0.35s;
	-moz-transition: top 0.35s;
	-webkit-transition: top 0.35s;
	transition: top 0.35s;
}

#socail_icon_box.scrolll {
	position: fixed;
}

/* 
#socail_icon_box:hover {
	opacity: 1;
} 
*/
#socail_icon_box a {
	padding: 0.5em 0.15em 0.8em 0.15em;
	width: 4.4em;
	left: 0;
	border-top-right-radius: 0.5em;
	border-bottom-right-radius: 0.5em;
	position: relative;
	-o-transition: right 0.35s;
	-moz-transition: right 0.35s;
	-webkit-transition: right 0.35s;
	transition: right 0.35s;
	margin-bottom: 0.5em;
	text-align: center;
}

/* #socail_icon_box a img {
	filter: drop-shadow(2px 2px 2px #6e6e6e);
} */
#socail_icon_box a p {
	color: rgba(255, 247, 240, 0);
	line-height: 1;
	font-size: 0.9em;
	font-weight: 300;
	letter-spacing: 6px;
	margin: 0.4em;
	display: block;
}

#socail_icon_box a:hover p {
	color: #009590;
}

@media screen and (max-width: 575px) {
	#socail_icon_box {
		background-color: #009590;
		position: fixed;
		top: unset;
		left: 0;
		bottom: 0;
		width: 100%;
	}

	#socail_icon_box a {
		background-color: unset;
		padding: 0.5 0 0.5em;
		width: 100%;
		margin-bottom: 0em;
		box-shadow: unset;

		-ms-flex-pack: justify !important;
		justify-content: space-between !important;

		-ms-flex-align: center !important;
		align-items: center !important;

		-ms-flex-direction: column !important;
		flex-direction: column !important;
	}

	#socail_icon_box a img {
		width: 2.5em;
		position: absolute;
		top: 50%;
		left: 62%;
		transform: translateY(-50%);
	}

	#socail_icon_box a p {
		line-height: 2;
		font-size: 1.1em;
		letter-spacing: 2px;
		font-weight: 300 !important;
		display: inline-block;
		color: #fff;

		margin: 0 !important;
		padding: 0 !important;
		margin-block-start: 0 !important;
		margin-block-end: 0 !important;
	}

	.head{ width:100%; padding:1%;
	height:auto;
		text-align:center;
	font-weight:bold;
	background-color:#000000;  }

.head a{  padding:1vw; 
		font-size:4.5vw;
	line-height: 7vw;
		text-decoration:none;
		text-align:center;	
		font-weight:bold;
 color:#FFFFFF;}
.head .pic{
	width:0;
	height:0;
	overflow:hidden;}
.head .pic-m{
	display:block;
	width:100%;
	height:auto;
	margin:0;}
.head a:hover{ 
    transform:translate(0,5px); color:#EDDB5F;
    box-shadow:1px 1px 15px rgba(20%,20%,40%,0.5);
	}

}

/**/

/************************************/
/*展開內容*/
/************************************/

.coll_close {
	top: 0;
	right: 0;
	border-radius: 50%;
	color: #fff !important;
	padding: 15px;
	position: absolute;
	font-size: 2em;
	text-align: center;
	z-index: 2000 !important;
	overflow: hidden;
}

.coll_close:hover {
	cursor: pointer;
	transform: scale(1, 1);
	transition: 0.35s all;
	-webkit-transition: 0.35s all;
	-moz-transition: 0.35s all;
	-o-transition: 0.35s all;
	-ms-transition: 0.35s all;
}

.s_overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 30em;
	height: 100vh;
	opacity: 0;
	visibility: visible;
	transform: translateX(-30em);
	-o-transition: all .15s linear;
	-moz-transition: all .15s linear;
	-webkit-transition: all .15s linear;
	transition: all .15s linear;
	overflow: hidden;
	z-index: 10000;
	font-size: 1vw;
}

.s_overlay::before {
	content: '';
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-color: #003945;
	opacity: 0.95;
	position: absolute;
}

.s_overlay.s_open {
	visibility: visible;
	opacity: 1;
	transform: translateX(0em);
}

@media screen and (max-width: 1199px) {
	.s_overlay {
		font-size: 1vw;
	}
}

@media screen and (max-width: 768px) {
	.s_overlay {
		font-size: 2vw;
	}
}

@media screen and (max-width: 575px) {
	.s_overlay {
		top: 100vh !important;
		left: 0;
		width: 100%;
		font-size: 4vw;
		transform: translateX(0em);
		-o-transition: all .15s linear;
		-moz-transition: all .15s linear;
		-webkit-transition: all .15s linear;
		transition: all .15s linear;
	}

	.s_overlay.s_open {
		top: 0vh !important;
		width: 100%;
	}
}

/**/

/*****************************************/
/************** social_title *************/
/*****************************************/
.social_title h3,
.social_title h4,
.social_title h5,
.social_title h6,
.social_title p {
	line-height: 1.8;
	letter-spacing: 2px;
	color: #fff;
}

.social_title .s_brand {
	margin-bottom: 0;
	background-color: #23D9BD;
	color: inherit;
	padding: 0.1em 0.5em;
	display: inline-block;
	text-align: center;
	font-size: 18px;
}

.social_title .s_title {
	margin: 15px 0;
	line-height: 1.5;
	font-size: 20px;
}

/*****************************************/
/*************** social_con **************/
/*****************************************/
.social_title,
.social_con {
	position: relative;
}

.social_title {
	padding: 0 1.5em;
}

.social_con>ul {
	width: 100%;
	padding: 0;
	list-style: none;
}

.social_con>ul>li>a {
	display: block;
	margin-bottom: 1px;
	padding: 10px;
	color: #fff;
	background-color: #00858c;
	cursor: pointer;
}

.social_con>ul>li>a.arrow {
	position: relative;
}

.social_con>ul>li>a.arrow::after {
	content: "\f0da";
	position: absolute;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	right: 10px;
}

ul .opA::after {
	transform: rotate(90deg);
}

ul.open-MnavSub {
	display: block;
}

.nav-mobile-sub {
	padding: 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	list-style: none;
}

.nav-mobile-sub li {
	width: calc((100% - 8px) / 4);
	text-align: center;
	margin: 1px;
	font-size: 0.8vw;
}

.nav-mobile-sub li:hover a {
	transform: scale(.9);
	transition: all .15s ease-in-out;
}

.nav-mobile-sub a {
	display: block;
	padding: 5px 0;
	color: #333;
	background-color: #23D9BD;
	border-radius: 5px;
}


@media screen and (max-width: 1399px) {
	.social_con>ul>li>a {
		font-size: 1em;
	}
}

@media screen and (max-width: 1199px) {}

@media screen and (max-width: 575px) {
	.social_con {
		font-size: 2vw;
	}

	.social_con>ul>li>a {
		font-size: 2em;
	}

	.social_title {
		padding: 0;
	}

	.social_title .s_title {
		font-size: 16px;
	}

	.nav-mobile-sub li {
		width: calc((100% - 6px) / 3);
		font-size: 1.8em;
	}
}

/*****************************************/
/**************   line_line  *************/
/*****************************************/
#line_line .overlay-con {
	padding: 3.5em 0;
}

@media screen and (max-width: 575px) {
	#line_line .overlay-con {
		padding: 0 1em 2em;
		position: absolute;
		bottom: 0;
	}
}

/**/

/**************   onlinept  *************/
ul.onlinept {
	display: -ms-flexbox !important;
	display: flex !important;
	-ms-flex-wrap: wrap !important;
	flex-wrap: wrap !important;
	-ms-flex-pack: justify !important;
	justify-content: center !important;
	-ms-flex-item-align: start !important;
	align-self: flex-start !important;
	/**/
	background-color: rgba(0, 0, 0, 0.4);
	border-radius: 1em;
	margin-top: 2em;
	padding: 0 1em;
}

.social_con ul.onlinept li {
	width: calc(100% / 3);
	margin: 0.6em 0;
}

.social_con ul.onlinept li.br_w {
	border-right: 1px solid rgba(255, 255, 255, 0.6);
}

.social_con ul.onlinept li a {
	color: #cfcfcf;
	background-color: rgba(0, 0, 0, 0);
	width: 100%;
	font-weight: 300;
	font-size: 0.9em;
	border: 0;
	line-height: 1.2;
	padding: 0.4em 0 !important;
}

.d-i-block {
	display: inline-block !important;
}

@media screen and (max-width: 575px) {
	.social_con ul.onlinept li {
		width: calc(100% / 3);
		margin: 1em 0;
	}

	.social_con ul.onlinept li a {
		padding: 0 !important;
		font-size: 1.5em;
	}
}

/**/

/************   #END_onlinept  **********/

/************************************/
/*按鈕特效*/
/************************************/

@keyframes sheen {
	0% {
		transform: skewY(-45deg) translateX(0);
	}

	100% {
		transform: skewY(-45deg) translateX(12.5em);
	}
}

a.shine {
	color: rgba(54, 50, 44, 0.8);
	/*border: 2px solid hsl(155, 10%, 23%);*/
	position: relative;
	overflow: hidden;
	-o-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-webkit-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}

a.shine:before {
	content: '';
	background-color: rgba(255, 255, 255, 0.3);
	height: 100%;
	width: 3em;
	display: block;
	position: absolute;
	top: 0;
	left: -4.5em;
	transform: skewX(-45deg) translateX(0);
	-o-transition: none;
	-moz-transition: none;
	-webkit-transition: none;
	transition: none;
}

a.shine:hover {
	background-color: #23D9BD;
	color: #003945;
}

a.shine:hover:before {
	transform: skewX(-45deg) translateX(13.5em);
	-o-transition: all 0.4s ease-in-out;
	-moz-transition: all 0.4s ease-in-out;
	-webkit-transition: all 0.4s ease-in-out;
	transition: all 0.4s ease-in-out;
}