@charset "UTF-8";
html {
	width: 100%;
	height: 100%;
}
body {
	position: relative;
	width: 100%;
	min-width: 1024px;
}

/*--------------------------------
	Header
--------------------------------*/
header {
	position: relative;
	height: 800px;
	width: 100%;
	min-width: 1024px;
	background: url(../img/top/bg_header.jpg) center center no-repeat;
	background-size: cover;
	z-index: 100;
}
#header_inner {
	position: relative;
	width: 960px;
	height: 800px;
	margin: 0 auto;
}
#title {
	position: absolute;
	top: 74px;
	left: 0;
	z-index: 10;
}
#top_lead {
	position: absolute;
	top: 10px;
	right: 0;
	z-index: 10;
}
#top_cast {
	position: absolute;
	top: 6px;
	left: 214px;
	z-index: 10;
}
#top_main {
	position: absolute;
	top: 1px;
	right: -32px;
	z-index: 2;
}
#btn_sell {
	position: absolute;
	top: 603px;
	left: 4px;
	z-index: 10;
}
#btn_sell a {
	background:url(../img/top/btn_sell.png) 0 0 no-repeat;
	width:379px;
	height:96px;
	text-indent:-9999px;
	margin:0 auto 64px;
	display:block;
}
#btn_sell a:hover {
	background:url(../img/top/btn_sell.png) 0 -107px no-repeat;
}
#btn_rental {
	position: absolute;
	top: 580px;
	right: 10px;
	z-index: 10;
}
#btn_rental a{
	background:url(../img/top/btn_rental.png) 0 0 no-repeat;
	width: 572px;
	height: 118px;
	text-indent:-9999px;
	margin:0 auto 64px;
	display:block;
}
#btn_rental a:hover {
	background:url(../img/top/btn_rental.png) 0 -129px no-repeat;
}

/*---------- NEWS ----------*/
#tumblr_widget{
	position: absolute;
	top: 448px;
	left: 18px;
	display: block;
	width: 422px;
	height: 134px;
	padding: 25px 30px 30px 35px;
	background: url(../img/top/bg_news.png) 0 0 no-repeat;
	z-index: 10;
}
#tumblr_widget ul {
	width: 345px;
	font-family: 'Lucida Grande', 'segoe UI', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
}
#tumblr_widget li {
	padding: 8px 0 8px 8px;
	border-bottom: #000 solid 2px;
	font-size: 16px;
	background: url(../img/common/news_line.png) 0.6em center no-repeat;
}
#tumblr_widget li:last-child {
	border-bottom: none;
}
#tumblr_widget #news_link {
	position: absolute;
	top: -25px;
	left: -20px;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
#news_link:hover {
	opacity: 0.7;
}
#tumblr_widget a {
	text-decoration: none;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
#tumblr_widget a:hover {
	color: #ff3668;
	text-decoration: none;
}
#news_inner {
	height: 93px;
}

/*---------- SNS ----------*/
#sns-wrap {
	position: absolute;
	width: 960px;
	height: 32px;
	top: 713px;
	left: 26px;
	z-index: 9999;
}
#sns_share li{
	float: left;
	margin-right: 6px;
	line-height: 1.5;
}
#sns_share li#spotw {
	margin-right: 12px;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
#spotw:hover {
	opacity: 0.7;
}

/*--------------------------------
	Navigation
--------------------------------*/
#nav {
	width: 100%;
	height: 50px;
	margin: 0 auto;
	background: url(../img/common/nav_repeat.gif) repeat;
	z-index: 8000;
}
#nav ul {
	width: 1024px;
	height: 45px;
	margin: 0 auto;
}
#nav ul li {
	display: block;
	float: left;
	height: 45px;
}
nav ul li a {
	display: block;
	height: 100%;
	background-image: url(../img/common/nav.png);
	background-repeat: no-repeat;
	text-indent: -9999px;
	-webkit-transition: all .25s ease;
	transition: all .25s ease;
}

