@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: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q,
blockquote {
  quotes: none;
}

q:before,
q:after,
blockquote:before,
blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

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

@charset "UTF-8";

body {
  font-family: "Helvetica Neue", Helvetica, Arial, "\30D2\30E9\30AE\30CE\89D2\30B4   ProN W3", "Hiragino Kaku Gothic ProN", "\30E1\30A4\30EA\30AA", Meiryo, sans-serif;
  -webkit-text-size-adjust: 100%;
}

main {
  display: block;
}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}

iframe[name="google_conversion_frame"] {
  position: absolute;
  height: 0;
  width: 0;
}

.disp-none {
  display: none;
}

.container {
  position: relative;
  z-index: 100;
  overflow: hidden;
}

a {
  display: inline-block;
}

.fancybox-inner {
  overflow: hidden !important;
}

.v-pc {
  display: inline-block;
}

.v-sp {
  display: none;
}

.fancybox-container .fancybox-close-small {
    background: url(../../resources/img/top/close_btn_9d6141e820ef3786d7b4ef2df1d67607.png) no-repeat;
    width: 246px;
    height: 47px;
    top: -55px;
    right: 0;
  }

.fancybox-container .fancybox-close-small:after {
      content: none;
    }

.to-top-btn {
  display: none;
  background: url(../../resources/img/common/to_top_btn/base_6ff71de8160dffe317b147e7a5eaea39.png) no-repeat;
  width: 91px;
  height: 53px;
  position: fixed;
  bottom: 84px;
  right: 91px;
  z-index: 100;
}

.to-top-btn > canvas {
    width: 190px;
    position: absolute;
    top: -136px;
    left: -10px;
  }

.to-top-btn .clickable-area {
    position: absolute;
    top: -10px;
    left: 54px;
    width: 64px;
    height: 128px;
  }

.cursor-deco {
  width: 97px;
  height: 97px;
  position: fixed;
  pointer-events: none;
  z-index: 1000;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.cursor-deco img {
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
  }

.cursor-deco .deco2 {
    -webkit-animation: cursorClockwise 5s linear infinite;
            animation: cursorClockwise 5s linear infinite;
  }

.cursor-deco .deco3 {
    -webkit-animation: cursorAnticlockwise 3s linear infinite;
            animation: cursorAnticlockwise 3s linear infinite;
  }

@-webkit-keyframes blink {
  0% {
    opacity: 1;
  }

  50% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes blink {
  0% {
    opacity: 1;
  }

  50% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes blink08 {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 0.8;
  }

  100% {
    opacity: 0;
  }
}

@keyframes blink08 {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 0.8;
  }

  100% {
    opacity: 0;
  }
}

@-webkit-keyframes cursorClockwise {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }

  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes cursorClockwise {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }

  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@-webkit-keyframes cursorAnticlockwise {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }

  100% {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}

@keyframes cursorAnticlockwise {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }

  100% {
    -webkit-transform: rotate(-360deg);
            transform: rotate(-360deg);
  }
}

