@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: #fffbb8;
	position: relative;
	z-index: 3;
}

.gDef-contents {
	background-color: #fff;
	color: #383440;
	font-family: BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-size: 2.4rem;
	line-height: 2;
	letter-spacing: .05em;
}

.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;
}

svg {
	width: 100%;
	height: auto;
}

section h2 {
	width: calc(303 / 650 * 100%);
	margin: 0 auto calc(80 / 650 * 100%);
}

.btn1 a {
	width: calc(420 / 650 * 100%);
	margin: 0 auto;
	-webkit-box-shadow: 0 1.2rem 2.9rem 0 rgba(50, 0, 92, 0.22);
	box-shadow: 0 1.2rem 2.9rem 0 rgba(50, 0, 92, 0.22);
	border-radius: 6rem;
}

@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
}

@media screen and (min-width: 768px) {
	html {
		font-size: calc(10 / 1400 * 100vw);
	}

	.gDef-contents {
		font-size: 1.6rem;
	}

	.set1 a {
		-webkit-transition: 0.3s ease;
		transition: 0.3s ease;
	}

	.inner {
		width: 100%;
		max-width: 1400px;
		padding: 0 calc(100 / 1400 * 100%);
	}

	section h2 {
		width: calc(303 / 1200 * 100%);
		margin: 0 auto calc(60 / 1200 * 100%);
	}

	.sp {
		display: none !important;
	}

	.btn1 a {
		width: calc(280 / 1200 * 100%);
		margin: 0 auto;
		-webkit-box-shadow: 0 1rem 2rem 0 rgba(50, 0, 92, 0.15);
		box-shadow: 0 1rem 2rem 0 rgba(50, 0, 92, 0.15);
		top: 0;
	}

	.btn1 a:hover {
		-webkit-box-shadow: 0 1.4rem 3rem 0 rgba(50, 0, 92, 0.2);
		box-shadow: 0 1.4rem 3rem 0 rgba(50, 0, 92, 0.2);
		top: -1rem;
	}

	.hover1::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background-image: -webkit-gradient(linear, left top, right top, color-stop(-25%, rgb(254, 255, 159)), color-stop(23%, rgb(176, 224, 255)), color-stop(77%, rgb(255, 179, 208)), color-stop(125%, rgb(255, 246, 189)));
		background-image: linear-gradient(90deg, rgb(254, 255, 159) -25%, rgb(176, 224, 255) 23%, rgb(255, 179, 208) 77%, rgb(255, 246, 189) 125%);
		position: absolute;
		top: 0;
		left: 0;
		opacity: 0;
		mix-blend-mode: screen;
		-webkit-transition: .5s ease;
		transition: .5s ease;
	}

	.hover1:hover::after {
		opacity: 0.8;
	}
}

@media screen and (min-width: 1400px) {
	html {
		font-size: 10px;
	}

	.inner {
		padding: 0 100px;
	}
}


