html {
	overflow-x: hidden;
	height: 100%;
} 
body {
	font-family: 'Noto Sans TC', '微軟正黑體', sans-serif, Arial;
	font-weight: 300;
	background: #322B29;
	color: #fff;
	overflow-x: hidden;
}

h1, h2 {
	font-family: 'GenYoMin TW', '微軟正黑體', sans-serif, Arial;
    font-weight: 600;
}

h1 {
	font-size: 2rem;
}

em {
	border-bottom: 1px solid #fff;
	margin: 0 2px 0 2px;
}

a {
	text-decoration: none;
	cursor: pointer;
	color: #FFAF47;
}

h5 {
	font-size: xx-small;
}
/* header */
.menu {
	height: 50px;
	position: fixed;
	z-index: 50;
	background: #322B29;
	width: 100%;
	color: #F9F9F9;
	font-size: 1rem;
	line-height: 50px;
	padding: 0;
	top: 0;
	transition: height 0.6s;
}

.menu .logo {
	display: inline-block;
	position: absolute;
	height: 100%;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 100%;
	z-index: -1;
	margin-left: 5px;
}
.menu .logo > a:first-of-type {
	display: none;
}

.logo img{
	display: inline-block;
	height: 100%;
	width: auto;
}
.menu .logo img:first-of-type {
	height: 96%;
}

.menu ul {
	width: 50%;
	text-align: right;
	background-color: #322B29;
	padding-bottom: 15px;
	margin-top: 50px;
	transform: translateX(200%);
	transition: transform 0.8s ease-in-out;
}
.menu ul li {
	display: block;
	line-height: 50px;
	cursor: pointer;
	transition: line-height 0.6s;
}

.menu ul li a {
	padding: 5px 10px;
	margin-right: 15px;
	transition: background-color 0.6s, color 0.6s;
	background-color: #F9F9F9;
	color: #231815;
}

.menu ul li:hover a, .menu ul li a.active {
	background-color: transparent;
	color: #fff;
}
.menu_btn {
	background-color: transparent;
	border-width: 0;
	outline: none;
	padding: 13px 10px 12px;
	vertical-align: middle;
	float: right;
}

.hamburger {
	width: 30px;
}
.hamburger > span {
	display: block;
	width: 100%;
	height: 3px;
	background-color: #fff;
	transform-origin: 0 0;
	transition: transform 0.4s;
	border-radius: 1px;
}
.hamburger > span + span {
	margin-top: 8px;
}

.menu_btn.active span:nth-of-type(1){
	transform: rotate(45deg);
}
.menu_btn.active span:nth-of-type(2){
	opacity: 0;
}
.menu_btn.active span:nth-of-type(3){
	transform: rotate(-45deg);
	margin-top: 7px;
    margin-left: -2px;
}

.menu_btn.active + ul {
	transform: translateX(100%);
}


/* banner */
.start_banner {
	width: 100%;
	height: 100vh;
	background: url('../img/start_banner.jpg') no-repeat;
	background-size: cover;
	background-position: center bottom;
	position: fixed;
}

.start_banner[data-fixed="false"] {
	position: relative;
}

.start_banner h1 {
	color: white;
	display: inline-block;
	vertical-align: middle;
	z-index: 10;
    position: absolute;
    line-height: 1.7;
	top: 0;
    bottom: 0;
    margin: auto auto auto 0.8em;
    height: 230px;
}
.start_banner h1 span:nth-of-type(2) {
	font-weight: 500;
	color: #974C38;
	font-size: 0.7em;
}

.start_banner h1 span:nth-of-type(2)::before {
	content: "";
	letter-spacing: 0px;
	width: 30%;
	border-top: 2px solid #974C38;
	display: inline-block;
	vertical-align: middle;
	padding-bottom: 8px;
	margin-right: 15px;
}

.start_banner::before {
	content: "";
	height: 100%;
	display: inline-block;
	width: 0;
	vertical-align: middle;
}

