@charset "UTF-8";

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@200;300;400;600;700&family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap");

html {
	scroll-behavior: smooth;
}

:root {
	--black: #000;
	--blueblack: #001B29;
	--white: #fff;
	--yellow: #F7FF07;
}
#fp-wrap {
	background: #001B29;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",
		Osaka, "メイリオ", "Meiryo", "Lucida Grande", Verdana, "ＭＳ Ｐゴシック",
		sans-serif;
	color: #fff;
	line-height: 2;
	font-size: 15px;
	overflow: hidden;
}
#fp-wrap p {
	font-weight: 500;
}

.center{
	text-align: center;
}

.l-mainvisual{
	background: url(../img/mainBg.jpg) center top / cover  no-repeat;
	position: relative;
}

.mainvisual{
	position: relative;
}
.mainvisualBox{
	text-emphasis: center;
	max-width: 460px;
	margin:  0 auto;
	padding: 110px 0 100px;
	display:  block;
}
.mainvisualBox img{
	width: 100%;
	height: auto;
}
.maivisialP{
	max-width: 440px;
	position: absolute;
	top: 0;
	right: 0;
	transform: translate(5%, 0px);
}
.low_l-mainvisual{
	background: url(../img/mainBg.jpg) center top / cover  no-repeat;
	position: relative;
	overflow: hidden;
}
.low_l-mainvisual .mainvisualBox{
    width: 300px;
    padding: 40px 0;
}
.low_l-mainvisual .maivisialP{
    width: 320px;
    top: -20px;
    right: 150px;
}
@media screen and (max-width: 768px) {
	/*バグ修正*/
	.fpWidth,
	.fpWidth #cx_spContentsMain {
		width: 100% !important;
	}
	/*--バグ修正*/

	.l-main {
		padding: 0 16px;
	}

	.mainvisual{
		overflow: hidden;
	}
	.mainvisualBox{
		width: 82%;
		padding: 45px 0 320px;
	}
	.maivisialP{
		right: 50%;
		transform: translate(50%, 42%);
		width: 98%;
	}

	.low_l-mainvisual .mainvisualBox{
		width: 230px;
		padding: 20px 0;
	}
}

.l-menu{
	background: var(--black);
}
.content{
	background: none;
	margin: 80px auto 0;
}
.contentInner780{
	max-width: 780px;
	margin: 0 auto;
	}
.content__title{
	background: none;
	padding: 0;
}
.content__subtitle {
    font-size: 1.7rem;
	line-height: 1.4;
    font-weight: bold;
    color: var(--yellow);
    border-bottom: 1px solid var(--yellow);
    padding-bottom: 5px;
}

@media screen and (max-width: 768px) {
	.content__subtitle {
		line-height: 1.7;
	}
}

.qaList{}
.qaList dt{
	padding-left: 40px;
	background: url(../img/icon-q.png) left top / 28px auto no-repeat;
	min-height: 30px;
	margin-bottom: 20px;
}
.qaList dd{
	padding-left: 40px;
	background: url(../img/icon-a.png) left top / 26px auto no-repeat;
	min-height: 34px;
	margin-bottom: 60px;
}


.slider .swiper-container{
	width: 100%;
}
.slider .swiper-slide{
	padding: 0;
	color: var(--white);
	background: none;
}
.slider__update{
	color: var(--white);
}
.slider .swiper-slide a,
.slider .swiper-slide p{
	color: var(--white);
}

.slider .swiper-next,
.slider .swiper-prev{
	background: #fff;
	position: absolute;
    width: 40px;
    height: 40px;
}

.slider .swiper-prev{
    top: 27%;
    left: 0;
    transform: translate(-120%, -50%);
}

