@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : base.css
Description :
===================================================================== */

/* =====================================================================
*    共通・大枠
* =================================================================== */
html {
	font-size: calc(10 / 750 * 100vw);
	overflow-x: hidden;
}

.gDef-top-banner {
	background-color: #67385d;
}

.gDef-contents {
	background-color: #fff;
	color: #000;
	font-family: "游明朝", "游明朝体", "Yu Mincho", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 2.4rem;
	line-height: 1.75;
}

.set1,
.set1 * {
	position: relative;
}

.set1 img {
	width: 100%;
	height: auto;
	display: block;
}

.set1 a {
	color: #000;
	display: block;
}

.inner {
	width: calc(650 / 750 * 100%);
	margin: 0 auto;
	z-index: 1;
}

section h2 {
	margin-bottom: calc(70 / 650 * 100%);
}

.btn1 {
	width: calc(360 / 650 * 100%);
	text-align: center;
	margin: 0 auto;
}

.btn1 a {
	border: .2em solid #060000;
	background: url(../images/common/bg_btn1.png) no-repeat center/cover;
	color: #fff;
	padding: .6em;
	-webkit-box-shadow: .6em .6em 0 0 rgba(201, 160, 183, 0.8);
	-ms-box-shadow: .6em .6em 0 0 rgba(201, 160, 183, 0.8);
	box-shadow: .6em .6em 0 0 rgba(201, 160, 183, 0.8);
}

.btn1 a::after {
	content: '';
	position: absolute;
	top: -.1em;
	left: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1.5em 1.5em 0 0;
	border-color: #060000 transparent transparent transparent;
}

.btn1 span {
	z-index: 2;
}

.btn_img img {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	display: block;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}



@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
}


@media screen and (min-width: 768px) {
	html {
		font-size: calc(10 / 1200 * 100vw);
	}

	.gDef-contents {
		font-size: 1.6rem;
	}

	.set1 a {
		-webkit-transition: 0.3s ease;
		transition: 0.3s ease;
	}

	.outer {
		max-width: 1600px;
		margin: 0 auto;
	}

	.inner {
		width: 100%;
		max-width: 1200px;
		padding: 0 calc(100 / 1200 * 100%);
	}

	section h2 {
		width: calc(530 / 1000 * 100%);
		margin: 0 auto calc(80 / 1000 * 100%);
	}

	.sp {
		display: none !important;
	}

	.btn1 {
		width: calc(270 / 1000 * 100%);
		margin: 0 auto;
	}

	.btn1 a {
		padding: 1.1em;
		font-size: 1.4rem;
		-webkit-box-shadow: .4em .4em 0 0 rgba(201, 160, 183, 0.8);
		box-shadow: .4em .4em 0 0 rgba(201, 160, 183, 0.8);
	}

	.btn1 a:hover::before {
		opacity: 1;
	}

	.btn1 a::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: url(../images/common/bg_btn1_h.png) no-repeat center/cover;
		opacity: 0;
		-webkit-transition: .2s ease;
		transition: .2s ease;
	}

	.btn_img:hover img:nth-of-type(2) {
		opacity: 0;
	}
}


@media screen and (min-width: 1200px) {
	html {
		font-size: 10px;
	}

	.gDef-contents {
		background-size: 250px auto;
	}

	.inner {
		padding: 0 100px;
	}
}


/* =====================================================================
*    submv
* =================================================================== */
.submv {
	height: calc(300 / 750 * 100vw);
	overflow: hidden;
}

.submv > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

.submv_wrap,
.submv .outer {
	height: 100%;
}

.submv_wrap::before,
.submv_wrap::after {
	content: '';
	position: absolute;
	width: 100%;
	height: 4px;
	background-color: #000;
	z-index: 1;
}

.submv_wrap::before {
	top: 0;
}

.submv_wrap::after {
	bottom: 0;
}

.submv .outer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: calc(440 / 750 * 100%);
	height: 100%;
	background: url(../images/common/img_submv.jpg) no-repeat center top/100% auto;
	margin: calc(4 / 750 * 100%) 0 0 calc(-12 / 750 * 100%);
}

.submv .outer::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: calc(330 / 750 * 100%);
	height: 100%;
	background: url(../images/common/bg_pattern3_sp.jpg) no-repeat center/cover;
}

