/****************
** Common
****************/
body {
  color: #000;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  body {
    font-size: max(3.2vw, 14px);
    line-height: 1.8;
  }
}
img {
  pointer-events: none;
  -webkit-touch-callout: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -moz-touch-callout: none;
  touch-callout: none;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  user-drag: none;
}
a {
  color: #000;
  font-weight: 500;
}
.indent{
  display: block;
    padding-left: 1em;
    text-indent: -1em;
}
.mini{
  font-size: 13px;
}
@media screen and (max-width: 768px) {
  .mini{
    font-size: max(3.0vw, 12px);
  }  
}
.icon {
  height: 20px;
  padding-left: 24px;
  position: relative;
  background: url(../../img/herovillain/linkicon.png) left 3px no-repeat;
  background-size: 20px 20px;
}
@media screen and (max-width: 768px) {
.icon {
  height: 30px;
  padding-left: 5.3vw;
  position: relative;
  background-size: 30px 30px;
}
}

@media screen and (max-width: 768px) {
section{
  margin-bottom: 10vw;
}
}

@media screen and (max-width: 768px) {
    .spnone{
        display: none !important;
    }
}
@media screen and (min-width: 769px) {
    .pcnone{
        display: none !important;
    }
}

/****************
** bg / header / subWrap
****************/
@media screen and (min-width: 769px) {
#bg {
  background-image: url(../../img/herovillain/c_bg.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  height: 100vh;
  width: 100%;
  min-height: 620px;
  min-width: 1200px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
}
}
#c_header {
  width: 1200px;
  height: 1109px;
  background: url(../../img/herovillain/c_head.png) no-repeat;
  margin: 45px auto 0;
}
@media screen and (max-width: 768px) {
#c_header {
  background-image: url(../../img/herovillain/sp_header.jpg);
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 103vw;
  background-size: 100%;
  margin-top: 17vw;
}
}
.subWrap__cont {
  width: 100%;
  margin-left: 0;
}
@media screen and (min-width: 769px) {
#contWrap {
  width: 1200px;
  margin: 0 auto;
}
#c_cont {
  width: 1000px;
  padding: 0px 40px 72px 40px;
  background: url(../../img/old/common/c_window_back1000.png) repeat-y;
  position: relative;
  margin: 0 auto;
}
.subWrap__cont{
  padding-bottom: 0;
}
}
@media screen and (max-width: 768px) {
#contWrap {
  border-top: 0;
  border-right: 7px solid #000;
  border-left: 4px solid #000;
  padding-bottom: 100px;
}
#c_cont {
  padding: 3vw 4vw;
}
.subWrap__cont{
  padding-top: 0;
}
}

/****************
** top_bar
****************/
@media screen and (min-width: 769px) {
#top_bar {
  width: 100%;
  height: 19px;
  background: url(../../img/old/common/c_topbar.gif) repeat-x;
  position: relative;
}
#top_bar a {
  text-decoration: none;
  display: block;
  width: 344px;
  height: 30px;
  background: url(../../img/jf2020/c_jf_topbn_off.png) no-repeat;
  position: absolute;
  top: 15px;
  left: 50%;
  transform: translateX(-145%);
}
#top_bar a:hover {
  background: url(../../img/jf2020/c_jf_topbn_on.png) no-repeat;
}
}

/****************
** nav
****************/
#nav li img{
	width: 100%;
}
#nav a{
  display: block;
}

@media screen and (min-width: 769px) {
#nav{
  margin: 40px 0 0 0;
} 
#nav ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#nav li{
	width: 300px;
  margin-left: 5px;
  margin-bottom:10px;
}
#nav li:first-child,
#nav li:nth-child(4),
#nav li:nth-child(7){
  margin-left: 0;
}
#nav li:last-child,
#nav li:nth-last-child(-n+2) {
	margin-bottom:0;
}
#nav a:hover{
	opacity: 0.7 ;
	transition: 0.5s ;
}
}

@media screen and (max-width: 768px) {
  #nav{
    margin-bottom: 8vw;
  }
  #nav ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  #nav li{
    width: 49%;
    margin-bottom:1vw;
  }
}

/****************
** h2 / h3
****************/
h2 > img{
  width: 100%;    
}
@media screen and (min-width: 769px) {
  h2{
    padding: 50px 0 20px 0;
  }  
}
@media screen and (max-width: 768px) {
  h2{
    padding-bottom: 3vw;
  } 
}

h3{
  background: #000;
  color: #fff;
  font-weight: 700;
  display: inline-block;
  padding: 0 1vw;
}

/****************
** Text
****************/
.txt__c{
  text-align: center;
}
.txt__w{
  font-weight: 700;
}
.title__l{
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .title__l{
    font-size: max(3.2vw, 16px);
    line-height: 1.8;
  }
}

