/*共通*/
.mod-button.opt-arrow.theme-reverse::before{
  z-index: 20;
}
a:hover{
  text-decoration: none;
}
.header.is-fixed{
  background-color: unset;
}
.content_box{
  padding: 0 5%;
}
.allstar_h2{
  font-size: 24px;
  font-weight: bold;
  color: #fff;
  width: fit-content;
  letter-spacing: 0px;
  padding: 0 15px;
}
.h2_img{
  width: 49px;
}
.h2_box{
  display: flex;
  justify-content: center;
}
.sub_title{
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  margin-top: 4px;
}
span.-red {
  color: #DC0000;
}


/*header*/
.menu{
  background-color: #2A2E35;
}
html.show-menu .menu-outer a{
  color: #F9A80D;
}
html.show-menu .header_button_menu>a::after, html.show-menu .header_button_menu>a::before{
  color: #fff;
}

/*バナー*/
.banner_box{
  position: fixed;
  width: 88px;
  right: 10px;
  bottom: 20px;
  z-index: 20;
}
.banner_box img{
  width: 100%;
}


/*fv*/
h1{
  text-align: center;
  margin-top: 26px;
}
.fv_section{
  background-image: url(/music/summerjazzcamp/allstarlive/images/img_bg_fv.jpg);
  background-repeat: no-repeat;
  background-size: 100%;
  padding-bottom: 90px;
  position: relative;
}
.content_box.fv_box{
  padding-top: 115px;
}
.fv_text{
  font-size: 16px;
  color: #fff;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0px;
}
.fv_text.top_border{
  border-top: 1px solid #fff;
  width: fit-content;
  margin: 12px auto 0;
  padding-top: 9px;
}
.fv_date_box{
  text-align: center;
  margin-top: 40px;
}
.fv_ticket_text{
  font-size: 14px;
  color: #fff;
  text-align: center;
  margin-top: 42px;
}
.fv_section .fv_ticket_link{
  background-color: #DC0000;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  padding: 12px 0;
  display: block;
  width: 100%;
  text-align: center;
  margin: 8px auto 0;
  position: relative;
}
.fv_section .fv_ticket_link.-finished{
  pointer-events: none;
  background-color: #D8D8D8;
  color: #000;
  font-size: 14px;
  margin: 35px auto 0;
}
.fv_ticket_link .mod-icon-blank.-arrow{
  background-image: url(/music/summerjazzcamp/allstarlive/images/icn_arrow_wh.svg);
  position: absolute;
  top: 18px;
  right: 15px;
}
.fv_credit_box{
  position: absolute;
  width: 30%;
  bottom: 8px;
}
.fv_credit{
  padding: 0 5%;
}
.fv_credit p{
  font-size: 12px;
  color: #fff;
}

/*introduction*/
.introduction_section{
  background-image: url(/music/summerjazzcamp/allstarlive/images/img_bg_orange.jpg);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding-bottom: 195px;
}
.introduction_box{
  padding: 60px 5% 0;
}
.introduction_section .whats_title{
  font-size: 24px;
}

