@charset "UTF-8";


/*-------------------------------------------------------------
 setting
-------------------------------------------------------------*/

/* 基本カラー
-----------------------------------------------

/* キーカラー
---------
#003f5d
---------
*/

/* ポイントカラー
---------
#fff
#0182b6
#e6f5fd
---------
*/

/* 背景カラー
---------

---------
*/


/* フォント
-------------------------------------------*/
.en {
	font-family: 'Hiragino maru Gothic ProN', 'ヒラギノ丸ゴ ProN';
	letter-spacing: .3rem;
}

.t_shadow {
	text-shadow:0px 0px 5px rgba(0,0,0,.3);
}


/*-------------------------------------------------------------
 レイアウト
-------------------------------------------------------------*/
/*コンテンツ枠
-------------------------------------------*/
.drama_page_wrap {
	background-image: url(../images/bg_contents.jpg);
	transition: all 0.3s ease;
}

.drama_page_contents {
	padding-bottom: 40px;
}

.drama_page_contents p {
	font-size: 1.8rem;
	line-height: 1.9;
	text-align: justify;
}

.drama_page_fit_contents {
	max-width: -webkit-calc(1240px + 60px);
	max-width: calc(1240px + 60px);
	margin: 0 auto;
	padding: 0 30px;
	text-align: left;
}


@media screen and (min-width: 751px) {
	.drama_page_wrap {
		background-size: cover;
		background-attachment: fixed;
	}
}


@media screen and (max-width: 750px) {
	/*.drama_page_wrap {
		background: #102250;
	}*/
	
	.drama_page_fit_contents {
		padding: 0 3%;
	}
	
	.drama_page_contents {
		padding-bottom: 20px;
	}
	
	.drama_page_contents p {
		font-size: 1.6rem;
		line-height: 1.8;
	}
}



/*ヘッダー
-------------------------------------------*/
/* ナビゲーション */
.drama_nav {
	background: url(../images/bg_nav.jpg) center;
	text-align: center;
}

.drama_nav nav {
    width: 100%;
    max-width: 1240px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	border-left: 1px solid rgba(255,255,255,.5);
	border-right: 1px solid rgba(255,255,255,.5);
}

.drama_nav nav .drama_title {
	width: 25%;
}

.drama_nav nav .drama_title a {
	padding: 5px;
	display: block;
}

.drama_nav nav .drama_title img {
	max-height: 75px;
}

.drama_nav nav ul {
	width: 75%;
	display: flex;
}

.drama_nav nav li {
	width: calc(100% / 3);
}

.drama_nav nav li a {
	width: 100%;
	min-height: 90px;
	border-left: 1px solid rgba(255,255,255,.5);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	color: #FFF;
	line-height: 1.4;
	text-align: center;
	vertical-align: middle;
}

.drama_nav nav li a.current {
	background: url("../images/bg_nav_active.png") center;
}

.drama_nav nav li .en {
	margin-top: -.5rem;
	display: block;
	color: #fff;
	font-size: 2.8rem;
}

.drama_nav nav li .jp {
	font-size: 1.4rem;
	color: #fff;
}

.drama_nav nav li:hover .en,
.drama_nav nav li:hover .jp,
.drama_nav nav li a.current .en,
.drama_nav nav li a.current .jp {
	color: #fff;
}


@media screen and (min-width: 751px) {
    .drama_nav {
        background: url("../images/bg_nav.jpg") center;
    }

	.drama_nav nav .drama_title:hover {
		opacity: .7;
	}
	.drama_nav nav li:hover a {
		background: url("../images/bg_nav_active.png") center;
	}
	.nav_sp,
	.nav_top {
		display: none !important;
	}
}