.overlay {
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	position: absolute;
	z-index: 0;
	top: 0;
	left: 0;
}

.overpic {
	width: 100%;
	height: auto;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 0;
}

/* creature img */
.creature_box {
	width: 200%;
	max-width: 1200px;
	margin: 0 auto;
	position: absolute;
	height: 100%;
	bottom: 0;
	left: 0;
	right: 0;
}
.creature {
	position: absolute;
	bottom: 10%;
	width: 100%;
	padding-top: 22.2%;
	left: 0;
}
.creature > div {
	background-image: url('../img/creature.png');
	background-repeat: no-repeat;
	background-size: cover;
	display: inline-block;
	position: absolute;
	bottom: 0;
	height: 100%;
}
#cr_group1 {
	bottom: 30%;
}
#cr_group2 {
	left: -50%;
    bottom: 5%;
}
.ct01 {	width: 18%;	background-position: 0 0; transition-delay: 0.6s;}
.ct02 {	width: 7.5%; background-position: 19.5% 0; left: 18%; transition-delay: 0s;}
.ct03 {	width: 8%;	background-position: 27.5% 0; left: 25.5%; transition-delay: 0.3s; }
.ct04 {	width: 14%;	background-position: 42% 0; left: 36%; transition-delay: 0.8s; }
.ct05 {	width: 17%;	background-position: 64% 0; left: 53%; transition-delay: 0s; }
.ct06 {	width: 15%;	background-position: 82.5% 0; left: 70%; transition-delay: 0.4s; }
.ct07 {	width: 15%;	background-position: 99% 0; left: 84%; transition-delay: 0.2s; }

/* scroll hint */
.scroll_hint {
	width: 30px;
	height: 50px;
	border: 2px solid #fff;
	border-radius: 15px;
	opacity: 0;
	transition: opacity 1s;
}
.scroll_hint.active {
	opacity: 0.7;
}
.scroll_hint div {
	border: 2px solid #fff;
	border-radius: 10px;
	height: 0;
	width: 0;
	margin: 0 auto;
	margin-top: 10px;
	opacity: 0;
	animation: scrollhint 2s infinite ease-in-out;
}
#banner .scroll_hint {
	position: absolute;
	bottom: 15%;
	left: 0;
	right: 0;
	margin: auto;
}
.tl_map .scroll_hint {
	position: absolute;
    top: auto;
    left: auto;
    bottom: 20px;
    right: 28%;
    opacity: 0.9;
    -webkit-filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.8));
    filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.8));
}

.tl_map .scroll_hint div {
	animation: scrollhint 2s infinite reverse ease-in-out;
}


@keyframes scrollhint {
	0%{opacity: 0; margin-top: 10px;}
	10%{opacity: 1; margin-top: 10px;}
	80%{opacity: 1; margin-top: 35px;}
	90%{opacity: 0; margin-top: 35px;}
	100%{opacity: 0; margin-top: 35px;}
}


/* container */
.container {
	max-width: 960px;
	width: 100%;
	padding: 0 15px;
	margin: 0 auto;
}

.content {
	margin: 50px auto 100px auto;
}

.content p {
	line-height: 2;
	text-align: justify;
	font-weight: 300;
}

.content p + p {
	margin-top: 1.5rem;
}

.content h2 {
	font-size: 1.6rem;
	margin-bottom: 15px;
	line-height: 1.5;
	font-weight: 500;
}
.content .gray {
	color: #B3B3B4;
}
.img_desc {
	margin: 60px auto;
}
.img_desc > span {
	display: inline-block;
    text-align: left;
    line-height: 2;
    color: #bbb;
    margin: 20px auto 0;
}

img.responsive {
	width: 100%;
	height: auto;
}

.margintb {
	margin: 30px auto;
}



/* youtube */
.youtube {
	width: 100%;
	padding-top: 56.25%;
	position: relative;
}
.youtube iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

