@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : cast.css
Description :
===================================================================== */


/* ********************************************************************
        キャスト・スタッフ
******************************************************************** */

.cast {
	padding: calc(78 / 750 * 100%) 0 calc(170 / 750 * 100%);
}

.cast::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url(../images/common/bg_pattern.png) repeat center /calc(200 / 750 * 100%) auto;
	opacity: .5;
}

.cast h2 {
	margin-bottom: calc(75 / 650 * 100%);
}

.cast_subttl {
	width: calc(116 / 650 * 100%);
	margin: 0 auto calc(50 / 650 * 100%);
}

.cast_list {
	margin-bottom: calc(110 / 650 * 100%);
}

.cast_list li:not(:last-child) {
	margin-bottom: calc(20 / 650 * 100%);
}

.cast_list li.margin {
	margin-top: calc(55 / 650 * 100%);
}

.cast_list dl {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.cast_wrap dt {
	color: #ab2825;
    font-weight: bold;
}

.cast_list dt {
	width: 50%;
	padding-right: 1.3em;
	text-align: right;
}

.cast_list dd {
	width: 50%;
	padding-left: 1.3em;
}

.enjin::after {
	content: "(円神)";
	font-size: 1.9rem;
	line-height: 2.2;
	position: absolute;
	display: block;
	top: 0;
	left: 100%;
	width: 20rem;
	padding-left: .5em;
	text-align: left;
	vertical-align: bottom;
}

.kokoriko::after {
	content: "(ココリコ)";
	font-size: 1.9rem;
	line-height: 2.2;
	position: absolute;
	display: block;
	top: 0;
	left: 100%;
	width: 30rem;
	padding-left: .5em;
	text-align: left;
	vertical-align: bottom;
}

.cast_list > *,
.staff_list > * {
	font-size: 2.8rem;
}

.staff_list {
	text-align: center;
}

.staff_list li {
	margin-bottom: calc(50 / 650 * 100%);
}

.staff_list dt {
	font-weight: bold;
	margin-bottom: calc(18 / 650 * 100%);
}

.staff_list li:nth-child(-n+5) dd {
	padding-left: 9.5em;
	text-align: left;
}

.kyodo::after {
	content: "(共同テレビジョン)";
	font-size: 1.9rem;
	line-height: 2.2;
	position: absolute;
	display: block;
	top: 0;
	left: 100%;
	width: 30rem;
	padding-left: .5em;
	text-align: left;
	vertical-align: bottom;
}

.yoshimoto::after {
	content: "(吉本興業)";
	font-size: 1.9rem;
	line-height: 2.2;
	position: absolute;
	display: block;
	top: 0;
	left: 100%;
	width: 30rem;
	padding-left: .5em;
	text-align: left;
	vertical-align: bottom;
}

@media screen and (min-width: 768px) {
	.cast {
		padding: calc(80 / 1200 * 100%) 0 calc(140 / 1200 * 100%);
	}

	.cast::before {
		background-size: calc(130 / 1200 * 100%) auto;
	}

	.cast h2 {
		margin-bottom: calc(80 / 1000 * 100%);
	}

	.cast_wrap {
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
	}

	.cast_wrap > div {
		width: 50%;
	}

	.cast_subttl {
		width: calc(116 / 500 * 100%);
		margin-bottom: calc(50 / 500 * 100%);
	}

	.cast_list {
		margin-bottom: 0;
	}

	.cast_list dl {
		display: block;
	}

	.cast_wrap li {
		margin-bottom: calc(30 / 500 * 100%) !important;
	}

	.cast_list li.margin {
		margin-top: calc(65 / 500 * 100%) !important;
	}

	.cast_list dl > * {
		width: 100%;
		text-align: center;
		padding: 0;
	}

	.cast_wrap dt {
		font-size: 1.6rem;
		margin-bottom: calc(5 / 500 * 100%);
	}

	.cast_wrap dd {
		font-size: 1.8rem;
	}

	.staff_list li:nth-child(-n+5) dd {
		padding-left: 11.8em;
	}

	.cast_wrap dd small {
		font-size: 1.4rem;
		vertical-align: baseline;
	}

	.enjin::after,
	.kokoriko::after,
	.kyodo::after,
	.yoshimoto::after {
		font-size: 1.4rem;
		line-height: 1.9;
	}
}

@media screen and (min-width: 1200px) {
	.cast {
		padding: 80px 0 140px;
	}

	.cast::before {
		background-size: 130px auto;
	}
}