/* =====================================================================
*    submv
* =================================================================== */
.submv::before {
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: calc(90 / 750 * 100%);
	background-image: -webkit-gradient(linear, left top, right top, from(#e5d8ff), color-stop(50%, #e7ebfc), to(#ffe3ea));
	background-image: linear-gradient(90deg, #e5d8ff 0%, #e7ebfc 50%, #ffe3ea 100%);
	-webkit-transform: skewY(6deg);
	transform: skewY(6deg);
	position: absolute;
	bottom: 0;
	left: 0;
	margin: 0 0 calc(-48 / 750 * 100%);
	z-index: 1;
}

.submv .inner {
	z-index: 3;
}

.class_sp .submv .inner {
	width: 100%;
}

.submv_ttl {
	width: calc(332 / 750 * 100%);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	margin: calc(2 / 750 * 100%) 0 0 calc(380 / 750 * 100%);
}

.submv_img {
	width: calc(337 / 750 * 100%);
}

.submv_date {
	margin: calc(-57 / 750 * 100%) 0 calc(65 / 750 * 100%);
	z-index: 3;
}

.class_sp .submv_date .inner {
	width: 100%;
}

.submv_date::before {
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: calc(86 / 750 * 100%);
	background-color: #ffff8c;
	-webkit-transform: skewY(-6deg);
	transform: skewY(-6deg);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}

.submv_date img {
	width: calc(691 / 750 * 100%);
	margin: 0 auto;
}

.submv_bg {
	width: 100%;
	height: 130%;
	-webkit-transform: skewY(-6deg);
	transform: skewY(-6deg);
	position: absolute;
	bottom: 3rem;
	left: 0;
	z-index: 2;
	overflow: hidden;
}

.submv_bg::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: url(../images/common/bg_mv.jpg) repeat left 49% bottom 43%;
	background-size: calc(1600 / 750 * 100%) auto;
	-webkit-transform-origin: left bottom;
	transform-origin: left bottom;
	-webkit-transform: skewY(6deg);
	transform: skewY(6deg);
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (min-width: 768px) {
	.submv::before {
		height: 100%;
		padding-top: 0;
		margin: 0 0 calc(-20 / 1400 * 100%);
	}

	.submv .inner {
		padding: 0;
	}

	.submv_ttl {
		width: calc(437 / 1400 * 100%);
		margin: 0 0 0 calc(680 / 1400 * 100%);
	}

	.submv_img {
		width: calc(443 / 1400 * 100%);
		margin: -1px 0 0 calc(158 / 1400 * 100%);
	}

	.submv_date {
		margin: calc(-77 / 1400 * 100%) 0 calc(60 / 1400 * 100%);
	}

	.submv_date::before {
		padding-top: calc(80 / 1400 * 100%);
	}

	.submv_date img {
		width: calc(691 / 1200 * 100%);
	}

	.submv_bg {
		width: 100%;
		height: 130%;
		-webkit-transform: skewY(-6deg);
		transform: skewY(-6deg);
		position: absolute;
		bottom: 3rem;
		left: 0;
		z-index: 2;
		overflow: hidden;
	}

	.submv_bg::after {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: url(../images/common/bg_mv.jpg) repeat center bottom 35.5%;
		background-size: calc(1600 / 1400 * 100%) auto;
		-webkit-transform-origin: left bottom;
		transform-origin: left bottom;
		-webkit-transform: skewY(6deg);
		transform: skewY(6deg);
		position: absolute;
		top: 0;
		left: 0;
	}
}

@media screen and (min-width: 1400px) {
	.submv::before {
		margin: 0 0 -20px;
	}

	.submv::after {
		margin: 0 0 80px;
	}

	.submv_date {
		margin: -77px 0 60px;
	}

	.submv_date::before {
		padding-top: 80px;
	}

	.submv_bg::after {
		background-size: 1600px auto;
	}
}


/* =====================================================================
*    nav
* =================================================================== */
.header_nav {
	z-index: 4;
}

.mv_bnr {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 0 0 calc(80 / 650 * 100%);
}

.mv_bnr li {
	width: calc(280 / 650 * 100%);
	margin: 0 calc(50 / 650 * 100%) 0 0;
}

.mv_bnr li:last-child {
	margin-right: 0;
}

.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-top: 1px solid #f0eef3;
	border-bottom: 1px solid #f0eef3;
	width: calc(130 / 650 * 100%);
	margin: 0 calc(43 / 650 * 100%) calc(20 / 650 * 100%) 0;
}

.nav_menu li:nth-child(4n) {
	margin-right: 0;
}

.nav_menu li a {
	padding: calc(5 / 130 * 100%) 0;
}

.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.2em 0 0;
	text-align: center;
	z-index: 3;
}

.nav_date span {
	display: inline-block;
	padding: .2em .7em;
	background-color: #ff7ecb;
	color: #fff;
	border-radius: 2em;
	font-size: 1.6rem;
	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 .4em 0 .4em;
	border-color: #ff7ecb transparent transparent transparent;
	margin-bottom: -.5em;
}

@media screen and (min-width: 768px) {
	.mv_bnr {
		margin: 0 0 calc(40 / 1200 * 100%);
	}

	.mv_bnr li {
		width: calc(240 / 1200 * 100%);
		margin: 0 calc(80 / 1200 * 100%) 0 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,
	.nav_menu li:nth-child(4n) {
		width: calc(126 / 1200 * 100%);
		margin: 0 calc(20 / 1200 * 100%) 0 0;
		border-width: 2px;
	}

	.nav_menu li:last-child {
		margin-right: 0;
	}

	.nav_menu li img,
	.nav_menu li.cs::before {
		width: calc(104 / 126 * 100%);
		margin: 0 auto;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.nav_menu li a {
		padding: 0;
	}

	.nav_menu li a::before {
		content: "";
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background: url(../images/nav/nav_h.png) no-repeat center center;
		background-size: auto 100%;
		opacity: 0;
		-webkit-transition: .5s ease;
		transition: .5s ease;
	}

	.nav_menu li a:hover::before {
		opacity: 1;
	}

	.nav_date {
		margin-top: -2em;
	}

	.nav_date span {
		padding: .3em 1.3em;
		font-size: 1.2rem;
	}

}

@media screen and (min-width: 1400px) {}


/* =====================================================================
*    banner
* =================================================================== */
.banner_list:not(:last-child) {
	margin-bottom: calc(30 / 650 * 100%);
}

.banner_list li {
	width: calc(560 / 650 * 100%);
	margin: 0 auto;
}

.banner_list .wide {
	width: 100%;
}

.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:not(:last-child) {
		margin-bottom: calc(30 / 1200 * 100%);
	}

	.banner_list li {
		width: calc(320 / 1200 * 100%);
		margin: 0 calc(10 / 1200 * 100%) !important;
	}

	.banner_list .wide {
		width: calc(420 / 1200 * 100%);
	}
}


/* =====================================================================
*    footer
* =================================================================== */
.footer {
	padding: calc(120 / 750 * 100%) 0 0;
}

.gDef-wrapper:not(#top) .footer {
	background-color: #f3ebff;
}

/*
.gDef-wrapper:not(#top) .footer::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-image: linear-gradient(70deg, rgba(254, 255, 159, 0.4) -25%, rgba(176, 224, 255, 0.4) 23%, rgba(255, 179, 208, 0.4) 77%, rgba(255, 246, 189, 0.4) 125%);
	position: absolute;
	top: 0;
	left: 0;
}
*/

.footer_bnr {
	width: calc(320 / 650 * 100%);
	margin: 0 auto calc(100 / 650 * 100%);
}

.pagetop {
	opacity: 0;
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 9999;
	width: calc(130 / 750 * 100%);
	margin: 0 calc(15 / 750 * 100%) calc(120 / 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(100 / 650 * 100%);
}

.footer_sns li {
	width: calc(95 / 650 * 100%);
	margin: 0 calc(-2 / 650 * 100%);
}

.copyright {
	background-color: #fff;
}

.copyright p {
	font-size: 1.6rem;
	color: #b2a5cb;
	text-align: center;
	padding: 2em 0;
}

@media screen and (min-width: 768px) {
	.footer {
		padding: calc(100 / 1400 * 100%) 0 0;
	}

	.gDef-wrapper:not(#top) .footer::before {
		background-image: linear-gradient(70deg, rgba(254, 255, 159, 0.4) -10%, rgba(176, 224, 255, 0.4) 33%, rgba(255, 179, 208, 0.4) 67%, rgba(255, 246, 189, 0.4) 110%);
	}

	.pagetop {
		width: calc(104 / 1400 * 100%);
		margin: 0 calc(25 / 1400 * 100%) calc(110 / 1400 * 100%) 0;
		-webkit-transition: .3s ease;
		transition: .3s ease;
	}

	.pagetop:hover {
		bottom: 15px;
	}

	.pagetop.fixed {
		margin-bottom: calc(50 / 1400 * 100%);
	}

	.footer_bnr {
		width: calc(320 / 1200 * 100%);
		margin: 0 auto calc(110 / 1200 * 100%);
	}

	.footer_sns {
		margin: 0 auto calc(80 / 1200 * 100%);
	}

	.footer_sns li {
		width: calc(76 / 1200 * 100%);
		margin: 0 calc(-2 / 1200 * 100%);
	}

	.footer_sns li a:hover {
		opacity: .7;
	}

	.copyright p {
		font-size: 1.2rem;
		padding: 3em 0;
	}
}

@media screen and (min-width: 1400px) {
	.footer {
		padding: 100px 0 0;
	}

	.pagetop {
		width: 104px;
		margin: 0 25px 110px 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: #fbef89;
	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 / 1400 * 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: 1400px) {
	.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;
	}
}
