@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');

/*要素のマージン・パディングなど*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video{
    margin: 0;
    padding: 0;
    border:0;
    outline:0;
    vertical-align: baseline;
    background:transparent;
}

/*横スクロールバーを表示させない*/
html{
    overflow-y: scroll;
}

/*liの行頭記号を出さない*/
li {
list-style-type: none;
}

/*画像を縦に並べたときに余白が出ない*/
img{
  vertical-align: top;
  font-size:0;
  line-height: 0;
}

body {
  width: 100%;
  margin: 0; }

.clearfix:after {
  display: block;
  clear: both;
  content: ""; }

div#bl_sp {
  background: url(./../img/pt02.jpg) repeat center top;
  width: 100%; }
  div#bl_sp img {
    vertical-align: bottom;
    width: 100%; }
  div#bl_sp section.top {
    background: url(./../img/pt01.jpg) repeat center top;
    background-size: 4%;
    width: 100%;
    margin: 0px auto 0px auto;
    margin-bottom: 0px;
    padding: 4vw 0;
    box-sizing: border-box; }
    div#bl_sp section.top img {
      display: block;
      width: 100%; }

  div#bl_sp .nav_wrap {
  display: block;
  background-color: #f87ea2;}
  div#bl_sp .nav_wrap .nav {
    margin: 0 auto;
    box-sizing: border-box;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
   flex-wrap: wrap; 
  }
  div#bl_sp .nav_wrap .nav li {
    text-align: center;
    width: 25%;}
  div#bl_sp .nav_wrap .nav li a {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 4vw;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 0.1em;
    padding: 3vw 0;
    display: inline-block;
    line-height: 1;
    width: 100%;
    color:#fff;}
  div#bl_sp .nav_wrap .nav li a:hover{
    opacity: 0.66;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease; }
  div#bl_sp section.main-contents {
    width: 100%; 
    margin: 0 auto;
    text-align: center;
    margin-top: 5%;}
    div#bl_sp section.main-contents .txt_italic {
      font-style: italic;
    }
    div#bl_sp section.main-contents .inner {
      font-family: 'Noto Sans JP', sans-serif;
      text-align: center;
      margin: 0 auto;
      width: 92%; }
        div#bl_sp section.main-contents .present_wrap {
          margin: 9.3333vw auto 0;
        }
        div#bl_sp section.main-contents .present_wrap .opac:hover {
          opacity: 0.8;
          -webkit-transition: all 0.5s ease;
          -moz-transition: all 0.5s ease;
          -o-transition: all 0.5s ease; 
        } 
      div#bl_sp section.main-contents .lead {
    margin: 9.3333vw auto; }
  div#bl_sp section.main-contents .cnt_ttl {
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1;
    font-weight: 700;
    color: #fb6793;
    font-size: 9.3333vw;
    letter-spacing: 0.08em;
    text-shadow:2px 2px 0 #fff, -2px -2px 0 #fff,-2px 2px 0 #fff, 2px -2px 0 #fff,0px 2px 0 #fff,  0 -2px 0 #fff,-2px 0 0 #fff, 2px 0 0 #fff;
    margin: 0 auto 6.6666vw;}
    div#bl_sp section.main-contents .cnt_sttl_txt {
      font-weight: 700;
      color: #fb6793;
      font-size: 4.8vw;
    }
  
  div#bl_sp section.main-contents .story_box {
    padding: 5.3333vw;
    border: 0.6666vw solid #f87ea2;
    background: #fff;
    text-align: left;
    margin-bottom: 9.3333vw;
    border-radius: 2.6666vw;}
    div#bl_sp section.main-contents .story_box p {
      color: #434242;
      font-size: 4vw;
      font-weight: 700;
      line-height: 2;
      letter-spacing: 0.1em; }
  div#bl_sp section.main-contents .chart_box {
    margin-bottom: 5.3333vw; }
  div#bl_sp section.main-contents .cast_box {
    padding: 4.8vw 2.6666vw;
    border: 0.6666vw solid #f87ea2;
    background: #fff;
    border-radius: 2.6666vw;
    margin-bottom: 9.3333vw; }
    div#bl_sp section.main-contents .cast_box p {
      color: #292828;
      font-size: 3.4666vw;
      line-height: 1.8;
      font-weight: 400;
      letter-spacing: 0.1em; }
      div#bl_sp section.main-contents .cast_box p .txt_l {
        font-weight: 700;
        font-size: 4.2666vw; }
  div#bl_sp section.main-contents .staff_box {
    margin-bottom: 4.6666vw; }
    div#bl_sp section.main-contents .staff_box p {
      text-align: center;
      color: #292828;
      font-size: 3.2vw;
      line-height: 1.8;
      font-weight: 400;
      letter-spacing: 0.1em; }
      div#bl_sp section.main-contents .staff_box p .txt_l {
        font-size: 4vw;}
  div#bl_sp section.main-contents .tw_wrap {
    width: 100%;
    margin: 9.3333vw auto 0;
    background-color: #fff;
    border-radius: 2.6666vw;
    padding: 5.3333vw;
    border: 0.6666vw solid #f87ea2;
    box-sizing: border-box; }
    div#bl_sp section.main-contents .twitter {
      overflow: hidden;
    }
    div#bl_sp section.main-contents .twitter iframe {
      width: calc(100vw - 20px)!important;
    }

    div#bl_sp section.main-contents .tw_wrap .tw_btn,
    div#bl_sp section.main-contents .movie_btn,
    div#bl_sp section.main-contents .release_btn {
      margin-top: 4vw;
      text-align: center; }
    div#bl_sp section.main-contents .tw_wrap .tw_btn a,
    div#bl_sp section.main-contents .movie_btn a,
    div#bl_sp section.main-contents .release_btn a {
      background-color: #f87ea2;
      color: #fff;
      font-size: 3.7333vw;
      text-decoration: none;
      border-radius: 6.6666vw;
      display: inline-block;
      padding: 2.6vw 0;
      font-weight: 700;
      width: 100%;
      position: relative; }
      div#bl_sp section.main-contents .tw_wrap .tw_btn a::after,
      div#bl_sp section.main-contents .movie_btn a::after,
      div#bl_sp section.main-contents .release_btn a::after {
        content: "";
        position: absolute;
        top: 50%;
        right: 4vw;
        width: 1.6vw;
        height: 1.6vw;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        -webkit-transform: translateY(-50%) rotate(45deg);
        -ms-transform: translateY(-50%) rotate(45deg);
        transform: translateY(-50%) rotate(45deg); }
  div#bl_sp section.main-contents .tw_bnr {
    width: 100%;
    text-align: center;
    margin: 9.3333vw auto 4vw;
  }
  div#bl_sp section.main-contents .ig_bnr {
    width: 100%;
    margin: 0 auto 9.3333vw;
    text-align: center; }
  div#bl_sp section.main-contents .btn_opac {
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -o-transition: all 0.5s ease; }
  div#bl_sp section.main-contents .btn_opac:hover {
    opacity: 0.8; }
