@charset "utf-8";

* {
  margin: 0;
  padding: 0;
  font-family:'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  -webkit-text-size-adjust:none;
  -webkit-font-smoothing: antialiased;
}
html,
body {
  color:#333333;
  font-size:16px;
  width: 100%;
}
body {
  background:url(../img/bg.png) top center repeat;
  background-attachment: fixed;
  min-width: 1200px;
}
a {color:#ff3e84;text-decoration: underline;outline: none;}
a:hover {  text-decoration: none; }
a,img {  border:none; }
li {  list-style-type:none; }
::selection {    background:#ddd; }
::-moz-selection {    background:#ddd;  }
.noselect,
img {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.legacy_ie {
  text-align:center;
  position: absolute;
  top: 120px;
  left:50%;
  width: 640px;
  margin-left: -320px;
  padding:10px 0;
  background:#000;
  color:#fff;
  z-index: 9000;
}
.anchor {
  display: block;
  height: 80px;
  margin-top:-80px;
}
.clear,
.clear:after {
  content: " ";
  clear: both;
  display: block;
}
.pc_br {
  display: block;
}
.sp_br {
  display: none;
}
.loading {
  background:url(../img/loading.gif) center center no-repeat #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  height: 80px;
  width: 80px;
  margin-top: -40px;
  margin-left: -40px;
  border-radius: 10px;
}

/*-----------------------*/
/* over */
/*-----------------------*/
#over {
  width: 100%;
  min-width: 1200px;
  height:auto;
  min-height: 100%;
  box-sizing:border-box;
  position: absolute;
  top: 0;
  left: 0;
  background:url(../img/over_bg.png) top center repeat;
  z-index: 9999;
  display: none;
  padding-bottom:60px;
}
#over > .inner {
  position: relative;
}
#over_image,
#over_youtube {
  background: #000;
  margin:0 auto;
}
#over_image {
  background: #fff;
  border-radius: 15px;
  overflow: hidden;
}
#over_youtube > div {
  margin:0 auto;
}
#over_youtube iframe {
  width: 100%;
  height: 100%;
}
#over_image img {
  display: block;
  width: 100%;
  height: 100%;
}
#over_controller {
  height:80px;
  width: 100%;
  position: relative;
}
#over_close {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 80px;
  width: 80px;
  overflow: hidden;
}
#over_close svg {
  display: block;
  height: 80px;
  width: 80px;
  transition-property: transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(0deg) scale(1);
}
#over_close:hover svg {
  transform:rotate(720deg) scale(1.1);
}
#over_close img {
  display: block;
  width: 80px;
  height: 80px;
}

/*-----------------------*/
/* countdown */
/*-----------------------*/
#over_countdown {
  background: #fff;
  margin:0 auto;
  display: none;
  width: 800px;
  height: 530px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 0 10px rgba(0,0,0,0.3);
  margin-top: 40px;
}
#over .countdown {
  height:80px;
  text-align: center;
  background: #ff3e84;
}
#countdown_image {
  width: 800px;
  height: 450px;
  display: block;
  background:#fff;
}

#over .audio_volume {
  display: inline-block;
  width: 60px;
  height: 80px;
  background-image: url(../countdown/btn_vol.png);
  background-repeat: no-repeat;
  text-indent: 105%;
  white-space: nowrap;
  overflow: hidden;
  transition-property: opacity;
  transition-duration: 200ms;
  transition-timing-function: ease;
}
#over .audio_volume:hover {
  opacity: 0.5
}
#over .audio_volume[data-volume^="0.6"] {
  background-position: 0 -80px;
}
#over .audio_volume[data-volume^="0.2"] {
  background-position: 0 -160px;
}
#over .audio_volume[data-volume="0"] {
  background-position: 0 -240px;
}


