@charset "UTF-8";
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 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  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; }

body {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  font-family: "Helvetica Neue", Helvetica, Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.75; }

*, *:before, *:after {
  box-sizing: border-box; }

a {
  outline: none;
  text-decoration: none; }

img {
  vertical-align: top; }

body, html {
  width: 100%;
  height: 100%; }

body {
  background-color: #fff100;
  font-family: "游ゴシック", "YuGothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", sans-serif;
  font-weight: normal; }

.yellow {
  background-color: #fff100; }

.black {
  background-color: #000000; }

.white {
  background-color: #FFFFFF; }

.l-wrapper {
  width: 100%;
  height: 100%;
  min-width: 1130px; }

.l-container {
  width: 1130px;
  position: relative;
  margin: 0 auto;
  zoom: 1; }
  .l-container:after {
    content: "";
    clear: both;
    display: block; }

.l-inner {
  width: 1130px;
  position: relative;
  margin: 0 auto;
  zoom: 1; }
  .l-inner:after {
    content: "";
    clear: both;
    display: block; }

#googlecode {
  position: fixed;
  left: 0;
  top: -500px;
  z-index: 0; }

@font-face {
  font-family: "pr-regular";
  src: url("/common_teaser/fonts/sub-webfont.eot");
  src: url("/common_teaser/fonts/sub-webfont.eot?#iefix") format("embedded-opentype"), url("/common_teaser/fonts/sub-webfont.woff2") format("woff2"), url("/common_teaser/fonts/sub-webfont.woff") format("woff"), url("/common_teaser/fonts/sub-webfont.ttf") format("truetype"), url("/common_teaser/fonts/sub-webfont.svg#websubsetfontregular") format("svg");
  font-weight: normal;
  font-style: normal; }
.font-min {
  font-family: "游明朝", "YuMincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif; }

.mouse_none {
  pointer-events: none; }

.l-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden; }

#cover {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 2;
  background-color: #fff100; }

#chara_bg {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0; }

#chara_bg_c {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1; }

#underIE8 {
  display: none;
  position: relative;
  width: 100%;
  height: 100%;
  background: url("/common_teaser/images/ie8_bg.png") center center repeat; }
  #underIE8 .underIE8_alert {
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -283px 0 0 -380px;
    z-index: 1; }
  #underIE8 .underIE8_copyright {
    position: fixed;
    left: 0;
    bottom: 10px;
    text-align: right;
    width: 100%;
    font-size: 10px;
    padding: 0 20px 0 0; }

.bg_shiki {
  background: url("/common_teaser/images/shiki_bg.png") center center no-repeat; }

.bg_moe {
  background: url("/common_teaser/images/moe_bg.png") center center no-repeat; }

.bg_moe_c {
  background: url("/common_teaser/images/moe_bg_chara.png") center center no-repeat; }

.bg_saikawa {
  background: url("/common_teaser/images/saikawa_bg.png") center center no-repeat; }

.bg_saikawa_c {
  background: url("/common_teaser/images/saikawa_bg_chara.png") center center no-repeat; }

#stage1, #stage2, #stage3, #stage4, #stage5, #stage6 {
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -400px 0 0 -720px; }

#stage2, #stage3, #stage4, #stage5, #stage6 {
  display: none; }

#chara_prof {
  width: 1440px;
  height: 800px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -400px 0 0 -720px;
  z-index: 1; }
  #chara_prof .prof_saikawa {
    position: absolute;
    left: 654px;
    top: 335px;
    z-index: 1;
    display: none;
    overflow: hidden; }
  #chara_prof .prof_moe {
    position: absolute;
    left: 684px;
    top: 79px;
    z-index: 1;
    display: none;
    overflow: hidden; }
  #chara_prof .prof_shiki {
    position: absolute;
    left: 1021px;
    top: 341px;
    z-index: 1;
    display: none;
    overflow: hidden; }

.l-side {
  width: 270px;
  height: 100%;
  position: absolute;
  z-index: 20; }

.side_wrap {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 30px 0 0 0; }

#loader {
  position: fixed;
  left: 50px;
  top: 20px;
  z-index: 100;
  width: 100%;
  height: 100%;
  background-color: #fff100; }
  #loader p {
    margin: 0 0 -5px 0; }
  #loader span {
    background-color: #000000;
    color: #FFFFFF;
    font-family: "pr-regular";
    letter-spacing: 0.2em;
    font-size: 13px;
    line-height: 15px;
    height: 15px;
    padding: 0 5px;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    display: none; }