/****************
** Color
****************/
.red{
  color: #aa0014;
}
.red__bg {
  background-color: #aa0014;
  color: #fff;
  display: inline-block;
}
.yellow__line{
  background: linear-gradient(transparent 70%, #fff100 30%);
  display: inline;
}

/****************
** Bold
****************/
.bold{
  font-weight: 700;
}

/****************
** Margin / Padding
****************/
.mt10{
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .mt10{
    margin-top: 2vw;
  }
}

.mt20{
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .mt20{
    margin-top: 4vw;
  }
}

.mt30{
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .mt30{
    margin-top: 6vw;
  }
}

.mt40{
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .mt40{
    margin-top: 8vw;
  }
}

/****************
** Cast
****************/

/* detailList */
.detailList dt {
  font-weight: 800;
  color: #aa0014;
}
@media screen and (min-width: 769px) {
.detailLists {
  width: 100%;
}
.detailList {
  display: flex;
  width: 100%;
  margin-bottom: 10px;
}
.detailList dt {
  flex-shrink: 0;
}
.detailList dd {
  max-width: 100%;
}
.rb{
  margin-top: 3px;
}
.ondemand{
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}
}

/* castList */
.castLists {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.castList {
  width: calc(100% / 5);
}
.castList img {
  width: 100%;
  pointer-events: none;
}

@media screen and (max-width: 768px) {
.castList {
  width: calc(100% / 4);
}
}

/****************
** Event Program
****************/
#eventprogram > p{
  text-align: center;
  font-weight: 800;
}

@media screen and (min-width: 769px) {
  #eventprogram > p{
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  #eventprogram > p{
    font-size: max(3.8vw, 15px);
    line-height: 1.4;
    margin-bottom: 4vw;
  }
}

/****************
** Event Infomation
****************/
.seat img{
  width: 100%;
}
@media screen and (min-width: 769px) {
  .seat img{
    width: 70%;
    margin-top: 15px;
  }
}

/****************
** Present
****************/
#present h4{
  text-align: center;
  font-weight: 800;
}

@media screen and (min-width: 769px) {
  #present h4{
    font-size: 20px;
  }
  #present p img{
    width: 50%;
  }
  #present p{
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  #present h4{
    font-size: max(3.8vw, 15px);
    line-height: 1.4;
  }
  #present p img{
    width: 100%;
  }
}



.presentTxt{
  text-align: center;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .presentTxt{
    margin-top: 1vw;
  }
}

/****************
** Goods
****************/
#goods > p{
  text-align: center;
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  #goods > p{
    font-size: 20px;    
  }
}
@media screen and (max-width: 768px) {
  #goods > p{
    font-size: max(3.8vw, 15px);
    line-height: 1.4;
  }
}

.goodsInfoA {
  text-align: center;
  font-weight: 800;
}

