@charset "UTF-8";
* { margin: 0px; padding: 0px; box-sizing: border-box; }
a, a:link, a:visited, a:hover, a:active { text-decoration:none; }
img { border: 0px none; vertical-align:middle; }

body {
    padding:0;
    margin:0;
    color: #000000;
    font-family: '微軟正黑體', 'Microsoft JhengHei', Verdana, Helvetica, Arial, 'HeitiTC', 'Microsoft YaHei', sans-serif;
	font-size: 1rem;
	line-height: 1.6em;
	background: #ffffff; 
}

h1, .h1 { font-size: 2rem; line-height: 3.0rem; }
h2, .h2 { font-size: 1.8rem; line-height: 2.5rem; }
h3, .h3 { font-size: 1.2rem; line-height: 1.8rem; }
h4, .h4 { font-size: 1.1rem; line-height: 1.5rem;}
h5, .h5 { font-size: 9rem; line-height: 1.2rem; }
h6, .h6 { font-size: .8rem; line-height: 1rem; }

@media only screen and (max-width: 992px) {
html, body { font-size: 0.9rem;  }
}	

.font-sm { font-weight: 900; }
.font-lg { font-weight: 600; }
.font-xs { font-weight: 300; }
.italic { font-style: italic; }
/** 對齊 **/
.text-right { text-align: right;	}
.text-left { text-align: left;	}
.text-center { text-align: center; }
/** 引用 **/
.text-warning { color: #ff9326; }
.text-error { color: #d90036; }
.text-info { color: #00468c; }
.text-success { color: #00664c; }
/*****************************/
blockquote.quote_v1 {
    position: relative;
	width: 100%;
    font-family: Open Sans;
    font-style: italic;
    color: #555555;
	line-height: 1.6em;
    margin: 20px auto;
	padding: 1.2em 75px;
    border-left: 8px solid #4A4A4A;
    background: rgba(238,238,238,0.5);
	}
blockquote.quote_v1::before{
    position: absolute;
    left: 10px;
    top: .4em;
    font-family: Arial;
	content: "\201C";
    color: #4A4A4A ;
    font-size: 8em;
	}
blockquote.quote_v1::after{
    content: '';
	}

pre {
	position: relative;
	white-space: pre-line;
    padding: 5px 10px;
	margin: 10px 0%;
	background-color: #2f333d;
    border-radius: 4px;
    color: #D2D2D2;
	}
/***********************
Responsive RWD
***********************/
.page-container{ 
    width: 100%;
	max-width: 1280px;
    padding: 0 1%; 
    margin: 0 auto;
	word-wrap: break-word; 
	word-break: normal;
	}
@media screen and (max-width: 1920px) {
    .page-container{ width: 100%;}
}
@media screen and (max-width: 1280px) {
    .page-container{ width: 100%;}
}
.page-wrapper img, 
.page-container img { 
    max-width: 100%; 
	}

/************************
HEADER
************************/
footer, 
section.main-content,
section.main-navigation,
header {
	position: relative;
	display: inline-block;
	float: left;
	width: 100%;
    padding: 0px;
	}
header { 
    min-height: 60px;
	color: #dddddd;
	background: #ffffff; 
	box-shadow: 0 0 30px rgba(0,0,0,.07);
	z-index: 99;
	}	
/************************/
header .h-left {
	position: absolute;
	display: inline-block;
	width: 200px; 
	height: 60px;
	line-height: 60px;
	margin: 0px 0px;
	z-index: 5;
	}
header .h-left a,
header .h-left a:hover { 
	font-size: 1.2rem;
	font-weight: 900;
	color: #373646;
	}

header .h_logo {
	position: relative; 
	display: inline-block; 
	color: #373646;
	text-align: left;
	font-size: 18px;
	line-height: 60px;
	font-weight: 500;
	margin-right: 10px;
	padding: 0px;
	}
	
header .h-right {
	position: relative;
	display: inline-block;
	float: right;	
	padding: 10px 0px;
	padding-left: 220px;
    width: 100%;
	text-align: left;
	}

/****************************
開闔按鍵 
****************************/
.toggle-button {
	position: absolute;
    display: none;
	right: 0;
	top: 0px;
	width: 40px;
    height: 40px;
    padding: 12px 10px;
    margin: 10px;
    transition: .25s;
    z-index: 15;
	}
.toggle-button:hover { cursor: pointer; }
.toggle-button .menu-bar {
	position: relative;
    width: 100%;
    transition: .2s;
    }
.toggle-button .menu-bar-top {
    border: 2px solid #000000;
    border-bottom: none;
    top: 0px;
    }
.toggle-button .menu-bar-middle {
    height: 2px;
    background-color: #000000;
    margin: 5px 0px;
    top: 0px;
    }
.toggle-button .menu-bar-bottom {
    border: 2px solid #000000;
    border-top: none;
    top: 0px;
    }
.toggle-button.open .menu-bar-top { 
    transform: rotate(45deg) translate(5px, 5px);
    transition: .2s;
    }
.toggle-button.open .menu-bar-middle {
    transform: translate(0px);
    transition: .1s ease-in;
    opacity: 0;
    }
.toggle-button.open .menu-bar-bottom {
    transform: rotate(-45deg) translate(5px, -5px);
    transition: .2s;
    } 
	
@media only screen and (max-width: 992px) {
    .toggle-button { display: block; }
    body.overflow { overflow: hidden; }
}
/****************************
NAV-MENU
****************************/
.main-menu li { 
	position: relative;
	display: inline-block;
	width: 100%;
	font-size: 1.2rem;
	}
.main-menu li a, 
.main-menu li a:hover { 
	display: inline-block;
	width: 100%;
	padding: 5px 10px;
	color: #373646;
	}
.main-menu li a:hover { 
    background-color: rgba(238,238,238,0.85);
	}
	
@media only screen and (max-width: 992px) {
header .h-right { display: none; }
header .h-right.open { 
    position: absolute;
	display: inline-block;
	top: 60px;
	left: 0px;
	width: 100%;
	padding: 0px 0px;
	background-color: rgba(0,0,0,0.85);
	z-index: 999;
	}
.main-menu li { 
    width: 100%; 
	padding: 15px;
	}
.main-menu li + li { 
    border-top: 1px solid rgba(255,255,255,0.07);
    }
.main-menu li:hover { 
    background-color: rgba(0,140,140,0.85);
	}	

.main-menu li a, 
.main-menu li a:hover { color: #ffffff; }
}
/************************
MAIN-CONTENT
************************/
section.main-content { 
    padding: 30px 0px; 
	text-align: center;
	min-height: 500px;
	}
section.main-content .m_left,
section.main-content .m_right { 
	position: relative;
	display: inline-block;
	float: left;
	padding: 10px;
	}

section.main-content .m_left { 
	float: left;
	width: 24%;
	text-align: left;
	}
section.main-content .m_right { 
	float: right;
	width: 75%;
	}	
	
	
/************************/
.nav-menu .nav-right,
.nav-menu .nav-left,
.nav-menu { 
	position: relative;
	display: inline-block;
	float: left;
	}
.nav-menu { 
	width: 100%;
	padding: 8px 10px;
	text-align: left;
	color: #373646;
	}
.nav-menu a,.nav-menu a:hover { 
	color: #373646;
	}

.nav-menu i { 
	color: #cccccc; 
	font-size: .8rem;
	}

.nav-menu .nav-right { 
	float: right;
	width: 50%;
	max-width: 300px;
	}
.nav-menu .search { 
	width: 100%;
	max-width: 300px;
	}	
/************************/	
section.main-navigation { 
	padding: 25px 0px;
	text-align: left;
	color: #888888;
	background: #f6f6f6;
	}
section.main-navigation a, 
section.main-navigation a:hover { 
    color: #888888;
	}

	
/************************
FOOTER
************************/	
footer { 
    padding: 10px 0px;
	color: #333333; 
	background: #eeeeee;
	border-top: 1px solid rgba(255,255,255,0.07);
	}

footer .f-copy a:hover,
footer .f-copy a,
footer .f-copy { 
    color: #666666; 
	padding: 10px 0px;
	font-size: .8rem;
	text-align: center;
	}

/************************
LOGIN
************************/
#login {
    position: relative;
    display: inline-block;	
	width: 100%;
	padding-top: 50px;
	text-align: center;
	background: rgba(255,255,255, 1);
	z-index: 999;
	overflow: hidden;
}
#login .formlogin {
    position: relative;
    display: inline-block;	
    max-width: 400px;
    width: 98%;
	margin: 0 1%;
    padding: 20px 15px;
	text-align: left;
	background: #f8f8f8;
	box-shadow: 0 0 10px rgba(0,0,0,.0);
}
.formlogin input[type="submit"],
.formlogin input[name="user_mail"],
.formlogin input[name="user_pass"] {
    outline: 0;
    width: 100%;
    border: 0;
    padding: 0px 15px;
	line-height: 20px;
}
.formlogin input[name="user_mail"],
.formlogin input[name="user_pass"] {
    background: rgba(255, 255, 255,0.9);
	border: 1px solid rgba(204,204,204,0.4); 
}
.formlogin input[type="checkbox"] {
	vertical-align: middle;
	margin: 0 2px;
}
.formlogin h3,
.formlogin li {
    position: relative;
    display: inline-block;	
    width: 100%;
	min-height: 30px;
	padding: 5px 0px;
}
/************************
BLACK
************************/
.black_p01 {
	position: relative;
	display: inline-block;
	float: left;
	width: 100%;
	padding: 0px 0px;
	text-align: left;
	}
	
.black_p01 h2 {
	position: relative;
	display: inline-block;
	float: left;
	width: 100%;
	padding: 0px .5%;
	text-align: left;
	font-weight: 400;
	}
.black_p01 h2 i {
	position: relative;
	display: inline-block;
	color: #777777;
	font-size: 0.8rem;
	line-height: 1.5rem;
	}

.black_p01 li {
	position: relative;
	display: inline-block;
	float: left;
	width: 24%;
	margin: .5%;
	border-radius: 0px;
	
	}
.black_p01 li:hover {
    -webkit-transition: all .35s;
    transition: all .35s;
	}
	
.black_p01 li .p-view {
	position: relative;
	display: inline-block;
	width: 100%;
	height: 220px;
	line-height: 12vw;
	border-radius: 0px;
	background-color: #f7f7f7;
	/*max-height: 200px;*/
	background-repeat: no-repeat; /*不重覆*/
	background-position: center;
	-moz-background-size: 100% auto;
	-webkit-background-size: 100% auto;
	-o-background-size: 100% auto;
	background-size: 100% auto;
	overflow: hidden; 
	}
.black_p01 li img {
	display: inline-block;
	width: auto;
	min-height: 12vw;
	}	
.black_p01 li img,	
.black_p01 li .svg {
	-moz-background-size: auto 60%;
	-webkit-background-size: auto 60%;
	-o-background-size: auto 60%;
	background-size: auto 60%;
	overflow: hidden;

    -webkit-transition: all .35s;
    transition: all .35s;	
	}
	
.black_p01 li:hover img,	
.black_p01 li:hover .svg {
	/*background-position: 5% 5%;*/
	-moz-background-size: auto 61.5%;
	-webkit-background-size: auto 61.5%;
	-o-background-size: auto 61.5%;
	background-size: auto 61.5%;
	
    -webkit-transition: all .35s;
    transition: all .35s;
	}

.black_p01 li .p-note,
.black_p01 li .p-text {
	position: relative;
	display: inline-block;
	width: 100%;
	padding: 4px 5px;
	}	
.black_p01 li .p-text {
	height: 80px;
	word-wrap: break-word;
	color: #555555;
	overflow: hidden; 
	}

.black_p01 li .p-note {
	height: 30px;
	font-size: .8rem;
	line-height: 1.2rem;
	overflow: hidden; 
	}
	
.black_p01 li .dt {
	position: relative;
	display: inline-block;
	height: 25px;
	overflow: hidden;
	}	
.black_p01 li .dd {
	color: #bbbbbb;
	}

.black_p01 li .p-text span {
	position: relative;
	display: inline-block;
	font-size: .8rem;
	line-height: 1.2rem;
	margin: 3px 0px;
	margin-right: 2px;
	padding: 1px 5px;
	color: #cccccc;
	background-color: #ffffff;
	border-radius: 20px;
	}		
.black_p01 li .dd a.download {
	position: relative;
	display: inline-block;
	float: right;
	padding: 1px 5px;
	color: #ffffff;
	background-color: #cccccc;
	border-radius: 5px;
	}
.black_p01 li .dd a.download:hover {
	color: #ffffff;
	background-color: #e60013;
	}
	
.black_p01 li .p-note .pn_left,
.black_p01 li .p-note .pn_right {
	width: 100%;
	float: right;
	text-align: right;
	}

.black_p01 li a,
.black_p01 li a:hover {
	color: #555555;
	}

@media screen and (max-width: 992px) {
    .black_p01 li { width: 24%; }
	.black_p01 li .p-view {
	height: 24vw;
	line-height: 24vw;
	}
	.black_p01 li img {
	min-height: 24vw;
	}
}
@media screen and (max-width: 768px) {
	.black_p01 li { width: 32%;	}
	.black_p01 li .p-view {
	height: 32vw;
	line-height: 32vw;
	}
	.black_p01 li img {
	min-height: 32vw;
	}
}
@media screen and (max-width: 468px) {
	.black_p01 li { width: 49%;	}
	.black_p01 li .p-view {
	height: 45vw;
	line-height: 45vw;
	}
	.black_p01 li img {
	min-height: 45vw;
	}
}
/************************/
.black_p01 .box_s01 {
	position: relative;
	display: inline-block;
	width: 100%;
	padding: 0px;
	}
.black_p01 .box_s01 .p01_left,
.black_p01 .box_s01 .p01_right,
.black_p01 .box_s01 .p01_top {
	position: relative;
	display: inline-block;
	float: left;
	width: 100%;
	padding: 10px;
	}
.black_p01 .box_s01 .p01_left,
.black_p01 .box_s01 .p01_right {
	width: 50%;
	}
.black_p01 .box_s01 .p01_left img {
	width: 100%;
	}	
.black_p01 .box_s01 .p01_right h3 {
	padding-top: 15px;
	}
	
@media screen and (max-width: 992px) {
.black_p01 .box_s01 .p01_left,
.black_p01 .box_s01 .p01_right {
	width: 100%;
	}
}
/****************************
iframe MAP
*****************************/
#map {
    width: 100%;
    height: 450px;
	position: relative;
	overflow: hidden;
    border-top: 1px solid #eeeeee;
	}

.iframe-map {
    position: relative;
    padding-bottom: 55.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
    }
.iframe-map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 450px;
    }
@media screen and (max-width: 768px) {
.iframe-map {
    position: relative;
    padding-bottom: 65.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
    }
.iframe-map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    }
}

