@charset "UTF-8";

/*==================================

 Layout

==================================*/
.ntv-wrapper{
  background: #dd9dae;
}
.ntv-main{
  margin-bottom: 10.67%;
}
.teaser-main-mainImg img {
  display: block;
  width: 100%;
}
.teaser-main-onair{
  background-color: #dd9dae;
  color: #fff;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 1px;
  font-weight: bold;
  padding: 10px;
}
.teaser-contents {
  box-sizing: border-box;
  font-size: 1.6rem;
}
.teaser-contents a:hover, .bnr_cast a:hover {
  transition: opacity .1s;
	text-decoration:none;
	opacity:0.65;
}

/* ブロック */
.teaser-block{
  color: #0d0d0d;
  letter-spacing: 0.06em;
  font-feature-settings: 'palt' 1;
  word-break: break-all;
  margin-top: 10.67%;
  position: relative;
  z-index: 0;
  font-size: 1.4rem;
}
.teaser-block-inner{
  padding: 2.67vw;
}

/* ブロックタイトル */
.teaser-block-title{
  background-image: url(../images/tit_sns.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  width: 100%;
  height: 0;
  padding-top:42.17vw;
  font-size: 0;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
  line-height: 1.0;
  text-align: center;
  margin-bottom: 4vw;
}
#twitter .teaser-block-title{
  background-image: url(../images/tit_sns.png);
  padding-top:21.08vw;
}
#intro .teaser-block-title{
  background-image: url(../images/tit_intro.png);
  padding-top:21.68vw;
}
#story .teaser-block-title{
  background-image: url(../images/tit_story.png);
  padding-top:21.68vw;
}
#cast .teaser-block-title{
  background-image: url(../images/tit_cast.png);
  padding-top:20.86vw;
}
#onair .teaser-block-title{
  background-image: url(../images/tit_onair.png);
  padding-top:21.16vw;
}
#staff .teaser-block-title{
  background-image: url(../images/tit_staff.png);
  padding-top:21.31vw;
}

/* ブロック内テキスト */
.teaser-block p{
  color: #0d0d0d;
  line-height: 1.86;
  font-size: 1.4rem;
  margin-bottom: 15px;
}

.bg-grid{
  background-image: url(../images/common/pattern.png);
  background-repeat: repeat;
  background-position: top center;
  background-size: 6.6%;
  width: 100%;
  padding-top: 100vw;
  position: absolute;
  z-index: -1;
  top: 8vw; left:0;
  opacity: 0.7;
}
/* ---------------------------------
 SP用
--------------------------------- */
@media screen and (max-width: 992px) {
}

/* ---------------------------------
 tablet用(SP設定を上書き）
--------------------------------- */
@media screen and (min-width : 601px){
  .bg-grid{
    padding-top: 70vw;
  }
}

/* ---------------------------------
 PC用
--------------------------------- */
@media screen and (min-width: 993px) {
  .ntv-main{
    margin-bottom: 40px;
  }
  /* ブロック */
  .teaser-block{
    margin-top: 40px;
  }
  .teaser-block-inner{
    padding: 20px;
  }
  /* ブロックタイトル */
  .teaser-block-title{
    margin-bottom: 20px;
  }
  #twitter .teaser-block-title{
    padding-top: 0;
    height: 140px;
  }
  #intro .teaser-block-title{
    padding-top: 0;
    height: 144px;
  }
  #story .teaser-block-title{
    padding-top: 0;
    height: 144px;
  }
  #cast .teaser-block-title{
    padding-top: 0;
    height: 138px;
  }
  #onair .teaser-block-title{
    padding-top: 0;
    height: 140px;
  }
  #staff .teaser-block-title{
    padding-top: 0;
    height: 141px;
  }
  .teaser-block p{
    font-size: 1.6rem;
  }
  .teaser-main-onair{
    padding-top: 0;
    font-size: 1.8rem;
  }
  .teaser-contents {
    padding-top: 0;
    margin-top: 20px;
  }
  .bg-grid{
    background-size: 6%;
    padding-top: 0;
    height: 41vw;
    max-height: 520px;
    top: 5vw;
  }
}

/* ---------------------------------
 右カラム設定
--------------------------------- */

/* 右カラム　タイトル */
.ntv-box-title {
  background: #7e7ec4;
}
.ntv-box-title.title-base {
  background: #7e7ec4;
}
.drama-box-title.title-base {
  background-color: #7e7ec4;
}
/*==================================

SNS

==================================*/
 /* SP用 */
 @media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
}

