@charset "UTF-8";
/* CSS INFORMATION -====================================================
File name : top.css
Description : トップページ
===================================================================== */
/* =====================================================================
    mv
======================================================================*/
.mv {
  position: relative;
  background: url(../images/top/mv_bg.png) repeat-x;
  background-size: contain;
}

.mv h1 {
  position: relative;
  z-index: 999;
  padding-top: calc(42 / 1133 * 100%);
}

.mv_move_wrap {
  overflow: hidden;
  position: absolute;
  top: 2em;
  left: 0;
  width: 100%;
  height: 3em;
}

.mv_move {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 200%;
  height: 100%;
}

.mv_move > * {
  background: url(../images/top/mv_txt.png) round center top/contain;
  width: 100%;
  height: 100%;
}

.mv_move01 {
  -webkit-animation: loopLeft 30s -15s linear infinite;
          animation: loopLeft 30s -15s linear infinite;
}

.mv_move02 {
  -webkit-animation: loopRight 30s linear infinite;
          animation: loopRight 30s linear infinite;
}

@-webkit-keyframes loopLeft {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes loopLeft {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@-webkit-keyframes loopRight {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}

@keyframes loopRight {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}

.oatime {
  text-align: center;
  line-height: 1.4;
  background: #cd2022;
  font-size: 4.6rem;
  color: #fff7cc;
  padding: 0.4em 0 0.6em;
}

.oatime span {
  font-size: 2.6rem;
}

@media screen and (min-width: 768px) {
  .mv h1 {
    max-width: 1200px;
    margin: 0 auto;
  }
  .mv_move01 {
    -webkit-animation: loopLeft 50s -25s linear infinite;
            animation: loopLeft 50s -25s linear infinite;
  }
  .mv_move02 {
    -webkit-animation: loopRight 50s linear infinite;
            animation: loopRight 50s linear infinite;
  }
  .oatime {
    line-height: 1;
  }
}

/* =====================================================================
    about
======================================================================*/
#about {
  padding: 4rem 0 0;
  background: #ffef86;
}

#about .about_box {
  position: relative;
  height: 118.6rem;
  padding: 11rem 0 48rem;
}

#about .about_box::before {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: calc(750 / 670 * 100%);
  height: 100%;
  margin-left: calc(-40 / 670 * 100%);
  background: url(../images/top/bg_circle.png) no-repeat center/cover;
  z-index: -1;
}

#about .about_box .about_box_lead {
  margin-bottom: 0.2em;
  font-size: 2.8rem;
  text-align: center;
}

#about .about_box h2 {
  margin-bottom: 0.6em;
  font-size: 7.7rem;
  text-align: center;
  color: #cc1329;
}

#about .about_box h2 small {
  font-size: 60%;
}

#about .about_box p {
  line-height: 1.6;
  text-align: center;
}

#about .about_box p span {
  color: #cc1329;
}

@media screen and (min-width: 768px) {
  #about .about_box {
    height: 97.5rem;
    padding: 12.8rem 0 42rem;
    background: url(../images/top/bg_circle.png) no-repeat center/97.7rem auto;
  }
  #about .about_box::before {
    display: none;
  }
  #about .about_box .about_box_lead {
    font-size: 2.6rem;
  }
  #about .about_box h2 {
    margin-bottom: 0.6em;
  }
  #about .about_box p {
    font-size: 1.8rem;
  }
}

/* =====================================================================
    nextstory
======================================================================*/
#nextstory::before {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 50rem;
  background: #ffef86;
}

#nextstory::after {
  content: '';
  position: absolute;
  display: block;
  top: 37rem;
  left: 0;
  width: 100%;
  height: 26rem;
  background: url(../images/common/bg_fire1.png) repeat-x center/auto 100%;
}

#nextstory h2 {
  margin-top: -12rem;
}

#nextstory .nextstory_date {
  margin-bottom: 3rem;
  font-size: 2.8rem;
  text-align: center;
}

#nextstory .nextstory_movie {
  position: relative;
  margin-bottom: 12rem;
}

#nextstory .nextstory_movie .nextstory_movie_photo {
  border-radius: 2.7rem;
  overflow: hidden;
}

#nextstory .nextstory_movie .nextstory_movie_photo a {
  position: relative;
}

#nextstory .nextstory_movie .nextstory_movie_photo a::before {
  content: '';
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  width: 9.9rem;
  height: 9.8rem;
  background: url(../images/top/img_pattern1.png) no-repeat center/contain;
}

#nextstory .nextstory_movie .nextstory_movie_photo a::after {
  content: '';
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 6em;
  height: 6em;
  background: url(../images/top/btn_play.png) no-repeat center/contain;
}

#nextstory .nextstory_movie .nextstory_vtr {
  position: absolute;
  bottom: -9rem;
  left: 3.4rem;
  width: 6em;
}

@media screen and (min-width: 768px) {
  #nextstory::before {
    height: 53rem;
  }
  #nextstory::after {
    height: 31.2rem;
  }
  #nextstory .nextstory_date {
    font-size: 2.4rem;
  }
  #nextstory .nextstory_movie {
    width: calc(800 / 1000 * 100%);
    margin: 0 auto 8.8rem;
  }
  #nextstory .nextstory_movie .nextstory_movie_photo a::after {
    width: 17.3rem;
    height: 17.3rem;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
  #nextstory .nextstory_movie .nextstory_movie_photo a:hover::after {
    opacity: .7;
  }
  #nextstory .nextstory_movie .nextstory_vtr {
    width: 15.7rem;
  }
}

/* =====================================================================
    twitter
======================================================================*/
#twitter {
  padding: 6rem 0;
  background: #ffef86;
}

#twitter::before {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 55rem;
  background: #fff7cc;
}

#twitter::after {
  content: '';
  position: absolute;
  display: block;
  top: 42rem;
  left: 0;
  width: 100%;
  height: 26rem;
  background: url(../images/common/bg_fire1.png) repeat-x center/auto 100%;
}

#twitter .twitter_box {
  padding: 4rem;
  background: #fff;
  border-radius: 2.6rem;
  border: 0.2rem solid #cc1329;
}

#twitter .twitter_box iframe {
  display: block !important;
  width: 59rem !important;
  height: 38rem !important;
  min-height: auto !important;
  margin: 0 auto;
}

@media screen and (min-width: 768px) {
  #twitter::before {
    height: 52rem;
  }
  #twitter::after {
    top: 37rem;
    height: 31.2rem;
  }
  #twitter .twitter_box {
    width: calc(900 / 1000 * 100%);
    margin: 0 auto;
  }
  #twitter .twitter_box iframe {
    width: 82rem !important;
  }
}

/* =====================================================================
    staff
======================================================================*/
#staff {
  padding: 10rem 0;
  background: #ffef86;
}

#staff h2 {
  margin-bottom: 5rem;
}

#staff .staff_list {
  margin-bottom: 10rem;
}

#staff .staff_list li {
  position: relative;
}

#staff .staff_list li:not(:last-child) {
  margin-bottom: 3rem;
}

#staff .staff_list li::before {
  content: '';
  position: absolute;
  top: 1.2em;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 1.6em;
  border-top: 0.4rem dotted #ff9743;
}

#staff .staff_list li dl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  line-height: 2.5;
}

#staff .staff_list li dl > * {
  width: calc(290 / 670 * 100%);
}

#staff .staff_list li dl dt {
  text-align: right;
}

@media screen and (min-width: 768px) {
  #staff h2 {
    margin-bottom: 5rem;
  }
  #staff .staff_list li dl > * {
    width: calc(465 / 1000 * 100%);
  }
}
/*# sourceMappingURL=top.css.map */