/***********************
TABLE 表格選單
***********************
table {
	min-width: 100%;
	max-width: 100%;
    margin: 10px 0;
    padding: 0;
	border: 1px solid #eeeeee;
    border-radius: 5px;
	}
table tr { padding: 3px 3px; text-align: left; }
table tr a { color:#3d5e85;	}	

tr:nth-of-type(odd) { background: #f9f9f9; }
table td { padding: 3px 10px; text-align: left; }
table td .view,
table td .icon {
	display: inline-block; 
	padding: 5px; 
	margin: auto; 
	min-width: 32px;
	max-height: 32px;
	text-align: center;
	vertical-align:middle;
	}
table td .view { float: right; }
	
table .act { min-width: 150px; text-align: right; }

@media only screen and (max-width: 640px) {
table { border: 0; }
table tr { 
    display: inline-block; 
	width: 100%; 
	margin: 10px 0px; 
	border: 1px solid #eeeeee;
	
	border-radius: 8px;

    }
table tr:hover {

	-webkit-box-shadow:0px 1px 8px #e5e5e5;
    -moz-box-shadow:0px 1px 8px #e5e5e5;
    box-shadow:0px 1px 8px #e5e5e5;	
	}	

table td { display: inline-block; float: left; width: 100%; content: attr(data-label); text-transform: uppercase; }
table .act { width: 100%; text-align: right; border-top: 1px dotted rgba(204,204,204,0.4); }
}
*/