#over .audio {
  display: inline-block;
  width: 330px;
  height: 80px;
  background-image: url(../countdown/btn.png);
  background-repeat: no-repeat;
  text-indent: 105%;
  white-space: nowrap;
  overflow: hidden;
  transition-property: opacity;
  transition-duration: 200ms;
  transition-timing-function: ease;
}
#over .audio:hover {
  opacity: 0.5
}
#over .audio_playing {
  background-position: 0 -80px;
}

/*-----------------------*/
/* main */
/*-----------------------*/
.main {
  width: 100%;
  overflow: hidden;
}
.main > .inner {
  width: 1200px;
  margin: 0 auto;
  position: relative;
}
.dangerbg {
  width: 100%;
  height: 1280px;
  min-width: 1200px;
  background:url(../img/bg_danger.png) top center no-repeat;
  position: fixed;
  top: 0;
  left: 0;
}

/*-----------------------*/
/* header */
/*-----------------------*/
.header {
  height: 120px;
  width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 1000;
}
.header .update {
  height: 50px;
}
.header .update ul:after,
.header .update ul li:after,
.header .update:after {
  content: " ";
  clear: both;
  display: block;
}
.header .update ul {
  display: block;
  width: 1150px;
  height: 50px;
  overflow: hidden;
  float: left;
}
.header .update ul li {
  display: none;
}
.header .update ul li:first-child {
  display: block;
}
.header .update .date {
  font-family: 'Ubuntu', sans-serif;
  color: #FF9EC1;
  font-size: 46px;
  float: left;
  font-style: italic;
  height: 50px;
  line-height: 70px;
  padding:0 15px 0 5px;
}
.header .update .text {
  height: 50px;
  line-height: 51px;
  float: left;
  width: 880px;
  font-weight: bold;
  text-shadow: 0 0 2px #fff,0 0 2px #fff,0 0 2px #fff;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.header .update .text a {
  color:#ff3e84;
}
.header .update .text br {
  display: none;
}
.header .update .more {
  width: 50px;
  height: 50px;
  display: block;
  float: left;
  color:#ccc;
  transition-property: transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(0deg) scale(1);
}
.header .update .more:hover {
  transform:rotate(720deg) scale(1.1);
}
.header .update .more svg {
  display: block;
}

/*-----------------------*/
/* menu */
/*-----------------------*/
.menu {
  height: 50px;
  background:#000;
  border-radius: 10px;
  font-size: 0;
  text-align: center;
  position: relative;
}
.menufix {
  position: fixed;
  top: 0;
  left:0;
  width: 100%;
  min-width: 1200px;
  border-radius: 0;
}
.menu > a {
  display: inline-block;
  text-decoration: none;
  color: #fff;
  vertical-align: top;
}
.menu > a div {
  display: inline-block;
  padding:0 10px;
  line-height: 50px;
  height: 50px;
  font-size: 20px;
  font-family: 'Ubuntu', sans-serif;
  transition-duration: 200ms;
  transition-timing-function: ease;
  transition-property: color;
}
.menu > a:hover div,
.menu .current {
  color: #ff3e84;
}
.menu > a .ext svg {
  display:inline-block;
  margin-bottom:-3px;
  margin-left: 2px;
}
.menu .share {
  display: inline-block;
  height: 50px;
  margin-left: 20px;
  position: absolute;
  top: 0;
  right: 0;
}
.menu .share a {
  margin-top:10px;
  display: inline-block;
  width: 30px;
  height: 30px;
  color:#fff;
  margin-right: 10px;
  transition-duration: 200ms;
  transition-timing-function: ease;
  transition-property: color;
}
.menu .share .share_tw:hover {
  color: #00aced;
}
.menu .share .share_fb:hover {
  color: #305097;
}




