@charset "utf-8";
/* CSS INFORMATION -====================================================
File name : top.css
Description : TOPページCSS
===================================================================== */

/* =====================================================================
*    #header
* =================================================================== */
#header {
	width: 100%;
	position: relative;
}

#header .ttl_bg {
	position: relative;
    background: url(../images/bg_logo.jpg) repeat left top;
    background-size: 41.67% auto;
}

#header .ttl_bg .inner {
    padding: 3.28% 0 5.78%;
}

#header .ttl_bg .inner::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: 0.63%;
    margin-bottom: 1.56%;
    position: absolute;
    left: 0;
    bottom: 0;
    background: url(../images/line_mv.png) repeat-x left bottom;
    background-size: auto 100%;
}

#header .site_ttl img {
	width: 59.38%;
    margin: 0 auto;
}

#header .main_visual {
}

#header .onair {
	width: 100%;
	position: absolute;
    left: 0;
    top: 0;
	padding-top: 34.38%;
    margin: 111% 0 0;
	z-index: 10;
}

#header .onair::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #fff;
    opacity: .88;
}

#header .onair img {
    width: 93.75%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 4.69% auto;
    z-index: 2;
}

#header .official_link {
	padding: 4.69% 0;
    background: url(../images/bg_mv.jpg) repeat center top;
    background-size: 41.67% auto;
}

#header .official_link a {
    display: block;
    position: relative;
	width: 77.5%;
    margin: 0 auto;
}

@media screen and (min-width:700px){
	#header {
	}

	#header .ttl_bg {
        background-size: 48.08% auto;
	}
    
    #header .ttl_bg .inner {
        padding: 1.92% 0 6.92%;
    }
    
    #header .ttl_bg .inner::after {
        padding-top: 2px;
        margin-bottom: 0.48%;
        background-size: auto 2px;
    }
    
    #header .site_ttl {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 320px 0 20px;
		margin: 0 auto;
	}
    
    #header .ttl_bg .site_ttl img {
        width: 54.29%;
        margin: 0 auto;
    }
    
    #header .mv_bg {
        background: url(../images/bg_mv.jpg) repeat center top;
        background-size: 41.67% auto;
    }
    
    #header .mv_bg .inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px;
		margin: 0 auto;
	}

	#header .main_visual {
		border: 1.9vw solid #fff;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        position: relative;
        margin: -7.5% 0 0;
	}

	#header .onair {
		width: 100%;
		position: relative;
        margin: 0;
        padding: 0;
	}

	#header .onair::after {
		display: none;
	}
    
    #header .onair img {
        width: 85.71%;
        margin: 2.86% auto 0;
        position: relative;
    }

	#header .official_link {
        padding: 2.86% 0 4.26%;
	}

	#header .official_link a {
        width: 70.86%;
	}

	#header .official_link a::before,
	#header .official_link a::after {
		content: "";
		width: 100%;
		height: 0;
		padding-top: 22.58%;
		display: block;
	}

	#header .official_link a::before {
		background: url(../images/btn_official_off.png) no-repeat center top;
		background-size: 100% auto;
	}

	#header .official_link a::after {
		background: url(../images/btn_official_on.png) no-repeat center top;
		background-size: 100% auto;
		position: absolute;
		top: 0;
		left: 0;

		opacity: 0;
	}

	#header .official_link a:hover::before {
		opacity: 0;
	}

	#header .official_link a:hover::after {
		opacity: 1;
	}

	#header .official_link a img {
		display: none;
	}
}

@media screen and (min-width:1040px){
    #header .ttl_bg {
        background-size: 500px auto;
	}
    
    #header .ttl_bg .inner {
        padding: 20px 0 72px;
    }

    #header .ttl_bg .inner::after {
        padding-top: 2px;
        margin-bottom: 5px;
        background-size: auto 2px;
    }
    
    #header .main_visual {
		border: 20px solid #fff;
    }
}


/* =====================================================================
*    #main
* =================================================================== */
.main {
    background: url(../images/bg_mv.jpg) repeat center top;
    background-size: 41.67% auto;
}

#main .inner {
}

#main .category_ttl {
	width: 60.94%;
    margin: 0 auto;
}