/*==================================

INTRO

==================================*/
#intro .teaser-block-inner{
  width: 100%;
  padding-top: 282.93vw;
  padding-left: 0;
  padding-bottom: 0;
  padding-right: 0;
  background-image: url(../images/intro_sp.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-top: -16vw;
}
#intro .teaser-block-inner p{
  display: none;
}
 /* SP用 */
 @media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
  #intro .teaser-block-inner{
    background-image: url(../images/intro.png);
    padding-top: 0;
    height: 1764px;
    margin-top: -160px;
  }
}

/*==================================

STORY

==================================*/
#story .bg-grid{
  padding-top: 88vw;
}
#story .teaser-block-inner{
  position: relative;
}
#story .story-number{
  width: 16.8%;
  padding-top: 16.8%;
  background-image: url(../images/story/num_01.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  font-size: 0;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top:-10%; left:auto; right:10.67%;
}
#story figure{
  width: 100%;
  margin-bottom: 7.04vw;
}
#story figure img{
  width: 100%;
  border: 4px solid #fff;
}
#story .story-text{
  padding: 0 2.67%;
  background: #dd9dae;
  padding-top: 1em;
  margin-bottom: 0;
}
#story .story-text .bold{
  font-weight: bold;
}
#story .btn-story{
  margin-top: 8%;
}
#story .btn-story a{
  background: #fff;
}
#story .story-number.num_01{
  background-image: url(../images/story/num_01.png);
}
#story .story-number.num_02{
  background-image: url(../images/story/num_02.png);
}
#story .story-number.num_03{
  background-image: url(../images/story/num_03.png);
}
#story .story-number.num_04{
  background-image: url(../images/story/num_04.png);
}
#story .story-number.num_05{
  background-image: url(../images/story/num_05.png);
}
#story .story-number.num_06{
  background-image: url(../images/story/num_06.png);
}
#story .story-number.num_07{
  background-image: url(../images/story/num_07.png);
}
#story .story-number.num_08{
  background-image: url(../images/story/num_08.png);
}
#story .story-number.num_09{
  background-image: url(../images/story/num_09.png);
}
 /* SP用 */
@media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
  #story .bg-grid{
    padding-top: 0;
    height: 42vw;
    max-height: 570px;
  }
  #story .story-number{
    width: 128px;
    height: 128px;
    padding-top: 0;
    top:-15%; right:5%;
  }
  #story figure{
    margin-bottom: 40px;
  }
  #story .story-text{
    padding: 1em 0 0;
  }
  #story .btn-story{
    margin-top: 40px;
  }
}
/*==================================

CAST

==================================*/
#cast .cast-list{
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}
#cast .cast-item{
  width: 42%;
  margin-bottom: 4vw;
}
#cast .cast-item img{
  width: 100%;
}
#cast .cast-item p{
  display: none;
}
#cast .cast-nav{
  width: 100%;
  padding-top: 5.63%;
  margin: 4% 0 0;
  background-image: url(../images/cast/michael-tomioka.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  font-size: 0;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
}
 /* SP用 */
 @media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
  #cast .cast-item{
    width: 22.44%;
    margin-bottom: 20px;
  }
  #cast .cast-nav{
    padding-top: 0;
    height: 22px;
  }
}
/*==================================

ONAIR

==================================*/
#onair{
  text-align: center;
}
#onair .bg-grid{
  padding-top: 15vw;
}
#onair .onair-list{
  text-align: center;
}
#onair .onair-list dt{
  background: #475784;
  color: #fff;
  font-size: 1.15em;
  font-weight: bold;
  display: inline-block;
  padding: 0 0.5em;
  margin-bottom: 2.67vw;
}
#onair .onair-list dd{
  margin-bottom: 5.33vw;
}
#onair .pre-onair{
  display: inline-block;
  width: 100%;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  margin-bottom: 5.33%;
}
#onair .pre-onair p{
  color: #fff;
  font-weight: bold;
  font-style: italic;
  font-size: 1.6rem;
  margin: 0.25em 0;
  padding: 0;
}
#onair .note{
  font-size: 1.2rem;
  text-align: left;
  padding: 0;
  margin: 0;
}
 /* SP用 */
 @media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
  #onair .bg-grid{
    padding-top: 0;
    height: 6vw;
    max-height: 80px;
  }
  #onair .onair-list dt{
    margin-bottom: 15px;
  }
  #onair .onair-list dd{
    margin-bottom: 30px;
  }
  #onair .pre-onair{
    margin-bottom: 30px;
  }
  #onair .note{
    text-align: center;
  }
}