/*-----------------------*/
/* footer */
/*-----------------------*/
.footer {
  width: 100%;
  position: relative;
  margin-top:50px;
  z-index: 800;
}
/*-----------------------*/
.footer .footer_product {
  width: 900px;
  background:#000;
  border-radius: 10px;
  font-weight: bold;
  font-size: 14px;
  color: #fff;
  padding:20px;
  margin: 0 auto;
  position: relative;
}
.footer .footer_product:before {
  content: "PRODUCT";
  position: absolute;
  font-family: 'Ubuntu', sans-serif;
  color: #ff3e84;
  font-size: 46px;
  line-height: 1em;
  bottom: 5px;
  right: 8px;
  z-index: 10;
}
.footer .footer_product > div {
  color: #ff3e84;
}
.footer .footer_product h6 {
  font-size: 20px;
}
.footer .footer_product dl {
  position: relative;
}
.footer .footer_product dl dt,
.footer .footer_product dl dd {
  display: inline-block;
  line-height: 1em;
  margin-top: 12px;
}
.footer .footer_product dl dt {
  margin-right: 10px;
  color: #ff3e84;
}
.footer .footer_product dl dd {
  margin-right: 20px;
  font-size: 15px;
}
.footer .footer_product .more {
  width: 80px;
  height: 80px;
  display: block;
  position: absolute;
  bottom:-50px;
  right: -50px;
}
.footer .footer_product .more svg {
  width: 80px;
  height: 80px;
  display: block;
}
.footer .footer_product .more .plus {
  transition-property: transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(0deg) scale(1);
  transform-origin:55px;
}
.footer .footer_product .more:hover .plus {
  transform:rotate(720deg) scale(1.1);
}


/*-----------------------*/
.footer .pagetop {
  width: 64px;
  height: 64px;
  margin: 0 auto;
  padding: 20px;
}
.footer .pagetop a {
  width: 64px;
  height: 64px;
  display: block;
}
.footer .pagetop_circle {
  fill: #ff3e84;
}
.footer .pagetop_arrow {
  fill: #fff;
  fill-rule: evenodd;
}

/*-----------------------*/
.footer .footer_contents {
  background:#000;
}
.footer .footer_contents > .inner {
  width: 1200px;
  margin:0 auto;
}
/*-----------------------*/
.footer .menu {
  padding-top: 20px;
}
/*-----------------------*/
.footer .footer_contents .banner {
  padding-top: 20px;
  font-size: 0;
  text-align: center;
}
.footer .footer_contents .banner:after {
  content: " ";
  clear: both;
  display: block;
}
.footer .footer_contents .banner li,
.footer .footer_contents .banner li a,
.footer .footer_contents .banner li a img {
  display: block;
  width: 220px;
  height: 80px;
}
.footer .footer_contents .banner li {
  display: inline-block;
  margin: 10px;
}
.footer .footer_contents .banner li a {
  border-radius: 10px;
  overflow: hidden;
  transition-property: transform;
  transition-duration: 200ms;
  transition-timing-function: ease-out;
  transform:scale(1);
}
.footer .footer_contents .banner li a:hover {
  transform:scale(1.1);
}
.footer .footer_contents .copy {
  padding-top: 30px;
  padding-bottom: 40px;
}
.footer .footer_contents .copy:after {
  content: " ";
  clear: both;
  display: block;
}
.footer .footer_contents .copy .logo {
  width: 940px;
  height: 100px;
  background:url(../img/copy.png) 0 0 no-repeat;
  float: left;
}
.footer .footer_contents .copy .logo a {
  width: 256px;
  height: 60px;
  display: block;
  text-indent: 105%;
  white-space: nowrap;
  overflow: hidden;
}
.footer .footer_contents .copy .cero {
  width: 57px;
  height: 70px;
  background:url(../img/cero.png) 0 0 no-repeat;
  text-indent: 105%;
  white-space: nowrap;
  overflow: hidden;
  float: right;
  margin-right: 10px;
}