.submv_ttl {
	position: absolute;
	top: 0;
	left: 0;
	width: calc(283 / 750 * 100%);
	margin: calc(85 / 750 * 100%) 0 0 calc(448 / 750 * 100%);
	z-index: 1;
}

.submv_onair {
	position: absolute;
	top: 0;
	left: 0;
	width: calc(300 / 750 * 100%);
	margin: calc(198 / 750 * 100%) 0 0 calc(435 / 750 * 100%);
	z-index: 1;
}

@media screen and (min-width: 768px) {
	.submv {
		height: calc(300 / 1600 * 100vw);
		-webkit-transition: .3s ease;
		transition: .3s ease;
	}

	.submv:hover {
		opacity: .7;
	}

	.submv::before,
	.submv::after {
		content: '';
		position: absolute;
		top: 0;
		height: 100%;
		background: url(../images/common/bg_pattern3.jpg) repeat-x center/cover;
		border-left: .3em solid #000;
	}

	.submv::before {
		width: calc(50% - calc(560 / 1600 * 100%));
		left: 0;
		background-position: center right;
	}

	.submv::after {
		width: calc(50% - calc(780 / 1600 * 100%));
		right: 0;
		background-position: center left;
	}

	/*	IE対策*/
	_:-ms-lang(x)::-ms-backdrop,
	.submv::before {
		width: 15vw;
	}

	_:-ms-lang(x)::-ms-backdrop,
	.submv::after {
		width: 2vw;
	}

	.submv_wrap::before,
	.submv_wrap::after {
		height: calc(8 / 1600 * 100vw);
	}

	.submv .outer::before {
		width: calc(566 / 1600 * 100%);
		margin: calc(-5 / 1600 * 100%) 0 0 calc(234 / 1600 * 100%);
		border-left: .4em solid #000;
	}

	.submv .outer::after {
		width: calc(780 / 1600 * 100%);
		background: url(../images/common/bg_pattern3.jpg) no-repeat center/cover;
		margin-right: calc(20 / 1600 * 100%);
		border-left: .4em solid #000;
	}

	.submv_ttl {
		width: calc(360 / 1600 * 100%);
		margin: calc(60 / 1600 * 100%) 0 0 calc(862 / 1600 * 100%);
		background: url(../images/common/bg_logo.jpg) no-repeat center/cover;
		padding: calc(21 / 1600 * 100%) 0 calc(18 / 1600 * 100%);
	}

	.submv_ttl img {
		width: calc(306 / 360 * 100%);
		margin: auto;
	}

	.submv_onair {
		width: calc(360 / 1600 * 100%);
		margin: calc(180 / 1600 * 100%) 0 0 calc(924 / 1600 * 100%);
		background-color: #000;
		padding: calc(17 / 1600 * 100%) 0 calc(16 / 1600 * 100%);
	}

	.submv_onair img {
		width: calc(315 / 360 * 100%);
		margin: auto;
	}
}

@media screen and (min-width: 1600px) {
	.submv {
		height: 300px;
	}

	.submv::before {
		width: calc(50% - 560px);
	}

	.submv::after {
		width: calc(50% - 780px);
	}

	.submv_wrap::before,
	.submv_wrap::after {
		height: 8px;
	}
}

/* =====================================================================
*    nav
* =================================================================== */
.header_nav {
	background-color: #67385d;
	padding: calc(27 / 750 * 100%) 0;
}

.header_nav .inner {
	width: calc(730 / 750 * 100%);
}

.nav_menu {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.nav_menu li {
	border-right: 2px dotted #110605;
	width: calc(142 / 730 * 100%);
}

.nav_menu li a {
	padding: .3em 0;
}

.nav_menu li img {
	width: calc(111 / 142 * 100%);
	margin: auto;
}

.nav_menu li:nth-child(1),
.nav_menu li:nth-child(6) {
	border-left: 2px dotted #110605;
}

.nav_menu li:nth-child(-n + 5) {
	margin-bottom: 2em;
}

.nav_menu::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 95%;
	height: 2px;
	background-color: #592f50;
}

.nav_menu li a {
	width: 100%;
	height: 100%;
	overflow: hidden;
}

.nav_menu li.nolink a,
.nav_menu li.cs a {
	pointer-events: none;
}

.nav_menu li.nolink a {
	opacity: .2;
}

.nav_menu li.cs img {
	opacity: 0;
}

.nav_menu li.cs::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	width: calc(111 / 142 * 100%);
	height: 100%;
	background: url(../images/nav/nav_cs.png) no-repeat center/contain;
}

