@font-face {
  font-family: 'tsukushi';
    src: url("../../fonts/FOT-TsukuARdGothicStd-R.otf");
}

@font-face {
  font-family: 'tsukushib';
    src: url("../../fonts/FOT-TsukuARdGothicStd-B.otf");
}

@font-face {
  font-family: 'tsukushie';
    src: url("../../fonts/FOT-TsukuARdGothicStd-E.otf");
}

@font-face {
  font-family: 'cooper';
    src: url("../../fonts/CooperBlackStd.otf");
}

@font-face {
  font-family: 'raglan';
    src: url("../../fonts/FOT-RaglanPunchStd-UB.otf");
}

body {
    font-family: 'tsukushib';
    font-size: 16pt;
    line-height: 160%;
    margin: 0;
    background-image: url(../../images/bg_ribon_03.jpg);
    color:#7E6952;
}

main {
    position: relative;
}

main::before {
    content: "";
   background: url("../images/tape.png") repeat-y top;
    background-size: 100%;
    width: 200px;
    height: -webkit-fill-available;
    position: absolute;
    top: 400px;
    left: -15px;

}
main::after {
    content: "";
  background: url("../images/tape02.png") repeat-y top;
    background-size: 100%;
    width: 200px;
    height: -webkit-fill-available;
    position: absolute;
    top:400px;
    right: -15px;
}

#xcover {
	width: 100%;
	margin: -500px auto 0;
   background-image: url("../images/bg02.png");
    background-size: 100%;

}

.onpu{	
    width: 1200px;
	margin: 0 auto;
	overflow-x: hidden;
    /*background-image: url("../images/bg_onpu.png");*/
    padding: 450px 0 0;

    
}


.story{
    margin: 0px 0 0;
    text-align: center;
    line-height: 2.0;
    
}

.story1{
    margin: 0px 0 0;
    text-align: center;
    line-height: 2.0;
    color: #F578FF;   
    font-weight: bold;
}


.story02{
    font-size: 18pt;
    margin: 0px 0 0;
    text-align: center;
    line-height: 2.0;
    
}

.shiteiseki{
    font-size: 20pt;
    font-weight: bold;
    color: #B40019;
    text-align: center;
    margin-top: 10px;
    margin-bottom: 20px;
        font-family: 'tsukushib' ;
}


.contents_midashi{
    font-size: 32pt;
    font-weight: bold;
    color: #FFF;
    text-align: center;
    margin-top: 10px;
    margin-bottom: 20px;
        text-shadow: 2px 2px 1px #AC71AC;
line-height: 1.3;
        font-family: 'raglan' ;
}

.contents_midashi02{
    font-size: 32pt;
    font-weight: bold;
    color: #B40019;
    text-align: center;
    margin-top: 10px;
    margin-bottom: 20px;
    line-height: 1.4;
        font-family: 'raglan' ;
}


.contents_txt{
    margin: 10px 0 45px;
    text-align: center;
}

.contents_txt_l{
    margin: 20px 0 35px 200px;
    text-align: left;
}

.contents{
    padding: 60px 0;
  }

.contents img {
    width: 80%;
    border-radius: 20px;

}

.hr{
    width: 85%;
    margin: 20px auto;

}

.contents_box{
    border-radius: 10px;
  margin: 0 auto;
    background: #FFF;
    padding: 15px 10px;
    width: 80%;

}

.contents_box p{
    color:#7E6952;
    text-align: left;
            font-family: 'tsukushib' ;
    padding-left: 20px

}

.title_img{
                font-family: 'cooper' ;
    margin: 70px auto 20px;
    color: #FFF;
    text-shadow: #fc0 5px 5px 5px;
    font-size: 72px;
}

.kugiri{
    width: 90%;
    margin: 0px auto;
    padding: 30px 0 50px;
}



.title_sp{
    margin: 70px 0 20px;
    display: none;
}

.clear{
    clear: both;
}

footer{
    padding: 30px ;
    text-align: center;
    background-color: #8e7c65;
    color: #FFF;
}

.top30{
    margin-top: 30px;
}

.top50{
    margin-top: 50px;
}

.top80{
    margin-top: 80px;
}

.btn_heart{width: 15%;
margin: 10px auto;
}



#popup {
  display: none; /* label でコントロールするので input は非表示に */
}

.popup-open {
  cursor: pointer; /* マウスオーバーでカーソルの形状を変えることで、クリックできる要素だとわかりやすいように */
}