#nav_top { width: 86px; }
#nav_news { width: 93px; }
#nav_movie { width: 168px; }
#nav_product { width: 169px; }
#nav_intro { width: 169px; }
#nav_story { width: 169px; }
#nav_cast { width: 170px; }

#nav_top a { background-position: 0 -45px; }
#nav_news a { background-position: -86px -45px; }
#nav_movie a { background-position: -179px -45px; }
#nav_product a { background-position: -347px -45px; }
#nav_intro a { background-position: -516px -45px; }
#nav_story a { background-position: -685px -45px; }
#nav_cast a { background-position: -854px -45px; }

#nav_top a:hover { background-position: 0 0; }
#nav_news a:hover { background-position: -86px 0; }
#nav_movie a:hover { background-position: -179px 0; }
#nav_product a:hover { background-position: -347px 0; }
#nav_intro a:hover { background-position: -516px 0; }
#nav_story a:hover { background-position: -685px 0; }
#nav_cast a:hover { background-position: -854px 0; }

/*--------------------------------
footer
--------------------------------*/
footer {
	position:relative;
	overflow:hidden;
	width:100%;
	height:100%;
}
footer:before {
	content: '';
	display: block;
	height: 74px;
	background: url(../img/common/footer_top_repeat.png) repeat-x 0 0;
}
.footer_bgcolor {
	width: 100%;
	background-color: #FFF;
}
footer .footer_att,
footer .copyright {
	margin-bottom: 15px;
	font-size: 10px;
	line-height: 2;
	text-align: center;
	color: #363636;
	font-family: 'Lucida Grande', 'segoe UI', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
}
.footer-inner {
	width: 1024px;
	margin: 0 auto;
	padding: 20px 0;
}

/*--------------------------------
	Contents
--------------------------------*/
#wrapper {
	position: relative;
	background-color: #ff56a6;
	padding-top: 50px;
}
#content_bg {
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
}
.content_bg {
	height: 100%;
	background-image: url(../img/common/bg_top.png),url(../img/common/bg_bottom.png);
	background-position: right top, left bottom;
	background-repeat: no-repeat,no-repeat;
	background-attachment: fixed;
	z-index: 2;
}
section {
	position: relative;
	padding: 65px 0 20px;
}
section h2 {
	text-align: center;
}
.w880 {
	width: 880px;
	margin: 0 auto;
}
.w960 {
	width: 960px;
	margin: 0 auto;
}
.bg_blue {
	background: #01b4ed;
}

/*--------------------------------
	Movie
--------------------------------*/
#movie {
	position: relative;
	height: 1024px;
	width: 100%;
	min-width: 1024px;
	background: url(../img/movie/bg_movie.png) center top repeat-x;
	background-color: none;
	text-align: center;
}
#movie h2 {
	margin-bottom: 64px;
}

#movie p {
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}

#movie p:hover {
	opacity: 0.7;
}

#movie ul {
	margin: 64px 0 0 0;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: center; /* Safari */
	justify-content: center;
}
#movie ul li {
	margin-right: 40px;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}

#movie  ul li:hover {
	opacity: 0.7;
}

#movie ul li:last-child {
	margin: 0;
}