/*-----------------------*/
/* common */
/*-----------------------*/
.circle {
  width: 290px;
  height: 290px;
  border-radius: 100%;
  position: absolute;
  overflow: hidden;
  border:5px solid #fff;
  background: url(../img/circle_bg.png) 0 0 repeat;
  transition-property: transform,opacity;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(720deg) scale(0);
  transition-duration: 600ms;
  opacity: 0;
}
.circlein {
  transform:rotate(0deg) scale(1);
  opacity: 1;
}
.circle div {
  border:5px solid rgba(0,0,0,0);
  height: 280px;
  width: 280px;
  overflow: hidden;
  border-radius: 100%;
}
.circle img {
  display: block;
  width: 100%;
  height: 100%;
}
.circle_l {
  width: 330px;
  height: 330px;
}
.circle_l div {
  width: 320px;
  height: 320px;
}

/*-----------------------*/
.slide {
  transition-property: transform,opacity;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:translate(100px,-5px);
  transition-duration: 600ms;
  opacity: 0;
}
.slidein {
  transform:translate(0,0);
  opacity: 1;
}
/*-----------------------*/
.tips {
  color:#00BAFF;
  text-decoration: none;
  display: inline-block;
  position: absolute;

  transition-property: transform,opacity;
  transition-duration: 600ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform-origin:right bottom;
  opacity: 0;
  transform:translate(-50px,-50px) scale(1);
}
.tips_lb {
  transform-origin:left bottom;
  transform:translate(50px,-50px);
}
.tips_lt {
  transform-origin:left top;
  transform:translate(50px,50px);
}
.tips_rt {
  transform-origin:right top;
  transform:translate(-50px,50px);
}
.tipsin {
  opacity: 1;
  transform:translate(0,0);
}
.tips:hover {
  transition-delay: 0ms;
  transition-duration: 300ms;
  transform:scale(1.2);
}

.tips > div {
  display: inline-block;
  position: relative;
}
.tips > div:before {
  content: " ";
  width: 60px;
  height: 60px;
  background:url(../img/tips/tips_rb.svg) 0 0 no-repeat;
  position: absolute;
  bottom: -18px;
  right: -20px;
}
.tips > div:after {
  content: " ";
  width: 23px;
  height: 23px;
  background:url(../img/tips/plus.svg) 0 0 no-repeat;
  position: absolute;
  bottom: -11px;
  right: -13px;
  transition-property: transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(0deg);
}
.tips_lb > div:after {
  bottom: -11px;
  left: -13px;
}
.tips_lt > div:after {
  top: -11px;
  left: -13px;
}
.tips_rt > div:after {
  top: -11px;
  right: -13px;
}
.tips:hover > div:after {
  transform:rotate(720deg);
}
.tips > div > div {
  background-color: #000;
  border-radius: 10px;
  position: relative;
  font-weight: bold;
  padding:6px 12px;
  font-size: 16px;
  margin-bottom: 19px;
  margin-right: 17px;
  text-wrap:none;
}
.tips_lb > div > div {
  margin:0;
  margin-bottom: 19px;
  margin-left: 17px;
}
.tips_lt > div > div {
  margin:0;
  margin-top: 19px;
  margin-left: 17px;
  margin-right: -17px;
}
.tips_rt > div > div {
  margin:0;
  margin-top: 19px;
  margin-right: 17px;
}
.tips_lb > div:before {
  background:url(../img/tips/tips_lb.svg) 0 0 no-repeat;
  bottom:-18px;
  left: -20px;
}
.tips_lt > div:before {
  background:url(../img/tips/tips_lt.svg) 0 0 no-repeat;
  top:-18px;
  left: -20px;
}
.tips_rt > div:before {
  background:url(../img/tips/tips_rt.svg) 0 0 no-repeat;
  top:-18px;
  right: -20px;
}

