@charset "UTF-8";



/* ----------------------------reset ---------------------------- */

html, body, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	background: transparent;
}
body {
	font-family: "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.75;
	letter-spacing: 1px;
	color: #000;
	text-align: left;
	-webkit-text-size-adjust: 100%;
	background: #f0f0f0;
	min-height: 100vh;
    display: flex;
    flex-direction: column;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: bold;
}
li {
	list-style-type: none;
}
a {
	outline: none;
	color: #000;
	text-decoration: none;
}
*:focus {
outline: none;
}
strong{
	font-weight: bold;
}
img {
  width: 100%;
  vertical-align: middle;
}

@media only screen and (max-width: 959px) {
body {
	font-size: 14px;
}
}

@media only screen and (max-width: 374px) {
body {
	font-size: 12px;
}
}



/* ----------------------------common ---------------------------- */

.nobreak {
	display: inline-block;
}
.onlysp {
	display: none!important;
}
.hover{
	display: block;
	transition: opacity 0.2s;
}
.oswald{
	font-family: Oswald, sans-serif;
}
.inner{
	width: 100%;
	max-width: 1200px;
	padding: 0 20px;
	margin: 0 auto;
	box-sizing: border-box;
}


@media only screen and (min-width: 960px) {
.hover:hover{
	opacity: 0.9;
}
.br-sp {
	display: none;
}
}
@media only screen and (max-width: 959px) {

.onlypc {
	display: none!important;
}
.onlysp {
	display: inline!important;
}
}

@media only screen and (max-width: 379px) {

.pconly {
	display: none!important;
}
.sponly {
	display: inline!important;
}
}

@media only screen and (min-width: 380px) {

.pconly {
	display: inline!important;
}
.sponly {
	display: none!important;
}
}


/* ----------------------------hero ---------------------------- */

.hero{
	background: url("../images/bg_hero_pc.jpg") no-repeat center center/cover;
}
.hero .inner{
	position: relative;
}
.hero_ttl_wrap{
	height: 15vw;
	min-height: 210px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.hero_ttl_grade{
	display: block;
	width: 50px;
	line-height: 50px;
	font-size: 22px;
	text-align: center;
	border-radius: 5px;
	margin-right: 20px;
	flex-shrink: 0;
}
.hero_ttl_grade.sg{
	background: #ee394e;
}
.hero_ttl_grade.g1{
	background: #ef9d00;
}
.hero_ttl_grade.g2{
	background: #56b439;
}
.hero_ttl_grade.g3{
	background: #15b0ca;
}
.hero_ttl_grade.general{
	font-size: 18px;
	font-weight: bold;
	background: #5f6772;
}
.hero_ttl{
	font-size: 28px;
	line-height: 1.5;
}
.hero_caution{
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	font-weight: bold;
	line-height: 1.35;
	margin-top: -47px;
	padding-bottom: 15px;
}
.hero_caution span{
	display: inline-block;
	padding: 5px 10px;
	background: #f44243;
}
@media only screen and (max-width: 959px) {
.hero{
	background: url("../images/bg_hero_sp.jpg") no-repeat center center/cover;
}
.hero_ttl_wrap{
	height: 32vw;
	min-height: 120px;
	max-height: 210px;
}
.hero_ttl_grade{
	width: 40px;
	line-height: 40px;
	font-size: 16px;
	border-radius: 3px;
	margin-right: 15px;
}
.hero_ttl{
	font-size: 16px;
}
.hero_caution{
	font-size: 10px;
	letter-spacing: 0.5px;
	margin-top: -10px;
	padding-bottom: 15px;
}
.hero_caution span{
	padding: 4px 8px;
}
}

/* ----------------------------nav_date ---------------------------- */

.nav_date{
	background: #000;
}
.nav_date ul{
	display: flex;
}
.nav_date_item{
	width: 100%;
}
.nav_date_item a{
	display: block;
	font-size: 22px;
	color: #fff;
	padding: 15px;
	text-align: center;
	transition: background 0.2s;
}
.nav_date_item.current a{
	background: #0069d5;
}
@media only screen and (min-width: 960px) {
.nav_date_item a:hover{
	background: #0069d5;
}
}
.nav_date_item.sat a{
	color: #b2e3f2;
}
.nav_date_item.sun a,
.nav_date_item.holiday a{
	color: #ffbec6;
}
.nav_date_item a .week{
	font-size: 16px;
}
@media only screen and (max-width: 959px) {
.nav_date{
	border-bottom: 5px solid #fff;
}
.nav_date .inner{
	padding: 0;
}
.nav_date.long ul{
	flex-wrap: wrap;
}
.nav_date.long .nav_date_item{
	width: 16.65%;
}
.nav_date_item a{
	font-size: 16px;
	line-height: 1.35;
	padding: 10px 10px 12px;
}
.nav_date_item.current a{
	background: #0069d5;
}	
.nav_date_item a .week{
	display: block;
	font-size: 10px;
}
}

/* ----------------------------nav_media ---------------------------- */

.media_wrap{
  position: relative;
  display: none;
}
.media_wrap.current{
  display: block;
}
.nav_media{
	width: 100%;
	position: absolute;
	z-index: 2;
	top: 20px;
	left: 0;
}
.nav_media.latter{
	position: fixed;
}
.nav_media_inner{
	background: #0069d5;
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: #fff;
	border-radius: 5px;
	box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.15);
	overflow: hidden;
}
.nav_media_date{
	font-size: 22px;
	padding: 0 30px;
	flex-shrink: 0;
}
.nav_media_date.sat {
	color: #b2e3f2;
}
.nav_media_date.sun,
.nav_media_date.holiday{
	color: #ffbec6;
}
.nav_media_date .week{
	font-size: 16px;
}
.nav_media_inner > ul{
	display: flex;
}
.nav_media_item a{
	display: inline-block;
	font-weight: bold;
	text-align: center;
	color: #fff;
	padding: 20px 30px;
	position: relative;
	transition: color 0.2s;
	word-break: keep-all;
}
.nav_media_item.current a{
	color: #fff000;
}
.nav_media_item a:after{
    display: inline-block;
    position: absolute;
    content: '';
    left: 0;
    bottom: 0;
    height: 5px;
    width: 100%;
	opacity: 0;
    background-color: #fff000;
	transition: opacity 0.2s;
}
.nav_media_item.current a:after {
    opacity: 1;
}