@media screen and (max-width: 750px) {
	.nav_pc .drama_nav ul {
		display: none;
	}
	
	.drama_nav nav,
	.drama_nav nav .drama_title {
		width: 100%;
	}
	.drama_nav nav li {
        background: url("../images/bg_nav.jpg") center;
		background-size: cover;
    }
	.drama_nav nav li a.current {
        background: url("../images/bg_nav_active.png") center;
		background-size: contain;		
	}
	.drama_nav nav .drama_title img {
		max-height: 60px;
	}
	
	.nav_sp {
		margin-top: 20px;
	}
	
	.nav_sp .drama_nav nav {
		width: 100%;
		display: block;
		position: relative;
	}

	.nav_sp .drama_nav nav .drama_title {
		display: none;
	}

	.nav_sp .drama_nav nav ul {
		width: 100%;
		display: block;
	}

	.nav_sp .drama_nav nav li {
		width: 100%;
		min-height: 68px;
	}
	
	.nav_sp .drama_nav nav li a {
		min-height: 68px;
		line-height: 1.1;
		border-left: none;
	}
	
	.nav_sp .drama_nav nav li:not(:first-child) a {
		border-top: 1px solid rgba(255,255,255,.5);
	}
	
	.nav_sp .drama_nav nav li .en {
		font-size: 2.2rem;
	}

	.nav_sp .drama_nav nav li .jp {
		font-size: 1.1rem;
	}
}



/*フッタ―
-------------------------------------------*/
.drama_copyright {
	margin-top: 40px;
	color: #003f5d;
	font-size: 1.4rem;
	font-weight: 700;
	text-align: center;
}


@media screen and (max-width: 750px) {
	.drama_copyright {
		margin-top: 20px;
		font-size: 1.2rem;
	}
}



/*-------------------------------------------------------------
 共通パーツ
-------------------------------------------------------------*/

/* ページタイトル */
.drama_page_ttl {
	margin-bottom: 30px;
	padding: 5px 30px;
	min-height: 60px;
	background: url("../images/bg_ttl.jpg");
	background-size: cover;
	display: flex;
	align-items: center;
	color: #ffffff;
	line-height: 1;
}

.drama_page_ttl .en {
	margin: 0 10px;
	font-size: 3.4rem;
}


/* タイトル */
.drama_ttl {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px dotted #003f5d;
}

.drama_ttl h3 {
	padding-left: 20px;
	border-left: 5px solid #003f5d;
	color: #003f5d;
	font-size: 2.5rem;
	font-weight: 700;
}


/* コンテンツ背景 */
.drama_contents {
	padding: 30px 40px;
	background: rgba(255,255,255,.8);
	position: relative;
	text-align: center;
}


/* ボタン */
.btn_area_drama {
	margin-top: 20px;
}

.btn_drama a {
	padding: 10px 20px;
	background-color: #003f5d;
	display: inline-block;
	color: #FFF;
	text-align: center;
}

.btn_drama a:hover {
	opacity: .7;
}

.btn_drama [class*="icon_arrow"]:before {
	margin-right: 10px;
	font-size: 12px;
	vertical-align: 15%;
}

/* SNSボタン */
.sns_block {
	margin: 20px 0;
}

.sns_list {
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
}

.sns_list li {
	margin-left: 10px;
	line-height: 0;
}

.top_maiimage .sns_block {
	position: absolute;
	top: 0;
	right: 20px;
	z-index: 1001;
}


/* 画像ダウンロード禁止対応 */
.guard_wrap {
	width: 100%;
	height:100%;
	position: relative;
}

.guard {
	display:block;
	width:100%;
	height:100%;
	position:absolute;
	background: url(data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7);
	z-index: 1000;
}


@media screen and (max-width: 750px) {
	.drama_page_ttl {
		margin-bottom: 15px;
		padding: 5px 10px;
		min-height: 50px;
	}

	.drama_page_ttl .en {
		margin: 0 5px;
		font-size: 2.4rem;
	}
	
	.drama_ttl {
		margin-bottom: 12px;
		padding-bottom: 10px;
	}

	.drama_ttl h3 {
		padding-left: 15px;
		font-size: 1.8rem;
	}
	
	.drama_contents {
		padding: 15px;
	}
	
	.btn_area_drama {
		margin-top: 15px;
	}
	
	.btn_drama a {
		display: block;
	}
	
	.sns_block {
		margin: 10px 0;
	}
	
	.top_maiimage .sns_block {
		position: absolute;
		top: 10px;
		right: 10px;
		margin: 0;
	}
}



