body{
	margin: 0px !important;
	padding: 0px !important;
}
#switch a{
	display:block;
}
#navi{
	width:100%;
}
#footer{
	width:100%;
}
.pc{
	display:none
}
.menu img{
	width:100%;
	height:100%
}
#navi nav {
    position: fixed;
    top: 0;
    right: -300px;
    width: 300px;
    height: 100%;
    padding-top: 50px;
    background:#1b667b;
    font-size: 16px;
    box-sizing: border-box;
    z-index: 2
}
#navi nav ul li {
    display:block;
    padding: 10px 28px;
}

#navi nav ul li a {
    text-decoration: none;
    color: #000000
}

#navi .btn-gnavi {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 30px;
    height: 24px;
    z-index: 3;
    box-sizing: border-box;
    cursor: pointer;
    -webkit-transition: all 400ms;
    transition: all 400ms
}

#navi .btn-gnavi span {
    position: absolute;
    width: 30px;
    height: 4px;
    background: #000000;
    border-radius: 10px;
    -webkit-transition: all 400ms;
    transition: all 400ms
}

#navi .btn-gnavi span:nth-child(1) {
    top: 0
}
#navi .btn-gnavi span:nth-child(2) {
    top: 10px
	}
	
#navi .btn-gnavi span:nth-child(3) {
    top: 20px
}



#navi .btn-gnavi.open span {
	   background: #ffffff ;
}

#navi .btn-gnavi.open span {
    width: 30px;
}

#navi .contents section p {
    position: absolute;
    top: 50%;
    width: 30%;
    line-height: 1.4;
    font-size: 20px;
    color: #fff;
}

#navi .contents section:nth-child(odd) p {
    left: 10%
}

#navi .contents section:nth-child(even) p {
    right: 10%
}

#switch{
	display: block;
	width:100%;
}
#main{	width:100%;

	background-color:#ffffff;
}
.contents{
	width:90%;
	margin-left:auto;
	margin-right:auto;
}
.main_image{
	width:100%;
}
.main_image img{
	width:100%;
}
.main_photo img{
	width:100%;
}
.plan{
	font-size:30px;
}
.ticket{
width:90%;
margin-left:auto;
margin-right:auto;

background-color:#000000;
}
.ticket_text {
    padding-right: 15px;
	}
.profile_hosaka{
	background-color:#CCCCCC;
	padding:20px;
	display:block;
	border-radius: 10px;
}
.hosaka_photo img{
	width:50%;
	border-radius: 10px;
}
.hosaka_photo{
	width: 100%;
}
.hosaka_text{
	width: 100%;
}

.subgrid-container {
    gap: 2px;
    grid-column: span 3;
    display: grid;
grid-template-columns: repeat(3, auto);
}
.subgrid-container1 {
	column-gap: 2px;
    row-gap: 0px;
	grid-column: span 3;
	display: grid;
grid-template-columns: repeat(3, auto);
}
.notice_text{
	padding: 10px;
    background-color: #f0f0f0;
    margin-left: auto;
    margin-right: auto;
    width: 90%;
	font-family: "Zen Maru Gothic", serif;
	font-size: 14px;
	line-height: 150%;
}
.new_notice_text2{
	padding: 10px;
    background-color: #f0f0f0;
    width: 90%;
	font-family: "Zen Maru Gothic", serif;
	font-size: 14px;
	line-height: 140%;
}
.story_txt{
	margin-top:50px;
	font-size:17px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	line-height:240%;
	letter-spacing:0.1em;
	text-align:center;
}

.matsunaga,.satou,.arimori{
	width:90%;
	float:left;
	margin:10px;
	text-align:center;
	font-family: "Zen Maru Gothic", serif;
	font-weight: 400;
	font-size:20px;
}
.matsunaga img,.satou img,.arimori img{
	width:100%;
	border-radius: 20px;

}

.sp_none{
	display:none;
}
.menu_txt_ja {
	color:#ffffff;

}
.menu_txt_en {
	color:#ffffff;
}
.subgrid-container_schedule_tokyo{
	width:95%;
	}
.subgrid-container_schedule_osaka{
	width:95%;
	margin-left:0px;
	margin-top:10px;
	}
.logo_banner{
 display:flex;
  flex-direction: column;
  align-items: center;
  }
.cast_photo img{
	width:50%;
	}
.sns_x_con{
 display:flex;
  flex-direction: column;
  align-items: center;
  }
.sns_insta_con{
 display:flex;
  flex-direction: column;
  align-items: center;
  }
.br-sp {
        display: block;
		}