/*==================================

STAFF

==================================*/
#staff{
  position: relative;
  z-index: 0;
}
#staff .bg-staff{
  background-image: url(../images/bg_staff_sp.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  width: 100%;
  padding-top: 57.87%;
  position: absolute;
  z-index: -1;
  top: 0; left:0;
}
#staff .staff-list{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#staff .staff-list dt, #staff .staff-list dd{
  width: 47%;
  margin-bottom: 1em;
}
#staff .staff-list dt{
  text-align: right;
}
#staff .staff-list dd{
  text-align: left;
}
 /* SP用 */
 @media screen and (max-width: 992px) {
}
/* tablet用(SP設定を上書き） */
@media screen and (min-width : 601px){
}
/* PC用 */
@media screen and (min-width: 993px) {
  #staff .bg-staff{
    background-image: url(../images/bg_staff.png);
    padding-top: 47.14%;
  }
}
/*==================================

Module

==================================*/


/* ---------------------------------
 メニュー設定
--------------------------------- */
.teaser-main-nav{
  position: relative;
  width: 100%;
  left: 0;
  bottom: 0;
  z-index: 10;
}
.teaser-main-nav .row{
  display: flex;
  justify-content:space-between;
  margin-bottom: 0;
}
.teaser-main-nav .row .col{
  width : 18.72%;
  padding: 0;
}
.teaser-main-nav ul{width: 100%;}
.teaser-main-nav ul li{
  margin: 0 auto;
}
.teaser-main-nav ul li a, .teaser-main-nav ul li span{
  display: block;
  text-align: center;
  padding: 0;
  font-size: 0;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
  background-image: url(../images/common/nav_intro.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  width: 100%;
  height: 0;
  padding-top:83.87%;
  cursor: pointer;
}
.teaser-main-nav ul li.nav-intro a, .teaser-main-nav ul li.nav-intro span{
  background-image: url(../images/common/nav_intro.png);
}
.teaser-main-nav ul li.nav-story a, .teaser-main-nav ul li.nav-story span{
  background-image: url(../images/common/nav_story.png);
}
.teaser-main-nav ul li.nav-cast a, .teaser-main-nav ul li.nav-cast span{
  background-image: url(../images/common/nav_cast.png);
}
.teaser-main-nav ul li.nav-onair a, .teaser-main-nav ul li.nav-onair span{
  background-image: url(../images/common/nav_onair.png);
}
.teaser-main-nav ul li.nav-staff a, .teaser-main-nav ul li.nav-staff span{
  background-image: url(../images/common/nav_staff.png);
}
.teaser-main-nav ul li span{
  opacity: 0.4;
  cursor: auto;
}

@media screen and (max-width: 992px) {
  .teaser-main-nav{
    height: 8%;
    margin: 4% 0 6%;
  }
}
@media screen and (min-width: 993px) {

  .teaser-main-nav{
    position: relative;
    z-index: 10;
    margin: 24px 0 40px;
  }
  .teaser-main-nav ul li a, .teaser-main-nav ul li span{
    padding: 0;
    height: 104px;
  }
  .teaser-main-nav ul li a{
    font-size: 12px;
    letter-spacing: 1.2px;
    padding: 15px 0;
    -webkit-transition: opacity 0.1s ease;
    transition: opacity 0.1s ease;
  }
  .teaser-main-nav ul li span{
    font-size: 12px;
    letter-spacing: 1.2px;
    padding: 15px 0;
  }
  .teaser-main-nav ul li a:hover{
    opacity: 0.6;
  }

}
@media only screen and (max-width: 992px) and (min-width: 601px){
  /* .ntv-wrapper{margin-bottom: 60px;} */
}
@media only screen and (max-width: 600px){
  /* .ntv-wrapper{margin-bottom: 60px;} */
}

/* ---------------------------------
 バナー
--------------------------------- */
.teaser-banner-area{
  width: 100%;
}
.teaser-banner-area ul{
  position: relative;
  width: 100%;
  display: flex;
  justify-content:space-between;
  flex-wrap: wrap;
  padding: 0 2.67%;
}
.teaser-banner-area ul li{
  width: 100%;
  margin: 5px 0;
  line-height: 0;
}
.teaser-banner-area ul li.banner-item_2col{
  width: 48.59%;
  margin: 5px 0;
  line-height: 0;
}
.teaser-banner-area ul li a{
}
.teaser-banner-area ul li a img{
  width: 100%;
}
@media screen and (min-width: 993px) {
  .teaser-banner-area{
    padding: 0;
  }
  .teaser-banner-area ul{
    padding: 0;
  }
  .teaser-banner-area ul li{
    margin: 10px 0;
  }
}

/* ---------------------------------
 動画
--------------------------------- */
.teaser-contents .movie-player{
  width: 100%;
  padding-top: 56.25%;
  position: relative;
  margin: 0 auto;
}
.teaser-contents .movie-player iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ---------------------------------
 Twitter
--------------------------------- */

/* タイムライン */
#teaser-twitter{
  position: relative;
  z-index: 0;
}
.teaser-contents .twitter-area{
  height: 350px;
}
.teaser-contents .twitter-area .twitter-timeline{
}

