/* CSS INFORMATION -====================================================
File name : top.sass
Description :
===================================================================== */
/* =====================================================================
* main　
* =================================================================== */
.main::before, .main::after {
  display: none;
}

/* =====================================================================
* 追加　
* =================================================================== */

.header_img {
  width: 100vw;
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
  line-height: 0;
}

.header_img img {
  width: 100%;
}

.page_back {
  background: #c0486a;
  padding: 1em 0;
  text-align: center;
  font-weight: 700;
  color: #fff;
  font-size: 1.8em;
}

h2 {
  font-size: 4rem;
  text-align: center;
  font-weight: 700;
  line-height: 1.2;
  padding: 4.4rem 0;
}

h2::before {
  content: "";
  position: absolute;
  bottom: -0.1em;
  display: inline-block;
  width: 3em;
  height: 0.2em;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #c0486a;
  border-radius: 2px;
}

@media screen and (min-width: 768px) {
  h2 {
    font-size: 2.4rem;
  }
  h2::before {
    content: "";
    bottom: -0.1em;
    width: 2em;
    height: 0.15em;
  }
}

/* =====================================================================
* live
* =================================================================== */
.live {
  padding: calc(80 / 750 * 100%) 0;
}

.live .inner .live_box {
  width: calc(640/670 *100%);
  margin: 0 auto;
}

.live .inner .live_box dl {
    /*
    max-width: 800px;
    width: calc(800 / 1000 * 100%);
    */
    margin: 0 auto;
}

.live .inner .live_box dt {
    margin: 20px 0 0;
}

.live .inner .live_box dd {
    margin: 10px 0 0;
    text-align: center;
}

.live .inner .live_box .youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.live .inner .live_box .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.live .inner .live_box .live_schedule {
    max-width: 600px;
    width: calc(600 / 800 * 100%);
    margin: 30px auto 0;
}

.live .inner .start_list_box,.live_box {
    font-size: 1.8em;
}

.live .inner .start_list_box h3 {
    border-left: 10px solid #c0486a;
    font-weight: 900;
    font-size: 1.2em;
    padding: 0 20px;
    margin: 50px auto 0;
}

.live .inner .start_list_box .start_list_select {
    width: 90%;
    padding: 0 20px;
    margin: 30px auto;
    background: #c0486a;
    text-align: center;
    border-top-left-radius: 40px;
    border-bottom-left-radius: 40px;
    border-top-right-radius: 40px;
    border-bottom-right-radius: 40px;
}

.live .inner .start_list_box .start_list_select:after {
    content:"";
    font-size: 0.8em;
    color: #FFFFFF;
    top:0;
    right: 25px;
    bottom:0;
    margin: 27px 0 0;
    position: absolute;
    pointer-events: none;

    border-top: 7px solid #ffffff;
    border-right: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 7px solid transparent;
}

.live .inner .start_list_box .start_list_select select {
    border:none;
    outline:none;
    display: inline-block;
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    cursor:pointer;
    color: #FFFFFF;
    width: 100%;
    z-index:2;
    background: transparent;
    padding: 0 20px;
    line-height: 60px;
}

.live .inner .start_list_box .start_list_select option {
  color: #000000;
}

.live .inner .start_list_box dl {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
}

.live .inner .start_list_box dt {
    background: #9b044f;
    color: #FFFFFF;
    text-align: center;
    padding: 8px;
    margin: 0;
    border: 1px solid #9b044f;
    width: 30%;
}

.live .inner .start_list_box dd {
    background: #eee8ec;
    color: #9b044f;
    text-align: left;
    padding: 8px 20px;
    margin: 0;
    border: 1px solid #9b044f;
    width: 70%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
}

.live .inner .start_list_box .name {
    width: 70%;
}

.live .inner .start_list_box .grade {
}

.start_list_box .start_list_download,.btn_moviemore {
    width: 90%;
    padding: 0 20px;
    margin: 30px auto;
    background: #c0486a;
    text-align: center;
    border-top-left-radius: 40px;
    border-bottom-left-radius: 40px;
    border-top-right-radius: 40px;
    border-bottom-right-radius: 40px;
}

.start_list_box .start_list_download:after,.btn_moviemore:after {
    content:"";
    font-size: 0.8em;
    color: #FFFFFF;
    top: 0px;
    right: 25px;
    bottom: 0px;
    margin: 24px 0 24px;
    position: absolute;
    pointer-events: none;
    border-top: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 7px solid #FFFFFF;
}

.start_list_box .start_list_download a,.btn_moviemore a {
    border:none;
    outline:none;
    display: inline-block;
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    cursor:pointer;
    color: #FFFFFF;
    width: 100%;
    z-index:2;
    background: transparent;
    padding: 0 20px;
    line-height: 60px;
}