div#bl_sp section.main-contents .music_wrap .cnt_ttl {
  width: 28.6666vw; }
div#bl_sp section.main-contents .music_box {
    margin-bottom: 10.6666vw; }
div#bl_sp section.main-contents .music_box p {
  color: #292828;
  font-size: 4vw;
  line-height: 1.8;
  font-weight: 700;
  letter-spacing: 0.1em; }

/* news */
div#bl_sp section.main-contents .news_wrap {
  margin-bottom: 9.3333vw;
  font-family: 'Noto Sans JP', sans-serif;
}
div#bl_sp section.main-contents .news_box {
  width: 92%;
  padding: 5.3333vw 4.6666vw 5.3333vw 4.6666vw;
  border: 0.6666vw solid #f87ea2;
  background: #fff;
  box-sizing: border-box;
  border-radius: 2.6666vw;
  margin: 0 auto;
}
div#bl_sp section.main-contents .news_list {
  margin: 0 auto;
  /* width: 92%;
  padding: 4.8vw 2.6666vw;
  border: 0.6666vw solid #f87ea2;
  background: #fff; */
  box-sizing: border-box;
  /* border-radius: 2.6666vw; */
  text-align: left;
  color: #292828;
  max-height: 400px;
  overflow: auto;
}
div#bl_sp section.main-contents .news_list li {
  margin-bottom: 4vw;
}
div#bl_sp section.main-contents .news_list li:last-child {
  margin-bottom: 0;
}
div#bl_sp section.main-contents .news_list .txt_box a {
  text-decoration: underline;
  color: #292828;
}
div#bl_sp section.main-contents .news_list .txt_box a:hover {
  text-decoration: none;
}
div#bl_sp section.main-contents .news_list .date span{
  background: #fa5bab;
  color: #fff;
  display: inline-block;
  line-height: 1;
  padding: 0.3em 0.8em;
  font-size: 3.2vw;
  font-weight: bold;
  border-radius: 5px;
  margin-bottom: 1.3333vw;
}
div#bl_sp section.main-contents .news_list .ttl {
  font-size: 4vw;
  margin-bottom: 1.3333vw;
  line-height: 1.6;
}
div#bl_sp section.main-contents .news_list .ttl:last-of-type {
  margin-bottom: 0;
}