.movie_bg {
	position: absolute;
	right: 0;
	bottom: 88px;
}
.movie_bg_shadow {
	background: url(../img/movie/movie_bg_shadow.png) 0 0 no-repeat;
	width: 218px;
	height: 541px;
	position:absolute;
	bottom:0;
	right:0;
}
.movie_bg2 {
	position: absolute;
	left: 77px;
	top: 204px;
}
.movie_bg_sparkle {
	background: url(../img/movie/movie_bg_sparkle.png) 0 0 no-repeat;
	width: 90px;
	height: 116px;
}
/*--------------------------------
	Products
--------------------------------*/
#products h2 {
	margin-bottom: 43px;
}
#products .w880 {
	padding: 0 24px;
}
.w880 > div {
	margin-top: 48px;
}
#products dl {
	padding: 23px 30px;
	background: rgba(255,255,255,0.8);
}
#sell h3 + dl {
	margin-bottom: 15px;
}
#products dl dt {
	display: block;
	float: left;
}
#sell dt {
	margin-right: 22px;
}
#sell dl dd {
	position: relative;
	float: left;
	display: block;
	width: 398px;
	height: 304px;
	font-size: 12px;
	line-height: 3;
}
#sell dl dd li.tokuten1 {
	margin: 20px 0 5px;
	line-height: 1.5;
}
#sell dl dd li.tokuten2 {
	margin: 5px 0 0;
	line-height: 1.5;
	letter-spacing: -1.8px;
}
#sell dl dd li.tokuten_att {
	margin: 0;
	padding-left: 1em;
	font-size: 10px;
	line-height: 1.5;
}
#btn_buy {
	position: absolute;
	right: 0;
	bottom: 0;
}
#btn_buy a {
	background:url(../img/products/btn_buy.png) 0 0 no-repeat;
	width: 206px;
	height: 59px;
	text-indent:-9999px;
	display:block;
}
#btn_buy a:hover {
	background:url(../img/products/btn_buy.png) 0 -59px no-repeat;
}
#rental dl {
	position: relative;
}
#rental dt {
	margin-right: 50px;
}
#rental dd {
	padding: 34px 0 0;
}
#rental ul li {
	margin-bottom: 13px;
	font-size: 12px;
	line-height: 1.8;
}
#rental ul li:first-child {
	margin-bottom: 30px;
}
#tsutaya {
	position: absolute;
	top: -27px;
	right: -20px;
}
.products_att {
	font-size: 12px;
	line-height: 2;
	text-align: right;
}

/*--------------------------------
	Introduction
--------------------------------*/
#intro h2 {
	margin-bottom: 25px;
}
#intro p {
	color: #FFF;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.6;
	text-shadow: #ff56a6 1px 1px 0px, #ff56a6 -1px 1px 0px, #ff56a6 1px -1px 0px, #ff56a6 -1px -1px 0px;
}
#intro_head {
	position: relative;
	margin-bottom: 35px;
}
.intro_head_img {
	position: relative;
	height: 560px;
}
.intro_h3 {
	position: relative;
	width: 100%;
	height: 110px;
	margin: 0 0 25px;
	padding: 20px 0;
	background: #fdd000;
	z-index: 2;
}
#intro_content {
	position: relative;
}
#intro_content h4 {
	margin-bottom: 25px;
}
.intro_block {
	position: relative;
	margin-top: -15px;
	z-index: 5;
}
.intro_block p {
	width: 632px;
	margin: 10px 0;
	padding: 0 32px;
}
/*---------- IMG ----------*/
.intro_img1 {
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -323px;
	z-index: 1;
}
.intro_img2 {
	position: absolute;
	top: 363px;
	left: 50%;
	margin-left: -433px;
	z-index: 1;
}
.intro_img3 {
	position: absolute;
	top: 130px;
	right: -5px;
	z-index: 1;
}
.intro_img4 {
	position: absolute;
	top: 535px;
	left: 3px;
	z-index: 1;
}
.intro_img5 {
	position: absolute;
	top: 940px;
	right: 34px;
	z-index: 1;
}

/*---------- SPARKLE ----------*/
.intro_sparkle1 {
	position: absolute;
	top: 120px;
	left: 155px;
	z-index: 1;
}
.intro_sparkle2 {
	position: absolute;
	top: 187px;
	left: 23px;
	z-index: 1;
}
.intro_sparkle3 {
	position: absolute;
	top: 47px;
	right: 140px;
	z-index: 1;
}
.intro_sparkle4 {
	position: absolute;
	top: 138px;
	right: 99px;
	z-index: 1;
}
.intro_sparkle5 {
	position: absolute;
	top: 213px;
	right: 272px;
	z-index: 1;
}
.intro_sparkle6 {
	position: absolute;
	top: 540px;
	left: 105px;
	z-index: 1;
}
.intro_sparkle7 {
	position: absolute;
	bottom: 70px;
	right: 5px;
	z-index: 1;
}