#side_news {
  width: 24px !important;
  height: 100%;
  position: fixed;
  z-index: 2;
  background-color: #FFF;
  left: 0;
  top: 0;
  display: none; }
  #side_news .title {
    background-color: #000000;
    color: #FFFFFF;
    font-family: "pr-regular";
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    font-size: 16px;
    line-height: 24px;
    padding: 15px 0;
    letter-spacing: 0.2em;
    display: inline-block;
    writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -o-writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl; }
  #side_news .detail {
    writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -o-writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    font-size: 10px;
    position: absolute;
    right: 5px;
    top: 85px;
    z-index: 0; }
  #side_news li {
    overflow: hidden;
    white-space: nowrap;
    margin: 0 0 0 15px;
    display: none; }
  #side_news a:link, #side_news a:visited {
    text-decoration: none;
    color: #000000; }
  #side_news a:hover, #side_news a:active {
    text-decoration: none;
    color: #999999; }

.menu {
  width: 185px;
  margin: 0 0 0 50px;
  display: none; }
  .menu li {
    margin: 0 0 2px 0;
    font-family: "pr-regular";
    display: block;
    vertical-align: top; }
  .menu a {
    display: block;
    height: 15px;
    line-height: 15px;
    text-decoration: none;
    margin: 0 0 -6px 0;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none; }
  .menu .name {
    background-color: #000000;
    display: inline-block;
    padding: 0 5px;
    color: #FFFFFF;
    letter-spacing: 0.2em;
    vertical-align: top;
    font-size: 13px;
    line-height: 15px;
    height: 15px; }
  .menu .sub {
    display: inline-block;
    font-size: 10px;
    line-height: 12px;
    height: 12px;
    padding: 0 5px;
    color: #000000;
    background-color: #FFFFFF; }
  .menu .second {
    margin: 10px 0 -10px 0;
    display: none; }
    .menu .second a {
      margin: 0; }

.sns {
  margin: 20px 0 0 50px;
  letter-spacing: -0.4em;
  display: none; }
  .sns li {
    letter-spacing: normal;
    display: inline-block;
    margin: 0 10px 0 0; }
  .sns .sns_line {
    display: none; }

h1 {
  position: absolute;
  left: 0;
  bottom: 90px;
  width: 0%;
  overflow: hidden; }

h2 {
  position: absolute;
  left: 48px;
  bottom: 40px;
  width: 0%;
  overflow: hidden; }

.copyright {
  position: absolute;
  left: 50px;
  bottom: 5px;
  width: 266px;
  display: none; }

/* 萌絵 */
.edgeLoad-EDGE-22565583 {
  visibility: hidden; }

/* 犀川 */
.edgeLoad-EDGE-23962846 {
  visibility: hidden; }

/* 四季 */
.edgeLoad-EDGE-29721197 {
  visibility: hidden; }

.edgeLoad-EDGE-141538611 {
  visibility: hidden; }

.edgeLoad-EDGE-149885805 {
  visibility: hidden; }

.edgeLoad-EDGE-178704609 {
  visibility: hidden; }

#ovarlay {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 10;
  background: url("/common_teaser/images/bg_cover2.png") center center repeat;
  width: 100%;
  height: 100%;
  display: none; }

.overlay_wrap {
  position: relative;
  width: 100%;
  height: 100%; }

.close_btn {
  position: absolute;
  top: 0px;
  20: 0px;
  z-index: left;
  left: 100%;
  margin: 0 0 0 -75px;
  display: none; }

#story {
  width: 540px;
  height: 520px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -265px 0 0 -275px;
  z-index: 0;
  display: none; }
  #story h3 {
    font-family: "pr-regular";
    font-size: 16px;
    letter-spacing: 0.15em;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    color: #FFFFFF;
    margin: 0 0 50px 0;
    height: 20px;
    overflow: hidden; }
  #story .story_text {
    margin: 0 0 35px 0; }
    #story .story_text p {
      margin: 0 0 2px 0;
      overflow: hidden; }
  #story .story_copy p {
    margin: 0 0 15px 0;
    overflow: hidden; }

