@charset "utf-8";
/* CSS Document */
@import url(//fonts.googleapis.com/earlyaccess/notosanstc.css);
html,
body {
	font-family: 'Noto Sans TC', sans-serif;
	font-size: 16px;
	line-height: 1.8rem;
	font-weight: 300;
}
html {
	overflow-x: hidden;
	height: 100%;
}
h1,
h2,
h3 { margin: 0; }
button {
	padding: 0;
	background-color: transparent;
	border: none;
	outline: none;
}
dl { margin-bottom: 0.85rem; }
dt,
dd {
	font-weight: 500;
	font-size: 1.2rem;
	line-height: 1.8rem;
}
dt { position: absolute; }
dd { margin-left: 6rem; }
h1,
h2 {
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}
h1 {
	background-image: url(../images/h1.png);
	margin-top: -80px;
	width: 960px;
	height: 420px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 3;
	background-size: contain;
	display: none;
}
h2 {
	width: 247px;
	height: 66px;
	margin: 44px auto 24px;
	background-repeat: no-repeat;
	background-size: contain;
	display: none;
}
h3 { margin-bottom: 0.25rem; }
a:hover {
	color: #fff;
	text-decoration: none;
}
img { /*max-width: 100%;*/ }
.btns {
	display: inline-block;
	cursor: pointer;
	text-decoration: none;
	background-repeat: repeat-x;
	text-align: center;
	border: none;
}
.header {
	background-image: url(../images/section-0.jpg);
	background-position: center top;
	text-align: center;
	height: 1100px;
	position: relative;
	overflow: hidden;
}
.header .container {
	height: 100%;
	width: 100%;
	position: relative;
	padding: 0;
	overflow: hidden;
}
.logo {
	width: 300px;
	margin-top: 70px;
	display: block;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 5;
}
.btn-area {
	position: absolute;
	left: 50%;
	top: 466px;
	margin-left: -472px;
	z-index: 5;
}
.section {
	background-repeat: no-repeat;
	background-position: center top;
	/*padding-bottom: 3rem;
	min-height: 100px;*/
	position: relative;
}
#section-1 {
	background-image: url(../images/section-1.jpg);
	height: 1250px;
	overflow: hidden;
}
#section-1 .wrap {
	padding-left: 3.5rem;
	padding-right: 3.5rem;
	padding-bottom: 1.5rem;/*background-color: rgba(255,255,255,.7);*/
}
#section-1 .container {
	width: 1170px;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -585px;/*background-color: rgba(0,0,255,.2);*/
}
#section-1 .container .dec {
	position: absolute;
	left: 0px;
	top: 0px;
	z-index: 10;/*background-color: rgba(0,255,0,.2);*/
}
#section-1 .container .dec .roledec {
	left: -580px;
	top: 130px;
	position: absolute;
	opacity: 0;
}
#section-1 .container .dec .roledec.roledec1 {
	opacity: 1;
	left: -190px;
	z-index: 1;
}
#section-1 .container .dec .roledec .player {
	background: url(../images/video_play.png);
	width: 751px;
	height: 299px;
	position: absolute;
	top: 230px;
	left: 83px;
	text-align: center;
	padding-top: 12px;
}
#section-1 .container .role {
	position: absolute;
	left: 500px;
	top: 0;
	opacity: 0;
}
#section-1 .container .role.role1 {
	opacity: 1;
	left: 0px;
}
#section-1 .container .dec .role-tab {
	width: 560px;
	height: 160px;
	margin-left: -10px;
	margin-top: 706px;
	position: relative;
	z-index: 2;
	/*background-color: rgba(255,0,0,.2);*/
	background-image: url(../images/role-tab.png);
	background-repeat: no-repeat;