/*-------------------------------------------------------------
 トップページ
-------------------------------------------------------------*/
.top_maiimage {
	max-width: 1240px;
	margin: 0 auto;
	padding-bottom: 40px;
	position: relative;
}


@media screen and (max-width: 750px) {
	.top_maiimage {
		padding-bottom: 20px;
	}
}



/*-------------------------------------------------------------
 番組紹介
-------------------------------------------------------------*/
.drama_contents.intro_contents {
	padding: 20px;
}

.intro_wrap {
	margin: 0 20px 60px 20px;
	/*background: url("../images/bg_intro.png") center 5% no-repeat;*/
	background-size: contain;
}

.intro_copy {
	padding: 60px 0;
	color: #0182b6;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.8;
}

.intro_ttl {
	margin: 60px 0 25px;
	color: #003f5d;
	font-size: 2.6rem;
	font-weight: 700;
}

.about_contents {
	margin-top: 40px;
	padding: 30px 40px;
	background: #003f5d;
	color: #FFF;
}

.about_ttl {
	margin: -10px 0 15px;
	position: relative;
	text-align: center;
	line-height: 1.4;
}

.about_ttl:before,
.about_ttl:after {
	width: calc( 50% - 9rem );
	height: 2px;
	background: #FFF;
	display: block;
	position: absolute;
	top: 50%;
	content: "";
}

.about_ttl:after {
	right: 0;
}

.about_ttl .en {
	font-size: 3.6rem;
}

.about_ttl .jp {
	display: block;
}

.intro_staff {
	font-size: 1.6rem;
	line-height: 1.7;
	text-align: left;
}

.intro_staff dt {
	margin-bottom: 1rem;
}

.intro_production p {
	margin-top: 3rem;
	font-size: 1.6rem;
}

@media screen and (min-width: 751px) {
	.intro_staff {
		margin-top: 30px;
	}
}


@media screen and (max-width: 750px) {
	.drama_contents.intro_contents {
		padding: 15px;
	}

	.intro_wrap {
		margin: 0 0 20px 0;
		background: none;
	}

	.intro_copy {
		padding: 20px 0;
		font-size: 1.8rem;
		line-height: 1.7;
	}

	.intro_ttl {
		margin: 30px 0 20px;
		font-size: 1.7rem;
	}

	.about_contents {
		margin-top: 20px;
		padding: 15px;
	}
	
	.about_ttl {
		margin-top: 0;
	}
	
	.about_ttl .en {
		font-size: 2.4rem;
	}

	.intro_staff {
		padding: 20px 0;
		font-size: 1.5rem;
		line-height: 1.6;
	}

	.intro_staff dt {
		margin-bottom: 5px;
	}

	.intro_production p {
		margin-top: 2rem;
		font-size: 1.5rem;
	}
	
}



/*-------------------------------------------------------------
 キャスト
-------------------------------------------------------------*/
.cast_list {
	margin-bottom: 20px;
}

.cast_list li {
	min-height: 528px;
	background: rgba(255,255,255,.8);
	display: flex;
}

.cast_list li:not(:first-child) {
	margin-top: 20px;
}

.cast_list li:nth-child(even) {
	flex-direction: row-reverse;
}

.cast_list .img {
	width: 450px;
	height: 528px;
	position: relative;
}

.cast_list .js_bg_img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: #eee;
	background-size: cover;
}

.cast_list .txt {
	padding: 30px 40px;
	display: flex;
	flex-wrap: wrap;
	flex: 1;
}

.cast_list .txt > div {
	width: 100%;
}

.actor_info {
	margin-top: 20px;
	padding: 15px 25px;
	align-self: flex-end;
	background-color: #e6f5fd;
}

.actor_info .name {
	color: #003f5d;
	font-size: 1.8rem;
	font-weight: 700;
}

.cast_info_name_sub {
	font-size: 2rem!important;
}