.nav_date {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	margin: -1.5em 0 0;
	text-align: center;
	z-index: 3;
}

.nav_date span {
	display: inline-block;
	padding: .3em 1.2em;
	background-color: #cc281d;
	color: #fff;
	border-radius: 2em;
	font-size: 2rem;
	font-family: 'Cabin', sans-serif;
	line-height: 1;
}

.nav_date span::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .5em .3em 0 .3em;
	border-color: #cc281d transparent transparent transparent;
	margin-bottom: -.5em;
}

@media screen and (min-width: 768px) {
	.header_nav {
		padding: calc(16 / 1200 * 100%) 0;
	}

	.nav_menu {
		-ms-flex-wrap: nowrap;
		-o-flex-wrap: nowrap;
		flex-wrap: nowrap;
		-ms-align-items: center;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}

	.nav_menu::before {
		display: none;
	}

	.nav_menu li {
		width: calc(100 / 1000 * 100%) !important;
		margin-bottom: 0 !important;
	}

	.nav_menu li:nth-child(6) {
		border-left: 0;
	}

	.nav_menu li a {
		padding: .8em 0;
	}

	.nav_menu li a:hover {
		opacity: .55;
	}

	.nav_menu li img,
	.nav_menu li.cs::before {
		width: calc(73 / 100 * 100%);
	}

	.nav_menu li a::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
		background-color: #cc281d;
		width: .6em;
		height: .6em;
		border-radius: 50%;
		opacity: 0;
		-webkit-transition: .3s ease;
		transition: .3s ease;
	}

	.nav_menu li a:hover::after {
		opacity: 1;
	}

	.nav_date {
		margin-top: -1.6em;
	}

	.nav_date span {
		padding: .2em 1.2em;
		font-size: 1.4rem;
	}

}

@media screen and (min-width: 1200px) {
	.header_nav {
		padding: 16px 0;
	}
}



/* =====================================================================
*    banner
* =================================================================== */
.banner_list li {
	width: calc(560 / 650 * 100%);
	margin: 0 auto;
}

.banner_list li a {
	-webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
	-ms-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
	box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
}

.banner_list li:not(:last-child) {
	margin-bottom: calc(30 / 560 * 100%);
}


@media screen and (min-width: 768px) {
	.banner_list {
		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;
	}

	.banner_list li {
		width: calc(320 / 1000 * 100%);
		margin: 0 calc(10 / 1000 * 100%) !important;
	}
    
    .banner1 .banner_list li {
        width: calc(460 / 1000 * 100%)!important;
    }


    .banner_list li a::before {
		opacity: 0;
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		border: 5px solid #a3839c;
		-webkit-transition: .5s ease;
		transition: .5s ease;
		z-index: 1;
	}

	.banner_list li a:hover::before {
		opacity: 1;
	}
}


/* =====================================================================
*    footer
* =================================================================== */
.footer {
	padding: calc(80 / 750 * 100%) 0 0;
	background-color: #67385d;
}

.footer_bnr {
	width: calc(630 / 650 * 100%);
	margin: 0 auto calc(80 / 650 * 100%);
}

.footer_bnr a {
	-webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
	box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
}

.pagetop {
	opacity: 0;
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 9999;
	width: calc(37 / 750 * 100%);
	margin: 0 calc(35 / 750 * 100%) calc(180 / 750 * 100%) 0;
	-webkit-transition: 500ms;
	transition: 500ms;
}

.pagetop.fixed {
	position: fixed;
	margin-bottom: calc(30 / 750 * 100%);
}

.footer_sns {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 auto calc(110 / 650 * 100%);
}

.footer_sns li {
	width: calc(100 / 650 * 100%);
	margin: 0 calc(30 / 650 * 100%);
}

.footer_sns li a {
	padding: calc(23 / 100 * 100%);
	border-radius: 50%;
	border: 1px solid #fff;
}

.copyright {
	background-color: #000;
}

.copyright p {
	font-size: 1.8rem;
	color: #fff;
	text-align: center;
	padding: calc(40 / 750 * 100%) 0;
	font-family: sans-serif;
}