@media screen and (min-width:700px){
	#main .category_ttl {
        width: 48.75%;
	}
}

@media screen and (min-width:1040px){
    #header .ttl_bg {
        background-size: 500px auto;
	}
    
    #header .ttl_bg .inner {
        padding: 20px 0 72px;
    }

    #header .ttl_bg .inner::after {
        padding-top: 2px;
        margin-bottom: 5px;
        background-size: auto 2px;
    }
    
    #header .main_visual {
		border: 20px solid #fff;
    }
}

/* #main #introduction */
#main #introduction {
	background: url(../images/bg_logo.jpg) repeat center top;
	background-size: 41.67% auto;
}

#main #introduction::before, #main #introduction::after {
    content: "";
    display: block;
    width: 100%;
    padding-top: 2.19%;
    background: url(../images/line_mv.png) repeat-x left bottom;
    background-size: auto 28.57%;
}

#main #introduction::after {
    background-position: left top;
}

#main #introduction .inner {
    position: relative;
	padding-top: 12.5%;
}

#main #introduction .inner::before, #main #introduction .inner::after {
	content: "";
    display: block;
    width: 15.63%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: url(../images/bg_intro_sp.jpg) repeat-y left top;
    background-size: 100% auto;
}

#main #introduction .inner::after {
    left: auto;
    right: 0;
}

#main #introduction .introduction_img1 {
    padding-top: 8.75%;
    position: relative;
    z-index: 2;
}

#main #introduction .introduction_img2 {
    padding: 10.94% 0 12.5%;
    position: relative;
    z-index: 2;
}

@media screen and (min-width:700px){
    #main #introduction {
	    background: url(../images/bg_intro_pc.jpg) repeat center top;
        background-size: 48.08% auto;
    }
    
    #main #introduction::before, #main #introduction::after {
        padding-top: 0.48%;
        background: url(../images/line_mv.png) repeat-x left bottom;
        background-size: auto 2px;
    }
    
    #main #introduction::after {
        background-position: left top;
    }
    
	#main #introduction .inner::before, #main #introduction .inner::after {
		display: none;
	}

	#main #introduction .inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px;
		margin: 0 auto;
	}
    
    #main #introduction .intro_bg {
        width: 114.29%;
        margin-left: -7.15%;
        background: url(../images/bg_logo.jpg) repeat center top;
	    background-size: 18.29% auto;
        padding: 10% 0 14.63%;
    }
    
    #main #introduction .introduction_img1 {
        padding-top: 3.5%;
    }

    #main #introduction .introduction_img2 {
        padding: 7.25% 0 0;
    }
}

@media screen and (min-width:1040px){
    #main #introduction {
	    background: url(../images/bg_intro_pc.jpg) repeat center top;
        background-size: 300px auto;
    }
    
    #main #introduction::before {
        padding-top: 7px;
        background-size: auto 2px;
    }
    
    #main #introduction .intro_bg {
        background: url(../images/bg_logo.jpg) repeat center top;
	    background-size: 128px auto;
    }
}

/* #main #cast #staff */
#main #cast, #main #staff {
    padding: 12.5% 0 0;
}

#main #cast .inner {
}

#main #cast .category_img {
    width: 96.88%;
    margin: 0 auto;
    padding-top: 7.5%;
}

#main #staff .category_img {
    width: 96.88%;
    margin: 0 auto;
    padding: 7.5% 0 34.69%;
}

@media screen and (min-width:700px){
	#main .bg_pink .category {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px !important;
		margin: 0 auto;
	}
    
    #main .bg_pink .inner {
        width: 114.29%;
        margin-left: -7.15%;
        padding: 9.75% 0 0;
    }
    
    #main #cast, #main #staff {
        padding: 0;
    }
    
    #main #cast .category_img {
        width: 77.5%;
        padding: 6.25% 0 0;
    }

    #main #staff .category_img {
        width: 77.5%;
        padding: 6.25% 0 15%;
    }
}

/* =====================================================================
*    .pagetop
* =================================================================== */
.pagetop {
	width: 100%;
}

.pagetop .pagetop_inner {
	width: 100%;
	position: relative;
}