@media only screen and (min-width: 960px) {
.nav_media_item a:hover{
	color: #fff000;
}
.nav_media_item a:hover:after {
    opacity: 1;
}
}

@media only screen and (max-width: 959px) {
.nav_media{
	top: 0;
}
.nav_media .inner{
	padding: 0;
}
.nav_media_inner{
	display: block;
	border-radius: 0;
}
.nav_media_date{
	font-size: 16px;
	line-height: 1.35;
	padding: 10px 10px 0;
}
.nav_media_date .week{
	font-size: 10px;
}
.nav_media_item{
	width: 100%;
}
.nav_media_item a{
	display: block;
	padding: 20px 1.9vw;
	font-size: 14px;
	letter-spacing: 0.25px;
	line-height: 1.35;
}
}
@media only screen and (max-width: 437px) {
.nav_media_item a{
	font-size: 3.2vw;
}
}

/* ----------------------------media ---------------------------- */

.media{
	padding-top: 110px;
}
.media_ttl{
	font-size: 20px;
	line-height: 1.5;
	color: #0069d5;
	padding: 20px 0 25px; 
	position: relative;
}
.media_ttl:before,
.media_ttl:after{
    display: inline-block;
    position: absolute;
    content: '';
    left: 0;
    top: 0;
    height: 3px;
}
.media_ttl:before{
    width: 100%;
    background-color: #cbcbcb;
}
.media_ttl:after{
    width: 160px;
    background-color: #0069d5;
}
.media_item{
	background: #fff;
	padding: 40px;
	border-radius: 5px;
	box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.15);
}
.media_item + .media_item{
	margin-top: 10px;
}
.media_time{
	margin-bottom: 20px;
	padding-left: 31px;
	position: relative;
	font-weight: bold;
}
.media_time:before{
    display: inline-block;
    content: '';
	width: 21px;
    height: 21px;
	background: url("../images/ico_time.svg") no-repeat center center/contain;
	position: absolute;
	top: 3px;
	left: 0;
}
.media_time_caption{
	font-size: 12px;
	font-weight: normal;
	display: inline-block;
}
.media_item_ttl_wrap{
	display: flex;
	flex-wrap: wrap;
}
.media_item_ttl{
	font-size: 28px;
	line-height: 1.5;
	margin-right: 30px;
	padding-bottom: 10px;
}
.media_btn{
	display: flex;
	padding-bottom: 10px;
}
.media_btn_item:not(:first-child){
	margin-left: 10px;
}
.media_btn_item a{
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6px 20px 6px 30px;
	border: 1px solid #0069d5;
	border-radius: 3px;
	font-weight: bold;
	color: #0069d5;
	background: #fff;
	transition: all 0.2s;
	position: relative;
}
.media_btn_item.media_btn_primary a{
	background: #0069d5;
	color: #fff;
}
.media_btn_item a:after{
    display: inline-block;
    content: '';
	width: 20px;
    height: 16px;
	margin-left: 10px;
}
.media_btn_item.modal a:after{
	background: url("../images/ico_modal.svg") no-repeat center center/contain;
}
.media_btn_item.window a:after{
	background: url("../images/ico_window.svg") no-repeat center center/contain;
}
.media_btn_item.media_btn_primary.window a:after{
	background: url("../images/ico_window_hover.svg") no-repeat center center/contain;
}
@media only screen and (min-width: 960px) {
.media_btn_item a:hover{
	background: #0069d5;
	color: #fff;
}
.media_btn_item.media_btn_primary a:hover{
	background: #fff;
	color: #0069d5;
}
.media_btn_item.modal a:hover:after{
	background: url("../images/ico_modal_hover.svg") no-repeat center center/contain;
}
.media_btn_item.window a:hover:after{
	background: url("../images/ico_window_hover.svg") no-repeat center center/contain;
}
.media_btn_item.media_btn_primary.window a:hover:after{
	background: url("../images/ico_window.svg") no-repeat center center/contain;
}

}
.media_regular{
	margin-top: 20px;
}
.media_performer{
	margin-top: 30px;
	display: flex;
	flex-wrap: wrap;
}
.media_performer_item{
	width: 23.5%;
	margin-left: 2%;
}
.media_performer_item:nth-child(4n+1){
	margin-left: 0;
}
.media_performer_item:nth-child(n+5){
	margin-top: 4%;
}
.media_performer_item h4{
	margin-top: 12px;
	text-align: center;
	padding-left: 10px;
	padding-right: 10px;
}
.media_performer_item p{
	font-size: 12px;
	text-align: center;
	padding-bottom: 12px;
	padding-left: 10px;
	padding-right: 10px;
}
.media_performer_item_regular{
	border: 1px solid #0069d5;
	box-sizing: border-box;
}
.media_performer_item_guest{
	border: 1px solid #0069d5;
	box-sizing: border-box;
	color: #0000FF;
}
.media_thumb{
	margin-top: 30px;
	text-align: center;
}
.media_thumb img{
	max-width: 460px;
}
.media_comment{
	margin-top: 40px;
}
.media_bnr{
	margin-top: 30px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.media_bnr_item{
	width: 49%;
}
.media_bnr_item:nth-child(n+3){
	margin-top: 2%;
}

@media only screen and (max-width: 959px) {
.media_wrap{
	padding-top: 55px;
}
.media{
	padding-top: 110px;
	margin-top: -55px;
}
.media .inner{
	padding: 0 10px;
}
.media_ttl{
	font-size: 16px;
	padding: 15px 0; 
}
.media_ttl:after{
    width: 80px;
}
.media_item{
	padding: 20px;
}
.media_item + .media_item{
	margin-top: 10px;
}
.media_time{
	margin-bottom:10px;
	padding-left: 28px;
}
.media_time:before{
	width: 18px;
    height: 18px;
	top: 2px;
}
.media_time_caption{
	font-size: 10px;
}
.media_item_ttl_wrap{
	display: block;
}
.media_item_ttl{
	font-size: 20px;
	margin-right: 0;
	padding-bottom: 10px;
}
.media_btn{
	justify-content: space-between;
	padding-bottom: 0;
}
.media_btn_item {
	width: calc(50% - 10px);
}
.media_btn_item:not(:first-child){
	margin-left: 0;
}
	
.media_btn_item a{
	padding: 7px;
	text-align: center;
	letter-spacing: 0.5px;
}
	
.btn_adj{
	padding-right:25px !important;
	line-height:1.5;
}
	
.media_btn_item a:after{
	width: 16px;
    height: 13px;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 10px;
	margin: auto 0;
}
.media_performer{
	margin-top: 20px;
	justify-content: space-between;
}
.media_performer_item{
	width: calc(50% - 10px);
	margin-left: 0;
}
.media_performer_item:nth-child(n+3){
	margin-top: 5%;
}
.media_performer_item h4{
	margin-top: 10px;
    letter-spacing: -0.02em;
    font-size:0.9em;
}
.media_performer_item p{
	font-size: 12px;
}
.media_thumb{
	margin-top: 20px;
	text-align: center;
}
.media_comment{
	margin-top: 25px;
}
.media_bnr{
	margin-top: 20px;
	display: block;
}
.media_bnr_item{
	width: 100%;
}
.media_bnr_item:nth-child(n+2){
	margin-top: 20px;
}
}

/* ----------------------------footer ---------------------------- */

.footer{
	margin-top: 110px;
}
.footer_pagetop{
	position: fixed;
	bottom: 25px;
	right: 25px;
	z-index: 98;
	width: 50px;
	display: none;
}
.footer_pagetop a{ 
	display: block;
	background: #0069d5;
	border-radius: 3px;
	box-shadow: 0px 5px 10px 0px rgb(0 0 0 / 15%);
}
.footer_caption{
	text-align: center;
	padding-bottom: 40px;
}

.footer_primary{
	padding: 40px 20px;
	background: #000;
}
.footer_sns{
	width: 330px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
.footer_sns_item{
	width: 50px;
}

.footer_copy{
	text-align: center;
	font-size: 12px;
	margin-top: 30px;
	color: #a3a3a3;
}

@media only screen and (max-width: 959px) {
.footer{
	margin-top: 55px;
}
.footer_pagetop{
	bottom: 20px;
	right: 20px;
	width: 42px;
}
.footer_primary{
	padding: 40px 20px 50px;
}
.footer_sns{
	width: 280px;
}
.footer_sns_item{
	width: 44px;
}
.footer_copy{
	font-size: 10px;
}	
}

/* ----------------------------modal ---------------------------- */

.remodal_ttl{
	font-size: 20px;
	color: #0069d5;
}
.remodal_table{
	margin-top: 30px;
	width: 100%;
	border-collapse: collapse;
}
.remodal_table_head{
	background: #0069d5;
}
.remodal_table_body tr:nth-child(even){
	background: #f0f0f0;
}
.remodal_table_head th{
	padding: 10px 20px;
	font-weight: normal;
	line-height: 1.5;
	color: #fff;
	text-align: center;
	width: 33.3%;
	box-sizing: border-box;
}
.remodal_table_body td{
	padding: 20px;
	line-height: 1.5;
	text-align: center;
}
@media only screen and (max-width: 959px) {
.remodal_ttl{
	font-size: 16px;
}
.remodal_table{
	margin-top: 20px;
}
.remodal_table_head th{
	padding: 5px 8px;
}
.remodal_table_head th:first-child{
width: 28%;
}
.remodal_table_head th:nth-child(2){
width: 29%;
}
.remodal_table_body td{
	padding: 15px 8px;
	letter-spacing: 0.5px;
}
}

/* ----------------------------not_held ---------------------------- */

.not_held{
	padding-top: 110px;
	-webkit-box-flex: 1;
    -webkit-flex: 1 0 auto;
    flex: 1 0 auto;
}

.not_held p{
	font-weight: bold;
	text-align: center;
	font-size: 18px;
}
@media only screen and (max-width: 959px) {
.not_held{
	padding-top: 55px;
}

.not_held p{
	font-size: 16px;
}	
}