@media screen and (min-width: 768px) {
	.footer {
		padding: calc(60 / 1200 * 100%) 0 0;
	}

	.pagetop {
		width: calc(25 / 1200 * 100%);
		margin: 0 calc(20 / 1200 * 100%) calc(100 / 1200 * 100%) 0;
		-webkit-transition: .3s ease;
		transition: .3s ease;
	}

	.pagetop:hover {
		bottom: 15px;
	}

	.pagetop.fixed {
		margin-bottom: calc(50 / 1200 * 100%);
	}

	.footer_bnr {
		width: calc(474 / 1000 * 100%);
		margin: 0 auto calc(40 / 1000 * 100%);
	}

	.footer_bnr a:hover {
		opacity: .55;
	}

	.footer_sns {
		margin: 0 auto calc(80 / 1000 * 100%);
	}

	.footer_sns li {
		width: calc(60 / 1000 * 100%);
		margin: 0 calc(21 / 1000 * 100%);
	}

	.footer_sns li a:hover {
		background-color: #fff;
	}

	.footer_sns li a img {
		-webkit-transition: 0.2s ease;
		transition: 0.2s ease;
	}

	.footer_sns li a:hover img {
		opacity: 0;
	}

	.footer_sns li a:hover::before {
		opacity: 1;
	}

	.footer_sns li a::before {
		content: "";
		display: block;
		width: calc(32 / 60 * 100%);
		height: calc(31 / 60 * 100%);
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		opacity: 0;
		margin: auto;
		-webkit-transition: 0.2s ease;
		transition: 0.2s ease;
	}

	.footer_sns li:nth-child(1) a::before {
		background: url(../images/common/btn_sns1_h.png) no-repeat center/contain;
	}

	.footer_sns li:nth-child(2) a::before {
		background: url(../images/common/btn_sns2_h.png) no-repeat center/contain;
	}

	.footer_sns li:nth-child(3) a::before {
		background: url(../images/common/btn_sns3_h.png) no-repeat center/contain;
	}

	.copyright p {
		font-size: 1rem;
		padding: calc(20 / 1200 * 100%);
	}
}

@media screen and (min-width: 1200px) {
	.footer {
		padding: 60px 0 0;
	}

	.pagetop {
		width: 25px;
		margin: 0 35px 100px 0;
	}

	.copyright p {
		padding: 20px 0;
	}
}

/* =====================================================================
*    movie_popup
* =================================================================== */
.popup_wrapper {
	width: 100%;
	height: 100%;
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	background-color: rgba(0, 0, 0, 0.7);
	z-index: 100000;
	display: none;
	cursor: pointer;
}

.popup_wrapper .return_box {
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

.popup_wrapper .popup_movie_wrap {
	width: 100%;
	height: auto;
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	margin: auto;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	text-align: center;
}

.popup_wrapper .popup_movie_wrap .popup_movie {
	width: 100%;
	padding-top: 56.25%;
	position: relative;
}

.popup_wrapper .popup_movie_wrap .popup_movie video {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
}

.popup_wrapper .popup_movie_wrap .popup_movie iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
}

.vjs-icon-placeholder {
	display: block;
	margin: -1em 0 0;
	position: static;
}

.popup_wrapper .btn2 {
	width: calc(300 / 750 * 100%);
	margin: calc(50 / 750 * 100%) auto 0;
}

.popup_wrapper .btn2 a {
	display: block;
	background-color: #f2ede1;
	font-size: 3.2rem;
	text-align: center;
	text-decoration: none;
	padding: .5em;
}

@media screen and (min-width: 768px) {
	.popup_wrapper .popup_movie_wrap {
		width: calc(800 / 1200 * 100%);
	}

	.popup_wrapper .btn2 {
		width: calc(300 / 800 * 100%);
		margin: calc(30 / 800 * 100%) auto 0;
	}

	.popup_wrapper .btn2 a {
		font-size: 1.6rem;
		-webkit-transition: .2s ease;
		transition: .2s ease;
	}

	.popup_wrapper .btn2 a:hover {
		background-color: #f2e1e1;
	}
}

@media screen and (min-width: 1200px) {
	.popup_wrapper .popup_movie_wrap {
		width: 800px;
	}
}


@media print {

	.nextstory_movie_photo img,
	.story_movie_photo img,
	.news_list_photo img {
		display: none;
	}

	.story_txt_list_photo img {
		display: none;
	}

	.bucknumber_list img {
		display: none;
	}

	.chain_photo img {
		display: none;
	}

	.topics_photo img {
		display: none;
	}

	.chart_btn_img,
	.chart_photo img {
		display: none;
	}

	.music_artist_img_bg img {
		display: none;
	}
}
