@charset "utf-8";
/* CSS INFORMATION -====================================================
File name : top.css
Description : TOPページCSS
===================================================================== */

/* =====================================================================
*    #header
* =================================================================== */
#header {
	width: 100%;
	position: relative;
}

#header .site_ttl h1 {
	margin:-17.33% 0 0;
}

#header .site_ttl .onair {
	height:0;
	padding-top:22.4%;
	background:url(../images/img_onair_sp.png) no-repeat top center ;
	background-size: auto 100%;
}

#header .official_link {
	background:url(../images/bg_official_sp.png) no-repeat top center ;
	padding:2% 4%;
	position: relative;
}

#header .official_link a {
    display: block;
}

@media screen and (min-width:700px){
	#header {
		display:-webkit-box;
		display: -webkit-flex;
		display:-ms-flexbox;
		display: flex;
		-webkit-flex-wrap:wrap;
		-ms-flex-wrap:wrap;
		flex-wrap:wrap;
		flex-wrap: wrap;
		width: 100%;
	}

	#header .inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 6px 325px 0 15px;
		margin: 0 auto;
        position: relative;
	}
	
	#header .main_visual{
		background: url(../images/bg_mv.png) no-repeat top center , url(../images/bg_main.png) repeat top left;
		background-size: cover, auto;
		position: relative;
		width:100%;
		-webkit-box-ordinal-group:2;
		-ms-flex-order:2;
		-webkit-order:2;
		order: 2;
	}

	#header .main_visual .inner{
		padding: 20px 325px 10px 15px;
	}
	#header .site_ttl {
		width:100%;
		-webkit-box-ordinal-group:1;
		-ms-flex-order:1;
		-webkit-order:1;
		order: 1;
	}
	#header .site_ttl h1 {
		margin:0;
	}

	#header .site_ttl .inner{
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		margin: 0 auto 0;
	}
	
	#header .site_ttl .onair {
		height:auto;
		background:none;
		padding:0;
	}

	#header .official_link {
		width: 100%;
		position: absolute;
		bottom:10px;
		background-image:none;
		margin-top:0;
		padding:0;
		}
    
    #header .official_link .inner {
		display: flex;
		justify-content: flex-end;
        
	}

	#header .official_link a {
        position: relative;
		width: 19.71%;
	}

	#header .official_link a::before,
	#header .official_link a::after {
		content: "";
		width: 100%;
		height: 0;
		padding-top: 115.94%;
		display: block;
	}

	#header .official_link a::before {
		background: url(../images/btn_official_off.png) no-repeat center top;
		background-size: auto 100%;
	}

	#header .official_link a::after {
		background: url(../images/btn_official_on.png) no-repeat center top;
		background-size: auto 100%;;
		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:1060px){
   
}


/* =====================================================================
*    #main
* =================================================================== */
.main {
	background:url(../images/bg_cast_staff_sp.png) repeat center left , url(../images/bg_main.png) repeat top left;
	background-size:100% auto , auto;
	position: relative;
}
.line01,
.line02,
.line03 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1;
}
.line01::before,.line01::after,
.line02::before,.line02::after,
.line03::before {
	content: '';
    display: block;
	width: 100%;
	background-image: linear-gradient(to right, #df0c1d 0%, #024098 100%);
}

.line01::before,
.line02::after {
	height: 2px;
    margin-bottom: 1px;
}
.line01::after,
.line02::before {
	height: 1px;
    margin-bottom: 1px;
}
.line03::before{
	height: 2px;
}

#main .inner h2.category_ttl {
	background: url(../images/bg_title.png) no-repeat 50% 100%;
	background-size:73.333% auto;
	text-align: center;
	padding-bottom:20px;
	margin-bottom:40px;
}
#main .inner h2.category_ttl span {
	font-family: "Yu Mincho", "YuMincho", serif;
	font-size:2rem;
}