/* ボタン */
.teaser-contents .official-sns-block {
  margin-top: 0;
  border-top: none;
}
.teaser-contents .teaser-btn + .teaser-btn{
  margin-top: 20px;
}
.teaser-contents .teaser-btn p{
  margin-bottom: 0;
}
.teaser-contents .teaser-btn a{
  width: 65%;
  max-width: 320px;
  display: block;
  margin: 0 auto;
  padding: 1.1em 0;
  text-align: center;
  color: #0d0d0d;
  line-height: 1;
  letter-spacing: 0.1em;
  border-radius: 1.6em;
  position: relative;
  box-shadow: 4px 4px 0px 0px #0d0d0d;
}
.teaser-contents .teaser-btn#btn-follow-twitter a{
  background-color: #fff;
  padding-left: 1.5em;
}
.teaser-contents .teaser-btn#btn-follow-twitter a::before{
  content: '';
  display: block;
  background-image: url(../images/icon_x.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  width: 1.5em;
  height: 1.5em;
  position: absolute;
  top: 50%; left: 50%;
  margin-left: -4.5em;
  margin-top: -0.75em;
}
.teaser-contents .teaser-btn#btn-follow-facebook a{
  background-color: #3b5998;
}
.teaser-contents .teaser-btn#btn-follow-instagram a{
  position: relative;
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
}
.teaser-contents .teaser-btn#btn-follow-instagram a::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: -webkit-linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
  background: linear-gradient(15deg, #ffdb2c, rgb(249, 118, 76) 25%, rgba(255, 77, 64, 0) 50%) no-repeat;
}
.teaser-contents .teaser-btn#btn-follow-line a{
  background-color: #00b900;
}
.teaser-contents .teaser-btn#btn-follow-tiktok a{
  background-color: #000000;
}
@media screen and (min-width: 993px) {
  .teaser-contents .twitter-area{
  }
  .teaser-contents .twitter-area .twitter-timeline{
  }
}


/* ---------------------------------
 ティザーTOPICS一覧用
--------------------------------- */

#topics.drama-area{
  padding: 0;
  margin: 0;
}
#topics .drama-box-title{display: none;}

/* ボタン */
#topics .drama-btn.btn-more {
  /* color: #ffffff; */
  display: block;
  width: 100%;
  margin: 0 auto;
  text-align: center;
  word-break: break-all;
  position: relative;
  background: transparent;
  border: 1px solid #222;
  padding: 1.3em 0 1.2em;
  font-size: 1.4rem;
  line-height: 1;
}
#topics .drama-btn.btn-more i {
  font-size: 1.5em;
  margin-right: 5px;
  vertical-align: middle;
}

@media screen and (max-width: 992px) {

  #topics .topics-btn {
    padding: 10px;
    margin: 0;
  }

}

/* リスト */
@media screen and (min-width: 993px) {

  #topics .topics-item {
    width: 49%;
  }
  #topics .topics-item:nth-of-type(n+3) {
    margin-top: 15px;
  }
  #topics .topics-item:nth-of-type(2n+1) {
    margin-left: 0;
  }
  #topics .topics-item:nth-of-type(2n) {
    margin-left: 2%;
  }

}
