@charset "UTF-8";
.ntv-wrapper {
  position: relative;
  background:
  url(../images/mv-bg.png) center top 50px / 100% auto no-repeat,
  url(../images/deco01.png) top 1230px right -810px / 1400px auto no-repeat,
  url(../images/deco01.png) bottom 35% left -750px / 1400px auto no-repeat,
  url(../images/bg01.png) center top / 150px auto repeat;
}
.ntv-wrapper > div {
  position: relative;
  z-index: 2;
}
.ntv-wrapper:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: min(61vw,720px);
  background: url(../images/deco01.png) center top / 175% auto no-repeat;
  content: "";
}
.ntv-contentsWrap {
  overflow: initial;
  display: flex;
  justify-content: space-between;
}
.ntv-contentsWrap:after {
  display: none;
}
.ntv-contentsWrap .ntv-main,
.ntv-contentsWrap .ntv-aside {
  float: none;
}
.ntv-contentsWrap .ntv-aside {
  z-index: 2;
}
.ntv-contentsWrap .ntv-main {
  position: relative;
  z-index: 1;
}
.ntv-main img {
  width: 100%;
  vertical-align: bottom;
  display: block;
}
@media screen and (max-width: 992px) {
  .ntv-wrapper {
    position: initial;
    background:
    url(../images/mv-bg.png) center top / min(260%,994px) auto no-repeat,
    url(../images/bg01.png) center top / 150px auto repeat;
  }
  .ntv-wrapper:after {
    display: none;
  }
  .ntv-wrapper > div {
    position: initial;
    z-index: initial;
  }
  .ntv-wrapper .ntv-contentsWrap {
    overflow: hidden;
    display: block;
  }
  .teaser-contents {
    background: url(../images/deco01.png) center bottom -120px / min(200vw,1700px) auto no-repeat;
  }
}

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

 Layout

==================================*/
.teaser-main-mainImg {
  position: relative;
  padding: 0 43px;
}
.teaser-main-mainImg img {
  display: block;
  width: 100%;
  pointer-events: none;
  user-select:none;
}
.teaser-main-mainImg span {
  position: absolute;
  bottom: 70px;
  left: 0;
  width: 100%;
}
.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{
  margin-top: 90px;
  color: #1A2338;
  word-break: break-all;
}
.teaser-block-inner{
  padding: 16px 10px;
}

/* ブロックタイトル */
.teaser-block-title{
  display: flex;
  justify-content: flex-end;
  width: 100%;
  height: 40px;
  padding: 0 20px;
  margin-bottom: 30px;
  position: relative;
  text-align: center;
}
.teaser-block-title:after {
  position: absolute;
  top: 50%;
  left: 160px;
  width: calc(100% - 270px);
  height: 1px;
  background: #1A2338;
  content: "";
}
.teaser-block-title img {
  width: auto;
  height: 100%;
}

/* ブロック内テキスト */
.teaser-block p,
.teaser-block li,
.teaser-block dt,
.teaser-block dd,
.teaser-block a{
  color: #1A2338;
  line-height: 1.8;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.1em;
}

.teaser-block .btn-deco {
  display: block;
  width: 100%;
  padding: 5px;
  background: url(../images/bg02.jpg) center / 1000px auto no-repeat;
  color: #1A2338;
  text-align: center;
  letter-spacing: 0.2em;
}
.teaser-block .ft-min {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 600;
}
.teaser-block ruby rt {
  font-weight: normal;
}

.teaser-block .br-pc {
  display: block;
}
.teaser-block .br-sp {
  display: none;
}
@media screen and (max-width: 992px) {
  .teaser-main-mainImg {
    max-width: 660px;
    margin: 0 auto;
    padding: 20px min(7vw, 220px) 0;
  }
  .teaser-main-mainImg span {
    bottom: 33px;
  }
  .teaser-contents {
    margin: 0 auto;
    padding: 0 20px;
  }

  /* ブロック */
  .teaser-block{
    margin-top: 70px;
  }
  .teaser-block-inner{
    padding: 16px 0;
  }

  /* ブロックタイトル */
  .teaser-block-title{
    height: 30px;
    padding: 0;
    margin-bottom: 20px;
  }
  .teaser-block-title:after {
    left: 40px;
    width: calc(100% - 120px);
  }

  /* ブロック内テキスト */
  .teaser-block p,
  .teaser-block li,
  .teaser-block dt,
  .teaser-block dd,
  .teaser-block a{
    font-size: 1.4rem;
  }

  .teaser-block .btn-deco {
    background-size: 500px auto;
  }
  .teaser-block .br-pc {
    display: none;
  }
  .teaser-block .br-sp {
    display: block;
  }
}

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

