@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : top.css
Description :
===================================================================== */

/* =====================================================================
*    mv
* =================================================================== */
.mv {
	padding-top: calc(495 / 750 * 100%);
}

.mv .inner {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	margin: auto;
	overflow: hidden;
}

.mv_ttl {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.mv_deli {
	position: absolute;
	top: 0;
	left: 0;
	width: calc(102 / 750 * 100%);
	margin: calc(103 / 750 * 100%) 0 0 calc(231 / 750 * 100%);
}

.mv_onair {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: calc(326 / 750 * 100%);
	margin: calc(360 / 750 * 100%) auto 0;
}


@media screen and (min-width: 768px) {
	.mv {
		padding-top: calc(659 / 1200 * 100%);
	}

	.mv::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: url(../images/bg_pattern.png) repeat center/calc(50 / 1200 * 100%);
		opacity: .2;
	}

	.mv_ttl {
		width: calc(1000 / 1200 * 100%);
		margin: auto;
		right: 0;
	}

	.mv_deli {
		width: calc(102 / 1200 * 100%);
		margin: calc(153 / 1200 * 100%) 0 0 calc(453 / 1200 * 100%);
	}

	.mv_onair {
		width: calc(370 / 1200 * 100%);
		margin: calc(506 / 1200 * 100%) auto 0;
	}
}

@media screen and (min-width: 1200px) {
	.mv {
		padding-top: 659px;
	}

	.mv::before {
		background-size: 50px;
	}

}

/* =====================================================================
*    banner1
* =================================================================== */
#banner {
	background-color: #4cb56f;
	padding: calc(55 / 750 * 100%) 0;
}


@media screen and (min-width: 768px) {
	#banner {
		padding: calc(40 / 1200 * 100%) 0;
	}

}

@media screen and (min-width: 1200px) {
	#banner {
		padding: 40px 0;
	}

}


/* =====================================================================
*    intro
* =================================================================== */
#intro {
	background: url(../images/bg_pattern_w.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(95 / 750 * 100%) 0;
}

#intro::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
}

#intro h2 {
	margin-bottom: 0;
}

.intro_img {
	width: calc(679 / 690 * 100%);
	margin: -3px 0 calc(65 / 690 * 100%) 0;
}

.intro_box p {
	line-height: 2;
}

.intro_box .blue {
	background-color: #4290d4;
	color: #fff;
}

.intro_box .red {
	background-color: #ed6e51;
	color: #fff;
}

@media screen and (min-width: 768px) {
	#intro {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0 calc(150 / 1200 * 100%);
	}

	#intro::after {
		padding-top: calc(12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	.intro_img {
		width: 100%;
		margin: 0 0 calc(30 / 1000 * 100%) 0;
	}

	.intro_box p {
		width: calc(807 / 1000 * 100%);
		margin: 0 auto;
		font-size: 1.8rem;
	}
}

@media screen and (min-width: 1200px) {
	#intro {
		background-size: 500px auto;
		padding: 100px 0 150px;
	}

	#intro::before {
		background-size: 50px;
	}

	#intro::after {
		background-size: 750px auto;
		padding-top: 12px;
	}
}


/* =====================================================================
*    nextstory
* =================================================================== */
#nextstory {
	background: url(../images/bg_pattern_g.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(60 / 750 * 100%) 0 calc(120 / 750 * 100%);
}

#nextstory h2 {
	margin-bottom: calc(77 / 690 * 100%);
}

.nextstory_movie {
	background: url(../images/bg_movie.png) no-repeat center/contain;
	width: calc(719 / 690 * 100%);
	margin: 0 0 calc(36 / 690 * 100%) calc(-14 / 690 * 100%);
}

.nextstory_movie_photo {
	width: calc(577 / 719 * 100%);
	padding: calc(25 / 719 * 100%) 0;
	margin: 0 auto;
}

.nextstory_movie_btn::after {
	content: "";
	display: block;
	width: calc(91 / 750 * 100vw);
	height: calc(65 / 750 * 100vw);
	position: absolute;
	background: url(../images/btn_movie.png) no-repeat center/contain;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 2;
}

.nextstory_subttl {
	width: calc(202 / 690 * 100%);
	margin: 0 auto calc(33 / 690 * 100%);
}

.nextstory_date {
	text-align: center;
}