/* split */
.row div.row  {
	display: block;
}
.row > div {
	display: block;
}

/* ainmation */
.hide {
	opacity: 0;
	transition-property: opacity;
	transition-duration: 0.6s;
}

.hide.show {
	opacity: 1;
}

.fade_in {
	opacity: 0;
	transform: translate(0, 20px);
	transition: opacity 0.6s, transform 0.6s ease;
}

.fade_in.show {
	opacity: 1;
	transform: translate(0, 0px);
}


/* slider */
.pic_slider {
	position: relative;
	width: 100%;
	padding-top: 67%;
	background: #fff;
	max-width: 960px;
}

.pic_slider div {
	position: absolute;
	height: 100%;
	top:0;
	max-width: 100%;
}

.overhide {
	position: absolute;
	height: 100%;
	top:0;
	width: 100%;
	overflow: hidden;
}

.pic_slider div:first-of-type {
	background: #ccc;
	width: 100%;
	left: 0;
}
.pic_slider div:nth-of-type(2) {
	background: #666;
	width: 50%;
	right: 0;
}

.pic_slider div img {
	height: 100%;
	width: auto;
}
.pic_slider div:nth-of-type(2) img {
	float: right;
}

.slider_line {
	position: absolute;
	height: 100%;
	left: 0px;
	top: 0;
	width: 3px;
	background: #322B29;
}

.slider_line span {
	position: absolute;
	top: 0;
	bottom: 0;
	height: 0;
	margin: auto;
    left: -11px;
    width: 24px;
    animation: sliderhint 1.8s infinite ease-in-out;
}
.slider_line span::before, .slider_line span::after {
	content: "";
    border-style: solid;
    border-width: 15px;
    border-color: transparent;
    display: inline-block;
    position: absolute;
    border-right-color: #322B29;
}
.slider_line span::before {
	left: -30px;
}
.slider_line span::after {
	transform: rotate(180deg);
	right: -30px;
}
@keyframes sliderhint {
	0% {opacity: 0; left: -11px; width: 24px;}
	30% {opacity: 0.7; left: -22px; width: 45px;}
	70% {opacity: 0; left: -22px; width: 45px;}
	100% {opacity: 0; left: -22px; width: 45px;}
}
.slider_text {
	position: absolute;
	bottom: 20px;
	left: 30px;
	color: #f9f9f9;
	white-space:nowrap;
}
.slider_time {
	position: absolute;
	top: 20px;
	left: 30px;
	font-size: 1rem;
	color: #322B29;
	white-space:nowrap;
	font-weight: 600;
}

/* parallax */
.parallax-window {
	min-height: 100vh;
    background: transparent;
	position: relative;
}
.banner {
	position: relative;
}

.banner h1 {
	position: absolute;
	display: inline-block;
	vertical-align: middle;
    line-height: 1.7;
	height: 160px;
	text-shadow: 0px 0px 5px rgba(0, 0, 0, 0.6);
}
/* multipic */
.multipic {
}
.multipic img {
	width: 100%;
	height: auto;
	margin-bottom: 10px;
}

.multipic > div > span {
	background-color: #322B29;
	color: #bbb;
	display: block;
	padding: 5px 0;
	font-size: 1em;
}

.multipic > div + div {
	position: absolute;
	top: 0;
	animation-name: fadeslide;
	animation-duration: 15s;
	animation-iteration-count: infinite;
	opacity: 0;
}

.multipic > div:nth-of-type(2) { animation-delay: 1.5s; }
.multipic > div:nth-of-type(3) { animation-delay: 4.5s; }
.multipic > div:nth-of-type(4) { animation-delay: 7.5s; }
.multipic > div:nth-of-type(5) { animation-delay: 10.5s; }

