/* =================================
	TBS Reset CSS
================================= */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video,main {margin:0;padding:0;border:0;font-size:100%;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section,main {display:block;}
body {font-family:Verdana,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;line-height:1;}
ol,ul {list-style:none;}
blockquote,q {quotes:none;}
blockquote:before,blockquote:after,q:before,q:after {content:'';content:none;}
table {border-collapse:collapse;border-spacing:0;}
wbr:after {content:"\00200B";}

/*	TBS reset
============================== */
.alt {position:absolute;top:-5000px;left:-9999px;}
.clearfix:after {content:"";clear:both;display:block;}
.hide-txt {text-indent:110%;white-space:nowrap;overflow:hidden;}
.fp-causion {display:none;}
.nocontxt {-webkit-touch-callout: none;-webkit-user-select: none;user-select: none;-webkit-user-drag:none;}
.nocontxt img {pointer-events: none;}
@media all and (min-width:768px) {
.alt-pc {position:absolute;top:-5000px;left:-9999px;}
.clearfix-pc:after {content:"";clear:both;display:block;}
.hide-txt-pc {text-indent:110%;white-space:nowrap;overflow:hidden;}
}
@media all and (max-width:767px) {
.alt-smp {position:absolute;top:-5000px;left:-9999px;}
.clearfix-smp:after {content:"";clear:both;display:block;}
.hide-txt-smp {text-indent:110%;white-space:nowrap;overflow:hidden;}
}
div.embed-tbsplayer {
background-color:#000;
position:relative;
height:0;
padding-top:56.25%;
}
div.embed-tbsplayer .tbs-player {
position:absolute;
left:0;
top:0;
width:100%;
height:100%;
}
div.embed-tbsplayer-audio {
background-color:#fff;
}
div.embed-tbsplayer-audio .tbs-player {
height:46px;
}
div.lbx-overlay {
z-index:10000;position:absolute;background-color:#000;width:100%;height:100%;left:0;top:0;right:0;bottom:0;opacity:0.9;
}

/*	Web Fonts
============================== */
.mgb05em {
  margin-bottom: 0.5em;
}
.mgb1em {
  margin-bottom: 1em;
}

.mgb2em {
  margin-bottom: 2em;
}

.mgb3em {
  margin-bottom: 3em;
}

.mgb4em {
  margin-bottom: 4em;
}

.mgb5em {
  margin-bottom: 5em;
}

.txt {
  line-height: 1.8;
}


@media all and (min-width: 768px) {
  .txt {
    font-weight: 400;
  }
}
.wbr {
  white-space: nowrap;
  display: inline-block;
}

.add {
  font-size: 80%;
  color: #666;
	line-height: 1.5em; margin-bottom: 0.5em;
}
.nolink {
  opacity: 0.5;
  cursor: default !important;
}

.underBlue {
  background: linear-gradient(transparent 50%, #b7eaf6 50%); padding: 2px;text-shadow: 1px 1px 0px #fff;
}

@media all and (min-width: 768px) {
  .fs50 {
    font-size: 50%;
  }

  .fs60 {
    font-size: 60%;
  }

  .fs70 {
    font-size: 70%;
  }

  .fs80 {
    font-size: 80%;
  }

  .fs90 {
    font-size: 90%;
  }

  .fs110 {
    font-size: 110%;
  }

  .fs120 {
    font-size: 120%;
  }

  .fs130 {
    font-size: 130%;
  }

  .fs140 {
    font-size: 140%;
  }

  .fs150 {
    font-size: 150%;
  }

  .fs160 {
    font-size: 160%;
  }

  .fs170 {
    font-size: 170%;
  }

  .fs180 {
    font-size: 180%;
  }

  .fs190 {
    font-size: 190%;
  }
.nobr { display:none; }
.nobrSp { display:block; }
}

@media all and (max-width: 767px) {
  .fs50 {
    font-size: 75%;
  }

  .fs60 {
    font-size: 80%;
  }

  .fs70 {
    font-size: 85%;
  }

  .fs80 {
    font-size: 90%;
  }

  .fs90 {
    font-size: 95%;
  }

  .fs110 {
    font-size: 105%;
  }

  .fs120 {
    font-size: 110%;
  }

  .fs130 {
    font-size: 115%;
  }

  .fs140 {
    font-size: 120%;
  }

  .fs150 {
    font-size: 125%;
  }

  .fs160 {
    font-size: 130%;
  }

  .fs170 {
    font-size: 135%;
  }

  .fs180 {
    font-size: 140%;
  }

  .fs190 {
    font-size: 145%;
  }
.nobr { display:block; }
.nobrSp { display:none; }
}

.nagisaPink{color: #f7439c;}
.nagisaOrange{color: #e74c09;}
.nagisaGreen{color: #009277;}
.nagisaBlue{color: #0063a4;}
.castName{color: #f7439c;}

.gray {color: #7b7b7b;}
.black {color: #171717;}
.purple {color: #940094;}
.blue {color: #0047a3;}
.lightblue {color: #21a5f1;}
.deepgreen {color: #060;}
.green {color: #179917;}
.kubotagreen {color: #009fa8;}
.yellowgreen {color: #4eb200;}
.yellow {color: #ffba00;}
.orange {color: #ee9a23;}
.pink {color: #ff2d85;}
.vermilion {color: #ff4e4e;}
.red {color: #e60012;}
.carmine {color: #e09966;}
.magenta {color: #ea33b2;}
.brown {color: #6a3906;}
.yellowocher {color: #b27b17;}
.gold { color: #c93;}
.silver {color: #b2b2b2;}
.bluegreen {color: #0b9d9b;}

.center {
  text-align: center;
  display: inline-block;
  width: 100%;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.bold {
  font-weight: bold;
}

span.super { vertical-align: super; font-size: 0.6em; }

a {
  text-decoration: none;
  color: #f7439c;
}

/*	background
============================== */
html, body, div#con-body {
  background-color: #fcd7e7;
	background-image: url(../img/bg_contents.png);
  /* デフォルトのグレーを上書き */
}
body.idx, body.idx div#con-body {
  /*background-image: url(../img/bg_top.jpg);*/
}
body.low, body.low div#con-body{
  /*background-image: url(../img/bg_low.jpg);*/
}

body {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
margin: 0!important;
}

@media all and (min-width: 768px) {
  .pcnone {
    display: none;
  }
}

@media all and (max-width: 767px) {
  .smpnone {
    display: none;
  }
}

/*	wrap
============================== */
@media all and (min-width: 768px) {
  div.wrap {
    width: 980px;
    margin: 0 auto;
  }
}


/*	nav
============================== */
nav#menu { background-color: #fff; border-top: solid 2px #e44793; border-bottom: solid 2px #e44793;}
@media all and (min-width: 768px) {
 
nav#menu ul { width:980px; margin: 0 auto; letter-spacing: -.4em;}
nav#menu ul li { display: inline-block; height: 86px; }
nav#menu ul li a, nav ul li span { /*display: inline-block;*/ display: block; width:107px; height: 86px; background-repeat: no-repeat; background-position: center center; text-indent: -9999px;}
nav#menu ul li.caststaff a, nav ul li.caststaff span { width:165px;}
nav#menu ul li.original a, nav ul li.original span, nav#menu ul li.message a, nav ul li.message span { width:140px;}

	
nav#menu ul li.intro a { background-image: url(../img/navi_01.png);}
nav#menu ul li.story a { background-image: url(../img/navi_02.png);}
nav#menu ul li.news a { background-image: url(../img/navi_03.png);}
nav#menu ul li.chart a { background-image: url(../img/navi_04.png);}
nav#menu ul li.caststaff a { background-image: url(../img/navi_05.png);}
nav#menu ul li.original a { background-image: url(../img/navi_06.png);}
nav#menu ul li.message a { background-image: url(../img/navi_07.png);}
nav#menu ul li.paravi a { background-image: url(../img/navi_08.png);}

nav#menu ul li.chart span { background-image: url(../img/navi_04.png); opacity:0.4;}
	
}
nav#menu ul li a:hover { opacity:0.7;}


@media all and (max-width: 767px) {
 
nav#menu, nav#menu ul {width:100%;}
nav#menu ul {letter-spacing: -.4em;}
nav#menu ul li { display: inline-block; width:25%; margin:0; vertical-align: top;}
nav#menu ul li:nth-child(1), nav#menu ul li:nth-child(2), nav#menu ul li:nth-child(3), nav#menu ul li:nth-child(4) { border-bottom: solid 2px #e44793;}
nav#menu ul li a, nav#menu ul li span { display: block; width:100%; height: 0; padding-top: 63.768%; background-repeat: no-repeat; background-position: center center; background-size:100% auto; text-align:center;  text-indent: -9999px; display: block;}

nav#menu ul li.intro a { background-image: url(../img/sp_navi_01.png);}
nav#menu ul li.story a { background-image: url(../img/sp_navi_02.png);}
nav#menu ul li.news a { background-image: url(../img/sp_navi_03.png);}
nav#menu ul li.chart a { background-image: url(../img/sp_navi_04.png);}
nav#menu ul li.caststaff a { background-image: url(../img/sp_navi_05.png);}
nav#menu ul li.original a { background-image: url(../img/sp_navi_06.png);}
nav#menu ul li.message a { background-image: url(../img/sp_navi_07.png);}
nav#menu ul li.paravi a { background-image: url(../img/sp_navi_08.png);}

nav#menu ul li.chart span { background-image: url(../img/sp_navi_04.png); opacity:0.4;}

}

/*	copyright
============================== */
p.copyright {
  font-size: 80%;
  color: #f7439c;
  text-align: center;
  padding: 80px 0 30px;
  line-height: 1.5;
  position: relative;
  font-family: fot-tsukuardgothic-std, sans-serif;
}
@media all and (min-width: 768px) {
p.copyright { padding: 50px 0;}
}
@media all and (max-width: 767px) {
p.copyright { padding: 30px 10px 45px;}
}

/*	back to top
============================== */
p.backtotop {
  z-index: 20;
  -webkit-transition-duration: 300ms;
  -webkit-transition-timing-function: ease-in-out;
  transition-duration: 300ms;
  transition-timing-function: ease-in-out;
  font-family: fot-tsukuardgothic-std, sans-serif;
}

p.backtotop a, p.backtotop span {
  display: block;
}

p.btot-on, p.btot-off {
  position: fixed;
}

@media all and (min-width: 768px) {
  p.backtotop {
    transition-property: bottom;
  }

  p.btot-on {
    right: 60px;
    bottom: 30px;
  }

  p.btot-off {
    right: 60px;
    bottom: -212px;
  }

  p.backtotop a {
    background-image: url(../img/backtotop.png);
    background-repeat: no-repeat;
    background-position: left top;
    width: 90px;
    height: 90px;
    text-indent: 110%;
    white-space: nowrap;
    overflow: hidden;
  }
}

@media all and (max-width: 767px) {
  p.backtotop {
    min-width: 320px;
    transition-property: bottom;
  }

  p.btot-on, p.btot-off {
    width: 100%;
  }

  p.btot-on {
    bottom: 0;
  }

  p.btot-off {
    bottom: -200px;
  }

  p.backtotop a {
    line-height: 1;
    z-index: 20;
    position: relative;
    text-decoration: none;
    color: #fff;
    background-color: hsla(330, 91%, 61%, 0.7);
    height: 60px;
    letter-spacing: 0;
  }

  p.backtotop a span {
    position: absolute;
    left: 50%;
    top: 50%;
    margin-top: -0.5em;
    margin-left: -2em;
    font-weight: bold;
  }

  p.backtotop a span {
    position: absolute;
    left: 50%;
    top: 50%;
    margin-top: -8px;
    margin-left: -4.5em;
    display: block;
    content: "";
    background-image: url(../img/sp_backtotop.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 150px 14px;
    width: 150px;
    height: 14px;
	  text-indent: -9999px;
  }
}

/*	footer
============================== */
footer {
  text-align: center;
  vertical-align: top;
  padding: 0px 0 20px;
  position: relative;
  z-index: 1;
}
#rect { width: 300px; margin: 0 auto;}
@media all and (max-width: 767px) {
  footer {
    padding: 0 0 20px;
  }
}

div.snsbtn {
  margin-left: 60px; margin-top: 40px;
}
@media all and (max-width: 767px) {
  div.snsbtn {
    margin-top: 20px; padding-bottom: 20px;
  }
}

/*	youtube
============================== */
.player-box {
    position: relative;
    height: 0;
    padding-top: 56.25%;
}
section.unit iframe {
    border: none;
}
.player-box iframe, .player-box video, .player-box .fp-player, .player-box .tbs-player, .player-box object {
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
}


/*	ph_cut
============================== */
.ph_cut, .ph_cut_l {
  border: 2px solid #ed549a; padding: 8px;
}

.ph_cut span, .ph_cut_l span {
  display: block;
  position: relative;
}

.ph_cut span, .ph_cut_l span {
  background-size: 100%;
}

@media all and (min-width: 768px) {

  .ph_cut,
  .ph_cut span {
    width: 600px;
    height: 400px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
  }

  .ph_cut {
    margin: 1em auto;
  }

  .ph_cut_l,
  .ph_cut_l span {
    width: 400px;
    height: 600px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
  }

  .ph_cut_l {
    margin: 1em auto;
  }
}

@media all and (max-width: 767px) {
  .ph_cut span img, .ph_cut_l span img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }

  .ph_cut {
    width: 100%;
    margin: 1em 0;
    box-sizing: border-box;
  }

  .ph_cut span {
    height: 0;
    padding: 66.66666% 0 0;
    position: relative;
  }

  .ph_cut_l {
    width: 60%;
    margin: 1em auto;
  }

  .ph_cut_l span {
    height: 0;
    padding: 150% 0 0;
    position: relative;
  }
}

ul.kome li:before {
  content: "※";
  float: left;
}

ul.kome li span {
  display: block;
}

.lazy img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

/*	cap
============================== */
.cap {
  text-align: center;
  margin: -0.5em auto 1.0em;
  width: 500px;
  padding: 0 !important;
  font-size: 85%;
  line-height: 1.5;
}
.cap span {
  padding: .1em; color: #0063a4;
}
@media all and (max-width: 767px) {
  .cap {
    width: 95%;
    margin: -0.5em auto 1em;
  }
  .cap span {
    font-size: 0.9em;
  }
}

.cr {
    padding: 1em;
	font-size: 80%;
    color: #229bb7;
    text-align: center;
    line-height: 1.5;
    font-family: fot-tsukuardgothic-std, sans-serif;
}

.linkBtn { text-align: center;}
.linkBtn a {
    color: #fff; font-weight: bold; font-size: 1.1em;
	background-color: #f7439c; padding: 0.6em 1.5em;
	border-radius: 20px 20px!important; letter-spacing: 0em;
	display: inline-block;
}
.linkBtn a:hover{opacity: 0.85;}
@media all and (min-width: 768px) {
.txtArea .linkBtn { margin-top: -1.5em;}
}
@media all and (max-width: 767px) {
.txtArea .linkBtn { margin-top: -0.5em;}
}




/*	bknm
============================== */
.story #bknm h3, .interview #bknm h3, .quiz #bknm h3, .gallery #bknm h3, .topics #bknm h3, .nagitech #bknm h3  {background-image: url("../img/h3_bkn.png"); background-position: center center; background-repeat: no-repeat; width:100%; height: 30px; text-indent: -9999px; padding: 0; }
.story #bknm ul, .interview #bknm ul, .gallery #bknm ul {
    margin: 2em 0 0 0px;
    text-align: left; letter-spacing: -.4em;
}
.story #bknm li, .interview #bknm li, .gallery #bknm li {
    display: inline-block;
    margin: 0 7px 30px;
    position: relative; vertical-align: top; box-shadow: 3px 3px #f4bad3; border: solid 1px #fff;
}
.story #bknm li a, .interview #bknm li a, .gallery #bknm li a {
    display: block;
    position: relative;
    overflow: hidden;
	width: 165px;
    height: 110px; background-size: contain;
	
}
.story #bknm li a span, .interview #bknm li a span, .gallery #bknm li a span {
	width: 165px;
    height: 110px; display: block; background-size: contain;}


.story #bknm li a:after, .interview #bknm li a:after, .gallery #bknm li a:after{
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
}
#bknm li span.epn {
    font-size: 100%;
    color: #fff;
    position: absolute;
    right: 0px;
    bottom: 0px;
    background-size: contain; width:40px; height: 40px; text-indent: -9999px;
}
#bknm li.bk9 span.epn, #bknm li.bk10 span.epn {
    width:53px; height: 40px;
}
#bknm li span.epn strong {
    font-size: 160%;
}
#bknm li span.name {
    font-size: 0.9em;
    color: #fff;
    position: absolute;
    right: 0px;
    bottom: 0px;
	background-color: #d84f8f; padding: 0.4em 0.6em;
	letter-spacing: 0em;
}

.story #bknm li a:hover, .interview #bknm li a:hover, .gallery #bknm li a:hover {opacity: 0.85;}

@media all and (min-width: 768px) {
.story #bknm, .interview #bknm, .quiz #bknm, .gallery #bknm {padding-top: 40px;}
}
@media all and (max-width: 767px) {
.story #bknm ul, .interview #bknm ul, .gallery #bknm ul {
      margin: 1em auto 0;
      letter-spacing: 0;
      text-align: left;
  }
.story #bknm li, .interview #bknm li, .gallery #bknm li {
      width: 28%;
      height: auto;
      margin: 0 1.5% 4%;
  }
.story #bknm li a, .interview #bknm li a, .gallery #bknm li a {
       width: 100%;
      height: 0; padding: 66.6% 0 0;
position: relative;
  }
	.story #bknm li a span, .interview #bknm li a span, .gallery #bknm li a span {
       font-size: 3.5vw;
      
  }

#story #bknm li a img,  #story #bknm li a span, #gallery #bknm li a img, #gallery #bknm li a span, .interview #bknm li a span{
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
  }

#bknm li span.epn {
    right: 0px;
    bottom: 0px;
width:26px; height: 26px;
}
#bknm li.bk9 span.epn, #bknm li.bk10 span.epn {width:35px; height: 26px;}
#bknm li span.name {
    font-size: 0.7em; padding: 0.2em 0.4em;
	right: 0;
    bottom: 0;
	}
}

/*--sns-share--*/
div.sns-share {
	text-align:center; 
}
div.sns-share section {  border-radius:35px; background-color:#fcf4e4; padding: 10px;
	display:table;
}
.idx div.sns-share section { background-color:#fff; }
div.sns-share section h2{ width:50%; text-align: right;}
div.sns-share section h2, div.sns-share section h3, div.sns-share section div.sns-rig {
	display:table-cell;
	 padding-top: 0!important; padding-bottom: 0!important; letter-spacing: 0em; color: #000;
}
div.sns-share section h2, div.sns-share section h3 {
	line-height:1.5;
	text-align:right;
	vertical-align:middle;
	-webkit-box-sizing:border-box;
	-moz-box-sizing:border-box;
	box-sizing:border-box;
}
body:not(.topics) div.sns-share section h2 > span,
body:not(.topics) div.sns-share section h3 > span {
	padding:0.25em 0.5em;
font-family: vdl-megag, sans-serif;
font-style: normal;
font-weight: bold;
	
}

div.sns-share section ul { letter-spacing: -.4em;}
div.sns-share section ul li {
	/*float:left;*/display:inline-block; vertical-align: middle; letter-spacing: 0em;
}
div.sns-share section ul li a {
	display:block;
	text-indent:110%;white-space:nowrap;overflow:hidden;
	background-image:url(../img/sns_logos.svg);
	background-repeat:no-repeat;
	border-radius:50%;
}
div.sns-share section ul li.shr-tw a {
	background-color:#55acee;
	background-position:left top;
}
div.sns-share section ul li.shr-ln a {
	background-color:#00b900;
	background-position:left bottom;
}
div.sns-share section ul li.shr-fb a {
	background-color:#315096;
	background-position:right top;
}
@media all and (min-width: 768px) {
div.sns-share { padding:20px 0 0px;}
div.sns-share section {width:40%; margin: 0 0 0 auto;}
.idx div.sns-share { padding:0px 0 20px;}
.idx div.sns-share section {width:40%; margin: 0 auto;}	
	
div.sns-share section h2, div.sns-share section h3 {
	font-size:83%;
	padding-right:10px;
}
div.sns-share section ul li {
	width:50px;
}
div.sns-share section ul li:not(:last-child) {
	margin-right:10px;
}
div.sns-share section ul li a {
	height:50px;
	background-size:100px 100px;
}
}
@media all and (max-width: 767px) {
div.sns-share { padding:0px 0 10px; }
div.sns-share section {width:100%; padding: 10px 0px; margin: 0 auto;}
.idx div.sns-share, .news div.sns-share  { padding:0px 0 20px;}
.idx div.sns-share section {width:90%;}	
	
.topics div.sns-share section h3 {
	width:55%;
}
.topics div.sns-share section div.sns-rig {
	width:45%;
}
div.sns-share section h2, div.sns-share section h3 {
	font-size:75%;
	padding-right:0px!important;
}
div.sns-share section ul li {
	width:40px;
}
div.sns-share section ul li:not(:last-child) {
	margin-right:6px;
}
div.sns-share section ul li a {
	height:40px;
	background-size:80px 80px;
}
}
@media all and (max-width: 374px) {
div.sns-share section h3 {
	font-size:62.5%;
}
div.sns-share section ul li:not(:last-child) {
	margin-right:3px;
}
div.sns-share section h2 {
	width:55%;
}
div.sns-share section div.sns-rig {
	width:45%;
}
}

/*	modal customize
============================== */
.md-close a span {
	background-image:url(/um/img/btn_modal.svg);
	background-color:#f7439c;
}
.md-inner {
	box-shadow: 8px 8px #f27eb1;
}
@media all and (max-width: 767px) {
.md-inner {
	box-shadow: 4px 4px #f27eb1;
}
}