/***********************
# PAGE 分頁樣式
***********************/
.page {
    display: inline-block;
	width: 100%;
	margin-top: 30px;
	margin-bottom: 30px;
	text-align: center;
	font-size: 13px;
    font-family: arial, helvetica, sans-serif;
}
.page a {
    color: #2A343E;
	border: #ddd 1px solid;
    margin-right: 2px;
    padding: 8px 10px;
    text-decoration: none;
}
.page a:hover {
    border-right: #2A343E 1px solid;
    border-top: #2A343E 1px solid;
    border-left: #2A343E 1px solid;
    color: #2A343E;
    border-bottom: #2A343E 1px solid;
    background-color: #AAB8C6;
}
.page a:active {
    border-right: #2A343E 1px solid;
    border-top: #2A343E 1px solid;
    border-left: #2A343E 1px solid;
    color: #2A343E;
    border-bottom: #2A343E 1px solid;
    background-color: #AAB8C6;
}
.page span.current {
    color: #fff;
    font-weight: 900;
    border: 1px solid #2A343E;
    margin-right: 2px;	
    padding: 8px 10px;
    background-color: #2A343E;
}
.page span.disabled {
    color: #ccc;
    border: #f3f3f3 1px solid;
    margin-right: 2px;
    padding: 8px 10px;
}
@media all and (max-width: 768px) {
.page .page-rwd  {
	width: 100%;
    display: block;
	margin: 25px 2px;
    }
	
}

/***********************
GO TOP
***********************/
#gotop {
    position: fixed;
	display: block;
	z-index: 10;

    right: 5px; 
    bottom: 30px;
	
	width: 45px;
	height: 45px;
	line-height: 45px;
	
    padding: 0px 5px;    
    font-size: 10px;
	font-size: 15px;
	font-weight: 400;
	text-align: center;
	
    color: #ffffff;
    cursor: pointer;
	background: #20c7ca;
	}
#gotop a { color: #ffffff; }
#gotop:hover { color:#ffffff; background: #20c7ca; }