.play-pause {
	position: absolute;
	cursor: pointer;
	z-index: 30;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background-color: rgba(0, 0, 0, 0.3);
	top: 0;
	bottom: 20px;
	left: 0;
	right: 0;
	margin: auto;
	border: none;
	opacity: 0;
	transition: opacity 0.4s;
}
.play-pause span::before, .play-pause span::after {
	content: "";
	width: 10px;
	height: 30px;
	background-color: #fff;
	margin: 0 5px;
	display: inline-block;
	opacity: 0.9;
	margin-top: 3px;
}
.multipic:hover .play-pause {
	opacity: 0.5;
}
.play-pause.active {
	opacity: 0.8;
}
.multipic:hover .play-pause.active {
	opacity: 1;
}
.play-pause.active + div ~ div {
	animation-play-state: paused;
}

@keyframes fadeslide {
    0% {opacity: 0;}
    10% {opacity: 1;}
    20% {opacity: 1;}
    30% {opacity: 0;}
    100% {opacity: 0;}
}

/* time line */
.timeline_sec {
	position: relative;
	margin: -60px auto -20px;
}

.timeline_fixed {
	width: 100%;
	max-width: 960px;
	right: 0;
	left: 0;
	margin: auto;
	position: relative;
	background-color: #9B9B9C;
}
.timeline_fixed > div {
	position: absolute;
	padding-top: 0;
	top: 0;
	width: 100%;
}

.timeline_scroll {
	margin: 0 auto;
	width: calc(100% + 17px);
	padding: 0 calc(50% - 480px + 17px) 0 calc(50% - 480px);
	overflow-y: auto;
	position: relative;
	top: 0;
	z-index: 10;
	min-height: 400px;
}
.timeline_scroll > div {
	position: absolute;
	height: 100%;
	top: 0;
	width: 100%;
	max-width: 960px;
}
.timeline_linear_top {
	content: "";
	position: absolute;
	height: 15px;
	width: 100%;
	z-index: 11;
	pointer-events: none;
	background: linear-gradient(to top,rgba(50,43,41,0),rgba(50,43,41,1));
}
.tl_desc {
	padding: 0 37px 0 20px;
	height: 100%;
	position: absolute;
}

.tl_desc > div {
	height: 100%;
	position: relative;
	top: 0;
	padding: 15px 0;
	opacity: 1;
	transition: opacity 0.6s ease-in-out;
	transition-delay: 0.3s;
}
.tl_desc > div.active {
	opacity: 1;
}
.tl_desc p {
	line-height: 1.5;
	margin-bottom: 30px;
	text-align: justify;
}

.tl_desc img {
	width: 100%;
	height: auto;
}


.tl_year {
	text-align: center;
	padding: 15px 0 15px 15px;
	line-height: 1.5;
	position: absolute;
	top: -3em;
	left: 0;
	z-index: 11;
	height: 3em;
    overflow: hidden;
    width: 100%;
}
.row > div.tl_year {
	display: none;
}
.tl_year ul {
	height: 100%;
	display: -webkit-inline-flex;
	display: inline-flex;
	flex-direction: column;
	justify-content:space-between;
    flex-wrap: nowrap;
}
.tl_year ul li {
	cursor: pointer;
	opacity: 0.2;
	transition: opacity 0.3s ease-in-out;
}
.tl_year ul li:hover {
	opacity: 0.8;
}
.tl_year ul li.active {
	opacity: 1;
}
.tl_year ul li + li{
	margin-top: 10px;
}
.tl_map {
	line-height: 0;
	right: 0;
	position: relative;
	top: 0;
	min-width: 420px;
}
.tl_map img {
	width: 100%;
	height: auto;
}
.tl_map_top {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.tl_map > div {
	position: absolute;
	top: 0;
	left: 0;
}
.tl_mask {
	width: 100%;
	height: 100%;
	-webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.5));
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.5))
}

.tl_mask > div {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	opacity: 0;
	transition: background-color 0.4s, opacity 0.4s;
	animation-name: shining;
	animation-duration: 1s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-play-state: paused;
	
}
.tl_mask > div.past {
	background: rgba(0, 0, 0, 0.3) ;
	opacity: 1;
	animation: none;
}
.tl_mask > div.active {
	background: rgba(224, 64, 145, 0.8);
	animation-play-state: running;
	opacity: 1;
}

