@import url('/css/fontawesome-all.css');
@import url('/css/font-awesome.min.css');
@import url('/css/fontawesome.min.css');
@import url('/css/SeoJump.css');
@import url('/css/contentBuilder.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&family=Noto+Sans+SC:wght@100;300;400;500;700;900&family=Montserrat:wght@100;200;300;400;500&display=swap');

* { margin: 0; padding: 0; }
*:focus { outline: none; }

body { margin: 0; }
body ::selection { background: #191919; text-shadow: none; color: #fff; }
body::-webkit-scrollbar { width: 5px; }
body::-webkit-scrollbar-track { background: #c0c0c0; }
body::-webkit-scrollbar-thumb { background: #191919; }
body::-webkit-scrollbar-thumb:hover { background: #000; }

header, footer, div, nav, article, h2, h3, h4, h5, h6, hr, p, form, label, input, textarea, ul, li, img, span, font, strong, b, a, i{ text-align: left; vertical-align: middle; margin: 0; padding: 0; line-height: 170%; border-width: 0; font-family: 'Montserrat', 'Noto Sans TC', 'Noto Sans SC', sans-serif; font-size: 16px;     word-wrap: break-word; word-break: keep-all; -webkit-transition: all .3s ease-out; -moz-transition: all .3s ease-out; -ms-transition: all .3s ease-out; -o-transition: all .3s ease-out; transition: all .3s ease-out; }

:before , :after { -webkit-transition: all .3s ease-out; -moz-transition: all .3s ease-out; -ms-transition: all .3s ease-out; -o-transition: all .3s ease-out; transition: all .3s ease-out; }

ul, ol { list-style: none; }

fieldset { border: 0; }

input,button,select,textarea { outline:none }

img { max-width: 100%; }

a , a:link , a:visited , a:hover { display: inline-block; text-decoration: none; }

.text-clamp , a.text-clamp { overflow: hidden; height: 27px; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1; }

/* a.photo */
a.photo , .bgBox { overflow: hidden; background: no-repeat 50% / cover; display: block; }

/* svg */
svg.arrow { width: 15px; }
svg.arrow.white { fill: #fff; }
svg.show { width: 8px; }

/* fancybox */
[class^="fancybox-"] , [class^="fancybox-"] * , .slick-track , .fa , .fas , .fa:before , .fas:before , .fa:after , .fas:after { -webkit-transition: none; -moz-transition: none; -ms-transition: none; -o-transition: none; transition: none; }

/* slick-slider */
.wrapper .slick-slider { margin-bottom: 0; }

/* webBox */
.webBox { position: relative; overflow: hidden; width: 100%; }
.webBox .pageh1 { position: absolute; top: 0; z-index: 1; }
.webBox .wrapper { position: relative; background: #fff; z-index: 2; }

/* workframe */
.workframe { position: relative; margin: 0 auto; width: 1440px; font-size: 0; z-index: 1; }

/* Sitemap */
#Sitemap #jsonUL a { display: block; font-size: 0; color: #000; }
#Sitemap #jsonUL a * { display: inline-block; line-height: 170%; font-size: 16px; vertical-align: top; }
#Sitemap #jsonUL a font { width: calc(100% - 15px); }
#Sitemap #jsonUL p a { font-size: 22px; }

/* header */
header { position: fixed; width: 100%; z-index: 999; }
header:before { position: absolute; width: 100%; height: 100%; display: block; top: 0; left: 0; z-index: 90; content: ""; }
header .barBox { position: relative; padding: 10px 60px; width: calc(100% - 120px); display: flex; z-index: 999; }
header .barBox a { display: inline-block; color: #fff; }
header #cis { margin: 0 auto 0 0; width: 180px; }
header #cis img { width: 100%; height: 44px; object-fit: contain; }
header .rightBox >div { margin-left: 15px; display: inline-block; line-height: 50px; }
header #searchBox form { position: absolute; background: rgb(0 0 0 / .7); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); font-size: 0; right: -500px; }
header #searchBox form input { padding: 5px 10px; width: 150px; background: none; display: inline-block; color: #fff; vertical-align: middle; }
header #searchBox form a { padding: 5px 10px; display: inline-block; vertical-align: middle; color: #fff; }
header #toolbar a { display: inline-block; }
header #menuIcon a { -webkit-transition: none; -moz-transition: none; -ms-transition: none; -o-transition: none; transition: none; }
header #menuIcon a font.btn { position: relative; margin-right: 10px; width: 20px; height: 17px; display: inline-block; }
header #menuIcon a font.btn span { position: absolute; width: 100%; height: 1px; background: #fff; display: block; top: 0; right: 0; }
header #menuIcon a[data-type="1"] font.btn span:nth-child(2) { top: calc(50% - 1px); }
header #menuIcon a[data-type="1"] font.btn span:nth-child(3) { top: calc(100% - 1px); }
header #menuIcon a[data-type="1"] font.btn span { transition: transform .4s cubic-bezier(.215,.61,.355,1),opacity .4s cubic-bezier(.215,.61,.355,1), -webkit-transform .4s cubic-bezier(.215,.61,.355,1); }
header #menuIcon a[data-type="2"] font.btn span { transition: .4s cubic-bezier(.645,.045,.355,1); }
header #menuIcon a[data-type="2"] font.btn span:nth-child(1) { top: 50%; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
header #menuIcon a[data-type="2"] font.btn span:nth-child(2) { opacity: 0; }
header #menuIcon a[data-type="2"] font.btn span:nth-child(3) { top: 50%; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }
header #menuBox { overflow: hidden; position: fixed; padding: 0 5vw; width: 90vw; height: 0; background: #1f1f1f; right: 0; top: 0; opacity: 0; z-index: -1; }
header #menuBox[data-type="2"] { padding: 15vh 5vw 0; height: 100vh; font-size: 0; opacity: 1; z-index: 998; }
header #menuBox .box >ul { padding-bottom: 15vh; }
header #menuBox .box >ul >li { padding: 0 20px; }
header #menuBox .box >ul >li:last-child { border-bottom: 0; }
header #menuBox .box >ul >li >p ,
header #menuBox .box ul li .menu_body ul li .bo { position: relative; }
header #menuBox .box ul li .menu_body ,
header #menuBox .box ul li .menu_body >ul li .sub2Option ,
header #menuBox .box ul li .menu_body >ul li .sub3Option { margin-bottom: 15px; display: none; -webkit-transition: none; -moz-transition: none; -ms-transition: none; -o-transition: none; transition: none; }
header #menuBox .box >ul >li >p a { padding: 10px 0; display: block; font-weight: 300; font-size: 22px; color: #fff; }
header #menuBox .box ul li b { position: absolute; padding: 5px 0; width: 23px; display: inline-block; text-align: center; color: #fff; top: calc((100% - 33px) / 2); right: 0; }
#menuBox .box ul li .menu_body >ul li .sub2Option { margin: 5px 0 15px; padding: 5px 15px; background: #3a3a3a; }
header #menuBox .box ul li .menu_body >ul li a { padding: 4px 0; display: block; font-size: 18px; color: #9b9b9b; }
header #menuBox .box ul li .menu_body .sub2Option a { color: #fff; }
header #menuBox .box ul li .menu_body .sub3Option a { color: #8b8b8b; }
header #menuBox .box ul li .menu_body .sub3Option a:before { content: "- "; }
header #menuBox .contactBox ul { padding: 20px 30px; border: 1px #353535 solid; }
header #menuBox .contactBox ul li { padding: 10px 15px; border-bottom: 1px #353535 solid; }
header #menuBox .contactBox ul li:last-child { border-bottom: 0; }
header #menuBox .contactBox ul li h4 { font-size: 16px; color: #676767; }
header #menuBox .contactBox ul li p a { padding: 5px 0; display: inline-block; font-size: 18px; color: #fff; }
header #menuBox .contactBox ul li p i { margin-right: 10px; font-size: 18px; display: inline-block; color: #ffb8b8; }
header #menuBox .contactBox ul li.community a { margin: 15px 10px 5px 0; width: 40px; height: 40px; border: 1px #bbb solid; border-radius: 50%; display: inline-flex; justify-content: center; align-items: center; color: #bbb; }
header #menuBox .contactBox ul li.community a i { font-size: 14px; }
header #menuBox .contactBox ul li.community a svg { width: 60%; height: 60%; fill: #bbb; }

header.headerfixed:before { background: #fff; }
header.headerfixed a { color: #1f1f1f; }
header.headerfixed #menuIcon a font.btn span { background: #1f1f1f; }
header.open:before { background: #1f1f1f; z-index: 999; }
header.open a { color: #fff; }
header.open #menuIcon a font.btn span { background: #fff; }

/* sPictureBox */
#sPictureBox { padding: 5vw 0; }
#sPictureBox .list { position: relative; }
#sPictureBox .list a { position: absolute; width: calc(100% - 60px); height: 100%; display: block; top: 0; left: 30px; z-index: 3; }
#sPictureBox .list .img { position: relative; margin: 0 30px; z-index: 1; }
#sPictureBox .list .img img { width: 100%; height: 200px; object-fit: cover; }
#sPictureBox .list .txt { position: absolute; padding: 65px 5%; width: calc(90% - 60px); background: -moz-linear-gradient(left,  rgba(240,244,247,1) 25%, rgba(240,244,247,0) 100%); background: -webkit-linear-gradient(left,  rgba(240,244,247,1) 25%,rgba(240,244,247,0) 100%); background: linear-gradient(to right,  rgba(240,244,247,1) 25%,rgba(240,244,247,0) 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f0f4f7', endColorstr='#00f0f4f7',GradientType=1 ); top: 0; left: 30px; z-index: 2; }
#sPictureBox .list .txt h4 { width: 55%; height: 40px; font-weight: 400; font-size: 24px; color: #1f1f1f; }
#sPictureBox .list .txt .more { margin-top: 5px; text-align: left; }
#sPictureBox .list .txt .more font { margin-right: 10px; text-align: center; font-family: 'Montserrat', 'Noto Sans TC', sans-serif; font-weight: 500; text-transform: uppercase; letter-spacing: .7px; font-size: 13px; color: #1f1f1f; }

/* footer */
footer { padding-top: 5vw; background: #1f1f1f; color: #9a9a9a; }
footer a { color: #9a9a9a; }
footer .wbox { width: 1400px; margin: auto; }
footer #flogo , footer #fnav { margin-bottom: 20px; text-align: center; }
footer #fnav a { padding: 10px 25px; display: inline-block; font-size: 18px; color: #fff; }
footer #footerinfo { margin-top: 20px; }
footer #footerinfo ul { margin-bottom: 20px; font-size: 0; }
footer #footerinfo ul li { position: relative; margin: 0 20px 3px; width: calc((100% / 3) - 40px); display: inline-block; }
footer #footerinfo ul li.plus-information img { position: absolute; max-width: 150px; bottom: 100%; left: 0; z-index: 8; max-height: 150px; display: none; }
footer #footerinfo .copyright { text-align: right; }
footer #footerinfo .copyright >div { margin-left: 10px; display: inline-block; font-size: 14px; color: #606060; }
footer #footerinfo .copyright .text { color: #fff; }

/* gotop */
#gotop { position: fixed; right: 20px; bottom: 95px; z-index: 99; }
#gotop a { padding: 20px 0 0 10px; border-left: 1px #fff solid; letter-spacing: .3em; font-weight: 300; font-size: 12px; color: #fff; white-space: nowrap; -webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; }
#gotop[data-type="1"] a { border-color: #000; color: #000; }

/* webSeo */
#webSeo { position: relative; overflow: hidden; margin-top: 40px; padding: 10px 0; }
#webSeo .js-marquee-wrapper * , #webSeo .js-marquee * , #webSeo .seo * { font-weight: 100; font-size: 13px; color: #959595; -webkit-transition: none; -moz-transition: none; -ms-transition: none; -o-transition: none; transition: none; }

/* SeoStarRating */
#SeoStarRating font { margin-right: 5px; display: inline-block; vertical-align: bottom; }
#SeoStarRating font:first-child { line-height: 130%; font-weight: bold; font-size: 18px; color: #FF9800; }
#SeoStarRating font:nth-child(2) { font-size: 16px; color: #FF9800; }
#SeoStarRating font:last-child { color: #383838; }

@media screen and (max-width: 1500px){
	.workframe , footer .wbox { width: 90%; }
}
@media screen and (min-width: 1281px){
	header #menuBox .box { overflow-y: scroll; width: 450px; height: 85vh; display: inline-block; }
	header #menuBox .box::-webkit-scrollbar { width: 0; }
	header #menuBox .contactBox { margin-left: calc(100% - 880px); width: 430px; display: inline-block; }
	footer #footerinfo ul li.plus-information:hover img { display: block; }
	#gotop a:hover { padding: 0 0 20px 10px; }
}
@media screen and (max-width: 1280px){
	header .barBox { padding: 10px 5%; width: 90%; }
	header #menuBox[data-type="2"] { overflow-y: scroll; height: 85vh; }
	header #menuBox[data-type="2"]::-webkit-scrollbar { width: 0; }
	header #menuBox .contactBox ul { padding: 0 0 15vh; border: 0; }
	footer #footerinfo ul li { margin: 0 10px 3px; width: calc(50% - 20px); }
}
@media screen and (max-width: 600px){
	footer { padding-bottom: 50px; }
	footer #footerinfo ul li { width: calc(100% - 20px); }
	footer #footerinfo .copyright { text-align: left; }
	header .rightBox .mb { position: fixed; margin-left: 0; width: 25%; background: #1f1f1f; line-height: 100%; left: 0; bottom: 0; }
	header .rightBox #searchBox { left: 25%; }
	header .rightBox #translateLink { left: 50%; }
	header .rightBox #oredericon { left: 75%; }
	header .rightBox .mb >a { padding: 10px 0; display: block; border-left: 1px #373737 solid; text-align: center; color: #fff; }
	header .rightBox #linelink { line-height: 47px; }
	header .rightBox #linelink a { margin: auto; padding: 5px 5% 4px; width: 90%; border-left: 0; display: inline-block; line-height: 140%; font-size: 14px; }
	header #searchBox form { position: fixed; bottom: 60px; }
}
@media screen and (max-width: 382px){
	header .rightBox #linelink { line-height: 46px; }
}