@charset "UTF-8";
/* CSS INFORMATION -====================================================
File name : top.css
Description : トップページ
===================================================================== */
/* =====================================================================
*    mv
* =================================================================== */
.mv {
  padding: 31.2rem 0 13rem;
  background: url(../images/top/bg_mv-sp.jpg) no-repeat center/cover;
  overflow: hidden;
}
.mv_ttl {
  margin: 0 0 0 calc(-27 / 670 * 100%);
  width: calc(721 / 670 * 100%);
}
.mv_date {
  margin: 3.3rem 0 0 calc(-25 / 670 * 100%);
  width: calc(718 / 670 * 100%);
}
.mv .calendar-btn {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .mv .calendar-btn {
    width: calc(400 / 900 * 100%);
  }
}
.mv .calendar-btn a {
  padding: 0.7em 0;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .mv .calendar-btn a {
    font-size: 2rem;
  }
}
.mv .calendar-btn a::after {
  right: 0.5em;
}

@media screen and (min-width: 768px) {
  .mv {
    padding: 4rem 0;
    background-image: url(../images/top/bg_mv-pc.jpg);
  }
  .mv_ttl {
    margin: 0 auto;
    width: calc(670 / 900 * 100%);
  }
  .mv_date {
    margin: -2rem auto 0;
    width: calc(760 / 900 * 100%);
  }
}
/* =====================================================================
    banner
======================================================================*/
#note {
  padding: 5rem 0;
}
#note p {
  text-align: center;
  line-height: 1.5;
}