/*--------------------------------
	Story
--------------------------------*/
#story h2 {
	margin-bottom: 60px;
}
#story p {
	margin-bottom: 40px;
	color: #FFF;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.625;
	text-shadow: #01b4ed 1px 1px 0px, #01b4ed -1px 1px 0px, #01b4ed 1px -1px 0px, #01b4ed -1px -1px 0px;
}
#story img {
	margin: 0 30px;
}
.story_sparkle_wrap {
	position: relative;
}
.story_sparkle2 {
	position: absolute;
	top: -90px;
	left: -30px;
	z-index: 1;
}
.story_sparkle1 {
	position: absolute;
	top: -90px;
	right: 170px;
	z-index: 1;
}

/*--------------------------------
	Cast & Staff
--------------------------------*/
#caststaff {
	height: 1130px;
}
#caststaff h2 {
	margin-bottom: 64px;
}
#caststaff p {
	margin-bottom: 40px;
	color: #FFF;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.625;
	text-shadow: #01b4ed 1px 1px 0px, #01b4ed -1px 1px 0px, #01b4ed 1px -1px 0px, #01b4ed -1px -1px 0px;
}
#soukanzu {
	position: relative;
	height: 758px;
	margin-bottom: 20px;
}
#chart {
	width: 934px;
	height: 758px;
	margin: 0 auto;
	background: url(../img/caststaff/chart.png) no-repeat center top;
	z-index: 3;
}
#chart li {
	display: block;
	text-indent: -9999px;
}
#chart li a {
	position: absolute;
	display: block;
}
#chart a:hover {
	background-image: url(../img/caststaff/chart_on.png);
	background-repeat: no-repeat;
}

.cast1 a { width: 210px; height: 155px; }
.cast2 a { width: 167px; height: 152px; }
.cast3 a { width: 150px; height: 152px; }
.cast4 a { width: 150px; height: 152px; }
.cast5 a { width: 116px; height: 115px; }

.cast1 a { top: 408px; left: 253px; }
.cast2 a { top: 422px; left: 567px; }
.cast3 a { top: 227px; left: 277px; }
.cast4 a { top: 41px; left: 710px; }
.cast5 a { top: 448px; left: 83px; }

.cast1 a:hover { background-position: -240px -408px; }
.cast2 a:hover { background-position: -554px -422px; }
.cast3 a:hover { background-position: -264px -227px; }
.cast4 a:hover { background-position: -697px -41px; }
.cast5 a:hover { background-position: -70px -448px; }

/*		Cast Inline		*/
#cast_hidden { display:none; }
.cast_content {
	position: relative;
	width: 800px;
	height: 500px;
	margin: 0 auto;
}
.cast_txt_wrap {
	position: absolute;
	top: 60px;
	left: 360px;
	width: 390px;
}
.cast_txt_wrap dt {
	margin-bottom: 20px;
}
.cast_txt1 {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.5;
}
.cast_txt2 {
	font-size: 13px;
	line-height: 1.6;
}
.cast_comment1 {
	position: absolute;
	display: block;
	left: -95px;
	bottom: -90px;
	width: 460px;
	color: #FFF;
}
.cast_comment2 {
	position: absolute;
	display: block;
	left: -100px;
	bottom: -120px;
	width: 450px;
	color: #FFF;
}
.cast_bg {
	background-repeat: no-repeat;
	background-position: 0 0;
}

.cast1_inner { background-image: url(../img/caststaff/cast1.png); }
.cast2_inner { background-image: url(../img/caststaff/cast2.png); }
.cast3_inner { background-image: url(../img/caststaff/cast3.png); }
.cast4_inner { background-image: url(../img/caststaff/cast4.png); }
.cast5_inner { background-image: url(../img/caststaff/cast5.png); }