/*	padding-left: 51px;*/
}
#section-1 .container .dec .role-tab a {
	border: none;
	outline: none;
	width: 52px;
	height: 74px;
	background-repeat: no-repeat;
	float: left;
	display: block;
	transform-origin: bottom;
	transform: skewX(-26.1deg);
	margin-bottom: 6px;
}
#section-1 .container .dec .role-tab a.on,
#section-1 .container .dec .role-tab a:hover { filter: brightness(150%); }
#section-1 .container .dec .role-tab a.on { cursor: default; }
#section-1 .container .dec .role-tab a:nth-child(6) {
	clear: left;
	margin-left: 10px;
}
#section-1 .container .dec .role-tab a:nth-child(11) { margin-left: 26px; }
#section-1 .container .dec .role-tab a:nth-child(12) {  }
#section-1 .container .dec .role-tab a:nth-child(13) {  }
#section-1 h2 {
	background-image: url(../images/h2.png);
	width: 214px;
	height: 78px;
	margin: 50px 0 0 107px;
	background-size: auto;
	display: block;
}
.leadimg {
	position: absolute;
	top: 70px;
	left: 50%;
	margin-left: -400px;
	z-index: 3;
}
.chara01 {
	position: absolute;
	z-index: 1;
	top: 0px;
	left: 0px;
}
.chara02 {
	position: absolute;
	z-index: 1;
	top: 0px;
	right: 0px;
}
.moveCharaL img {
	transition: .3s ease all;
	transform: translate3d(300px, 450px, 0);
	opacity: 0;
}
.moveCharaR img {
	transition: .3s ease all;
	transform: translate3d(-300px, 450px, 0);
	opacity: 0;
}
.animeStartWrap.active .moveCharaL {
	animation: moveCharaL 6s ease-in-out both 1 alternate;
	animation-delay: -2s;
}
.animeStartWrap.active .moveCharaR {
	animation: moveCharaR 6s ease-in-out both 1 alternate;
	animation-delay: -2s;
}
.animeStartWrap.active .moveCharaR img {
	transform: translate3d(0, 0, 0);
	opacity: 1;
}
.animeStartWrap.active .moveCharaL img {
	transform: translate3d(0, 0, 0);
	opacity: 1;
}
 @keyframes moveCharaL {  0% {
 transform: translate3d(50px, 30px, 0);
}
 100% {
 transform: translate3d(0px, 0, 0);
}
}
 @keyframes moveCharaR {  0% {
 transform: translate3d(-50px, 30px, 0);
}
 100% {
 transform: translate3d(0px, 0, 0);
}
}
body.firstview {
	overflow: hidden;
	width: 100%;
	height: 100%;
}
#mainimage {
	width: 100%;
	min-height: 950px;
	overflow: hidden;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 9999;
	background-color: #FFF;
}
#mainimage .image {
	width: 100%;
	position: absolute;
	bottom: 0;
}
#mainimage .image img {
	width: 100%;
	display: block;
	margin: 0 auto;
}
#section-2 {
	background-image: url(../images/section-2.jpg);
	height: 1250px;
}
#section-2 h2 { background-image: url(../images/s2_h2.png); }
#section-3 {
	background-image: url(../images/section-3.jpg);
	height: 1400px;
}
#section-3 h2 { background-image: url(../images/s3_h2.png); }
#controller {
	width: 80px;
	height: 284px;
	padding-top: 48px;
	z-index: 70;
	position: absolute;
	top: 280px;
	right: 5px;
	overflow: hidden;
	background-image: url(../images/controller.png);
	background-repeat: no-repeat;
	text-align: center;
}
#controller ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
#controller li { }
#controller li a {
	text-decoration: none;
	font-size: 16px;
	color: #fff;
	height: 34px;
	line-height: 34px;
	display: block;
}
#controller li.m3 a {
	line-height: 18px;
	height: 44px;
	padding-top: 4px;
}
#controller a:hover,
#controller .on a { color: #faffa9; }
#audio {
	position: absolute;
	bottom: 50px;
	right: -105px;
	z-index: 125;
	width: auto;
}
.jp-audio { width: 120px; }
.jp-audio .jp-interface { height: 52px; }
.jp-stop { background-image: none; }
.jp-play {
	position: absolute;
	left: -35px;
	top: 21px;
	width: 25px;
	height: 25px;
	background: url(../images/play_off.png) no-repeat;
	cursor: pointer;
}
.jp-play:focus { background: url(../images/play_off.png) no-repeat; }
.jp-pause {
	display: none;
	position: absolute;
	left: -35px;
	top: 21px;
	width: 25px;
	height: 25px;
	background: url(../images/play_on.png) no-repeat;
	cursor: pointer;
}
.jp-volume-controls {
	background: url(../images/bar.png) no-repeat;
	height: 5px;
	position: absolute;
	top: 26px;
	left: 20px;
	display: none;
}
.jp-volume-bar {
	width: 123px;
	background: none;
	height: 6px;
	left: 0px;
	top: 0px;
}
.jp-volume-bar-value {
	background: url(../images/volume.png) no-repeat;
	height: 6px;
	position: absolute;
	top: 0px;
	left: 0px;
}
.jp-audio .jp-controls {
	width: 140px;
	padding: 20px 20px 0 20px;
}
.btns_play { transition: all .2s ease; }
.btns_play:hover { filter: brightness(120%) contrast(100%); }
.drawing {
	width: 73px;
	height: 70px;
	background: url(../images/drawing.png) no-repeat;
	display: block;
	z-index: 100;
	text-indent: -9999px;
	transition: all .2s ease;
	position: absolute;
	top: 793px;
	left: 50%;
	margin-left: 363px;
}
.drawing:hover { filter: brightness(120%) contrast(100%); }
.video {
	width: 605px;
	/*height: 343px;*/
	margin-top: 156px;
	margin-left: 353px;
	margin-bottom: 40px;
}
.video-container {
	position: relative;
	padding-bottom: 51%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
}
.video-container iframe,
.video-container object,
.video-container embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.footer {
	height: 80px;
	background-image: url(../images/footer.png);
	background-position: center top;
	background-repeat: no-repeat;
	background-color: #000;
	position: relative;
}
.footer.footer_w {
	background-image: url(../images/footer_w.png);
	background-color: #fff;
}
.layerPop {
	display: none;
	z-index: 3001;
	position: fixed;
	left: 50%;
	top: 50%;
	margin: -312px 0 0 -550px;
	width: 1090px;
	height: 614px;
	border: 0px solid #ccc;
	background: #000;
}
#popDrawing {
	position: fixed;
	top: 20px;
	margin: 0 0 0 -358px;
	width: 717px;
	height: 922px;/*position: absolute;
    top: 1080px;
	background: url(../images/bg_picture.png) no-repeat;*/
}
#popDrawing .link {
	position: absolute;
	bottom: 19px;
	left: 244px;
}
#popDrawing .link a {
	display: block;
	width: 229px;
	height: 67px;
	text-indent: -9999px;
}
.layerPop .btnclose {
	position: absolute;
	right: 0px;
	top: -50px;
	opacity: 1;
}
#popDrawing.layerPop .btnclose {
	right: 0px;
	top: 0px;
}
.layerPop .btnclose button {
	display: block;
	text-indent: -9999px;
	width: 49px;
	height: 49px;
	background: url(../images/btn_close_movie.jpg) no-repeat;
	cursor: pointer;
	filter: grayscale(50%);
}
.layerPop .btnclose button:hover { filter: grayscale(0%); }
.overlay {
	z-index: 3000;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.75);
	display: none;
}
.fb_btn {
	background: #4267b2;
	border: 1px solid #4267b2;
	cursor: pointer;
	margin: 0;
	white-space: nowrap;
	border-radius: 0.25rem;
	color: #fff;
	font-size: 1.25rem;
	padding: 0.15rem 0.95rem;
}
.dropdown-menu {
	border: 1px solid #101010;
	border-radius: 0px;
	background-color: #101010;
	background-color: rgba(0,0,0,.85);
}
.dropdown-menu>li { border-bottom: 1px solid #333; }
.dropdown-menu>li>a {
	color: #9d9d9d;
	font-size: 15px;
	line-height: 1.5;
}
.dropdown-menu>li>a:hover {
	color: #fff;
	background-color: #101010;
}
.dropdown-header {
	font-size: 15px;
	color: #fff;
	line-height: 1.5;
}
.home {
	position: absolute;
	top: 3px;
	left: 20px;
	z-index: 999;
}
.fb {
	position: absolute;
	top: 12px;
	right: 30px;
	display: none;
}
.navbar-brand { display: none; }
.dropdown:hover .dropdown-menu { display: block; }
#bottomMenu.fix { position: absolute; }
.pop {
	background: url(../images/pop.png) no-repeat;
	background-repeat: no-repeat;
	background-position: center top;
	width: 100%;
	height: 110px;
	position: fixed;
	z-index: 60;
	left: 0;
	bottom: 0;
}
.pop_elin {
	position: absolute;
	left: 507px;
	top: -27px;
}
.pop.down { bottom: -237px; }
.pop .btns {
	background-color: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	position: absolute;
	bottom: 0px;
	left: 50%;
	background-repeat: no-repeat;
	display: block;
	transition: filter .3s ease;
}
.pop .btn_download:hover { filter: brightness(130%); }
.pop .btn_download {
	background: url(../images/btn_download.png) no-repeat;
	background-position: 0 0;
	height: 74px;
	width: 223px;
	margin-left: 12px;
}
.pop .btn_register {
	background: url(../images/btn_register.png) no-repeat;
	background-position: 0px 0;
	height: 74px;
	width: 223px;
	margin-left: -230px;
	display: block;
}
.pop .btn_register:hover { filter: brightness(130%); }
.gohome {
	position: absolute;
	top: 25px;
	left: 50%;
	margin-left: 282px;
	color: #FFFFFF;
	text-decoration: none;
	font-size: 15px;
}
@keyframes flash { 0% {
background-position: 0 0;
}
 5% {
background-position-y: -100px;
}
 10% {
background-position-y: -200px;
}
 15% {
background-position-y: -300px;
}
 20% {
background-position-y: -400px;
}
 25% {
background-position-y: -500px;
}
 30% {
background-position-y: -600px;
}
 100% {
background-position-y: -600px;
}
}
.close_pop {
	position: absolute;
	bottom: 10px;
	right: 0px;
	cursor: pointer;
	z-index: 11;
}
.open_pop {
	position: fixed;
	bottom: 0px;
	right: 0px;
	cursor: pointer;
	z-index: 11;
	display: none;
}
.leaves {
	z-index: 1;
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -750px;
	width: 1920px;
	height: 1500px;
}
.october-leaf {
	z-index: 0;
	position: absolute;
	background-color: transparent;
	background-image: url('../images/flower.png');
	opacity: 0.8 !important;
	-webkit-transform: translateZ(0);
	-moz-transform: translateZ(0);
	transform: translateZ(0);
}
@media (max-width: 767px) {
.navbar-brand { display: block; }
.pop,
.home,
#controller,
.drawing { display: none; }
.footer {
	background-size: 100%;
	height: 80px;
}
.abgne_tab {
	width: 100%;
	margin-left: 0vh;
}
.skill_tab.abgne_tab { margin-top: 42vh; }
.video-container { padding-top: 5px; }
.abgne_tab .abgne_tab ul.tabs {
	padding-left: 1.5vw;
	overflow: hidden;
	padding-top: 18px;
}
.abgne_tab .abgne_tab ul.tabs li {
	margin-right: 1vw;
	margin-bottom: 20vh;
}
ul.tabs li a {
	/*width: 44px;
	height: 44px;*/
	width: 13.6vw;
	height: 13.6vw;
	background-size: cover;
}
.skill_tab>ul.tabs li a {
	height: 33px;
	background-size: auto;
}
.abgne_tab .abgne_tab .tab_content {
	padding: 15px 15px;
	min-height: 64vh;
}
/*.header {
	background-image: url(../images/section_m_header.jpg);
	height: 107.2vh;
	background-repeat: no-repeat;
	background-size: cover;
}
#section-1 {
	background-image: url(../images/section_m_1.jpg);
	height: 131.2vh;
	background-size: cover;
}
#section-2 {
	background-image: url(../images/section_m_2.jpg);
	height: 128.3vh;
	background-size: cover;
}
#section-3 {
	background-image: url(../images/section_m_3.jpg);
	height: 206vh;
	background-size: cover;
}*/
.btn-area {
	left: 4vw;
	top: 31vh;
	width: 54vw;
	margin-left: auto;
}
.video {
	position: absolute;
	left: 7vw;
	top: 21vh;
	width: 52vw;
	margin: auto;
	z-index: 1;
}
img { max-width: 100%; }
.leadimg {
	position: relative;
	top: 10vh;
	left: auto;
	margin-left: auto;
}
.chara01 {
	top: 64vh;
	display: none;
}
.chara02 {
	top: 58vh;
	right: 2vh;
}
.header {
	height: 100vh;
	background-size: cover;
}
#section-1 .container {
	width:100vw;
	position:relative;
	margin-left:auto;
	left:auto;
}
#section-1 {
	height: 100vh;
	background-size: cover;
}
#section-1 .container .dec {
	width:100vw;
	height:100vh;
}
#section-1 h2 {
    width: 120px;
    height: 48px;
    margin: 70px auto 0;
    z-index: 5;
    position: relative;
    background-size: contain;
}
#section-1 .container .dec .role-tab {
    margin-left: -80px;
    margin-top: 0px;
    z-index: 20;
    position: absolute;
    bottom: 0;
    transform: scale(.7);
}
#section-1 .container .role {
    top: 28vh;
}
#section-1 .container .dec .roledec {
    margin-left: 130px;
}
#section-1 .container .dec .roledec .player {
	display:none !important;
}
#section-2 {
    background-image: url(../images/section-2-m.jpg);
    height:84.5vh;
}
#section-3 {
    background-image: url(../images/section-3-m.jpg);
    height:84.5vh;
}
}
@media (max-width: 480px) {
.footer { height: 50px; }
}
@media (max-width: 320px) {
}
@media (min-width: 768px) and (max-width: 979px) {
.footer { background-size: 100%; }
}
@media (min-width: 980px) {
}
@media (min-width: 1400px) {
.fb { display: block; }
}