@media screen and (min-width: 751px) {
	
	/*サブキャスト*/
	.sub_cast_list .cast_list  {
		margin-left: -20px;
		display: flex;
		flex-wrap: wrap;
	}

	.sub_cast_list .cast_list li {
		width: calc(33.333333% - 20px);
		background: rgba(255,255,255,.8);
		flex-wrap: wrap;
		margin-top: 0;
		margin-left: 20px;
	}
	
	.sub_cast_list .cast_list li:nth-child(n + 4) {
		margin-top: 20px;
	}

	.sub_cast_list .cast_list .img {
		width: 400px;
		height: 400px;
		position: relative;
	}

	.sub_cast_list .cast_list .js_bg_img {
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background-color: #eee;
		background-size: cover;
	}

	.sub_cast_list .cast_list .txt {
		padding: 30px 40px;
	}

	.sub_cast_list .cast_list .actor_info {
		margin-bottom: 20px;
		padding: 15px 25px;
		align-self: flex-end;
		background-color: rgba(231,240,239,.7);
	}
	
}



@media screen and (max-width: 750px) {
	.cast_list {
		margin-bottom: 10px;
	}
	
	.cast_list li {
		padding: 15px;
		min-height: initial;
		display: block;
	}

	.cast_list li:not(:first-child) {
		margin-top: 10px;
	}

	.cast_list .img {
		width: 100%;
        height: 0;
		min-height: auto;
        padding-top: 100%;
		position: relative;
	}
	
	.cast_list .txt {
		margin-top: 15px;
		padding: 0;
		display: block;
	}

	.actor_info {
		margin-top: 15px;
		padding: 15px;
	}

	.sub_cast_list .actor_info {
		margin-top: 0;
		margin-bottom: 15px;
		padding: 15px;
	}

	.cast_info_name_sub {
		font-size: 1.8rem!important;
	}
}



/*-------------------------------------------------------------
 あらすじ
-------------------------------------------------------------*/
.story_item {
	padding: 25px 40px;
	background: rgba(255,255,255,.8);
	display: flex;
}

.story_item:not(:first-child) {
	margin-top: 20px;
}

.story_item .txt {
	padding-right: 60px;
	flex: 1;
}

.story_item .img {
	margin-top: 10px;
	width: 480px;
}

.pagenation {
	margin-top: 40px;
	color: #003f5d;
	text-align: center;
	font-weight: 700;
}

.pagenation a {
	color: #003f5d;
}

.pagenation b {
	color: #003f5d;
}


@media screen and (max-width: 750px) {
	.story_item {
		padding: 15px;
		display: block;
	}

	.story_item:not(:first-child) {
		margin-top: 10px;
	}

	.story_item .txt {
		padding-right: 0;
	}
	
	.story_item .img {
		margin-top: 15px;
		width: 100%;
	}

	.pagenation {
		margin-top: 20px;
	}

}



/*-------------------------------------------------------------
 相関図
-------------------------------------------------------------*/
.tab_nav {
	margin-bottom: 20px;
	border-bottom: 2px solid #003f5d;
	display: flex;
	align-items: center;
	justify-content: center;
}

.tab_nav li {
	min-width: 20%;
	min-height: 60px;
	margin-bottom: -2px;
	border: 2px solid #003f5d;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #003f5d;
	font-size: 2rem;
	font-weight: 700;
}

.tab_nav li:not(:first-child) {
	margin-left: -2px;
}

.tab_nav li.c_nav_on {
	background-color: #003f5d;
	color: #FFF;
}

.tab_contents_inner {
    display: none;
}
.tab_contents_inner.current {
    display: block;
}

@media screen and (max-width: 750px) {
	.tab_nav {
		margin-bottom: 10px;
	}

	.tab_nav li {
		min-height: 40px;
		font-size: 1.4rem;
		font-weight: 700;

	}
}

.text_s {
	font-size: 1.6rem !important;
} 

@media screen and (max-width: 750px) {
	.text_s {
		font-size: 1.4rem !important;
	} 	
}	