@media screen and (min-width: 768px) {
	#nextstory {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0 calc(170 / 1200 * 100%);
	}

	#nextstory h2 {
		margin: 0 auto calc(60 / 1000 * 100%);
	}

	.nextstory_movie {
		width: 100%;
		margin: 0 0 calc(50 / 1000 * 100%);
	}

	.nextstory_movie_photo {
		width: calc(800 / 1000 * 100%);
		padding: calc(34 / 1000 * 100%) 0;
	}

	.nextstory_movie_btn::after {
		width: calc(91 / 1200 * 100vw);
		height: calc(65 / 1200 * 100vw);
		-webkit-transition: .3s;
		transition: .3s;
	}

	.nextstory_movie_photo:hover .nextstory_movie_btn::after {
		-webkit-transform: scale(1.197);
		transform: scale(1.197);
	}

	.nextstory_subttl {
		width: calc(202 / 1000 * 100%);
		margin: 0 auto calc(50 / 1000 * 100%);
	}

	.nextstory_date {
		font-size: 2rem;
	}
}

@media screen and (min-width: 1200px) {
	#nextstory {
		background-size: 500px auto;
		padding: 100px 0 170px;
	}

	.nextstory_movie_btn::after {
		width: 91px;
		height: 65px;
	}
}


/* =====================================================================
*    summary
* =================================================================== */
#summary {
	background: url(../images/bg_pattern_w.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(50 / 750 * 100%) 0 calc(120 / 750 * 100%);
}

#summary::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
	-webkit-transform: scale(-1, -1);
	transform: scale(-1, -1);
}

#summary h2 {
	margin-bottom: calc(35 / 690 * 100%);
}

.slick-slide {
	/*	margin: 0 1em;*/
}

.summary_slider li:focus {
	outline: none;
}

.summary_box {
	/*	width: 300px !important;*/
	padding: calc(20 / 750 * 100%);
	background-color: #faf6f0;
	border-radius: 15px;
	border: .2em solid #363534;
	-webkit-transform: scale(0.85);
	transform: scale(0.85);
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}

.slick-center .summary_box {
	background-color: #e4f0df;
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}

.summary_img {
	border-radius: 15px;
	border: .15em solid #363534;
	margin-bottom: .8em;
	overflow: hidden;
}

.summary_slider dl {
	padding: .5em;
}

.summary_slider dt {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-align-items: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding-bottom: .7em;
	margin-bottom: 1em;
	border-bottom: .2em dotted #4cb56f;
}

.summary_ttl {
	width: calc(121 / 528 * 100%);
}

.summary_slider dd {
	margin-bottom: .5em;
}

.summary_slider .slick-arrow {
	display: block;
	position: absolute;
	bottom: 0;
	top: 0;
	margin: auto;
	z-index: 3;
	width: calc(40 / 750 * 100%);
	height: calc(57 / 750 * 100vw);
}

.summary_slider .slick-arrow.prev {
	background: url(../images/img_arrow_l.png) no-repeat center/contain;
	left: calc(20 / 750 * 100%);
}

.summary_slider .slick-arrow.next {
	background: url(../images/img_arrow_r.png) no-repeat center/contain;
	right: calc(20 / 750 * 100%);
}

@media screen and (min-width: 768px) {
	#summary {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0 calc(150 / 1200 * 100%);
	}

	#summary::after {
		padding-top: calc(12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	#summary h2 {
		margin-bottom: calc(60 / 1000 * 100%);
	}

	.summary_box {
		width: 33em !important;
		-webkit-transform: scale(0.95);
		transform: scale(0.95);
		margin: 0 1.7em;
		padding: calc(20 / 1000 * 100%);
		border-radius: 30px;
	}

	.summary_img {
		border-radius: 30px;
	}

	.summary_slider dt {
		padding-bottom: 1.2em;
	}

	.summary_ttl {
		width: calc(121 / 528 * 100%);
	}

	.summary_slider .slick-arrow {
		width: calc(32 / 1200 * 100%);
		height: calc(48 / 1200 * 100vw);
		-webkit-transition: .3s ease;
		transition: .3s ease;
		cursor: pointer;
	}

	.summary_slider .slick-arrow:hover {
		-webkit-transform: scale(1.2);
		transform: scale(1.2);
	}

	.summary_slider .slick-arrow {
		margin: auto;
	}

	.summary_slider .slick-arrow.prev {
		right: 0;
		left: -37.5em;
	}

	.summary_slider .slick-arrow.next {
		left: 0;
		right: -37.5em;
	}
}

@media screen and (min-width: 1200px) {
	#summary {
		background-size: 500px auto;
		padding: 100px 0 150px;
	}

	#summary::after {
		background-size: 750px auto;
		padding-top: 12px;
	}

	.summary_slider li {}

	.summary_slider .slick-arrow {
		width: 32px;
		height: 48px;
	}

}