/* ---------------------------------
 PC用
--------------------------------- */
@media screen and (min-width: 993px) {
  .teaser-block-inner{
    padding: 20px;
  }
  /* ブロックタイトル */
  .teaser-main-onair{
    font-size: 1.8rem;
  }
}

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

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


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

 Template-Module
 不使用の場合は削除してください

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


/* ---------------------------------
 メニュー（UNIT04タイプ）設定
--------------------------------- */
.teaser-main-nav {
  width: 83%;
  margin: -30px auto 20px;
  padding: 0 10px;
  z-index: 2;
  position: relative;
}
.teaser-main-nav ul {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  width: 100%;
  margin: 0 auto;
}
.teaser-main-nav ul li {
  position: relative;
  vertical-align: top;
}
.teaser-main-nav ul li:nth-child(even) {
  margin-top: 5px;
}
.teaser-main-nav ul li .label {
  font-size: 1rem;
  position: absolute;
  top: -2px;
  left: 50%;
  z-index: 30;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 95%;
  background-color: #fff844;
  border-radius: 5px;
  transform: translateX(-50%);
}
.teaser-main-nav ul li a {
  text-indent: -9999px;
  display: block;
  overflow: hidden;
  line-height: 0;
  font-size: 0;
  height: 118px;
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  transition: 0.2s;
}
.teaser-main-nav ul li a:hover {
  filter: grayscale(1);
}
.teaser-main-nav ul li.is-coming a {
  pointer-events: none;
  opacity: 0.6;
}
.teaser-main-nav ul li:nth-of-type(1) a {
  background-image: url("../images/nav/nav-intro.png");
}
.teaser-main-nav ul li:nth-of-type(2) a {
  background-image: url("../images/nav/nav-cast.png");
}
.teaser-main-nav ul li:nth-of-type(3) a {
  background-image: url("../images/nav/nav-music.png");
}
.teaser-main-nav ul li:nth-of-type(4) a {
  background-image: url("../images/nav/nav-staff.png");
}
.teaser-main-nav ul li:nth-of-type(5) a {
  background-image: url("../images/nav/nav-topics.png");
}
.row:after {
  display: none;
}
/* row-5（4列） */
.teaser-main-nav ul.row-5 li {
  width: calc((100% - 12px) / 5);
}

/* row-4（4列） */
.teaser-main-nav ul.row-4 li {
  width: calc((100% - 15px) / 4);
}

/* row-3（3列） */
.teaser-main-nav ul.row-3 li {
  width: calc((100% - 10px) / 3);
}

@media screen and (max-width: 992px) {
  .ntv-main a:hover {
    opacity: 1;
  }
  .teaser-main-nav {
    width: min(100vw, 500px);
    margin: -20px auto 10px;
  }
  .teaser-main-nav ul {
    gap: 3px;
  }
  .teaser-main-nav ul.row-4 li {
    width: calc((100% - 9px) / 4);
  }
  .teaser-main-nav ul li a {
    height: min(22vw,108px);
  }
}

/* ---------------------------------
 動画
--------------------------------- */
.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%;
}
/*.teaser-contents .movie-player .box__cover {
  position: absolute;
  left: calc(50% - 95px);
  top: calc(50% - 95px);
  width: 190px;
  height: 190px;
  z-index: 1;
}
.teaser-contents .movie-player .box__cover.hidden{
  display: none;
}*/
@media screen and (max-width: 992px) {
/*  .teaser-contents .movie-player .box__cover {
    left: calc(50% - 60px);
    top: calc(50% - 60px);
    width: 120px;
    height: 120px;
  }*/
}

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

/* タイムライン */
.teaser-contents .twitter-area{
}
.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 a{
  width: 100%;
  display: block;
}
.teaser-contents .teaser-btn a{
  padding: 1.3em 0 1.2em;
  text-align: center;
  color: #ffffff;
  font-weight: bold;
  line-height: 1;
}
.teaser-contents .teaser-btn#btn-follow-twitter a{
  background-color: #1da1f2;
}
.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;
}