/*-----------------------*/
.tips_window {
  width: 940px;
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -470px;
  background:url(../img/tips/bg.png) left bottom no-repeat #fff;
  border:6px solid #000;
  border-radius: 20px;
  box-shadow: 15px 15px 0px rgba(0,0,0,0.1);
  display: none;
  z-index: 900;
}
.tips_window:hover {
  cursor: pointer;
}
.tips_window > .inner {
  position: relative;
}
.tips_window:after {
  content: " ";
  width: 360px;
  height: 200px;
  background:url(../img/tips/chira.png) 0 0 no-repeat;
  position: absolute;
  display: block;
  top: -98px;
  right: 20px;
}
.tips_window .close {
  display: block;
  width: 80px;
  height: 80px;
  position: absolute;
  top: -56px;
  right: -56px;
}
.tips_window .close:after {
  content: " ";
  width: 30px;
  height: 30px;
  background:url(../img/tips/close.svg) 0 0 no-repeat;
  position: absolute;
  top: 10px;
  right: 10px;
  transition-property: transform;
  transition-duration: 1000ms;
  transition-timing-function: cubic-bezier(0,1,1,1);
  transform:rotate(0deg) scale(1);
}
.tips_window:hover .close:after {
  transform:rotate(720deg) scale(1.1);
}

.tips_window .title {
  background:#000;
  color:#00baff;
  font-size: 28px;
  height: 64px;
  line-height: 64px;
  padding:0 100px;
  font-weight: bold;
}
.tips_window .text {
  padding:50px 100px;
  font-size: 18px;
  line-height: 28px;
  font-weight: bold;
  position: relative;
  overflow: hidden;
}
.comment_window {
  background:#fff;
}
.comment_window .text:before {
  content: "CAST COMMENT";
  position: absolute;
  font-family: 'Ubuntu', sans-serif;
  color: #eee;
  font-size: 60px;
  line-height: 1em;
  bottom: -8px;
  right: 8px;
  z-index: 10;
}
.comment_window:after {
  display: none;
}
.comment_window .title {
  color:#ff3e84;
}
.comment_window .title span {
  font-size: 80%;
}
.comment_window .text {
  padding:50px 90px 60px 90px;
}
.comment_window .question {
  text-align: left;
  font-size: 18px;
  line-height: 24px;
  margin-bottom: 15px;
  color: #7435b3;
}
.comment_window .answer {
  margin-bottom: 30px;
  font-size: 15px;
  line-height: 22px;
}
.comment_window .photo {
  width: 200px;
  height: 200px;
  border-radius: 100px;
  float: right;
  margin-left: 20px;
  margin-bottom: 20px;
  margin-right: -20px;
  margin-top: -10px;
  background-position: center center;
  background-size: 200px 200px;
  background-repeat: no-repeat;
}
.comment_window[data-comment] .text {
  background-position: left bottom;
  background-repeat: no-repeat;
  overflow: hidden;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
.comment_window[data-comment=inoue] .text {  background-image: url(../img/character/comment_bg_inoue.png);  }
.comment_window[data-comment=amamiya] .text {  background-image: url(../img/character/comment_bg_amamiya.png);  }
.comment_window[data-comment=kugimiya] .text {  background-image: url(../img/character/comment_bg_kugimiya.png);  }
.comment_window[data-comment=kotobuki] .text {  background-image: url(../img/character/comment_bg_kotobuki.png);  }
.comment_window[data-comment=tomatsu] .text {  background-image: url(../img/character/comment_bg_tomatsu.png);  }
.comment_window[data-comment=yoshida] .text {  background-image: url(../img/character/comment_bg_yoshida.png);  }

.comment_window[data-comment=inoue] .photo {  background-image: url(../img/character/comment_photo_inoue.jpg);  }
.comment_window[data-comment=amamiya] .photo {  background-image: url(../img/character/comment_photo_amamiya.jpg);  }
.comment_window[data-comment=kugimiya] .photo {  background-image: url(../img/character/comment_photo_kugimiya.jpg);  }
.comment_window[data-comment=kotobuki] .photo {  background-image: url(../img/character/comment_photo_kotobuki.jpg);  }
.comment_window[data-comment=tomatsu] .photo {  background-image: url(../img/character/comment_photo_tomatsu.jpg);  }
.comment_window[data-comment=yoshida] .photo {  background-image: url(../img/character/comment_photo_yoshida.jpg);  }