/* =====================================================================
*    cast
* =================================================================== */
#cast {
	background: url(../images/bg_pattern_g.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(120 / 750 * 100%) 0 calc(80 / 750 * 100%);
}

#cast::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	margin-top: calc(-12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
}

#cast h2 {
	margin-bottom: calc(104 / 690 * 100%);
}

.cast_list li {
	border-radius: 1em;
	background-color: #e4f0df;
	padding: calc(45 / 690 * 100%) calc(35 / 690 * 100%);
}

.cast_list li:not(:last-child) {
	margin-bottom: calc(60 / 690 * 100%);
}

.cast_list dl {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-align-items: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding-bottom: .7em;
	margin-bottom: 1em;
	border-bottom: .2em dotted #4cb56f;
}

.cast_list dt {
	font-size: 3.6rem;
	font-weight: bold;
}

.cast_list dt.boku {
	color: #4290d4;
}

.cast_list dt.tsuchinoko {
	color: #ed6e51;
}

.cast_list dd {
	font-weight: bold;
}

.cast_list dd span {
	font-size: 2.6rem;
	font-weight: 400;
}

.cast_list p {
	line-height: 2;
}



@media screen and (min-width: 768px) {
	#cast {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0;
	}

	#cast::after {
		padding-top: calc(12 / 1200 * 100%);
		margin-top: calc(-12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	#cast h2 {
		margin-bottom: calc(60 / 1000 * 100%);
	}

	.cast_list {
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.cast_list li {
		border-radius: 30px;
		width: calc(460 / 1000 * 100%);
		padding: calc(40 / 1000 * 100%);
	}

	.cast_list li {
		margin-bottom: calc(80 / 1000 * 100%);
	}

	.cast_list dl {
		padding-bottom: .7em;
		margin-bottom: 1em;
		border-width: .3em;
	}

	.cast_list dt {
		font-size: 2.1rem;
	}

	.cast_list dd span {
		font-size: 1.4rem;
	}

	.cast_list p {
		line-height: 2;
	}

}

@media screen and (min-width: 1200px) {
	#cast {
		background-size: 500px auto;
		padding: 100px 0;
	}

	#cast::after {
		background-size: 750px auto;
		padding-top: 12px;
		margin-top: -12px;
	}
}


/* =====================================================================
*    staff
* =================================================================== */
#staff {
	background: url(../images/bg_pattern_w.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(100 / 750 * 100%) 0;
}

#staff::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
	-webkit-transform: scale(-1, -1);
	transform: scale(-1, -1);
}

#staff h2 {
	margin-bottom: calc(80 / 690 * 100%);
}

.staff_box {
	text-align: center;
}

.staff_box li {
	margin-bottom: calc(50 / 690 * 100%);
}

.staff_box dt {
	font-size: 2.4rem;
	color: #4cb56f;
	font-weight: bold;
	padding-bottom: calc(30 / 690 * 100%);
}

.staff_box dt::before {
	content: '…';
	position: absolute;
	color: #363534;
	width: 100%;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	font-size: 2.8rem;
	line-height: 1;
}

/*IE対策*/
_:-ms-lang(x)::-ms-backdrop,
.staff_box dt {
	padding-bottom: 1em;
}

/*IE対策*/
_:-ms-lang(x)::-ms-backdrop,
.staff_box dt::before {
	bottom: .5em;
}

@media screen and (min-width: 768px) {
	#staff {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0;
	}

	#staff::after {
		padding-top: calc(12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	#staff h2 {
		margin-bottom: calc(60 / 1000 * 100%);
	}

	.staff_box li {
		margin-bottom: calc(40 / 1000 * 100%);
	}

	.staff_box dt {
		font-size: 1.4rem;
		padding-bottom: calc(25 / 1000 * 100%);
	}

	.staff_box dt::before {
		font-size: 2rem;
		line-height: 1.2;
	}

	.staff_box dd {
		font-size: 1.6rem;
	}

}

@media screen and (min-width: 1200px) {
	#staff {
		background-size: 500px auto;
		padding: 100px 0;
	}

	#staff::before {
		background-size: 50px;
	}

	#staff::after {
		background-size: 750px auto;
		padding-top: 12px;
	}
}

/* =====================================================================
*    stamp
* =================================================================== */
#stamp {
	background: url(../images/bg_pattern_g.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(100 / 750 * 100%) 0;
}

#stamp::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	margin-top: calc(-12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
}

#stamp::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	margin-bottom: calc(-12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
	-webkit-transform: scale(-1, -1);
	transform: scale(-1, -1);
	z-index: 2;
}

