/* ------------------------------- common style */
a {
	text-decoration: none; 
	color: inherit;
	-moz-transition: all .5s; 
	-webkit-transition: all .5s;  
	-ms-transition: all .5s;  
	-o-transition: all .5s;  
	transition: all .5s; 
}
a:hover {
	text-decoration: none; 
	opacity: 0.8;
}
*{
	margin: 0;
	padding: 0;
	font-family: 'Noto Sans TC', sans-serif;
}
body {
	font-size: 18px;
	font-family: "Noto Sans TC", sans-serif;
	line-height: 2;
	color: #111111;
}
h1,h2,h3,h4,h5,h6 {
	font-family: "Noto Sans TC", sans-serif;
	line-height: 1.3;
}
h1, h2 {font-size: 46px;}
h3 {font-size: 36px;}
h4 {font-size: 28px;}
h5 {font-size: 18px;}
p {
	margin-bottom: 1rem;
	line-height: 1.5;
}
p:last-child {margin-bottom: 0;}
img{
	max-width: 100%;
	display: block;
	vertical-align: top;
	margin: auto;
}
.main {
	width: 940px;
	margin: auto;
}
.container {padding: 25px 0;}
section {display: block; padding: 20px 0;}
.content {padding: 40px 0;}
.clearfix {clear: both;}
.title h1, .title h2 {
	font-family: 'Noto Serif TC', serif;
	text-align: center;
	padding: 1rem 0;
	letter-spacing: 2px;
}
.title {
	position: relative;
	margin-bottom: 1rem;
	z-index: 2;
	text-align: center;
}
.title h1 span {
	font-size: 64px;
	font-family: 'Noto Serif TC', serif;
}
.dot {
	width: 1rem;
	height: 1rem;
	background: #a6a6a6;
	margin: auto;
	margin-bottom: 1rem;
}
.title h2 {
	padding-top: 0;
	margin-bottom: -3.5rem;
}
.title h3 {
	color: #848484;
}
.title p {
	line-height: 1.5;
}
.title h4 {
	color: #808080;
	padding-top: 20px;
	font-weight: 400;
}
.bg-gray {background: #eee;}
.bg-black {background: #000;}
.row {
	width: 100%;
	display: block;
}
.row:after {
	content: '';
	clear: both;
	display: block;
}
.col {
	float: left;
	padding: 0 1%;
    box-sizing: border-box;
}
.col-2 {width: 50%;	}
.col-md-3 {width: 31.33%;}
.margin-bottom-20 {
	margin-bottom: 20px;
}
.block {
	border: 3px solid #000;
	text-align: center;
	font-size: 24px;
	line-height: 1.5;
	margin: 10px auto;
}
/* ------------------------------- fv style */
.fv {
	background: url('../images/fv_bg.jpg');
	background-size: cover;
	/* position: fixed; */
	z-index: -99;
	width: 100%;
	height: 500px;
}
.fv .main {
	position: absolute;
    left: 50%;
    transform: translate(-50%);
}
.fv .fv_sub {
	padding: 7rem 0 7rem 0;
}
.logo {padding: 10px 0;}
.logo img {
	margin: auto;
}
/* ------------------------------- section style */
.about {
	background: url('../images/about_bg.png') no-repeat;
	background-size: contain;
	background-position: left top;
}
.intro {
	text-align: center;
}

.carousel {
	padding: 50px 30px;
	position: relative;
}
.carousel .item .desc {
	border-left: 5px solid #000;
	padding: 4px 10px;
	margin: 10px 0;
}
.carousel .item .desc h5 {
	line-height: 1;
}
.carousel .item .desc p {
	margin-bottom: 0.5rem;
}
.carousel .item .desc .category {
	background: #000;
	color: #fff;
	padding: 0 8px;
	margin: 0 8px;
}
.carousel:after {
	content: 'PERFORMANCE';
	font-weight: 700;
	position: absolute;
	bottom: 0;
    left:50%;
    transform: translate(-50%);
    line-height: 0.7;
    color: #fff;
    font-size: 36px;
    font-family: sans-serif;
}
.owl-theme .owl-nav {display: none;}
.select .select_link {
	position: relative;
}
.select .img_text {
	position: absolute;
	bottom: 0;
    left:50%;
    transform: translate(-50%);
    width: 100%;
    padding: 0 0 5% 0;
    text-align: center;
    color: #fff;
    box-sizing: border-box;
}
.select .img_text img {
    width: 80%;
    margin: auto;
    max-width: fit-content;
}
.select .img_text h1 {
	font-size: 60px;
}
.select .img_text h4 {
	letter-spacing: 1px;
}
.select .img_text .block {
	width: 80%;
	border-color: #fff;
	margin: 40px auto;
}
.select .select_link a img {
	-moz-transition: all .5s; 
	-webkit-transition: all .5s;  
	-ms-transition: all .5s;  
	-o-transition: all .5s;  
	transition: all .5s; 
}
.select .select_link a:hover img {
	opacity: 0.8;
}
.project {
	padding: 10px;
}
.project .title h1 {
	padding: 0;
}
.project_title h3 {
	background: #eee;
	text-align: center;
	width: fit-content;
	margin: auto;
	padding: 0 20px;
}
.project_title {
	background: url('../images/project_title_bg.png') repeat-x;
	background-position: left center;
	margin-top: 10px;
}
.project .movie {
	padding: 20px;
}
.project .movie iframe {
	width: 100%;
	height: 490px;
}
.place {
	padding: 20px;
	box-sizing: border-box;
}
.place .item {
	background: #fff;
	text-align: center;
	margin: 10px 1%;
	padding: 20px 0 10px;
}
.place .item img {
	margin: auto;
}
.place .item p {
	margin: 10px 0;
}
.service .item {
	text-align: center;
	padding: 10px 0 15px;
	margin: 10px 1%;
}
.producer {
	display: flex;
}
.director {
	display: flex;
	border-right: 1px solid #fff;
	width: 50%;
}
.art {
	display: flex;
	width: 50%;
}
.producer .photo {
	width: 275px;
    display: contents;
}
.intro_d >* {
	color: #fff;
}
.intro_d {
	width: 278px;
	z-index: 2;
	position: relative;
	margin: 0 -22%;
	padding: 3% 0;
}
.intro_d  .name {
	text-align: center;
	padding: 10% 0;
	line-height: 1;
    letter-spacing: 2px;
}
.intro_d  .name h4 {
	color: #4f4f4f;
	margin-top: -24px;
	z-index: -1;
    position: relative;
}
.intro_d  .name p {
	font-size: 18px;
    line-height: 1.2;
    color: #c0c0c0;
}
.intro_d p {
	font-size: 16px;
	margin-bottom: 0.5rem;
}
.director .intro_d {
	margin-right: 15px;
}
.art .intro_d {
	margin-left: 15px;
}
.contact a {
	display: inline-flex;
}
.contact img {
	padding: 0 10px;
}

/* ------------------------------- footer */
.footer {
	text-align: center;
    color: #fff;
}
.footer h3 {
	margin: 10px 0 30px;
    font-size: 34px;
    letter-spacing: 2px;
}
.footer h2 {
	margin: 30px 0 60px;
    font-size: 42px;
    letter-spacing: 2px;
}


/* ------------------------------- max-witdh < 940px */
@media screen and (max-width: 940px){
	.main{width: 100%;}
	h1, h2 {font-size: 36px;}
	h3 {font-size: 20px}
	h4 {font-size: 18px;}
	p {font-size: 15px;}
	.fv {background-position: center; height: 260px;}
	.fv .fv_sub {padding: 2rem 10px 2rem 10px;}
	.fv .fv_sub img {width: 80%;}
	.select .img_text h1 {font-size: 46px;}
	.select .img_text h4 {font-size: 20px;}
	.project .movie iframe {height: 400px;}
	.row {display: block;}
	.col-2, .col-md-3 {width: 100%; margin-bottom: 15px;}
	.col-sm-2 {width: 48%;}
	.place .item {margin: 5px 1%;}
	.producer {display: block;}
	.director {border-right: none; width: 100%; border-bottom: 1px solid #fff;}
	.art {width: 100%;}
	.intro_d {margin: 0 -32%;}
	.intro_d .name h4 {margin-top: -16px;}
	.title h1, .title h2 {letter-spacing: 0;}
	.footer {padding-right: 10px; padding-left: 10px;}
	.footer h3 {font-size: 20px; letter-spacing: 0px;}
	.footer h2 {font-size: 26px; letter-spacing: 0px;}
	.footer .footer_logo {width: 15%;}
}
@media screen and (max-width: 560px){
	.project .movie iframe {height: 200px;}
}