.popup-overlay {
  display: none; /* input にチェックが入るまでは非表示に */
}

#popup:checked ~ .popup-overlay {
  display: block;
  z-index: 99999;
  background: rgba(0,0,0,0.5);
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
}

.popup-window {
    width: 720px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 6px;
  position: fixed;
  top: 50%;
    left: 50%;
  transform: translate(-50%, -50%);
}

.popup-window img{
    width: 100%
}


.popup-text {
  margin: 0;
}

.popup-text:not(:last-of-type) {
  margin-bottom: 1em
}

.popup-close {
  cursor: pointer;
  position: absolute;
  top: -26px;
  right: 0;
}

.link_btn{
    display: flex;
    list-style: none;
    justify-content: center;
    width: 75%;
    margin: 60px auto;
   
}

.link_btn li{
     padding: 8px 25px;
}

.sp_only{
    display: none;
}


.contents_box p.youkou_midashi{
    font-weight: bold;
    margin-top: 40px;
    }


.contents_box p.youkou_txt{
    padding-left: 80px;
    padding-right: 30px;
    text-indent: -1em;
        margin-top: -5px;

    }

.contents_box p.youkou_tyui{
    padding-left: 100px;
    text-indent: -1em;
    font-size: 14pt;
        margin-top: -5px;

    }


.swiper-container
{
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: inherit;
}
.swiper-slide img {
    width: 100%;
    border-radius: 14px;
    /* border: 4px solid #fff; */
}

.swiper-slide p {
   font-size: 18pt;
}

.swiper-slide p span{
   font-size: 20pt;
}


.swiper-button-next, .swiper-button-prev {
    width: 40px;
    height: 40px;
    margin-top: -25px;
    -moz-background-size: cover;
    -webkit-background-size: cover;
    background-size: cover;
    background-color: #FF759F;
    background-image: none;
    border-radius: 50%;
}
.swiper-button-prev {
    left: -15px;
    right: auto;
    transform: rotateZ(180deg);
}

.swiper-button-next {
    right: -15px;
    left: auto;
}

.swiper-button-prev::before , .swiper-button-next::before {
    content: '\f04b';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 16px;
    position: absolute;
    top: 50%;
    right: 50%;
    transform: translate(60% , -50%);
    color: #fff;
}



.swiper-box {
	width: 60%;
	margin: 0 auto 20px;
	/* box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.3); */
	border-radius: 14px;
}


.button{
    width: 40%;
    margin: 20px auto;
}


.idol_contents{
    padding: 100px 0 50px;
}

/*---------------------------------------------------
                                  Accordion
---------------------------------------------------*/
/*ボックス全体*/
.accbox {
    margin: 0 0;
    padding: 0;
    /*max-width: 400px;最大幅*/
}
/*ラベル*/
.accbox label {
    display: block;
	margin: 10px auto 0;
    padding: 13px 12px;
    width: 80%;
	background: #7E6952;
    font-weight: bold;
    text-align: center;
    border-radius: 30px;
    position: relative;
    cursor: pointer;
	z-index: 100 ;color: #fff;
}
#faq .accbox label {
	text-align: inherit;
	padding: 13px 80px 13px 40px;
}
#faq .accshow p {
	color: #fff;
	padding: 0 40px;
	font-size: 18px;
	margin: 0;
}
.accbox label::after {
    content: "" ;
    position: absolute ;
    top: 0 ;
    right: 0 ;
    bottom: 0 ;
    left: 0 ;
	border-radius: 30px;
    margin: 2px ;
    display: block ;
    z-index: -5 ;
	border: none;
	background: #7E6952;
}
.accbox label img {
    width: 170px;
}
/*アイコン*/
.accbox label:before {
    content: ' ';
    display: block;
    width: 25px;
    height: 25px;
    background-image: url('../images/open.png');
    background-size: cover;
    position: absolute;
    top:25%;
    right: 25px;
}
/*ラベルホバー時*/
.accbox label:hover {
    /*background :#ffe9a9;*/
}
/*チェック隠す*/
.accbox input {
    display: none;
}
/*初期非表示*/
.accbox .accshow {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    /*transition: 0.8s;*/
}

/*クリックで表示*/
.cssacc:checked + label + .accshow {
    height: auto;
    padding: 20px 0;
    border: none;
	background: #7E6952;
	margin-top: -8px;
	border-top: none;
	border-bottom-left-radius: 30px;
	border-bottom-right-radius: 30px;
    opacity: 1;
}