#staff {
  width: 660px;
  height: 520px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -265px 0 0 -250px;
  z-index: 0;
  display: none; }
  #staff h3 {
    font-family: "pr-regular";
    font-size: 16px;
    letter-spacing: 0.15em;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    color: #FFFFFF;
    margin: 0 0 50px 0;
    height: 20px;
    overflow: hidden; }
  #staff .staff_detail {
    color: #FFFFFF;
    font-size: 14px;
    letter-spacing: 0.08em;
    line-height: 30px;
    overflow: hidden;
    white-space: nowrap;
    width: 100%; }
    #staff .staff_detail dl {
      zoom: 1;
      width: 660px; }
      #staff .staff_detail dl:after {
        content: "";
        clear: both;
        display: block; }
    #staff .staff_detail dt {
      width: 150px;
      float: left; }
    #staff .staff_detail dd {
      width: 500px;
      float: right; }

#movie {
  width: 860px;
  height: 560px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -320px 0 0 -350px;
  z-index: 0;
  display: none; }
  #movie h3 {
    font-family: "pr-regular";
    font-size: 16px;
    letter-spacing: 0.15em;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    color: #FFFFFF;
    margin: 0 0 50px 0;
    height: 20px;
    overflow: hidden; }
  #movie .movie_detail {
    overflow: hidden; }

#special {
  width: 540px;
  height: 560px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -320px 0 0 -270px;
  z-index: 0;
  display: none; }
  #special h3 {
    font-family: "pr-regular";
    font-size: 16px;
    letter-spacing: 0.15em;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    color: #FFFFFF;
    margin: 0 0 50px 0;
    height: 20px;
    overflow: hidden; }
  #special .special_detail {
    color: #FFFFFF;
    overflow: hidden; }
  #special .special_poster {
    margin: 0 0 0 100px; }

#news {
  width: 700px;
  height: 100%;
  margin: 0 auto;
  display: none;
  overflow: auto; }
  #news h3 {
    font-family: "pr-regular";
    font-size: 16px;
    letter-spacing: 0.15em;
    -webkit-font-smoothing: none;
    -moz-osx-font-smoothing: none;
    color: #FFFFFF;
    margin: 50px 0;
    height: 20px;
    overflow: hidden; }
  #news .news_detail {
    color: #FFFFFF;
    font-size: 12px;
    line-height: 2em;
    letter-spacing: 0.05em;
    padding: 0 30px 50px 0; }
  #news .news_box {
    border-bottom: solid 1px #FFFFFF;
    padding: 0 0 30px 0;
    margin: 0 0 30px 0; }
  #news .news_date {
    font-size: 10px; }
  #news .news_title {
    font-size: 16px;
    margin: 0 0 15px 0; }
  #news a:link, #news a:visited {
    color: #FFFFFF;
    text-decoration: underline; }
  #news a:hover, #news a:active {
    color: #999999;
    text-decoration: none; }

.pc_only {
  display: block; }

.sp_only {
  display: none; }

.sp .pc_only {
  display: none; }
.sp .sp_only {
  display: block; }
.sp #loader p {
  margin: 0 0 5px 0; }
.sp #loader span {
  letter-spacing: 0;
  font-size: 64px;
  line-height: 64px;
  height: 64px; }
.sp #side_news {
  width: 50px !important; }
  .sp #side_news .title {
    font-size: 34px;
    line-height: 50px;
    letter-spacing: 0; }
  .sp #side_news .detail {
    font-size: 30px;
    position: absolute;
    right: 5px;
    top: 140px;
    z-index: 0; }
  .sp #side_news li {
    margin: 0 0 0 15px;
    display: none; }
.sp .l-wrapper {
  width: 1440px;
  overflow: auto; }
.sp #cover {
  width: 100%; }
.sp #chara_bg {
  width: 1440px; }
.sp #chara_bg_c {
  width: 1440px; }
.sp #ovarlay {
  position: absolute; }
.sp .l-side {
  width: 700px; }