#stamp h3 {
	font-size: 3rem;
	font-weight: bold;
	line-height: 1.866;
	margin-bottom: 1.5em;
	text-align: center;
}

.stamp_list {
	background-color: #e4f0df;
	border: .2em solid #363534;
	border-radius: 15px;
	padding: 0 calc(60 / 690 * 100%);
}

.stamp_list li {
	padding: calc(60 / 690 * 100%) 0;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-align-items: flex-end;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}

.stamp_list li:not(:last-child) {
	border-bottom: .2em dotted #4cb56f;
}

.stamp_img {
	width: calc(250 / 570 * 100%);
}

.stamp_txt {
	width: calc(290 / 570 * 100%);
}

.stamp_txt dl {
	margin-bottom: 1.5em;
}

.stamp_txt dt {
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: .2em;
	letter-spacing: -.1rem;
}

.btn_stamp {
	color: #fff !important;
	background-color: #4cb56f;
	padding: .6em 1em;
	text-align: center;
	border-radius: 2em;
}


@media screen and (min-width: 768px) {
	#stamp {
		background-size: calc(500 / 1200 * 100%) auto;
		padding: calc(100 / 1200 * 100%) 0 calc(150 / 1200 * 100%);
	}

	#stamp::before,
	#stamp::after {
		padding-top: calc(12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	#stamp::before {
		margin-top: calc(-12 / 1200 * 100%);
	}

	#stamp::after {
		margin-bottom: calc(-12 / 1200 * 100%);
	}

	#stamp h3 {
		font-size: 2.4rem;
	}

	.stamp_list {
		border-radius: 30px;
		padding: calc(60 / 1000 * 100%) 0;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.stamp_list li {
		width: 50%;
		padding: 0 calc(60 / 1000 * 100%);
		-ms-align-items: center;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}

	.stamp_list li:not(:last-child) {
		border-right: .2em dotted #4cb56f;
		border-bottom: 0;
	}

	.stamp_img {
		width: calc(180 / 380 * 100%);
	}

	.stamp_txt {
		width: calc(180 / 380 * 100%);
	}

	.stamp_txt dt {
		font-size: 1.8rem;
	}

	.btn_stamp:hover {
		opacity: .7;
	}

}

@media screen and (min-width: 1200px) {
	#stamp {
		background-size: 500px auto;
		padding: 100px 0 150px;
	}

	#stamp::before,
	#stamp::after {
		background-size: 750px auto;
		padding-top: 12px;
	}

	#stamp::before {
		margin-top: -12px;
	}

	#stamp::after {
		margin-bottom: -12px;
	}
}


/* =====================================================================
*    sns
* =================================================================== */

#twitter {
	background: url(../images/bg_pattern_g.jpg) repeat center/calc(500 / 750 * 100%) auto;
	padding: calc(84 / 750 * 100%) 0 calc(160 / 750 * 100%);
}

#twitter::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	padding-top: calc(12 / 750 * 100%);
	margin-top: calc(-12 / 750 * 100%);
	background: url(../images/bg_line.png) repeat center/100% auto;
}

.twitter {
	background-color: #e4f0df;
	border: .2em solid #363534;
	border-radius: 15px;
	padding: calc(40 / 690 * 100%);
}

.twitter_box {
	padding-top: calc(600 / 570 * 100%);
	background-color: #e4f0df;
	overflow: hidden;
}

.twitter_box iframe {
	width: 740px !important;
	height: 30em !important;
	font-size: 2rem;
	position: absolute !important;
	top: 0;
	left: 0;
	-webkit-overflow-scrolling: touch;
}


@media screen and (min-width: 768px) {
	#twitter {
		padding: calc(100 / 1200 * 100%) 0 calc(160 / 1200 * 100%);
		background-size: calc(500 / 1200 * 100%) auto;
	}

	#twitter::after {
		padding-top: calc(12 / 1200 * 100%);
		margin-top: calc(-12 / 1200 * 100%);
		background-size: calc(750 / 1200 * 100%) auto;
	}

	.twitter {
		width: calc(690 / 1000 * 100%);
		margin: 0 auto;
		border-radius: 30px;
		padding: calc(40 /1000 * 100%);
	}

	.twitter_box {
		padding-top: 100%;
	}

	.twitter_box iframe {
		height: 100% !important;
	}

}

@media screen and (min-width: 1200px) {
	#twitter {
		padding: 100px 0 160px;
		background-size: 500px auto;
	}

	#twitter::after {
		background-size: 750px auto;
		padding-top: 12px;
		margin-top: -12px;
	}
}