.tl_mask > div:nth-of-type(1) {
	-webkit-mask-image: url(../img/sec2_timeline/01.svg?v=1002);
            mask-image: url(../img/sec2_timeline/01.svg?v=1002);
}
.tl_mask > div:nth-of-type(2) {
	-webkit-mask-image: url(../img/sec2_timeline/02.svg?v=1002);
            mask-image: url(../img/sec2_timeline/02.svg?v=1002);
}
.tl_mask > div:nth-of-type(3) {
	-webkit-mask-image: url(../img/sec2_timeline/03.svg);
            mask-image: url(../img/sec2_timeline/03.svg);
}
.tl_mask > div:nth-of-type(4) {
	-webkit-mask-image: url(../img/sec2_timeline/04.svg);
            mask-image: url(../img/sec2_timeline/04.svg);
}
.tl_mask > div:nth-of-type(5) {
	-webkit-mask-image: url(../img/sec2_timeline/05.svg);
            mask-image: url(../img/sec2_timeline/05.svg);
}
.tl_mask > div:nth-of-type(6) {
	-webkit-mask-image: url(../img/sec2_timeline/06.svg);
            mask-image: url(../img/sec2_timeline/06.svg);
}
.tl_mask > div:nth-of-type(7) {
	-webkit-mask-image: url(../img/sec2_timeline/07.svg);
            mask-image: url(../img/sec2_timeline/07.svg);
}

@keyframes shining {
	0% {opacity: 0.3}
	100% {opacity: 1}
}

/* picline */
.picline {
	width: 100%;
	background-color: #231815;
	height: auto;
	margin: -60px auto -20px;
	padding: 40px 0 0 0;
}

.picline > div {
	display: inline-block;
	width: 100%;
	vertical-align: middle;
	margin-bottom: 30px
}

.picline > div > div {
	width: 100%;
	padding-top: 60%;
	position: relative;
	overflow: hidden;
	margin-bottom: 15px;
}

.picline img {
	width: 100%;
	height: auto;
	position: absolute;
	top: 0;
}

.picline span {
	padding-left: 15px;
}

/* QA */
.QAcontent {
	position: relative;
	min-height: 80vh;
	margin: 50px auto 100px auto;
	padding: 100px 15px;
}
.QAtitle {
	max-width: 330px;
	width: 80%;
	position: absolute;
	padding-top: 40px;
	z-index: 1;
	top: 0;
	left: 0;
}
.QAtitle > div {
	width: 100%;
	padding-top: 67%;
	background: url('../img/QAtitle_dec.png') no-repeat;
	background-size: contain;
	position: relative;
}
.QAtitle h2 {
	font-size: 1.6em;
	line-height: 1.5;
	position: absolute;
	height: 80px;
	transform: rotate(-13deg);
	transform-origin: 50% 50%;
	text-shadow: 0px 0px 5px rgba(0, 0, 0, 0.6);
}

.QAcontent .row div + div { 
	margin-left: 0.5%; 
}
.QAcontent .row div + div .QAtalk > li {
	text-align: center;
}
.QAcontent .row + .row .QAtalk {
	margin-top: 50px;
}
.QAcontent .row + .row > div { 
	vertical-align: bottom; 
}
.QAtalk {
	position: relative;
	width: 100%;
	top: 0;
	bottom: 0;
	z-index: 1;
}
.parallax-window .QAtalk {
	margin-top: 150px;
}
.QAtalk > li {
	position: relative;
	display: block;
	text-align: center;
}
.QAtalk > li + li {
	margin-top: 50px;
}