@media screen and (min-width: 768px) {
  .live {
    padding: calc(80 / 1200 * 100%) 0 calc(0 / 1200 * 100%);
    background-size: calc(505/1200 *100%) auto;
  }
  .live .inner .live_box {
    width: 100%;
  }
  .live .inner .live_box dl {
      max-width: 800px;
      width: calc(800 / 1000 * 100%);
      margin: 0 auto;
  }
  .live .inner .live_box dt {
      margin: 40px 0 0;
  }
  .live .inner .live_box .live_schedule {
      margin: 50px auto 0;
  }
  .live .inner .start_list_box {
      font-size: 1.1em;
  }
  .live .inner .start_list_box h3 {
      max-width: 500px;
      width: calc(500 / 1000 * 100%);
      margin: 70px auto 0;
  }
  .live .inner .start_list_box .start_list_select {
      max-width: 400px;
      width: calc(400 / 100 * 100%);
      margin: 50px auto;
  }
  .live .inner .start_list_box .start_list_select select,.live_box {
      font-size: 1.2em;
  }

  .live .inner .start_list_box dl {
      max-width: 500px;
      width: calc(500 / 1000 * 100%);
  }
  .start_list_box .start_list_download,.btn_moviemore {
    max-width: 400px;
    width: calc(400 / 100 * 100%);
    margin: 50px auto;
    font-size: 1.2em;
  }
}

@media screen and (min-width: 1400px) {
  .live {
    padding: 80px 0 50px;
    background-size: 505px auto;
  }
}


/* =====================================================================
* rank
* =================================================================== */
.rank {
  padding: 0;
}

.rank .inner .sec_ttl::before {
  background: url(../images/common/icon_rank.svg) no-repeat center left/contain;
}

.rank .inner .rank_box {
  width: calc(640/670 *100%);
  margin: 0 auto;
  font-size: 1.8em;
}

.rank .inner .rank_box ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	flex-wrap: wrap;
    margin: 30px auto;
}

.rank .inner .rank_box li {
    width: 70px;
    border: 2px solid #9b044f;
    text-align: center;
    padding: 10px 0;
    margin: 0 5px 5px 0;
    cursor: pointer;
}
.rank .inner .rank_box li.current {
    background: #9b044f;
    color: #ffffff;
}

.rank .inner .rank_box li:last-child {
    width: 120px;
}

.rank .inner .rank_box table {
  margin: 0 auto;
  border: 2px solid #9b044f;
}

.rank .inner .rank_box thead th {
  background: #9b044f;
  color: #FFFFFF;
  padding: 8px;
}

.rank .inner .rank_box tbody th {
    color: #FFFFFF;
    padding: 8px 20px;
    text-align: left;
}

.rank .inner .rank_box tbody tr:nth-child(odd) th {
    background: #9b044f;
}

.rank .inner .rank_box tbody tr:nth-child(even) th {
    background: #7d0c44;
}

.rank .inner .rank_box .rank_list li:not(:last-child) {
  margin-bottom: calc(60/640 *100%);
}

.rank .inner .rank_box tbody td {
    color: #9b044f;
    padding: 8px;
    text-align: center;
}

.rank .inner .rank_box tbody tr:nth-child(odd) td {
    background: #FFFFFF;
}

.rank .inner .rank_box tbody tr:nth-child(even) td {
    background: #eee8ec;
}


.rank .inner .rank_box .rank_list li:not(:last-child) {
  margin-bottom: calc(60/640 *100%);
}

.rank .inner .rank_box .rank_list li dl dt a span {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: rgba(16, 25, 49, 0.3);
}

.rank .inner .rank_box .rank_list li dl dt a span::before {
  content: "";
  display: block;
  width: calc(80 / 640 * 100vw);
  height: calc(80 / 640 * 100vw);
  background: url(../images/common/img_movie.png) no-repeat center/contain;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 2;
}

.rank .inner .rank_box .rank_list li dl dd {
  color: #fff;
  font-size: 2.4rem;
  font-weight: 700;
  margin-top: calc(20/640 *100%);
}

@media screen and (min-width: 768px) {
  .rank {
    padding: 0 0 0;
    background-size: calc(505/1200 *100%) auto;
  }
  .rank .inner .rank_box {
    width: 100%;
    font-size: 1.0em;
  }
  .rank .inner .rank_box ul {
      max-width: 800px;
      width: calc(800/1000 *100%);
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      margin: 30px auto;
  }
  .rank .inner .rank_box li {
      width: 100px;
      border: 2px solid #9b044f;
      text-align: center;
      padding: 10px 0;
      margin: 0 5px 5px 0;
      font-size: 1.2em;
      /*
      border-top-left-radius: 20px;
      border-bottom-left-radius: 20px;
      border-top-right-radius: 20px;
      border-bottom-right-radius: 20px;
      */
  }
  .rank .inner .rank_box table {
    max-width: 800px;
    width: calc(800/1000 *100%);
    margin: 0 auto;
    font-size: 1.3em;
    border: 2px solid #9b044f;
  }
  .rank .inner .rank_box tbody th {
      border-left: 2px solid #9b044f;
  }
  .rank .inner .rank_box tbody td {
      border-left: 2px solid #9b044f;
  }
}

@media screen and (max-width: 767px) {
    .rank .inner .rank_box table.table01 {
        width: 100%;
    }
    .rank .inner .rank_box table.table01 thead {
        display: none;
    }
    .rank .inner .rank_box table.table01 tbody th {
        display: block;
    }
    .rank .inner .rank_box table.table01 tbody td {
        display: block;
        border-bottom: 1px solid #9b044f;
    }
    .rank .inner .rank_box table.table01 tbody td::before {
        content: attr(label);
        float: left;
        clear: both;
        font-weight: bold;
    }
    .rank .inner .rank_boxtable.table01 tbody td p {
        /*
        padding-left: 10em;
        */
    }
}

@media screen and (min-width: 1400px) {
  .rank {
    padding: 0 0 100px;
    background-size: 505px auto;
  }
}

/*# sourceMappingURL=top.css.map */