/* youtube */
div#bl_sp section.main-contents .youtube-box {
width: 100%;
margin: 9.3333vw auto 5vw; }
div#bl_sp section.main-contents .youtube-box .youtube-inner {
  position: relative;
  width: 100%;
  padding-top: 56.25%; }
  div#bl_sp section.main-contents .youtube-box .youtube-inner iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important; }
/* movie_list */
div#bl_sp section.main-contents .movie_list {
  /*padding-top: 4vw;*/
  width: 100%;
  margin: 0 auto;
}
div#bl_sp section.main-contents .movie_list_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  text-align: center;
}
div#bl_sp section.main-contents .movie_list_box a {
  display: inline-block;
}
div#bl_sp section.main-contents .movie_list_box a img {
  width: 44vw;
  max-width: 425px;
}

/* release_wrap */
div#bl_sp section.main-contents .release_box {
    padding: 5.3333vw;
    border: 0.6666vw solid #f87ea2;
    background: #fff;
    text-align: left;
    margin-bottom: 9.3333vw;
    border-radius: 2.6666vw;}
    div#bl_sp section.main-contents .release_box p {
      color: #434242;
      font-size: 4.2666vw;
      line-height: 1.8;
      letter-spacing: 0.1em; }
    div#bl_sp section.main-contents .release_box .release_ttl {
      font-weight: 700;
      margin-bottom: 5.3333vw;
    }
    div#bl_sp section.main-contents .release_box .release_lead {
      font-size: 3.6vw;
      margin-bottom: 4vw;
      line-height: 1.6;
    }
    div#bl_pc section.main-contents .release_box .release_lead_last {
      margin-bottom: 5.3333vw;
    }
    div#bl_sp section.main-contents .release_box .release_txt {
      line-height: 1.6;
      font-size: 3.4666vw;
      margin-bottom: 6.6666vw;
    }
    div#bl_sp section.main-contents .release_box .txtB {
      font-weight: 700;
    }
    div#bl_sp section.main-contents .release_box .txtS {
      font-size: 2.6666vw;
    }
    div#bl_sp section.main-contents .release_img {
      text-align: center;
      margin: 6.6666vw auto;
    }
    div#bl_sp section.main-contents .release_img img {
      width: 100%;
    }

/* manga_wrap */
div#bl_sp section.main-contents .manga_wrap {
  margin: 9.3333vw auto 0;
}
div#bl_sp section.main-contents .manga_wrap img {
  vertical-align: top;
}

/* external-link */
div#bl_sp section.main-contents a.external-link:hover:before,
div#bl_sp section.main-contents a.external-link:active:before {
  content: "";
  width: 80px;
  height: 32px;
  display: block;
  background: url(./../img/external.png) no-repeat;
  background-size: 100%;
  position: absolute;
  top: -32px;
  left: -8px;
  z-index: 1000; }

  div#bl_sp section.main-contents a.external-link {
    display: inline-block;
  position: relative; }