@-webkit-keyframes balloonAnimation {
  8.5% {
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }

  16.5% {
    -webkit-transform: translateY(-6px);
            transform: translateY(-6px);
  }

  25% {
    -webkit-transform: translateY(4px);
            transform: translateY(4px);
  }

  33.2% {
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
  }

  41% {
    -webkit-transform: translateY(1px);
            transform: translateY(1px);
  }

  50% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }

  100%,
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes balloonAnimation {
  8.5% {
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }

  16.5% {
    -webkit-transform: translateY(-6px);
            transform: translateY(-6px);
  }

  25% {
    -webkit-transform: translateY(4px);
            transform: translateY(4px);
  }

  33.2% {
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
  }

  41% {
    -webkit-transform: translateY(1px);
            transform: translateY(1px);
  }

  50% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }

  100%,
  to {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@-webkit-keyframes fuwafuwa {
  0% {
    top: 0;
  }

  25% {
    -webkit-transform: translate(0, 5px);
            transform: translate(0, 5px);
  }

  75% {
    -webkit-transform: translate(0, -5px);
            transform: translate(0, -5px);
  }

  100% {
    top: 0;
  }
}

@keyframes fuwafuwa {
  0% {
    top: 0;
  }

  25% {
    -webkit-transform: translate(0, 5px);
            transform: translate(0, 5px);
  }

  75% {
    -webkit-transform: translate(0, -5px);
            transform: translate(0, -5px);
  }

  100% {
    top: 0;
  }
}

@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate(-100px, 0);
            transform: translate(-100px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate(-100px, 0);
            transform: translate(-100px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate(100px, 0);
            transform: translate(100px, 0);
  }
}

@keyframes fadeOutRight {
  from {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate(100px, 0);
            transform: translate(100px, 0);
  }
}

.wrapper {
  width: 640px;
  position: relative;
  margin: auto;
}

header a, section a {
    -webkit-transition-duration: 0.5s;
            transition-duration: 0.5s;
  }

header a:hover, section a:hover {
      -webkit-transform: scale(1.1);
              transform: scale(1.1);
      -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
              transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
    }

header {
  height: 830px;
}

header .header-bg {
    background:
      url(../../resources/img/comic/common/bg_side_749ee6f91f32dcb72ad73b5c341b5e42.png) repeat-y center top,
      url(../../resources/img/comic/common/header_bg_d7b42bb1cfe29b89713e80e18c50ab5a.jpg) no-repeat center top;
    width: 100%;
    height: 830px;
    position: absolute;
    top: 0;
    left: 0;
  }

header .float-bnr-box {
    position: absolute;
    top: 530px;
    right: 10px;
    z-index: 5;
  }

header .float-bnr-box.run {
      position: fixed;
      top: 50px;
    }

header .float-bnr-box .float-bnr-order {
      background: url(../../resources/img/comic/common/float_bnr_order_2a3db0c4a2cd5740ea155229664a82cb.png) no-repeat;
      width: 389px;
      height: 182px;
    }

header h1 {
    padding-top: 27px;
    margin-left: 28px;
    position: relative;
  }

header .header-illust {
    margin: -91px 0 0 -116px;
  }

footer {
  background: #000;
  padding: 25px 0 16px;
}

footer a {
    position: relative;
    display: inline-block;
  }

footer .atlus-logo {
    background: url(../../resources/img/common/atlus_logo_836a62399f2dcd5b215bee11523feb2a.png) no-repeat;
    width: 130px;
    height: 39px;

    top: -7px;
    margin-left: 29px;
    margin-right: 15px;
  }

footer .vanillaware-logo {
    background: url(../../resources/img/common/vanillaware_logo_c9e476bbabb0b4cc5d91da71e8343a41.png) no-repeat;
    width: 71px;
    height: 58px;

    margin-right: 160px;
  }

footer .copyright {
    font-size: 13px;
    display: inline-block;
    position: relative;
    top: -19px;
    color: #fff;
  }

.jump-vol1-btn {
  background: url(../../resources/img/comic/common/btn_vol1_d05c81d7f94345392a20c4a638a0a47e.png) no-repeat;
  width: 610px;
  height: 259px;

  margin-left: 19px;
}

.jump-vol2-btn {
  background: url(../../resources/img/comic/common/btn_vol2_9924b8cccd1353a5ad0137e953d469f2.png) no-repeat;
  width: 646px;
  height: 290px;

  margin-left: -17px;
}

.dlc-info {
  position: relative;
  margin-left: -41px;
}

.dlc-info .event-btn {
    background: url(../../resources/img/comic/common/dlc_btn_event_fdb172c5f913002e4f0c0e408fdf5b2d.png) no-repeat;
    width: 354px;
    height: 91px;

    position: absolute;
    top: 553px;
    left: 183px;
  }

.dlc-info .order-btn {
    background: url(../../resources/img/comic/common/dlc_btn_order_a2305984d35278df4f3bf9a537a50659.png) no-repeat;
    width: 411px;
    height: 101px;

    position: absolute;
    top: 691px;
    left: 154px;
  }

.sns-btn {
  padding: 0 162px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.sns-btn .twitter-btn {
    background: url(../../resources/img/comic/common/btn_sns_twitter_a582cf4a3188e20275eb32e0e1968cfb.png) no-repeat;
    width: 88px;
    height: 88px;
  }

.sns-btn .facebook-btn {
    background: url(../../resources/img/comic/common/btn_sns_facebook_7ee1a5e6da07282e910cc48604933aa8.png) no-repeat;
    width: 88px;
    height: 88px;
  }

.sns-btn .line-btn {
    background: url(../../resources/img/comic/common/btn_sns_line_538b1dd075e5d2180e134dea5dced94f.png) no-repeat;
    width: 87px;
    height: 88px;
  }

.comic-info {
  background:
    url(../../resources/img/comic/common/bg_side_749ee6f91f32dcb72ad73b5c341b5e42.png) repeat-y center top,
    url(../../resources/img/comic/top/about_header_74b65412965baf7ac9b979ae577471f7.png) no-repeat center bottom,
    url(../../resources/img/comic/top/s2_bg_c0c8b2f010780f5dd4f2054109531d02.jpg) no-repeat center top 115px;
  height: 2052px;
}

.comic-info .summary {
    margin: -115px 0 45px -46px;
  }

.comic-info .jump-vol1-btn {
    margin-top: -15px;
  }

.comic-info .jump-vol2-btn {
    margin-top: -16px;
  }

.comic-info .profile {
    margin: 70px 0 0 23px;
  }

.game-info {
  background:
    url(../../resources/img/comic/common/bg_side_749ee6f91f32dcb72ad73b5c341b5e42.png) repeat-y center top,
    url(../../resources/img/comic/common/bg_pattern_2d24a37d649fcf8ceeee5a16cf65fb6a.png) repeat-y center top;
  margin-top: -2px;
  padding-bottom: 31px;
  position: relative;
}

.game-info h2 {
    margin-left: -159px;
    position: relative;
    z-index: 2;
  }

.game-info .about-kv {
    position: absolute;
    top: 13px;
    left: -16px;
  }

.game-info .about-logo {
    margin: 547px 0 0 95px;
    position: relative;
  }

.game-info .about-text {
    margin: 50px 0 0 2px;
    position: relative;
  }

.game-info .about-pv {
    background: url(../../resources/img/comic/top/about_pv_a69404c7c2ed1dee135ef89f4923d83a.png) no-repeat;
    width: 569px;
    height: 357px;

    margin: 31px 0 0 38px;
  }

.game-info .dlc-info {
    margin-top: 37px;
  }

.game-info .btn-official {
    background: url(../../resources/img/comic/top/btn_official_b89b5db20b33a02a9594a54723391a1b.png) no-repeat;
    width: 630px;
    height: 143px;

    margin: 45px auto 0;
  }

.game-info .sns-btn {
    margin-top: 29px;
  }

.comic-body {
  text-align: center;
  padding-bottom: 10px;
  background:
    url(../../resources/img/comic/common/bg_side_749ee6f91f32dcb72ad73b5c341b5e42.png) repeat-y center top,
    url(../../resources/img/comic/sub/bg_07032999d515218adbe788b42c7f050c.jpg) repeat-y center top;
}

.comic-body h2 {
    margin: -60px 0 0 -3px;
  }

.comic-body .comic-pages {
    width: 608px;
    margin: 16px auto 0;
    background: #fff;
  }

.comic-body .comic-pages li {
      margin: 0 auto;
    }

.comic-body .comic-pages li + li {
      margin-top: 11px;
    }

.comic-body .comic-comment {
    margin: -3px 0 23px -36px;
  }

.sub-game-info {
  background:
    url(../../resources/img/comic/common/bg_side_749ee6f91f32dcb72ad73b5c341b5e42.png) repeat-y center top,
    url(../../resources/img/comic/sub/bg_bottom_4126acfce285e3e5b3e82bd652d9c700.png) no-repeat center top,
    url(../../resources/img/comic/common/bg_pattern_2d24a37d649fcf8ceeee5a16cf65fb6a.png) repeat-y center top;
  padding-bottom: 41px;
  text-align: center;
}

.sub-game-info .jump-vol1-btn {
    margin-top: 41px;
  }

.sub-game-info .jump-vol2-btn {
    margin-top: 10px;
  }

.sub-game-info .dlc-info {
    margin-top: 58px;
  }

.sub-game-info .btn-comic-top {
    background: url(../../resources/img/comic/sub/btn_comic_top_42c8590a64edc77f8dd468951e50b329.png) no-repeat;
    width: 534px;
    height: 118px;

    margin: 45px auto 0;
  }

@media screen and (min-width: 641px) {
  .hover {
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }

    .hover:hover {
      opacity: 0.8;
    }

  .hover-shop {
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }

    .hover-shop:hover {
      -webkit-transform: scale(1.05);
              transform: scale(1.05);
    }
}

@media screen and (max-width: 640px) {
  .v-pc {
    display: none;
  }

  .v-sp {
    display: inline-block;
  }

  .wrapper {
    width: 640px;
  }
      .fancybox-container .fancybox-slide--iframe.fancybox-slide--video .fancybox-content {
        width: 640px;
        height: 330px;
        max-width: 100%;
      }

  .to-top-btn {
    right: 50px;
    bottom: 150px;
  }
    header a, section a {
      -webkit-transition-duration: 0;
              transition-duration: 0;
    }

      header a:hover, section a:hover {
        -webkit-transform: none;
                transform: none;
        -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
                transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
      }
    header .float-bnr-box {
      position: fixed;
      top: auto;
      right: 0;
      bottom: -7px;
    }

      header .float-bnr-box.run {
        top: -18px;
        bottom: auto;
      }

      header .float-bnr-box .float-bnr-order {
        background: url(../../resources/img/comic/common/float_bnr_order_sp_fb1f4f88b6a0c655af54a36aac7f5d61.png) no-repeat;
        width: 639px;
        height: 114px;
      }
}