/*cast*/
.cast_section{
  background-color: #2A2E35;
  padding-bottom: 60px;
  padding-top: 60px;
}
.cast_list_box{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.cast_list{
  width: 47%;
  margin-top: 32px;
}
.cast_list a{
  background-color: #fff;
  font-size: 14px;
  font-weight: 400;
}
.cast_figure img{
  max-width: 100%;
}
.cast_instrument{
  font-size: 14px;
  color: #fff;
  text-align: center;
}
.cast_name_en{
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  letter-spacing: 0px;
  margin-top: 4px;
}
.cast_name_jp{
  font-size: 12px;
  color: #fff;
  text-align: center;
  margin-top: 0;
}
.cast_list .mod-button.opt-narrow{
  width: 170px;
}
.cast_caution{
  font-size: 16px;
  color: #fff;
  margin-top: 32px;
  text-align: center;
}
.fusanka_text{
  font-size: 14px;
  text-align: center;
  color: #fff;
}
.overlay{
  position: fixed;
  z-index: -100;
}
.overlay.-active{
  width: 100%;
  height: 100%;
  z-index: 40;
  background-color: rgba(0, 0, 0, 0.8);
  top: 0;
}
.cast_modal{
  opacity: 0;
  position: fixed;
  z-index: -100;
  justify-content: center;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  transform: scale(0, 0);
}
.cast_modal.-active{
  opacity: 1;
  z-index: 50;
  transition: all 0.3s;
  transform: scale(1, 1);
  width: 90%;
  height: 84svh;
  margin: 70px auto 0;
}
.cast_modal_inner{
  width: 100%;
  height: 486px;
  position: relative;
}
.cast_modal_wrap{
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
}
.cast_modal_content{
  background-color: #2A2E35;
  padding: 32px 16px 100px;
  position: relative;
}
.close{
  position: absolute;
  top: 16px;
  right: 16px;
  display: none;
}
.close.-active{
  display: block;
}
.modal_instrument{
  color: #fff;
  font-size: 16px;
  font-weight: bold;
}
.modal_name_en{
  font-size: 22px;
  font-weight: bold;
  color: #F9A80D;
  margin-top: 8px;
}
.modal_name_jp{
  color: #fff;
  font-size: 16px;
  margin-top: 0px;
}
.cast_modal .cast_modal_figure{
  display: none;
}
.cast_modal.-active .cast_modal_figure{
  display: block;
} 
.cast_modal_figure img{
  width: 100%;
}
.cast_modal_title{
  color: #fff;
  font-size: 18px;
  font-weight: bold;
}
.modal_col .cast_modal_title{
  margin-top: 16px;
}
.cast_modal_description{
  color: #fff;
  font-size: 16px;
  letter-spacing: -0.32px;
}

/*ticket*/
.ticket_section{
  background-color: #2A2E35;
  padding-bottom: 110px;
}
.place_ancor{
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-top: 24px;
}
.ancor_item{
  margin-right: 10px;
  padding: 0 10px 0 0;
  border-right: 1px solid #fff;
}
.ancor_item .place_ancor_link{
  position: relative;
  display: block;
  padding-left: 19px;
  padding-top: 4px;
  background: url(/music/summerjazzcamp/allstarlive/images/icn_arrow.svg) no-repeat left center;
  background-size: 9px 6px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
}
.note{
  font-size: 14px;
  color: #fff;
}
.ticket_item_box{
  position: relative;
}
.ticket_item{
  background-color: #fff;
  padding: 24px 20px 20px 20px;
  margin-top: 24px;
  position: relative;
}
.detail_list{
  display: flex;
  margin-top: 16px;
}
.detail_list.-mt24{
  margin-top: 24px;
}
.category{
  min-width: 102px;
  margin-right: 12px;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: -0.3px;
}
.detail{
  margin-top: unset;
  font-size: 14px;
  font-weight: bold;
}
.ticket_section .googlemap_link{
  text-decoration: underline;
  text-decoration-color: #2A2E35;
}
.concert_title_box{
  display: flex;
  align-items: center;
}
.concert_place{
  min-width: fit-content;
  height: fit-content;
  padding: 9px 8px;
  font-size: 18px;
  font-weight: bold;
  color: #FFE6B7;
  background-color: #2A2E35;
}
.concert_name{
  margin-top: unset;
  margin-left: 14px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: -0.3px;
}
.ticket_link{
  display: block;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: #DC0000;
  padding: 15px 34px;
  text-align: center;
  letter-spacing: -0.36px;
  margin: 24px auto 0;
  position: relative;
  transition: 0.5s;
  max-width: 312px;
}
.ticket_link:link, .ticket_link:visited{
  color: #fff;
}
.ticket_link .mod-icon-blank{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 8px;
  background-image: url(/music/summerjazzcamp/allstarlive/images/icn_open_new_wh.svg);
}
.ticket_link.-soldout{
  background-color: #D8D8D8;
  color: #DC0000;
  pointer-events: none;
}
.ticket_link.-soldout span{
  text-decoration: line-through;
}
.ticket_link.-finished{
  background-color: #D8D8D8;
  color: #000;
  pointer-events: none;
}
.ticket_link.-soldout .mod-icon-blank, .ticket_link.-tel .mod-icon-blank{
  background-image: unset;
}
.ticket_link.-tel{
  color: #fff;
}
.ticket_section .blank_text_link{
  font-weight: bold;
  text-decoration: underline;
  text-decoration-color: #2A2E35;
}
.ticket_grayout{
  background-color: rgba(0, 0, 0, 0.6);
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 20;
}

/*loop*/
.loop_box{
  position: relative;
}
.loop{
  position: absolute;
  top: -50px;
  background-image: url(/music/summerjazzcamp/allstarlive/images/img_live.png);
  animation: slide1 100s linear infinite;
  height: 105px;
  width: 100%;
  background-size: auto 105px;
}
@keyframes slide1 {
  from {
      background-position: 0 0;
  }
  to {
      background-position: -737px 0;
  }
}
.loop_credit{
  position: absolute;
  top: 60px;
  padding: 0 5%;
}
.loop_creadit p{
  font-size: 12px;
}

/*report*/
.report_section{
  padding-top: 120px;
}
.allstar_column{
  margin-top: 40px;
}
.report_fig{
  width: 100%;
  margin-top: 16px;
}
.report_fig img{
  width: 100%;
}
.report_title{
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0px;
  text-align: center;
}
.report_section .report_title{
  margin-top: 16px;
}
.report_date{
  font-size: 16px;
  text-align: center;
}
.border_orange{
  border-top: 2px solid #F9A80D;
  width: 54px;
  margin: 0 auto;
}

/*movie*/
.movie_section{
  padding-top: 0;
}
.introducing_video iframe{
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
}

/*snsエリア*/
.sns_section{
  padding: 0 5%;
  margin-top: 60px;
}
.content_box.share-sns{
  background-color: #EEEEEE;
  padding: 16px 0;
}
.share_title{
  font-size: 16px;
  font-weight: bold;
  text-align: center;
}
.sns_list{
  display: flex;
  justify-content: space-between;
  max-width: 185px;
  margin: 12px auto 0px;
}

/*page top*/
.pagetop_button_box{
  margin-top: 40px;
  margin-bottom: 40px;
  text-align: center;
}

/*footer*/
footer{
  background-color: #2A2E35;
  padding: 40px 5% 32px;
}
.footer_text{
  font-size: 16px;
  color: #fff;
  text-align: center;
}
.footer_text:nth-child(n+2){
  margin-top: 40px;
}
.footer_link{
  display: flex;
  margin: 40px auto 0;
  flex-wrap: wrap;
  justify-content: center;
}
.footer_link_item{
  margin-right: 10px;
  padding: 0 10px 0 0;
  border-right: 1px solid #fff;
}
.footer_link_item .footer_link_text{
  color: #fff;
  font-size: 16px;
}
.footer_link_text:hover{
  text-decoration: none;
}
.footer_media_list{
  display: flex;
  justify-content: space-between;
  margin: 16px auto 40px;
  width: 176px;
}
.footer_logo_box{
  width: 247px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto 40px;
}
.footer_jc_logo{
  width: 85px;
}
.footer_seiko_logo{
  width: 122px;
}
.copy_right{
  font-size: 12px;
  color: #fff;
  letter-spacing: 0px;
  text-align: center;
}

/*sp only*/
@media screen and (max-width: 767px){
  html.show-menu .header_button_menu>a::after, html.show-menu .header_button_menu>a::before, html.show-menu .header_button_menu>a>span::after, html.show-menu .header_button_menu>a>span::before{
    border-top-color: #fff;
    border-width: medium;
  }
  .pc-only{
    display: none;
  }
  .menu_list{
    width: auto;
  }
  .fv_section{
    background-color: #000;
    padding-top: 0;
  }
  .fv_box{
    padding: 0 4%;
  }
  .fv_title{
    width: 100%;
    max-width: 400px;
    margin: 24px auto 0;
  }
  .fv_title img{
    width: 100%;
  }
  .cast_name_en{
    height: 58px;
  }
  .cast_section .mod-button.opt-narrow:nth-child(n+2){
    margin-top: 6px;
  }
  .ticket_section .sp-tel{
    text-decoration: underline;
    text-decoration-color: #2A2E35;
  }
  .detail{
    max-width: 62%;
  }
  .ancor_item{
    margin-bottom: 20px;
  }
  .cast_modal_figure{
    margin-top: 8px;
  }
  .report_section .report_date{
    margin-top: 32px;
  }
  .report_section .mod-button.opt-narrow:nth-child(n + 2) {
    margin-top: 16px;
  }
  .movie_section .introducing_section_body:nth-child(n+2){
    margin-top: 20px;
  }
  .movie_section .report_title{
    margin-top: 20px;
  }
}

/*pc only*/
@media screen and (min-width: 768px){
  /*共通 pc*/
  .allstar_h2{
    font-size: 32px;
  }
  .sub_title{
    font-size: 18px;
  }

  /*メニューバー*/
  .menubar{
    position: fixed;
    top: 20px;
    width: 100%;
    z-index: 40;
    transition: 0.5s;
  }
  .menubar.disable{
    top: -100px;
  }
  .menubar_list{
    display: flex;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    background-color: #2A2E35;
    padding: 15px 0;
    border-radius: 5px;
    box-shadow: 0px 4px 6px;
    justify-content: space-between;
  }
  .menubar_list_item{
    width: auto;
    max-width: 200px;
    text-align: center;
    border-right: 1px solid #fff;
    flex-grow: 1;
  }
  .menubar_list_item:nth-of-type(6){
    border-right: unset;
  }
  .menubar_list_item p{
    display: inline-block;
  }
  .menubar_list_item a{
    color: #F9A80D;
    font-size: 20px;
    font-weight: 700;
  }
  .content_box{
    max-width: 1200px;
    padding-left: unset;
    padding-right: unset;
    margin: 0 auto;
  }

  /*fv pc*/
  .fv_section{
    background-color: #000;
    background-image: unset;
    overflow: hidden;
    padding-top: 140px;
    max-height: 630px;
    padding-bottom: 5%;
  }
  .content_box.fv_box{
    background-image: url(/music/summerjazzcamp/allstarlive/images/img_bg_fv_pc.jpg);
    background-repeat: no-repeat;
    background-size: 100%;
    padding: 0;
    padding-bottom: 40px;
  }
  .fv_pc_box{
    max-width: 100vw;
  }
  .fv_section .fv_ticket_link:hover{
    background-color: #A71A1A;
  }
  h1 img{
    max-width: 420px;
    width: 35vw;
  }
  .fv_date_box img{
    width: 286px;
  }
  .fv_text{
    font-size: 24px;
  }
  .fv_text.top_border{
    margin-top: 24px;
    padding-top: 16px;
  }
  .fv_ticket_text{
    font-size: 18px;
  }
  .fv_ticket_link{
    max-width: 490px;
  }
  .fv_section .fv_ticket_link.-finished{
    font-size: 18px;
  }
  .fv_credit_box{
    position: relative;
    padding: 0 5%;
    margin-top: 65px;
  }
  .fv_credit{
    padding: unset;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
  }

  /*introduction pc*/
  .introduction_section{
    background-image: url(/music/summerjazzcamp/allstarlive/images/img_bg_orange_pc.jpg);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding-bottom: 220px;
    padding-top: 100px;
  }
  .introduction_box{
    padding-top: 0;
  }
  .introduction_section p{
    font-size: 16px;
  }
  .introduction_section .whats_title{
    font-size: 32px;
  }

  /*cast pc*/
  .cast_section{
    padding-bottom: 100px;
    padding-top: 100px;
  }
  .cast_list{
    max-width: 22.5%;
    margin-top: 34px;
  }
  .cast_instrument{
    font-size: 16px;
  }
  .cast_name_en{
    font-size: 18px;
  }
  .cast_name_jp{
    font-size: 16px;
  }
  .cast_list a{
    font-size: 16px;
  }
  .cast_list a:hover{
    background-color: unset;
  }
  .cast_list .mod-button.opt-narrow{
    margin-top: 4px;
  }
  .cast_modal.-active{
    max-width: 840px;
    max-height: 486px;
    margin: 0 auto;
    top: 25%;
  }
  .cast_modal_wrap{
    max-height: 486px;
  }
  .cast_modal_inner{
    max-width: 840px;
  }
  .cast_modal_content{
    padding: 40px 40px 30px;
  }
  .modal_flex_box{
    display: flex;
    padding-top: 24px;
    border-top: 1px solid #fff;
  }
  .modal_col{
    max-width: 52%;
    margin-left: 32px;
  }
  .modal_col .cast_modal_title{
    margin-top: 0;
  }

  /*ticket pc*/
  .ticket_section{
    padding-bottom: 210px;
  }
  .place_ancor{
    margin: 40px auto 0;
    width: fit-content;
  }
  .ticket_item{
    width: 44%;
  }
  .ticket_item_box{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .ticket_link:hover{
    color: #fff;
    background-color: #A71A1A;
  }
  .ticket_link.-tel{
    color: #fff;
  }
  .concert_name{
    font-size: 18px;
  }
  .detail{
    font-size: 16px;
  }
  .sp-tel{
    pointer-events: none;
  }
  .ancor_item .place_ancor_link{
    margin-top: 0;
  }

  /*loop pc*/
  .loop{
    height: 214px;
    background-size: auto 214px;
    top: -100px;
  }
  .loop_credit{
    position: unset;
    padding: 130px 0 0;
    max-width: 1200px;
    margin: 0 auto;
  }

  /*report*/
  .report_section{
    padding-top: 100px;
  }
  .allstar_column{
    display: flex;
    justify-content: space-between;
  }
  .report_fig{
    width: 48%;
  }
  .allstar_col{
    width: 48%;
  }
  .report_col_box{
    padding: 60px 0;
    padding-right: 20px;
  }
  .report_section .report_title{
    margin-top: 24px;
  }

  /*movie*/
  .movie_col_box{
    padding: 60px 0;
    padding-left: 20px;
    max-width: 48%;
  }
  .introducing_section_body{
    max-width: 50%;
    width: 48%;
  }
  .introducing_video{
    width: 100%;
    height: 100%;
  }

  /*sns pc*/
  .sns_section{
    margin-top: 100px;
  }
  .content_box.share-sns{
    max-width: 580px;
    padding: 24px 0;
  }

  /*pagetop link pc*/
  .pagetop_button_box{
    margin: 60px 0;
  }

  /*footer pc*/
  .footer_link{
    width: fit-content;
    margin-top: 40px;
  }

  /*banner pc*/
  .banner_box{
    width: 130px;
    right: 6.25%;
    bottom: 40px;
  }
}

/*1200px以下用メディアクエリ*/
@media screen and (max-width: 1200px) and (min-width: 768px){
  .content_box{
    padding: 0 5%;
  }
}

/*1000px以下用メディアクエリ*/
@media screen and (max-width: 1000px) and (min-width: 768px){
  .cast_name_jp{
    height: 60px;
  }
}

/*820px以下用メディアクエリ*/
@media screen and (max-width: 820px) and (min-width: 768px){
  .cast_name_en{
    height: 65px;
  }
}