@charset "UTF-8";

@font-face {
  font-family: 'GoodTimes';
  src: url(/common/font/good_times_rg.ttf)
}

.sp {
  display: none
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .sp {
    display: inline-block
  }
}

.pc {
  display: inline-block
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .pc {
    display: none
  }
}

.mv {
  padding: 7rem 0 3rem
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .mv {
    padding: 6rem 0 3rem
  }
}

.mv .mv__title {
  font-weight: bold;
  font-size: 130px;
  line-height: 125px;
  letter-spacing: 0.05em;
  margin-bottom: 0;
  margin-top: 0
}

@media only screen and (max-width:1168px) {
  .mv .mv__title {
    font-size: calc(130 / 1168 * 100vw);
    line-height: calc(125 / 1168 * 100vw)
  }
}

.mv .date {
  font-weight: bold;
  font-size: 50px;
  letter-spacing: 0.05em;
  margin-bottom: 47px;
  margin-top: 19px;
  line-height: 65px;
  font-family: 'GoodTimes', sans-serif !important
}

@media only screen and (max-width:1168px) {
  .mv .date {
    font-size: calc(50 / 1168 * 100vw);
    line-height: calc(65 / 1168 * 100vw);
    margin-bottom: calc(50 / 1168 * 100vw)
  }
}

.mv .date span {
  font-size: 25px;
  font-family: 'Noto Sans JP', sans-serif
}

@media only screen and (max-width:1168px) {
  .mv .date span {
    font-size: calc(34 / 1168 * 100vw);
    line-height: calc(48 / 1168 * 100vw)
  }
}

.mv .lead {
  font-size: 34px;
  line-height: 48px;
  font-weight: bold
}

@media only screen and (max-width:1168px) {
  .mv .lead {
    font-size: calc(34 / 1168 * 100vw);
    line-height: calc(48 / 1168 * 100vw)
  }
}

.mv #inner-content {
  display: block
}

.main-visual {
  position: relative;
}

.main-visual .archive_link {
  position: absolute;
  top: 70%;
  left: 17%;
  width: 45%;
  height: 45px;
  line-height: 45px;
  background-color: #fff;
  border-radius: 20px;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  color: #e00741;
}

@media only screen and (max-width:1050px){
  .main-visual .archive_link {
    height: 35px;
    line-height: 35px;
    font-size: 16px;
  }
}

@media only screen and (max-width:767px){
  .main-visual .archive_link {
    height: 30px;
    line-height: 30px;
    font-size: 12px;
  }
}

@media only screen and (max-width:480px){
  .main-visual .archive_link {
    height: 30px;
    line-height: 30px;
    font-size: 9px;
  }
}

.main-visual .archive_link::after{
  content: "";
  position: absolute;
  top: 50%;
  right: 5%;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 20px solid #e00741;
  transform: translateY(-50%);
}

@media only screen and (max-width:1050px){
  .main-visual .archive_link::after {
    right: 3%;
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 14px solid #e00741;
  }
}

@media only screen and (max-width:767px){
  .main-visual .archive_link::after {
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 10px solid #e00741;
  }
}

@media only screen and (max-width:480px){
  .main-visual .archive_link::after {
    border-top: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-left: 6px solid #e00741;
  }
}

.about_contents .about__article {
  color: #333333;
  font-size: 20px;
  line-height: 32px;
  margin-bottom: 45px;
  letter-spacing: 0.04em;
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .about__article {
    font-size: 18px;
    line-height: 27px;
    text-align: justify;
    text-justify: inter-ideograph
  }
}

.about_contents .event-overview {
  background: #f0f0f0;
  border-radius: 10px;
  padding: 35px 90px 50px;
  margin-bottom: 96px
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .event-overview {
    padding: 35px 15px 50px
  }
}

.about_contents .event-overview .common__button {
  margin-bottom: 1.6rem
}

.about_contents .event-overview .col a {
  color: #4f96f6;
}

.about_contents .flexbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .flexbox {
    flex-direction: column
  }
}

.about_contents .flexbox .col {
  color: #333333;
  font-size: 20px;
  line-height: 30px;
  letter-spacing: -0.88px;
  font-weight: bold
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .flexbox .col {
    font-size: 18px;
  }
}


.about_contents .flexbox .col:first-of-type {
  margin-right: 60px;
  padding-left: 14px
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .flexbox .col:first-of-type {
    padding-left: 0;
    margin-right: 0;
    margin-bottom: 30px;
  }
}

.about_contents .flexbox .col:last-of-type {
  margin-right: 60px;
  padding-left: 14px;
  padding-left: 0;
  margin-right: 0
}

.about_contents .flexbox .col p:not(:last-of-type) {
  margin-bottom: 40px
}

.about_contents .end_message {
  padding-left: 14px;
  margin-top: 0px;
  margin-bottom: 1.6rem;
  font-weight: 500
}

.about_contents .common__button {
  max-width: 380px;
  margin: 0 auto
}

.about_contents .mobile_common__button {
  font-size: 18px
}

.about_contents .sponsors .logo-img {
  width: 100%;
  margin: 0 auto
}

.about_contents .sponsors .sponsors__list {
  text-align: center;
  margin-bottom: 124px
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .sponsors .sponsors__list {
    margin-bottom: 80px
  }
}

@media only screen and (max-width:480px),
only screen and (max-width:767px) {
  .about_contents .sponsors .sponsors__list .flex {
    flex-wrap: wrap
  }
}

.about_contents .container__footer {
  padding-top: 3rem;
  border-top: 1px solid #000
}

.about_contents .container__footer .common__button {
  margin-bottom: 1.6rem
}