#main .inner h2.category_ttl::after {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	content: attr(data-jp);
    display: block;
    color: #024098;
}
@media screen and (min-width:700px){
	.line01::before,
	.line02::after {
	height: 4px;
    margin-bottom: 2px;
}
	.line01::after,
	.line02::before {
	height: 2px;
    margin-bottom: 2px;
}
	.main {
	background:url(../images/bg_cast_staff.png) repeat center left , url(../images/bg_main.png) repeat top left;
	}
	
	#main .inner h2.category_ttl {
		background: url(../images/bg_title.png) no-repeat 50% 100%;
		background-size:56.28% auto;
	}
	#main .inner h2.category_ttl span {
		font-size:3rem;
	}
}

/* #main #introduction */
#main #introduction {
	background-color: #fff;
}

#main #introduction .inner {
    position: relative;
	padding: 12.5% 0;
}

@media screen and (min-width:700px){
    #main #introduction {
	    background-size: 5px 5px;
        padding: 5.77% 0;
    }

	#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;
	}
    
}

@media screen and (min-width:1040px){
    #main #introduction {
        padding: 60px 0;
    }
}

/* #main #cast */
#main #cast {
    background-size:  100% auto;
}

#main #cast .inner {
    position: relative;
	padding: 12.5% 0;
}

#main #cast .category_img {
	width:90%;
	margin:0 auto;
	padding: 4% 0;
	background-color:rgba(255,255,255,0.5);
	border-color:#fff
}

@media screen and (min-width:700px){
    #main #cast {
        padding: 5.77% 0;
    }

	#main #cast .inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px;
		margin: 0 auto;
	}
    
}

@media screen and (min-width:1040px){
    #main #cast {
        padding: 60px 0;
    }
}

/* #main #staff */
#main #staff {
    background-size: 100% auto;
}

#main #staff .inner {
    position: relative;
	padding: 12.5% 0 27%;
}

#main #staff .category_img {
	width:90%;
	margin:0 auto;
	padding: 4% 0;
	background-color:rgba(255,255,255,0.5);
	border-color:#fff;
}

@media screen and (min-width:700px){
    #main #staff {
	    background-size: 5px 5px;
        padding: 5.77% 0 8.79%;
    }

	#main #staff .inner {
		width: 100%;
		max-width: 1040px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 0 325px 0 15px;
		margin: 0 auto;
	}
    
}

@media screen and (min-width:1040px){
    #main #staff {
        padding: 60px 0 90px;
    }
}


/* =====================================================================
*    .pagetop
* =================================================================== */
.pagetop {
	width: 100%;
}

.pagetop .pagetop_inner {
	width: 100%;
	position: relative;
}

.pagetop .pagetop_inner a {
	width: 16%;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: 0 auto 4%;
}

@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: 5.76%;
		left: auto;
		margin: 0 auto 0;
	}

	.pagetop .pagetop_inner a::before,
	.pagetop .pagetop_inner a::after {
		content: "";
		width: 100%;
		height: 0;
		padding-top: 115.94%;
		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: auto 100%;
	}

	.pagetop .pagetop_inner a::after {
		position: absolute;
		top: 0;
		left: 0;
		background: url(../images/btn_pagetop_on.png) no-repeat center top;
		background-size: auto 100%;
		opacity: 0;
	}
	.pagetop .pagetop_inner a:hover::before {
		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-color: #fff;
	position: relative;
}

#footer .footer_inner {
    color: #000;
	font-size: 1.15rem;
	line-height: 1;
    letter-spacing: 0.05em;
    text-align: center;
    padding: 5% 3%;
}

@media screen and (min-width:700px) {
    
	#footer .footer_inner {
		width: 100%;
		max-width: 1040px;
		font-size: 1rem;
		line-height: 1;
        text-align: center;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding-right: 300px;
        padding: 2.21% 0;
        margin: 0 auto;
	}
}

@media screen and (min-width:1040px) {
    #footer {
        padding-top: 5px;
    }
    
    #footer::before {
        padding-top: 2px;
    }
    
    #footer .footer_inner {
        padding: 23px 0;
    }
}
