@charset "UTF-8";

.pc {
  display: none;
}
.sp {
  display: block;
}
.row .inner {
  padding: 0;
}
.pageTitleContainer .inner {
  padding: 20px;
}

.denshi .innerCont {
	width:100%;
  p{
    height: auto;
  }
  p span{
    display: inline-block;
    margin-bottom: 10px;
  }
}

.ticketTitle {
	margin: 30px 30px 20px;
  .titleText {
    font-size: 5vw;
  }
  .titleText span {
    font-size: 8vw;
  }
  .titleDate {
    font-size: 4vw;
    width: auto;
  }
  .annotation {
    font-size: 14px;
  }
}

.ticketInfo {
	display: block;
  margin: 0 auto;
  width: 90%;
}
.ticketInfo__item {
  flex-direction: column;
  gap: 20px 0;
  padding: 20px 0;
}
.ticketInfo__title {
  font-size: 2.4rem;
}

.ticket__description {
  padding-right: 0;
}

.ticketPrice {
  width: 100%;
  padding: 10px 10px 20px;
  .ticketType {
    margin: 10px 0 20px;
    font-size: 2.2rem;
  }
  .ticketType span {
    font-size: 1.8rem;
  }
  .price {
    font-size: 5rem;
    margin-bottom: 15px;
  }
  .price span {
    font-size: 3rem;
  }
  .limit {
    font-size: 1.6rem;
    line-height: 1;
  }
}
.ticketPrice::before {
  width: 6px;
  border-left: 6px dotted #fff;
}
.ticketPrice::after {
  width: 12px;
  height: 12px;
}

.ticketContent .inner .ticketPrice a{
  color: #333;
  text-decoration: none;
}
.ticket__description--text {
  margin-bottom: .5em;
  font-size: 2rem;
  line-height: 1.5;
  text-align: center;
}

.free {
	font-size: 5vw;
}

.infoTitle {
  padding: 25px 0;
  font-size: 2.2rem;
  letter-spacing: 0;
}

.ticketInfoText {
  font-size: 1.5rem;
}

/*
前売り券について
================================================ */
.advanceInfo {
  padding-bottom: 40px;
  .infoTitle span:before {
    left: -58px;
    top: -40px;
    margin: 0;
    background-size: 50%;
  }
}

.advanceInfoWrap {
  margin-top: -5px;
  padding-top: 5px;
}
.advanceInfoBox {
  margin: 20px auto 0;
  padding: 20px 15px;
  width: 90%;
  border-radius: 10px;
}

.advanceInfoBoxTitle {
  padding: 0 0 10px 75px;
  text-align: left;
  line-height: 1.3;
  font-size: 2rem;
}
.advanceInfoBoxText {
  line-height: 1.5;
  text-align: left;
}
#advance01 .advanceInfoBoxTitle {
  background: url(../../images/ticket/flow01.png) no-repeat left top;
  background-size: 65px auto;
}
#advance02 .advanceInfoBoxTitle {
  background: url(../../images/ticket/flow02.png) no-repeat left top;
  background-size: 65px auto;
}
#advance03 .advanceInfoBoxTitle {
  background: url(../../images/ticket/flow03.png) no-repeat left top;
  background-size: 65px auto;
}
#advance04 .advanceInfoBoxTitle {
  background: url(../../images/ticket/flow04.png) no-repeat left top;
  background-size: 65px auto;
}
:is(.advanceInfoBox#advance01, .advanceInfoBox#advance02, .advanceInfoBox#advance03, .advanceInfoBox#advance04)::before {
  display: none;
}
.advanceInfoBoxNote {
  margin-left: -75px;
  padding: 5px 10px;
  width: calc(100% + 75px);
  box-sizing: border-box;
  line-height: 1.5;
}
.advanceInfoBoxSubTitle span {
  padding: 5px 10px;
  width: 100%;
  font-size: 1.6rem;
  line-height: 1.5;
  box-sizing: border-box;
}
.advanceInfoBoxInner {
  display: block;
}

.innerCont,
.conveni .innerCont,
.innerCont.fee.sevenTicket{
  margin: 0 auto 30px;
  padding: 20px;
  width: 100%;
  height: auto;
}

.conveni .seveneleven {
	display: block;
}

:is(.innerCont) a.buyBtn {
  position: static;
  display: block;
  margin: 15px auto 0;
  width: 70%;
}

.attentBox {
  margin: 20px auto 30px;
  padding: 20px;
  width: 90%;
  box-sizing: border-box;
  p {
    width: 100%;
    line-height: 1.5em;
  }
}

.registrationBox {
  margin-bottom: 40px;
  padding: 20px 15px;
  .title {
    font-size: 2rem;
    line-height: 1.5;
  }
  .text {
    margin-top: 10px;
    text-align: left;
  }
  .registrationLink {
    margin-top: 15px;
  }
  .buttonLink {
    width: 100%;
    font-size: 1.4rem;
    box-sizing: border-box;
  }
}

#advance03 .innerCont a.commissionLink {
	position: initial; 
}

/*
当日券について
================================================ */
.detailsInfo__list {
  padding: 40px 0;
}
.detailsInfo__item {
  margin: 0 auto 20px;
  padding: 20px 15px 5px;
  width: 90%;
  border-radius: 10px;
}
.detailsInfo__head {
  padding-bottom: 14px;
  font-size: 2.0rem;
}
.detailsInfo__table {
  width: 100%;
  th,td {
    display: block;
  }
  th {
    margin: 0 0 .5em;
    width: 100%;
    font-size: 1.5rem;
  }
  td {
    padding: 0 0 15px 10px;
    font-size: 1.5rem;
  }
}