.accbox .accshow02 {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    position: relative;
}
.accshow02::before {
    content: "";
    width: 90%;
    height: 1px;
    position: absolute;
    top: 2%;
    right: 50%;
    -webkit-transform: translate(50%, 0);
        -ms-transform: translate(50%, 0);
            transform: translate(50%, 0);
    display: block;

}

.cssacc:checked + label + .accshow02 {
    height: auto;
    padding: 20px 0;
    border: none;
	background: #fff;
	/* margin-bottom:0; */
	border-top: none;
	border-bottom-left-radius: 30px;
	border-bottom-right-radius: 30px;
    opacity: 1;
}



/*アイコン切り替え*/
.cssacc:checked + label:before {
	background-image: url('../images/close.png')
}
/*ボーダー変形*/
.cssacc:checked + label {
	border-bottom-left-radius: 30px;
	border-bottom-right-radius: 30px;
	border-top-left-radius: 30px;
	border-top-right-radius: 30px;
}
/*非表示内スタイル*/
.accshow dl {
    flex-wrap: wrap;
    display: flex;
	align-items: center;
	position: relative;
}
.accshow dt {
	color: #fff;
    width: 20%;
	padding: 10px;
}
.accshow dd {
    width: 80%;
	padding: 10px;
	background: #FFF;
}
.accshow dl:last-child dd {
    border-bottom-right-radius: 25px;
}
.accshow dl:before {
    content: ' ';
    display: inline-block;
    width: 100%;
    height: 2px;
	position: absolute;
	bottom: 0;
	left: 1%;
    background: #fff;
}
.accshow dl:after {
    content: ' ';
    display: inline-block;
    width: 79%;
    height: 2px;
    position: absolute;
    bottom: 0;
    right: 1%;
    background: #ff498a;
}
.accshow dl:last-child:before ,.accshow dl:last-child:after {
	display: none;
}



ul.kaien {
  width: 96%;
  margin: 10px auto;
  padding: 0;
  display: table;
}
 li.tbl1 {
  list-style: none;
  width: 32%;
  height: 65px;
  float: left;
  border-top-width: 2px;
  border-right-width: 2px;
  border-bottom-width: 0px;
  border-left-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: none;
  border-left-style: solid;
  border-top-color: #7E6952d;
  border-right-color: #7E6952;
  border-left-color: #7E6952;
  position: relative;
  display: table-cell;
}
 li.tbl2 {
  list-style: none;
  width: 68%;
  height: 65px;
  float: left;
  border-top-width: 2px;
  border-right-width: 2px;
  border-bottom-width: 0px;
  border-left-width: 0px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: none;
  border-left-style: none;
  border-top-color: #7E6952;
  border-right-color: #7E6952;
  position: relative;
  display: table-cell;
}
 li.tbl3 {
  list-style: none;
  width: 32%;
  height: 65px;
  float: left;
  border-width: 2px;
  border-top-style: dotted;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: solid;
  border-color: #7E6952;
  position: relative;
  display: table-cell;
}
li.tbl4 {
  width: 68%;
  list-style: none;
  height: 65px;
  float: left;
  border-width: 2px;
  border-top-style: dotted;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: none;
  border-color: #7E6952;
  position: relative;
  display: table-cell;
}

 li.tbl5 {
  list-style: none;
  width: 32%;
  height: 65px;
  float: left;
  border-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: solid;
  border-color: #7E6952;
  position: relative;
  display: table-cell;
}
li.tbl6 {
  width: 68%;
  list-style: none;
  height: 65px;
  float: left;
  border-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: none;
  border-color: #7E6952;
  position: relative;
  display: table-cell;
}

li.tbl7 {
  width: 100%;
  list-style: none;
  height: 65px;
  float: left;
  border-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: none;
  border-left-style: solid;
  border-color: #7E6952;
  position: relative;
  display: table-cell;
}

 .odemukae {
  padding-left: 1.0em;
  margin: auto 0px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8px;
  font-size: 18px;
  line-height: 1.4;
  color: #4a74ed;
}
 .odemukae02 {
  padding: 0 1.0em 0 2.0em;
  margin: auto 0px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8px;
  font-size: 18px;
  line-height: 1.2;
  text-indent: -1.0em;
}

.shiteiseki_box{
    width: 80%;
    padding: 5%;
    background-color:#FFF6DF;
    border: double 6px #930;
    margin: 0 auto;
}

.shiteiseki_txt{
    color: #7E6952;
}