.QAwho {
	margin-bottom: 7px;
	font-weight: 600;
	line-height: 1.4;
}
.QAwhat {
	line-height: 1.5;
}
.QAtalk .arrow_box {
	position: relative;
	max-width: 350px;
	width: calc(100% - 30px);
	color: #0F0F0F;
	display: inline-block;
	text-align: left;
}
.arrow_box {
	border-radius: 10px;
	padding: 15px 20px;
	background: rgba(255, 255, 255, 0.8);
}
.arrow_box::after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0px;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(255, 255, 255, 0);
	border-top-color: rgba(255, 255, 255, 0.8);
	border-width: 18px;
	border-top-width: 20px;
	margin-left: -20px;
}
.ar_left::after {
	left: 20%;
	border-right-width: 0;
}
.ar_right::after {
	left: 80%;
	border-left-width: 0;
}

.QAvideo, .QAimg {
	width: 100%;
	height: auto;
	position: relative;
	display: block;
}
.QAvideo {
	margin: 150px auto 50px auto;
}
.QAimg {
	margin: 50px auto 0;
}

.QAfade_in li > div {
	opacity: 0;
	transform: translate(0, 20px);
	transition: opacity 0.6s, transform 0.6s ease;
} 

.QAfade_in .show {
	opacity: 1;
	transform: translate(0, 0px);
} 

#QA1 { min-height: 90vh; }
#QA4 { min-height: 140vh; }


/* video */
.video_wide {
	background: #111;
}
.video_desc_wide {
	padding: 15px 0 20px;
	position: relative;
}

.video_desc_wide h3 {
	font-size: 1.2rem;
	line-height: 2;
}
.video_desc_wide p {
	font-size: 1rem;
	line-height: 1.8;
}

.video {
	width: 100%;
	display: inline-block;
	margin-right: 0%;
	vertical-align: top;
}

.video_desc {
	padding: 8px 0 0;
	position: relative;
	background: #322B29;
	margin-bottom: 45px;
}

.video_desc h3 {
	font-size: 1rem;
	line-height: 2;
}

.video_desc p {
	font-size: 0.9rem;
	line-height: 1.8;
	height: 50px;
	overflow: hidden;
	transition: height 0.6s;
	text-align: left;
}

.video_desc .more_btn {
	border: 0;
	font-size: 0.9rem;
	height: 1.8em;
	width: 3.2em;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: 0;
	background: #322B29;
	padding-left: 5px;
	color: #fff;
	cursor: pointer;
	opacity: 1;
	transition: opacity 0.6s;
}

.video_desc .more_btn::before {
	content: "";
	position: absolute;
	height: 1.8em;
	width: 3em;
	left: -3em;
	bottom: 0;
	background: linear-gradient(to right,rgba(50,43,41,0),rgba(50,43,41,1));
}
.video_desc .more_btn::after {
	content: "......";
}
.video_desc .more_btn:hover::after {
	content: "▼";
}

.video_desc .more_btn:focus {
	opacity: 0;
	pointer-events: none;
}
.video_desc .more_btn:focus + p {
	height: auto;
}

.video_desc_wide > span, .video > span {
	font-size: 0.8rem;
	line-height: 2.4;
	color: #777;
}

.ab_tr {
	position: absolute;
	top: 15px;
	right: 0;
}
.ab_center {
	top: 0;
	bottom: 0;
	margin: auto;
	left: 0;
	right: 0;
	text-align: center;
}
.tcenter, .tcenter p {
	text-align: center;
}

br.responsive {
	display: inline;
}

/* footer */
footer {
	padding: 100px 0 40px;
	text-align: center;
	background-color: #322B29;
}

footer .row .w4 > div{
	margin-bottom: 30px;
}

footer .logo {
	height: 60px;
}

footer .logo a {
	margin: 0 5px;
	opacity: 1;
	transition: opacity 0.6s;
}
footer .logo a:hover {
	opacity: 0.5;
}

footer h5 {
	line-height: 1.5;
}

.line-it-button {
	transform: scale(1.4) translateY(-3px);
    margin: 0 30px;
}