@media screen and (min-width: 769px) {
  .goodsInfoA{
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .goodsInfoA{
    font-size: max(3.8vw, 15px);
    line-height: 1.4;
    margin-bottom: 4vw;
  }
}

.goodsInfoB{
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .goodsInfoB{
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .goodsInfoB{
    font-size: max(3.8vw, 15px);
  }
}

@media screen and (min-width: 769px) {
  .goodsInfoC{
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .goodsInfoC{
    font-size: max(3.8vw, 15px);
  }
}


/* goods list */
@media screen and (min-width: 769px) {
  .shop_ttl {
    font-size: 20px;
    line-height: 1;
    padding: 12px 24px;
    color: #ffed00;
    font-weight: 700;
    background-color: #000;
    background-image: radial-gradient(#212121 20%, transparent 20%), radial-gradient(#212121 20%, transparent 20%);
    background-size: 20px 20px;
    background-position: 0 0, 10px 10px;
    text-align: center;
    display: block;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  .item_list {
    display: table;
    width: 100%;
    margin: auto;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 10px 0;
  }
  .item_list li {
    width: calc(100% / 3 - 4px);
    padding: 5px;
    margin: 2px;
    border: 3px solid #222;
    position: relative;
  }
  .item_list li a {
    display: block;
    width: 100%;
    height: 195px;
    overflow: hidden;
    border: 1px solid #ccc;
    box-sizing: border-box;
    background-size: 100%;
    background-repeat: no-repeat;
    position: relative;
  }
  .item_list li a::before{
    content: '';
    position: absolute;
    bottom: 15px;
    right: 15px;
    width: 40px;
    height: 40px;
    background: url(../../img/aj2025/goods/goods_icon.svg) no-repeat center / contain;
  }
  .item_list li a img {
    width: 100%;
  }
  .item_info {
    width: 255px;
    margin: auto;
    padding-bottom: 30px;
  }
  .item_info .item_ttl {
    font-size: 16px;
    line-height: 26px;
    font-weight: bold;
    padding-top: 10px;
  }
  .item_info .item_detail {
    font-size: 14px;
    line-height: 24px;
    padding-top: 10px;
    padding-bottom: 5px;
  }
  .senkou,
  .gentei,
  .juchu {
    width: 100%;
    height: 30px;
    font-size: 14px;
    line-height: 30px;
    font-weight: bold;
    text-align: center;
    position: absolute;
    bottom: -1px;
    left: 0;
    color: #ffed00;
  }
  .senkou {
    background: #aa0014;
  }
  .gentei {
    background: #212f78;
  }
  .juchu{
    background: #246a52;
  }
  }
  
@media screen and (max-width: 768px) {  
  .shop_ttl {
    font-size: max(3.2vw, 14px);
    line-height: 1.8;
    padding: 1vw;
    color: #ffed00;
    font-weight: 700;
    background-color: #000;
    background-image: radial-gradient(#212121 20%, transparent 20%), radial-gradient(#212121 20%, transparent 20%);
    background-size: 2.8vw 2.8vw;
    background-position: 0 0, 1.5vw 1.5vw;
    text-align: center;
    display: block;
    margin-top: 8vw;
    margin-bottom: 3vw;
  }
  .shop_ttl:first-child{
    margin-top: 3vw;
  }
  .item_list {
    width: 100%;
    margin: auto;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .item_list li {
    width: 100%;
    padding: 18px 18px 0;
    border: 2px solid #222;
    position: relative;
  }
  .item_list li:not(:first-child) {
    margin-top: 2vw;
  }
  .item_list li a {
    display: block;
    width: 100%;
    height: 400px;
    overflow: hidden;
    border: 2px solid #ccc;
    box-sizing: border-box;
    background-size: 596px auto;
    background-repeat: no-repeat;
    background-position: center;
    position: relative;
  }
  .item_list li a::before {
    content: "";
    position: absolute;
    bottom: 15px;
    right: 15px;
    width: 64px;
    height: 64px;
    background: url(../../img/aj2025/goods/goods_icon.svg) no-repeat center / contain;
  }
  .item_list li a img {
    width: 100%;
  }
  .item_info .item_ttl {
    width: 100%;
    margin: auto;
    font-size: max(3.2vw, 15px);
    font-weight: bold;
    padding-top: 2vw;
  }
  .item_info .item_detail {
    width: 100%;
    margin: auto;
    font-weight: normal;
    padding-top: 1vw;    
  }
  .item_detail{
    padding-bottom: 2vw;
  }
  .senkou,
  .gentei,
  .juchu {
    width: calc(100% + 36px);
    margin: auto;
    height: 48px;
    font-size: 22px;
    line-height: 48px;
    font-weight: bold;
    text-align: center;
    color: #ffed00;
    margin-top: 20px;
    margin-left: -18px;
    position: relative;
  }
  .senkou {
    background: #aa0014;
  }
  .gentei {
    background: #212f78;
  }
  .juchu {
    background: #246a52;
  }
}

/* tohoLink */
.tohoLink{
  display:block;  
  font-weight: bold;
  text-align: center; 
  text-decoration: none ;
  color: #fff; 
  background-color: #aa0014;
 
}
@media screen and (min-width: 769px) {
.tohoLink{
  padding: 10px 20px;
  margin: 10px 0 20px 0;
  cursor: pointer;
  transition: 0.3s;
}
.tohoLink:hover {
  background-color: #000;
  color: #fff; 
}
}
@media screen and (max-width: 768px) {
  .tohoLink{
    padding: 1vw;
    margin: 2vw 0 7vw 0;
    font-size: max(3.2vw, 14px);
  }
}

/* goodsRed */
.goodsRed{
  color: #aa0014;
  font-weight: 600;
}

/* goodssettlement */
.goodssettlement{
  width: 60%;
  margin: 0 auto;
}
.goodssettlement img{
  width: 100%;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .goodssettlement{
    width: 100%;
  }
  .goodssettlement img{
    margin: 2vw 0;
  }
}

/****************
** Footer
****************/
@media screen and (min-width: 769px) {
#c_end {
  width: 1000px;
  height: 18px;
  background: url(../../img/old/common/c_window_footer1000.png) no-repeat;
  margin: 0 auto 80px;
}
}
@media screen and (min-width: 769px) {
  .footerNav__copyR {
    padding: 13px;
    background-color: #000;
    color: #fff;
    text-align: center;
    font-size: 12px;
  }
  .footer__policy a{
    color: #fff;
  }
}
@media screen and (max-width: 768px) {
  #c_end_sp {
    width: 100%;
    height: 2vw;
    background: url(../../img/old/common/c_window_footer1000.png) no-repeat;
  } 
  .footer__policy{
    text-align: center;
  } 
  .footer__policy a{
    font-size: max(2.2vw, 12px);
  }
}