/* normalize.css v7.0.0 */
html{line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}abbr[title]{border-bottom:0;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,html [type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details,menu{display:block}summary{display:list-item}canvas{display:inline-block}template{display:none}[hidden]{display:none}

/* 入場動畫 */
.intro-ani, .overlay{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 200;
	overflow: hidden;
}
.overlay{
	background: url(img/loading2.gif) 50% 50% no-repeat #312419;
}
.intro-ani.start{
	background: url(img/main-bg.jpg) 50% 50% no-repeat;
}
.intro-ani.start .book-base{
	width: 100%;
	height: 100%;
	background: url(img/book-base.png) 50% 50% no-repeat;
}
.img-preload{
	width: 10px;
	height: 10px;
	opacity: .01;
}
.intro-ani.start .wrap-ori{
	position: absolute;
	top: 50%;
	left: 50%;
	margin-left: -279px;
	margin-top: -421px;
}
.intro-ani.start .position{
	position: absolute;
	width: 559px;
	height: 806px;
	transform: rotateZ(-26.4deg) skewY(0deg);
}
.intro-ani.start .position .page{
	width: 100%;
	height: 100%;
	position: absolute;
	background: url(img/page.jpg) left top no-repeat;
	animation: flip 2s 1 linear;
	animation-fill-mode: forwards;
	transform-origin: 0% 0%;
	transform: perspective(3000px) rotateX(31deg) rotateY(10deg) rotateZ(0deg);
}
.intro-ani.start .position.p1{
	animation: flip1 2s 1 linear;
	animation-delay: 1s;
}
.intro-ani.start .position.p2{
	animation: flip2 2s 1 linear;
	animation-delay: 1.2s;
}
.intro-ani.start .position.p3{
	animation: flip3 2s 1 linear;
	animation-delay: 1.4s;
}
.intro-ani.start .position.p4{
	animation: flip4 2s 1 linear;
	animation-delay: 1.6s;
}
.intro-ani.start .position.fake-cover{
	z-index: 5;
}
.intro-ani.start .position.p1 .page, .intro-ani.start .position.fake-cover .page{
	background: url(img/cover.jpg) left top no-repeat;
	padding: 12px 12px 12px 0;
	margin-top: -12px;
	border-radius: 0px 12px 12px 0px;
	animation-delay: 1s;
}
.intro-ani.start .position.p2 .page{
	animation-delay: 1.2s;
}
.intro-ani.start .position.p3 .page{
	animation-delay: 1.4s;
}
.intro-ani.start .position.p4 .page{
	animation-delay: 1.6s;
}
.intro-ani.start .position.fake-cover .page{
	opacity: 0;
	animation: hide-fake-cover 2s 1 linear;
}
@keyframes flip {
	0%{transform: perspective(3000px) rotateX(31deg) rotateY(10deg) rotateZ(0deg);}
	49.9%{background-position: left top;}
	50%{transform: perspective(3000px) rotateX(31deg) rotateY(-80deg) rotateZ(0deg); background-position: right top;}
	100%{transform: perspective(3000px) rotateX(31deg) rotateY(-170deg) rotateZ(0deg); background-position: right top;}
}
@keyframes flip1 {
	0%{z-index: 4;}
	49.99%{z-index: 4;}
	50%{z-index: 1;}
}
@keyframes flip2 {
	0%{z-index: 3;}
	49.99%{z-index: 3;}
	50%{z-index: 2;}
}
@keyframes flip3 {
	0%{z-index: 2;}
	49.99%{z-index: 2;}
	50%{z-index: 3;}
}
@keyframes flip4 {
	0%{z-index: 1;}
	49.99%{z-index: 1;}
	50%{z-index: 4;}
}
@keyframes hide-fake-cover {
	0%{opacity: 1;}
	49.99%{opacity: 1;}
	50%{opacity: 0;}
}

/* 主視覺和選單 */
.keyV{
	min-width: 1220px;
	height: 931px;
	background: url(img/index/top-bg.jpg) center top no-repeat;
}
.keyV .wrap-ori{
	width: 1200px;
	margin: 0 auto;
	position: relative;
}
.keyV .menus{
	padding-top: 210px;
	overflow: auto;
}
.keyV .menus > div{
	width: 196px;
	height: 452px;
	box-sizing: border-box;
	text-align: center;
	padding: 26px 20px 0 20px;
	background: url(img/index/menu-bg.png) center top no-repeat;
}
.keyV .menus .L{
	float: left;
}
.keyV .menus .R{
	float: right;
}
.keyV .menus a{
	display: block;
}
.keyV .menus a.no-link{
	cursor: default;
}
.keyV .menus img{
	display: block;
	margin: 0 auto;
}
.keyV .menus img+img{
	display: none;
}
.keyV .menus a:hover img:first-child{
	display: none;
}
.keyV .menus a:hover img+img{
	display: block;
}
.ligntning{
	width: 702px;
	height: 640px;
	background: url(img/index/lightning.png) left top no-repeat;
	position: absolute;
	top: 0px;
	left: 50%;
	margin-left: -351px;
}

/* 最上方topBar */
.menubar{
	background: #fff;
	position: relative;
	z-index: 999 !important;
}

/* footer */
footer {
	display: block;
	clear: both;
	overflow: hidden;
	width: 100%;
	text-align: center;
	background-color: #000;
}

/* 外包來的CSS */
* {
	margin: 0;
	padding: 0;
}
html,
body {
	font-family: '微軟正黑體', Helvetica, Arial, 'LiHei Pro', sans-serif;
	width: 100%;
	height: 100%;
	background-color: #070a18;
}

p {
	font-size: 26px;
	font-weight: bold;
	line-height: 2;
	display: inline-block;
	text-align: left;
	color: rgb(255, 255, 255);
}

ul,
ol,
li {
	font-size: 26px;
	font-weight: bold;
	line-height: 2;
	color: rgb(255, 255, 255);
}

.box {
	position: relative;
	left: 50%;
	width: 1200px;
	height: auto;
	margin-left: -600px;
}

.wrap {
	position: relative;
	width: 100%;
	height: auto;
}

.main_01 {
	position: relative;
	width: 100%;
	height: 900px;
	background-image: url(../img/main_01.jpg);
	background-repeat: no-repeat;
	background-position: center;
}

.main_02 {
	position: relative;
	width: 100%;
	height: 1570px;
	background-image: url(../img/main_02.jpg);
	background-repeat: no-repeat;
	background-position: center bottom;
}

.main_03 {
	position: relative;
	width: 100%;
	height: auto;
	background-image: url(../img/main_03.jpg);
	background-repeat: no-repeat;
	background-position: center bottom;
}

.main_04 {
	position: relative;
	width: 100%;
	height: auto;
}

.main_05 {
	position: relative;
	width: 100%;
	height: auto;
}

.main_06 {
	position: relative;
	width: 100%;
	height: auto;
	background-image: url(../img/main_06.jpg);
	background-repeat: no-repeat;
	background-position: center top;
}


/*-- 選單左邊 --*/

.bn_left {
	position: absolute;
	z-index: 100;
	top: 30px;
	left: 0;
	width: 206px;
	height: 488px;
}

.bn_left_01 {
	display: block;
	width: 206px;
	height: 148px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_left_01.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_01:hover {
	background-image: url(../img/bn_left_01_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_02 {
	display: block;
	width: 206px;
	height: 123px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_left_02.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_02:hover {
	background-image: url(../img/bn_left_02_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_03 {
	display: block;
	width: 206px;
	height: 70px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_left_03.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_03:hover {
	background-image: url(../img/bn_left_03_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_04 {
	display: block;
	width: 206px;
	height: 56px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_left_04.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_04:hover {
	background-image: url(../img/bn_left_04_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_05 {
	display: block;
	width: 206px;
	height: 91px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_left_05.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_left_05:hover {
	background-image: url(../img/bn_left_05_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}


/*-- 選單右邊 --*/

.bn_right {
	position: absolute;
	z-index: 100;
	top: 170px;
	right: 0;
	width: 206px;
	height: 488px;
}

.bn_right_01 {
	display: block;
	width: 206px;
	height: 125px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_01.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_01:hover {
	background-image: url(../img/bn_right_01_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_02 a {
	display: block;
	width: 206px;
	height: 100px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_02.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_02 a:hover {
	background-image: url(../img/bn_right_02_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_03 {
	display: block;
	width: 206px;
	height: 71px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_03.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_03:hover {
	background-image: url(../img/bn_right_03_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_04 a {
	display: block;
	width: 206px;
	height: 54px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_04.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_04 a:hover {
	background-image: url(../img/bn_right_04_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_05 a {
	display: block;
	width: 206px;
	height: 47px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_05.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_05 a:hover {
	background-image: url(../img/bn_right_05_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_06 a {
	display: block;
	width: 206px;
	height: 92px;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
	background-image: url(../img/bn_right_06.png);
	background-repeat: no-repeat;
	background-position: center top;
}

.bn_right_06 a:hover {
	background-image: url(../img/bn_right_06_hover.png);
	background-repeat: no-repeat;
	background-position: center top;
}

#toTop {
	position: fixed;
	z-index: 105;
	right: 10px;
	bottom: 10px;
	width: 206px;
	height: 56px;
	cursor: pointer;
	display: none;
}


/*-- 人物 --*/

.peple_01 {
	position: absolute;
	z-index: 101;
	top: 470px;
	left: 50%;
	width: 1200px;
	height: auto;
	margin-left: -600px;
}

.peple_01 img {
	float: right;
}

.peple_02 {
	position: absolute;
	top: 3300px;
	left: 50%;
	width: 1200px;
	height: auto;
	margin-left: -600px;
}

.peple_02 img {
	float: left;
}

.peple_03 {
	position: absolute;
	top: 0px;
	left: 50%;
	width: 1200px;
	height: auto;
	margin-left: -600px;
}

.peple_03 img {
	float: right;
}


/*-- 標題 --*/

.title_01 img {
	display: block;
	clear: both;
	width: auto;
	height: auto;
	margin: 0 auto 30px auto;
}

.title_02 img {
	display: block;
	clear: both;
	width: auto;
	height: auto;
	margin: 0 auto;
}


/*-- 其他 --*/

.text_box {
	font-size: 30px;
	font-weight: bold;
	line-height: 2;
	display: block;
	clear: both;
	width: 1000px;
	height: auto;
	margin: 30px auto;
	margin-top: 100px;
}

.text_box_02 {
	font-size: 30px;
	font-weight: bold;
	line-height: 2;
	display: block;
	clear: both;
	width: 1000px;
	height: auto;
	margin: 30px auto;
	margin-top: -50px;
}

.text_box_03 {
	font-size: 30px;
	font-weight: bold;
	line-height: 2;
	display: block;
	clear: both;
	width: 680px;
	height: auto;
	margin: 0px auto;
}

.text_box_04 {
	font-size: 30px;
	font-weight: bold;
	line-height: 2;
	display: block;
	clear: both;
	width: 1000px;
	height: auto;
	margin: 0px auto;
	background-image: url(..img/time.png);
}

.list_box_01 {
	display: inline-block;
	width: 160px;
	height: 60px;
	margin-right: 20px;
	margin-bottom: 35px;
	padding: 10px;
	text-align: center;
	color: #070a18;
	background-color: #aeb1dc;
}

.list_box_02 {
	display: inline-block;
	width: 195px;
	height: 60px;
	margin-right: 20px;
	margin-bottom: 35px;
	padding: 10px;
	text-align: center;
	color: #070a18;
	background-color: #aeb1dc;
}

.list_box_03 {
	display: inline-block;
	width: 250px;
	height: 60px;
	margin-right: 20px;
	margin-bottom: 35px;
	padding: 10px;
	text-align: center;
	color: #070a18;
	background-color: #aeb1dc;
}

.set_01 {
	width: 605px;
	margin-left: 30px;
}

.set_02 {
	width: 900px;
	margin-left: 30px;
}

.set_03 {
	position: absolute;
	width: 500px;
	top: 400px;
	right: 50px;
}

.little {
	font-size: 46px;
	display: block;
	clear: both;
	margin: 30px auto;
	text-align: center;
	color: #fdff73;
}

.little_02 {
	font-size: 46px;
	display: block;
	clear: both;
	margin: 30px auto;
	text-align: center;
	color: #56a6c6;
}

.monster_S {
	display: inline-block;
	border-width: 2px;
	border-color: rgb(174, 177, 220);
	border-style: solid;
	background-color: #1b1c32;
	width: 253px;
	height: 408px;
	clear: both;
	margin-right: 30px;
	margin-left: 30px;
}

.monster_L {
	display: block;
	border-width: 2px;
	border-color: rgb(174, 177, 220);
	border-style: solid;
	background-color: #1b1c32;
	width: 781px;
	height: 411px;
	clear: both;
	margin: 0px auto;
	margin-bottom: 50px;
}

p.mon_p {
	display: block;
	width: 100%;
	height: 60px;
	line-height: 60px;
	text-align: center;
	background: #2a2a48;
	color: #64ccee;
}

img.mon_i {
	display: block;
	clear: both;
	margin: 50px auto;
}

img.mon_i2 {
	display: inline-block;
	clear: both;
	margin: 50px 32px;
}

.time {
	width: 1006px;
	height: 176px;
	background-image: url(../img/time.png);
	background-repeat: no-repeat;
	background-position: center;
}

p.time_p1 {
	width: 215px;
	height: 190px;
	line-height: 30px;
	text-align: center;
	color: #64ccee;
	margin-top: 55px;
}

p.time_p2 {
	width: 215px;
	height: 190px;
	line-height: 30px;
	text-align: center;
	color: #1b1c32;
	margin-top: 55px;
}

table {
	font-size: 30px;
	font-weight: bold;
	display: block;
	clear: both;
	width: 900px;
	margin: 0 auto;
	color: #fff;
	margin-bottom: 100px;
	line-height: 1;
}

th {
	width: 33.3%;
	height: 90px;
	color: #2e1502;
	background: #feffab;
}

td {
	font-size: 24px;
	padding: 20px;
	color: #070a18;
	background-color: rgba(220, 220, 220, .7);
}

tr:nth-child(even) {
	background-color: rgba(200, 200, 200, .7);
}

ul.t_li li,
ol.t_li li {
	font-size: 24px;
	margin-left: 20px;
	color: #070a18;
	line-height: 1;
	margin-bottom: 20px;
}

.center {
	text-align: center;
}

.w450 {
	width: 450px;
}

.w25 {
	width: 25%;
}

img.img07 {
	display: block;
	clear: both;
	border: solid #ccc 2px;
	margin: 0px auto;
}