/* スカパーオンデマンド */

div#bl_sp section.main-contents .skyper_ondemand-bnr {
  margin: 9.3333vw auto 9.3333vw;
}

div#bl_sp section.main-contents .skyper_ondemand-bnr a {
  display: block;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 {
  border-radius: 25px;
  border: 2px solid #009fe8;
  background-color: #ffffff;
  padding: 10% 6%;
  margin: 10% auto;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .ttl03 {
  font-size: 15px;
  color: #2f2525;
  font-weight: bold;
  text-align: center;
  line-height: 1.8;
  margin: 1.8em 0;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .txt02 {
  font-size: 13px;
  color: #2f2525;
  text-align: left;
  line-height: 1.6;
  margin-bottom: 20px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .txt02 .link {
  text-decoration: underline;
  color: #0000ee;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .txt02 .link:hover {
  opacity: 0.6;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .txt02 .link.btn_viewing {
  background-color: #f77a22;
  color: #fff;
  padding: 0.6em 2em;
  border-radius: 8px;
  text-decoration: none;
  line-height: 4;
  font-size: 16px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .skyper_ondemand-logo {
  text-align: center;
  margin: 0 auto;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .skyper_ondemand-logo img {
  max-width: 282px;
  width: 55%;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .guide-line {
  border-top: 1px solid #cecece;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .font-red {
  color: red;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-title {
  margin-bottom: 30px!important;
  text-align: center;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-os {
  font-size: 14px;
  margin-bottom: 20px!important;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-os span {
  font-size: 18px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-text {
  text-align: left!important;
  font-size: 14px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-note {
  text-align: left!important;
  font-size: 12px!important;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-text li {
  margin: 5px!important;
  text-indent: -1em;
  padding-left: 1em;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .app-note li {
  margin-bottom: 3px!important;
  text-indent: -1em;
  padding-left: 1em;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .bottom-btn .guide-btn .blue-button {
  margin-bottom: 30px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .mb1 {
  margin-bottom: 1rem;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .mb20 {
  margin-bottom: 20px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .mb30 {
  margin-bottom: 30px;
}

div#bl_sp section.main-contents #skyper_ondemand.cnt02 .mb50 {
  margin-bottom: 50px;
}


.sky_frame {
  background-image: url(./../img/sp_sky_back.jpg);
  background-size: contain;
  width: 100%;
  margin: 0px;
  padding: 15px 10px;
  border: 1px #cccccc solid;
  box-sizing: border-box; }

.sky_frame a {
  text-decoration: none; }

.sky_ttl {
  padding: 0 0 15px; }

.sky_text {
  font-size: 11px;
  line-height: 14px;
  padding: 5px 0;
  text-align: right;
  background: #ffffff; }

.sky_text2 {
  font-size: 11px;
  line-height: 14px;
  padding: 2% 0 1%;
  text-align: right; }

.sky_ttl_frame {
  padding-bottom: 10px; }

.sky_web_frame {
  background: url(./../img/sp_skaper_zeroen_back.png) #ffffff;
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center top;
  margin-bottom: 15px; }

.sky_button {
  padding-top: 13%;
  text-align: center; }

.sky_button_image {
  display: block;
  box-shadow: 0px 5px 15px -5px rgba(0, 0, 0, 0.8);
  margin-left: auto;
  margin-right: auto;
  width: 92.5% !important; }

.bangumi_text {
  font-size: 14px;
  text-align: center;
  width: 90%;
  margin: 20px auto 5px auto; }

.foot_info {
  width: 100%;
  padding: 15px;
  box-sizing: border-box; }

.foot_info .info_midashi {
  width: 100%;
  margin: 0;
  color: #f0027f; }

.foot_info p {
  margin: 10px auto 0;
  font-size: 14px;
  line-height: 22px;
  color: #000000; }

.foot_info .info_midashi--ch2 {
  width: 100%;
  margin: 0;
  background: #fff;
  color: #f0027f; }