.banner {
  padding: 10rem 0 6rem;
  background: url(../images/common/bg_pattern4.jpg) repeat center/14.2rem auto;
  border-style: solid;
  -o-border-image: linear-gradient(to right, #f6b000 0%, #ffeb00 25%, #fff799 50%, #ffeb00 75%, #f6b000 100%) 1/0 0 4px 0;
     border-image: -webkit-gradient(linear, left top, right top, from(#f6b000), color-stop(25%, #ffeb00), color-stop(50%, #fff799), color-stop(75%, #ffeb00), to(#f6b000)) 1/0 0 4px 0;
     border-image: linear-gradient(to right, #f6b000 0%, #ffeb00 25%, #fff799 50%, #ffeb00 75%, #f6b000 100%) 1/0 0 4px 0;
}

.banner_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.banner_list li {
  margin-bottom: 4rem;
  width: calc(650 / 670 * 100%);
}
.banner_list li.large {
  width: calc(696 / 670 * 100%);
}

@media screen and (min-width: 768px) {
  #note {
    padding: 3rem 0;
  }
  .banner {
    background-size: 7.2rem auto;
    padding: 5rem 0 1rem;
  }
  .banner_list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
  .banner_list li {
    width: calc(432 / 900 * 100%);
  }
  .banner_list li.large {
    width: calc(900 / 900 * 100%);
  }
  .banner_list li a:hover {
    -webkit-box-shadow: 0 0 2rem #cc9200;
            box-shadow: 0 0 2rem #cc9200;
  }
}
/* =====================================================================
    banner2
======================================================================*/
.banner2 {
  padding: 8rem 0;
  background: url(../images/common/bg_pattern_topt-sp.png) no-repeat top right/100% auto;
}

@media screen and (min-width: 768px) {
  .banner2 {
    position: relative;
    padding: 6rem 0;
    background-image: url(../images/common/bg_pattern_t-pc.png);
    background-position: top -10rem right;
    overflow: hidden;
  }
  .banner2::before {
    content: "";
    position: absolute;
    display: block;
    bottom: 0;
    left: 0;
    width: 100%;
    padding-top: calc(604 / 1000 * 100%);
    background: url(../images/common/bg_pattern_b-pc.png) no-repeat bottom left/100% auto;
  }
  .banner2 a:hover {
    -webkit-box-shadow: 0 0 2rem #cc9200;
            box-shadow: 0 0 2rem #cc9200;
  }
}
/* =====================================================================
    news
======================================================================*/
.news {
  padding: 15rem 0;
  background: url(../images/top/bg_news-sp.jpg) no-repeat center/cover;
  border-top: 2px solid #f6b000;
  border-bottom: 2px solid #f6b000;
  -o-border-image: linear-gradient(to right, #ffffff 0%, #f6b000 15%, #ffeb00 30%, #fff799 50%, #ffeb00 70%, #f6b000 85%, #ffffff 100%);
     border-image: -webkit-gradient(linear, left top, right top, from(#ffffff), color-stop(15%, #f6b000), color-stop(30%, #ffeb00), color-stop(50%, #fff799), color-stop(70%, #ffeb00), color-stop(85%, #f6b000), to(#ffffff));
     border-image: linear-gradient(to right, #ffffff 0%, #f6b000 15%, #ffeb00 30%, #fff799 50%, #ffeb00 70%, #f6b000 85%, #ffffff 100%);
  border-image-slice: 1;
}

.news_list {
  overflow-x: hidden;
  overflow-y: auto;
  max-height: 48.5rem;
}
.news_list::-webkit-scrollbar {
  width: 1rem;
}
.news_list::-webkit-scrollbar-track {
  background: rgba(174, 150, 81, 0.3);
  border-radius: 2em;
}
.news_list::-webkit-scrollbar-thumb {
  background: #c6b78d;
  border-radius: 2em;
}
.news_list li {
  border-top: 1px solid #cc9200;
  padding: 1em 0;
  letter-spacing: 0.24em;
}
.news_list li:last-of-type {
  border-bottom: 1px solid #cc9200;
}
.news_list li dt {
  color: #cc9200;
  font-size: 84%;
  margin-bottom: 1rem;
}
.news_list li dd {
  line-height: 1.4;
}

@media screen and (min-width: 768px) {
  .news {
    padding: 10rem 0 8rem;
    background: url(../images/top/bg_news-pc.jpg) no-repeat center/cover;
  }
  .news_list {
    max-height: 24rem;
  }
  .news_list li {
    padding: 2rem 12rem;
  }
  .news_list li dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 3.6rem;
  }
  .news_list li dl dt {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 7em;
    margin: 0;
  }
  .news_list li dl dd {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
  .news_list li dl dd a {
    display: inline;
  }
  .news_list li dl dd a:hover {
    opacity: 0.7;
  }
}
/* =====================================================================
    artist & mc
======================================================================*/
.artist_mc {
  position: relative;
  background-color: #f6f5f3;
  padding: 14rem 0 25rem;
  background: url(../images/common/bg_pattern_b-sp.png) no-repeat bottom left/100% auto;
}
.artist_mc::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  right: 0;
  width: 100%;
  padding-top: calc(980 / 750 * 100%);
  background: url(../images/common/bg_pattern_t-sp.png) no-repeat top right/contain;
}

.artist {
  margin-bottom: 10rem;
  padding-bottom: 16rem;
  border-bottom: 1px solid #ae9651;
  -o-border-image: linear-gradient(90deg, transparent 0%, #ae9651 25%, #ae9651 75%, transparent 100%);
     border-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(25%, #ae9651), color-stop(75%, #ae9651), to(transparent));
     border-image: linear-gradient(90deg, transparent 0%, #ae9651 25%, #ae9651 75%, transparent 100%);
  border-image-slice: 1;
}
@media screen and (max-width: 767px) {
  .artist-btn {
    margin-left: calc(-15 / 670 * 100%);
    width: calc(700 / 670 * 100%);
  }
}

.mc-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
}
@media screen and (max-width: 767px) {
  .mc-list {
    margin-left: calc(-15 / 670 * 100%);
    width: calc(700 / 670 * 100%);
  }
}
.mc-list li {
  width: 48.8571428571%;
}
.mc-list-name {
  position: relative;
  text-align: center;
  padding: 0.7em 0;
  font-size: 133%;
  background-color: #2f2f2f;
  z-index: 1;
}
.mc-list-name::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto 0;
  width: 100%;
  height: calc(100% - 4px);
  -o-border-image: linear-gradient(90deg, transparent 0%, #ae9651 50%, transparent 100%) 1/1px 0 1px 0;
     border-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(50%, #ae9651), to(transparent)) 1/1px 0 1px 0;
     border-image: linear-gradient(90deg, transparent 0%, #ae9651 50%, transparent 100%) 1/1px 0 1px 0;
  border-style: solid;
  z-index: -1;
}
.mc-list-name .en {
  display: block;
  margin-bottom: 0.5em;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  font-size: 58%;
  letter-spacing: 0.14em;
  color: #ffd461;
}
.mc-list-name .ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #fff;
}
.mc-btn {
  margin: 12rem auto 0;
  width: calc(600 / 670 * 100%);
}
.mc-btn a {
  position: relative;
  text-align: center;
  padding: 1.2em 0;
  font-size: 130%;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: #fff;
  line-height: 1.3;
  text-shadow: 0 0 0.4em #ffa200, 0 0 0.4em #ffa200, 0 0 0.4em #ffa200, 0 0 0.4em #ffa200, 0 0 0.4em #ffa200;
  background: -webkit-gradient(linear, left bottom, left top, from(#cc2f2f), to(#a83535));
  background: linear-gradient(to top, #cc2f2f 0%, #a83535 100%);
  border-radius: 3em;
}
.mc-btn a::after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 1em;
  width: 0.55em;
  height: 0.55em;
  margin-right: 3rem;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%);
  -webkit-filter: drop-shadow(0 0 0.3em #ffa200) drop-shadow(0 0 0.3em #ffa200) drop-shadow(0 0 0.3em #ffa200);
          filter: drop-shadow(0 0 0.3em #ffa200) drop-shadow(0 0 0.3em #ffa200) drop-shadow(0 0 0.3em #ffa200);
}

@media screen and (min-width: 768px) {
  .artist_mc {
    padding: 10rem 0 14rem;
    background-image: url(../images/common/bg_pattern_b-pc.png);
    overflow: hidden;
  }
  .artist_mc::before {
    padding-top: calc(778 / 1600 * 100%);
    background-image: url(../images/common/bg_pattern_t-pc.png);
  }
  .artist {
    margin-bottom: 6.6rem;
    padding-bottom: 6.9rem;
  }
  .mc-list li {
    width: calc(380 / 900 * 100%);
  }
  .mc-list-name {
    font-size: 212%;
  }
  .mc-btn {
    margin-top: 7rem;
    width: calc(600 / 900 * 100%);
  }
  .mc-btn a {
    font-size: 162%;
  }
}
.artist a:hover,
.mc-btn a:hover {
  -webkit-box-shadow: 0 0 2rem #cc9200;
          box-shadow: 0 0 2rem #cc9200;
}/*# sourceMappingURL=top.css.map */