.pagetop .pagetop_inner a {
	width: 31.25%;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
}

@media screen and (min-width:700px){
	.pagetop {
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
        margin: auto;
	}

	.pagetop .pagetop_inner a {
		width: 20.67%;
		left: auto;
		margin-right: 4.13%;
	}

	.pagetop .pagetop_inner a::before,
	.pagetop .pagetop_inner a::after {
		content: "";
		width: 100%;
		height: 0;
		padding-top: 55.81%;
		display: block;
		-webkit-transition: opacity 0 ease;
		transition: opacity 0 ease;
	}

	.pagetop .pagetop_inner a::before {
		background: url(../images/btn_pagetop_off.png) no-repeat center top;
		background-size: 100% auto;
	}

	.pagetop .pagetop_inner a::after {
		position: absolute;
		top: 0;
		left: 0;
		background: url(../images/btn_pagetop_on.png) no-repeat center top;
		background-size: 100% auto;
		opacity: 0;
	}

	.pagetop .pagetop_inner a:hover::after {
		opacity: 1;
	}

	.pagetop .pagetop_inner a img {
		display: none;
	}
}

/* =====================================================================
*    #banner_area
* =================================================================== */
#banner_area {
	background: url(../images/bg_bnr.jpg) repeat center top;
	background-size: 41.67% auto;
}

#banner_area .banner_inner {
	background: url(../images/line_bnr.png) repeat-x left top;
    background-size: auto 6.5%;
}

#banner_area ul {
	text-align: center;
	padding: 21.41% 0 12.5%;
}

#banner_area ul li {
	width: 58.28%;
	display: block;
    margin: 0 auto 3.13%;
}

#banner_area ul li:last-child {
    margin-bottom: 0;
}

@media screen and (min-width:700px){
	#banner_area {
		background: url(../images/bg_bnr.jpg) repeat center top;
		background-size: 40px auto;
        position: relative;
	}
    
    #banner_area::before {
        content: "";
        display: block;
        width: 100%;
        padding-top: 3.65%;
	    background: url(../images/line_bnr.png) repeat-x left top;
        background-size: auto 100%;
    }

	#banner_area .banner_inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px;
		margin: 0 auto;
        background: none;
	}

	#banner_area ul {
		width: 60%;
		padding: 8.57% 0 6.19%;
        margin: 0 auto;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
	}

	#banner_area ul li {
		width: 47.62%;
        margin: 0 0 2.38%;
	}

	#banner_area ul li a {
		width: 100%;
		height: auto;
		display:block;
		-webkit-transition: opacity 0.2s ease;
		transition: opacity 0.2s ease;
	}

	#banner_area ul li a:hover {
		opacity: 0.7;
	}
}

@media screen and (min-width:1040px){
    #banner_area::before {
        padding-top: 38px;
        background-size: auto 38px;
    }
}

/* =====================================================================
*    #footer
* =================================================================== */
#footer {
	background: url(../images/bg_footer.jpg) repeat center top;
    background-size: 41.67% auto;
    padding: 1.56% 0 0;
}

#footer .footer_inner {
	font-size: 1.15rem;
	line-height: 1.5;
	color: #FFF;
    padding: 6.25% 3% 5%;
    background: url(../images/line_footer.png) repeat-x left top;
}

@media screen and (min-width:700px) {
    #footer {
        padding: 0.48% 0 0;
    }
    
    #footer::before {
        content: "";
        display: block;
        width: 100%;
        padding-top: 0.19%;
        background: url(../images/line_footer.png) repeat-x left top;
        background-size: auto 2px;
    }
    
	#footer .footer_inner {
		width: 100%;
		max-width: 1040px;
		font-size: 1.4rem;
		line-height: 1;
        text-align: center;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding-right: 300px;
        padding: 3.85% 300px 3.85% 0;
        margin: 0 auto;
        background: none;
	}
}

@media screen and (min-width:1040px) {
    #footer {
        padding-top: 5px;
    }
    
    #footer::before {
        padding-top: 2px;
    }
    
    #footer .footer_inner {
        padding: 40px 300px 40px 0;
    }
}