.shiteiseki_tyui{
    color: #7E6952;
    padding-left: 1em;
}

.season-check01{
    width: 80%;
    margin: 55px auto 0px;
    background-size: 100% auto;
    padding: 45px 0;
    position: relative;
    background-color: #D6EBFF;
    border-radius: 20px;
     background-image: url("../images/check-lt02.png"),url("../images/check-rt02.png"),url("../images/check-rb02.png"),url("../images/check-lb02.png");

    background-repeat: no-repeat;
    background-position: left 10px top 10px, right 10px top 10px, right 10px bottom 10px, left 10px bottom 10px;
    background-size: 90px;
}

.season-check02{
    width: 80%;
    margin: 55px auto 0px;
    background-size: 100% auto;
    padding: 45px 0;
    position: relative;
    background-color: #FFE6F9;
    border-radius: 20px;
background-image: url("../images/check-lt.png"),url("../images/check-rt.png"),url("../images/check-rb.png"),url("../images/check-lb.png");       background-repeat: no-repeat;
    background-position: left 10px top 10px, right 10px top 10px, right 10px bottom 10px, left 10px bottom 10px;
    background-size: 90px;
}

.ms_txt{
    text-align: center;
    color:#000FC9;
}


.ms_midashi{
    text-align: center;
    color: #000FC9;
    margin: -10px 0 15px;
    
}

.gs_txt{
    text-align: center;
    color: #FF1493;
}


.gs_midashi{
    text-align: center;
    color: #FF1493;
    margin: -10px 0 15px;
    
}

/*
.chara_ms{
    width: 90%;
    margin: 10px auto;
        
}

.chara_ms ul li{
    float: left;
    width: 25%;
}




.chara_gs{
    width: 95%;
    margin: 10px auto;
        
}

.chara_gs ul li{
    float: left;
    width: 20%;
}

*/
ul.ms_live {
    display: flex;
    flex-wrap: nowrap;
    width: 60%;
    margin: 0 auto;
    padding: 0;
    list-style: none;
}

ul.ms_live li {
    flex: 1 1 auto;
}

ul.ms_live  li img {
    display: block;
    width: 100%;
}

ul.gs_live {
    display: flex;
    flex-wrap: nowrap;
    width: 58%;
    margin: 0 auto;
    padding: 5px 10px;
    list-style: none;
}

ul.gs_live li {
    flex: 1 1 auto;
}

ul.gs_live  li img {
    display: block;
    width: 100%;
}


ul.gs_live02 {
    display: flex;
    flex-wrap: nowrap;
    width: 90%;
    margin: 0 auto;
    padding: 5px 10px;
    list-style: none;
}

ul.gs_live02 li {
    flex: 1 1 auto;
}

ul.gs_live02  li img {
    display: block;
    width: 100%;
}

.modal-wrapper {
  z-index: 999;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 60px 10px;
  text-align: center
}

.modal-wrapper:not(:target) {
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s, visibility .3s;
}

.modal-wrapper:target {
  opacity: 1;
  visibility: visible;
  transition: opacity .4s, visibility .4s;
}

.modal-wrapper::after {
  display: inline-block;
  height: 100%;
  margin-left: -.05em;
  vertical-align: middle;
  content: ""
}

.modal-wrapper .modal-window {
  box-sizing: border-box;
  display: inline-block;
  z-index: 20;
  position: relative;
  width: 80%;
  max-width: 700px;
  padding: 30px 30px 15px;
  border-radius: 2px;
  background: #fff;
  box-shadow: 0 0 30px rgba(0, 0, 0, .6);
  vertical-align: middle
}

.modal-wrapper .modal-window .modal-content {
  max-height: 80vh;
  overflow-y: auto;
}

.modal-overlay {
  z-index: 10;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, .8)
}

.modal-wrapper .modal-close {
  z-index: 20;
  position: absolute;
  top: 0;
  right: 0;
  width: 35px;
  color: #95979c!important;
  font-size: 20px;
  font-weight: 700;
  line-height: 35px;
  text-align: center;
  text-decoration: none;
  text-indent: 0
}

.modal-wrapper .modal-close:hover {
  color: #2b2e38!important
}

.ticket_online{
    width: 100%;
    margin: 20px auto;
}

.ticket_online img{
    width: 100%;
}

.live_ticket{
    width: 100%;
    margin: 0 auto;
}

.live_ticket li{
    width: 50%;
    float: left;
    margin: 2% 0;
}

.live_ticket li img {
    width: 100%;
    }