.swiper-prev:before{
	content: "";
	position: absolute;
	display: block;
	width: 15px;
	height: 15px;
	border-left: 2px solid var(--black) ;
	border-top: 2px solid var(--black);
	top: 50%;
    left: 50%;
    transform: rotate(-45deg) translate(10%, -60%);
}
.slider .swiper-next{
    top: 27%;
    right: 0;
    transform: translate(120%, -50%);
}
.swiper-next:before{
	content: "";
	position: absolute;
	display: block;
	width: 15px;
	height: 15px;
	border-left: 2px solid var(--black) ;
	border-top: 2px solid var(--black);
	top: 50%;
    left: 50%;
    transform: rotate(135deg) translate(20%, 80%);
}
@media screen and (max-width: 768px) {
	.slider .swiper-prev{
		top: 40%;
		left: 0;
		transform: translate(0%, -50%);
	}
	.slider .swiper-next{
		top: 40%;
		right: 0;
		transform: translate(0%, -50%);
	}
}


/*イントロダクション*/
.sectionIntro .contentInner{
	position: relative;
}
.sectionIntro .content__title{
	position: absolute;
	left: 0;
	top: 0;
}
.intro_read{
	text-align: center;
	color: var(--yellow);
	font-family: "Noto Serif JP", serif;
	font-size: 30px;
}
.intro_text{
	font-size: 18px;
	line-height: 2;
}

@media screen and (max-width: 768px) {
	.sectionIntro .content__title {
		top: -25px;
	}
	.intro_read{
		font-size: 21px;
		line-height: 1.7;
	}
}

/*キャストスタッフ*/
.cast-list{
	font-family: "Noto Serif JP", serif;
}
.cast-list dl{font-size: 2.1rem;}

.cast-list p{
	color: var(--white);
}
.contentCastStaff h3{
	font-family: "Noto Serif JP", serif;
	text-align: center;
	font-size: 1.2em;
	font-weight: bold;
}

.staffList_box dd {
    font-size: 2.1rem;
}
.staff-list{
	font-family: "Noto Serif JP", serif;
}
.staff-list span{
	font-size: 0.6em;
}

/*リンク*/

.linksArea{ text-align: center; padding-bottom: 200px;}
.linksArea p{
	font-size: 18px;
	line-height: 3;
}
.linksArea p a{
	color: var(--white);
	text-decoration: underline;
}
.linksArea p a:hover{
	text-decoration: none;
}
@media screen and (max-width: 768px) {
	.linksArea p{
		font-size: 16px;
		line-height: 3;
	}
}



/*ナビゲーション*/
.call_menu{
	position: relative;
}
.call_menu.cmsn{
	
}
.call_menu.cmsn a{
	opacity: 0.25;
	pointer-events: none;
}
.call_menu::after{
	content: "";
	display: block;
	background: var(--white);
	width: 1px;
	height: 60px;
	position: absolute;
	top: 20px;
	right: 0;
}
.call_menu:last-child:after{
	display: none;
}
.menu--4.menu--sp2 .call_menu a{
	display: block;
}
.menu--4.menu--sp2 .nav-intro a{
	background: url(../img/nv01.png) center center / 158px auto no-repeat;
}
.menu--4.menu--sp2 .nav-story a{
	background: url(../img/nv02.png) center center / 66px auto no-repeat;
}
.menu--4.menu--sp2 .nav-caststaff a{
	background: url(../img/nv03.png) center center / 118px auto no-repeat;
}
.menu--4.menu--sp2 .nav-chart a{
	background: url(../img/nv04.png) center center / 71px auto no-repeat;
}

@media screen and (max-width: 768px) {
	.call_menu:after{
		display: none;
	}
	.menu--4.menu--sp2 .menu__item {
		border: 1px solid #333;
	}
}

.official__account li a{
	background: url(../img/btnBg.png) center center / cover;
	overflow: hidden;
	border: 1px solid #fff;
	border-radius: 2px;
	color: #fff;
	font-weight: bold;
}
.official__account li span {
    padding-left: 50px;
}

@media screen and (max-width: 768px) {
	.official__account li span {
		padding-left: 35px;
	}
}


.youtubeBox {
    position: relative;
    width: 100%;
    margin: 0 auto;
    max-width: 780px;
}
.youtubeBoxInner {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    margin: 0 auto;
}
.youtubeBox iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

.readText{
	font-size: 1.5em;
	color: var(--yellow);
	font-family: "Noto Serif JP", serif;
}

@media screen and (max-width: 768px) {
	.readText{
		font-size: 1.25em;
	}
}