.sp .menu {
  width: 700px;
  margin: 0 0 0 80px;
  display: none; }
  .sp .menu li {
    margin: 0 0 10px 0; }
  .sp .menu a {
    height: 64px;
    line-height: 64px;
    margin: 0 0 5px 0; }
  .sp .menu .name {
    letter-spacing: 0;
    font-size: 60px;
    line-height: 60px;
    height: 60px; }
  .sp .menu .sub {
    font-size: 30px;
    line-height: 30px;
    height: 30px; }
.sp .sns {
  margin-top: 50px;
  margin-left: 80px; }
  .sp .sns li img {
    width: 120px;
    height: auto; }
  .sp .sns .sns_line {
    display: inline-block; }
.sp h1 {
  bottom: 190px;
  left: 30px; }
  .sp h1 img {
    width: 500px;
    height: auto; }
.sp h2 {
  left: 78px;
  bottom: 80px; }
  .sp h2 img {
    width: 450px;
    height: auto; }
.sp .copyright {
  font-size: 30px;
  width: 700px;
  margin-left: 30px; }
.sp .close_btn {
  position: absolute;
  top: 0px;
  20: 0px;
  z-index: left;
  margin-left: -150px !important; }
  .sp .close_btn img {
    width: 150px;
    height: auto; }
.sp #story {
  width: 650px;
  height: auto;
  position: relative;
  left: none;
  top: none;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  margin: 0 0 0 550px;
  padding: 200px 0 0 0;
  font-size: 30px; }
  .sp #story h3 {
    font-family: "pr-regular";
    font-size: 60px;
    line-height: 70px;
    height: 70px;
    letter-spacing: 0;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
    margin: 0 0 50px 0; }
  .sp #story .story_text p img {
    height: 15px;
    width: auto; }
  .sp #story .story_copy p img {
    height: 60px;
    width: auto; }
.sp #staff {
  width: 650px;
  height: auto;
  position: relative;
  left: none;
  top: none;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  margin: 0 0 0 550px;
  padding: 200px 0 0 0;
  font-size: 30px; }
  .sp #staff h3 {
    font-family: "pr-regular";
    font-size: 60px;
    line-height: 70px;
    height: 70px;
    letter-spacing: 0;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
    margin: 0 0 50px 0; }
  .sp #staff .staff_detail {
    font-size: 30px;
    letter-spacing: 0;
    line-height: 1.6em;
    white-space: normal; }
    .sp #staff .staff_detail dl {
      zoom: 1;
      width: 100%; }
      .sp #staff .staff_detail dl:after {
        content: "";
        clear: both;
        display: block; }
    .sp #staff .staff_detail dt {
      float: none;
      font-weight: bold;
      width: auto; }
    .sp #staff .staff_detail dd {
      float: none;
      width: auto;
      margin: 0 0 30px 0; }
      .sp #staff .staff_detail dd .font-min {
        font-size: 42px;
        font-weight: bold; }
.sp #movie {
  width: 650px;
  height: auto;
  position: relative;
  left: none;
  top: none;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  margin: 0 0 0 550px;
  padding: 200px 0 0 0;
  font-size: 30px; }
  .sp #movie h3 {
    font-family: "pr-regular";
    font-size: 60px;
    line-height: 70px;
    height: 70px;
    letter-spacing: 0;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
    margin: 0 0 50px 0; }
  .sp #movie .movie_detail {
    overflow: auto; }
.sp #special {
  width: 650px;
  height: auto;
  position: relative;
  left: none;
  top: none;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  margin: 0 0 0 550px;
  padding: 200px 0 0 0;
  font-size: 30px; }
  .sp #special h3 {
    font-family: "pr-regular";
    font-size: 60px;
    line-height: 70px;
    height: 70px;
    letter-spacing: 0;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
    margin: 0 0 50px 0; }
.sp #news {
  width: 650px;
  height: auto;
  position: relative;
  left: none;
  top: none;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  margin: 0 0 0 550px;
  padding: 200px 0 0 0;
  font-size: 30px; }
  .sp #news h3 {
    font-family: "pr-regular";
    font-size: 60px;
    line-height: 70px;
    height: 70px;
    letter-spacing: 0;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
    margin: 0 0 50px 0; }
  .sp #news .news_detail {
    color: #FFFFFF;
    font-size: 40px;
    line-height: 1.6em;
    letter-spacing: 0;
    width: 100%; }
  .sp #news .news_date {
    font-size: 30px; }
  .sp #news .news_title {
    font-size: 50px; }
