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;
    border: none;
    outline: none;
}
video{
    filter: drop-shadow(0px 0px rgba(0, 0, 0, 0));
}
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
}

body {
    font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    font-size: 14px;
    color: #000;
    position: relative
}

* {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    outline: none
}

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

a:hover img:not(.ov) {
    transition: opacity 0.3s;
    opacity: 0.7
}

sub {
    vertical-align: sub
}

sup {
    vertical-align: super
}

.disp-none {
    display: none
}

.clearfix {
    *zoom: 1
}

.clearfix:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

.v-pc {
    display: inline-block
}

.v-sp {
    display: none
}

@media (max-width: 640px) {
    html,
    body {
        min-width: 640px;
        width: 100%
    }
    body {
        -webkit-text-size-adjust: 100%
    }
    * {
        box-sizing: border-box
    }
    .v-pc {
        display: none
    }
    .v-sp {
        display: inline-block;
        text-align: center;
        margin: 15px auto
    }
    img {
        max-width: 100vw
    }
    a:hover img:not(.ov) {
        transition: none;
        opacity: 1
    }
}

.pankuzu {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    .pankuzu {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

.pankuzu li {
    display: inline;
    color: #fff
}

.pankuzu li a {
    color: #fff
}

.pankuzu li:after {
    content: " ＞ ";
    display: inline
}

.pankuzu li:last-child {
    text-decoration: underline
}

.pankuzu li:last-child:after {
    display: none
}

@media (max-width: 640px) {
    .pankuzu {
        display: none
    }
}

.to-top-btn {
    display: none;
    background: url("../img/common/to_top_btn.png") no-repeat;
    width: 67px;
    height: 68px;
    position: fixed;
    right: 21px;
    bottom: 158px;
    z-index: 100
}

@media (max-width: 640px) {
    .to-top-btn {
        bottom: 90px
    }
}

.jspContainer {
    overflow: hidden;
    position: relative
}

.jspPane {
    position: absolute
}

.jspVerticalBar {
    position: absolute;
    top: 0;
    right: 0;
    width: 16px;
    height: 100%;
    background: red
}

.jspHorizontalBar {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 16px;
    background: red
}

.jspCap {
    display: none
}

.jspHorizontalBar .jspCap {
    float: left
}

.jspTrack {
    background: #dde;
    position: relative
}

.jspDrag {
    background: #bbd;
    position: relative;
    top: 0;
    left: 0;
    cursor: pointer
}

.jspHorizontalBar .jspTrack,
.jspHorizontalBar .jspDrag {
    float: left;
    height: 100%
}

.jspArrow {
    background: #50506d;
    text-indent: -20000px;
    display: block;
    cursor: pointer;
    padding: 0;
    margin: 0
}

.jspArrow.jspDisabled {
    cursor: default;
    background: #80808d
}

.jspVerticalBar .jspArrow {
    height: 16px
}

.jspHorizontalBar .jspArrow {
    width: 16px;
    float: left;
    height: 100%
}

.jspVerticalBar .jspArrow:focus {
    outline: none
}

.jspCorner {
    background: #eeeef4;
    float: left;
    height: 100%
}

.jspVerticalBar {
    width: 5px;
    background: transparent
}

.jspVerticalBar .jspTrack {
    background: transparent
}

.jspDrag {
    background: #dda60b
}

* html .jspCorner {
    margin: 0 -3px 0 0
}

.header {
    overflow: hidden;
    *zoom: 1;
    background: url(../img/common/bg_header.png) center top no-repeat;
    background-size: cover
}

.header__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    .header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

.header__logo {
    float: left;
    margin: 4px 0 5px
}

.header__hard {
    float: right;
    margin-top: 26px
}

.header-l {
    width: 100%;
    height: 121px;
    background: url(../img/common/header_extention_bg.png) center top repeat-x;
    position: relative;
    top: 0;
    left: 0;
    z-index: 102;
}

.header-l__extention {
    background: url(../img/common/header_bg.png) center top no-repeat
}

.header-l__top {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden;
    margin-bottom: 3px
}

@media (max-width: 640px) {
    .header-l__top {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

.header-l__reserve {
    float: left;
    height: 50px
}

.header-l__hard {
    float: right;
    margin-top: 10px
}

.header-l__nav {
    background: url(../img/common/header_nav_bg.png) center top no-repeat #000;
    overflow: hidden
}

.header-l__nav__wrap {
    width: 1024px;
    margin: 0 auto;
    padding-left: 40px
}

@media (max-width: 640px) {
    .header-l__nav__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

.header-l__nav li {
    position: relative;
    float: left;
    height: 52px;
    margin-right: 5px
}

.header-l__nav li.is-active a {
    background: radial-gradient(circle 40px at bottom center, rgba(163, 141, 31, 0.7), rgba(0, 0, 0, 0)), linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(125, 98, 17, 0.7) 15%, rgba(125, 98, 17, 0.7) 85%, rgba(0, 0, 0, 0))
}

.header-l__nav li:last-child {
    margin-right: 0
}

.header-l__nav a {
    display: block;
    height: 52px;
    padding-top: 18px
}

.header-l__nav--cs {
    padding-top: 18px
}

.header-l__nav--new:after {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 20px;
    width: 35px;
    height: 12px;
    background: url(../img/common/header_ico_new.png) left top no-repeat
}

.header-l__nav img {
    display: block;
    margin: 0 20px
}

.header-l__nav img.v-sp {
    display: none
}

@media (max-width: 640px) {
    .header-l {
        background: none;
        z-index: 907;
        position:relative;
        top: auto;
        left: auto;
        height: auto;
		display:inline-block;
		width: 100%;
		border-top: solid 1px  #F8A90E;
		margin-bottom: -9px;
		
    }
    .header-l__wrap {
        padding: 0 0
    }
    .header-l__top {
        background: url(../img/common/sp/header_bg.png) center top repeat-x;
        position: relative;
        top: 0;
        left: 0;
        padding: 0 0;
        width: 100%;
        height: 100px;
        z-index: 905;
        overflow: visible
    }
    .header-l__extention {
        background: none;
    }
    .header-l__reserve {
        float: left;
        height: auto;
       /* margin-top: 14px*/
    }
    .header-l__hard {
        margin-top: 18px;
        float: left
    }
    .header-l__menu {
        float: none;
        display: block;
        margin-right: 16px;
        position: fixed;
       /* top: 14px;*/
        right: 0
    }
    .header-l__nav {
        display: none;
        position: fixed;
        top: 94px;
        right: 0;
        z-index: 904;
        width: 512px;
        background: rgba(0, 0, 0, 0.9)
    }
    .header-l__nav__wrap {
        padding: 0 0
    }
    .header-l__nav.open {
        display: block
    }
    .header-l__nav img.v-pc {
        display: none
    }
    .header-l__nav img.v-sp {
        display: inline
    }
    .header-l__nav--cs {
        height: auto;
        display: block;
        padding: 20px 0
    }
    .header-l__nav--new:after {
        content: "";
        display: block;
        position: absolute;
        top: 24px;
        left: 26px;
        width: 76px;
        height: 25px;
        background: url(../img/common/sp/header_ico_new.png) left top no-repeat
    }
    .header-l__nav--close {
        background: #302500
    }
    .header-l__nav--close a {
        text-align: right;
        padding-right: 20px !important
    }
    .header-l__nav li {
        width: 100%;
        float: none;
        border-bottom: 1px solid #5c5c5c;
        text-align: center;
        height: auto;
        margin-right: 0
    }
    .header-l__nav li a {
        height: auto;
        display: block;
        padding: 20px 0
    }
    .header-l__nav li img {
        display: inline;
        margin: 0 0
    }
}

.spec-box {
    background: url("../img/common/footer_bg.jpg") no-repeat center top;
    padding: 43px 0;
    background-size: cover
}

.spec-box .wrapper {
    width: 976px;
    margin: auto;
    position: relative
}

.spec-box .footer-logo {
    float: left;
    margin: 0 40px 0 43px;
    position: relative;
    top: 8px
}

.spec-box .spec {
    float: left;
    width: 472px;
    position: relative;
    font-weight: bold
}

.spec-box .spec__title {
    border-bottom: 1px solid #fd8b25;
    margin-bottom: 16px
}

.spec-box .spec__title>div {
    padding-bottom: 8px;
    border-bottom: 1px solid #000000
}

.spec-box .spec__dl {
    overflow: hidden;
    *zoom: 1;
    line-height: 1.6;
    font-size: 16px
}
.spec-box .spec__dl a{
    text-decoration: underline;
    color: #0050fd;
}

.spec-box .spec__dl dt {
    width: 105px;
    float: left;
    clear: both
}

.spec-box .spec__dl dd {
    width: calc(100% - 105px);
    float: left
}

.spec-box .spec .cero {
    position: absolute;
    right: 0;
    bottom: 0
}

.spec-box .staff {
    width: 469px;
    float: right;
    font-weight: bold
}

.spec-box .staff__title {
    border-bottom: 1px solid #fd8b25;
    margin-bottom: 16px
}

.spec-box .staff__title>div {
    padding-bottom: 8px;
    border-bottom: 1px solid #000000
}

.spec-box .staff__dl {
    overflow: hidden;
    *zoom: 1;
    line-height: 1.6;
    font-size: 16px;
    letter-spacing: -1px
}

.spec-box .staff__dl dt {
    width: 268px;
    float: left;
    clear: both
}

.spec-box .staff__dl dd {
    width: calc(100% - 268px);
    float: left
}

.spec-box .price {
    clear: both;
    line-height: 1.6;
    font-weight: bold
}

.spec-box .price__title {
    margin-bottom: 5px;
    font-size: 16px
}

.spec-box .price__dl {
    font-size: 16px;
    overflow: hidden;
    *zoom: 1
}
.spec-box .price__dl .app_linkbanner a {
    display: inline-block;
    margin-right: 10px;
}
.spec-box .price__dl .app_linkbanner a img{
    height: 37px;
    width: auto;
    vertical-align: middle;
}

.spec-box .price__dl dt {
    color: #fff;
    float: left;
    width: 137px;
    font-size: 15px;
    background: url(../img/common/bg_footer_dt.png) left top no-repeat;
    height: 26px;
    line-height: 26px;
    text-align: center;
    clear: both;
    margin-bottom: 10px;
    text-indent: -5px
}

.spec-box .price__dl dd {
    float: left;
    width: calc(100% - 137px);
    margin-bottom: 10px
}

@media (max-width: 640px) {
    .spec-box {
        background: url("../img/common/sp/footer_bg.jpg") no-repeat center top;
        background-size: cover;
        padding: 30px 0 47px;
        text-align: center
    }
    .spec-box .wrapper {
        width: auto
    }
    .spec-box .footer-logo {
        margin: 0 0 43px 0;
        top: auto;
        left: 15px
    }
    .spec-box .footer-logo,
    .spec-box .spec {
        float: none
    }
    .spec-box .spec {
        float: none;
        width: auto;
        position: relative;
        padding: 0 10px;
        margin-bottom: 0px
    }
    .spec-box .spec__title {
        text-align: left;
        border-bottom: 1px solid #fd8b25;
        margin-bottom: 16px
    }
    .spec-box .spec__title>div {
        padding-bottom: 8px;
        border-bottom: 1px solid #000000
    }
    .spec-box .spec__dl {
        overflow: hidden;
        *zoom: 1;
        line-height: 1.6;
        font-size: 18px
    }
    .spec-box .spec__dl dt {
        width: 100px;
        float: left;
        clear: both;
        text-align: left;
        margin-bottom: 5px
    }
    .spec-box .spec__dl dd {
        width: auto;
        float: left;
        margin-bottom: 5px
    }
    .spec-box .spec .cero {
        position: absolute;
        right: 140px;
        bottom: 25px;
        text-align: left
    }
    .spec-box .staff {
        width: auto;
        float: none;
        padding: 0 10px;
        margin-bottom: 30px
    }
    .spec-box .staff__title {
        text-align: left;
        border-bottom: 1px solid #fd8b25;
        margin-bottom: 16px
    }
    .spec-box .staff__title>div {
        padding-bottom: 8px;
        border-bottom: 1px solid #000000
    }
    .spec-box .staff__dl {
        overflow: hidden;
        *zoom: 1;
        line-height: 1.6;
        font-size: 18px;
        letter-spacing: -1px
    }
    .spec-box .staff__dl dt {
        width: 280px;
        float: left;
        text-align: left;
        margin-bottom: 5px
    }
    .spec-box .staff__dl dd {
        width: auto;
        float: left;
        margin-bottom: 5px
    }
    .spec-box .price {
        clear: both;
        line-height: 1.6;
        padding: 0 10px;
        font-size: 18px
    }
    .spec-box .price__title {
        text-align: left;
        margin-bottom: 10px
    }
    .spec-box .price__dl {
        font-size: 16px;
        overflow: hidden;
        *zoom: 1
    }
    .spec-box .price__dl dt {
        color: #fff;
        float: none;
        width: 137px;
        background: url(../../assets/img/common/bg_footer_dt.png) left top no-repeat;
        height: 26px;
        line-height: 26px;
        text-align: center;
        clear: both;
        margin-bottom: 10px
    }
    .spec-box .price__dl dd {
        clear: both;
        text-align: left;
        float: left;
        width: auto;
        margin-bottom: 10px
    }
}

footer {
    background: #000;
    padding: 55px 0 20px
}

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

footer .footer-social__follow {
    text-align: center;
    margin-bottom: 30px;
    padding-left: 60px
}

footer .footer-social__buttons {
    margin-bottom: 35px;
    text-align: center
}

footer .footer-social__buttons.v-pc {
    display: block
}

footer .footer-social__buttons.v-sp {
    display: none
}

footer .footer-social__buttons li {
    display: inline-block;
    margin: 0 1px
}

footer .footer-top-banners {
    text-align: center;
    margin-bottom: 9px
}

footer .footer-banners {
    margin: 0 0px 20px;
    text-align: center;
    font-size: 0
}

footer .footer-banners li {
    margin-right: 11px;
    margin-bottom: 11px;
    display: inline-block
}

footer .footer-banners li:nth-child(3n){
    margin: 0
}

footer .footer-banners li:last-child {
    margin: 0
}

footer .footer-banners li a {
    display: inline-block
}

@media (max-width: 640px) {
    footer .footer-social__follow {
        text-align: center;
        margin-bottom: 50px;
        padding-left: 10px
    }
    footer .footer-social__buttons {
        margin-bottom: 50px;
        text-align: center
    }
    footer .footer-social__buttons.v-sp {
        display: block
    }
    footer .footer-social__buttons.v-pc {
        display: none
    }
    footer .footer-social__buttons li {
        display: inline-block;
        margin: 0 9px;
        background: #17a1d0
    }
    footer .footer-top-banners {
        text-align: center;
        margin-bottom: 18px
    }
    footer .footer-banners {
        margin: 0 17px 0px;
        text-align: center;
        font-size: 0
    }
    footer .footer-banners li {
        float: left;
        width: calc(50% - 10px);
        margin-right: 20px;
        margin-bottom: 19px;
        display: block
    }
    footer .footer-banners li:nth-child(2n) {
        margin-right: 0
    }
    footer .footer-banners li:nth-child(3n) {
        margin-right: 20px
    }
    footer .footer-banners li:nth-child(6n) {
        margin-right: 0
    }
    footer .footer-banners li:last-child {
        margin-right: 0
    }
    footer .footer-banners li a {
        display: block
    }
    footer .footer-banners li img {
        width: 100%
    }
}

footer .copyright {
    float: left;
    position: relative;
    top: 8px;
    margin-left: 16px
}

footer .marvelous {
    float: right;
    background: url("../img/common/marvelous_logo.png") no-repeat;
    width: 108px;
    height: 49px;
    margin-right: 11px
}

@media (max-width: 640px) {
    footer {
        padding: 20px 0 40px
    }
    footer .wrapper {
        width: auto
    }
    footer li {
        margin: 0 0 20px 0
    }
    footer .bnr {
        width: 600px;
        height: 220px
    }
    footer .footer-bottom {
        position: relative
    }
    footer .footer-bottom2 {
        position: relative
    }
    footer .copyright {
        float: none;
        top: auto;
        margin-left: 11px
    }
    footer .marvelous {
        float: none;
        position: absolute;
        margin: 0;
        top: 178px;
        right: 26px
    }
}

#spec {
    background: url(../img/spec/bg_spec.png) center top no-repeat #000;
    background-attachment: fixed
}

#spec .spec-header {
    padding-top: 40px;
    margin-bottom: 10px
}

#spec .spec-header__wrap {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden;
    *zoom: 1
}

@media (max-width: 640px) {
    #spec .spec-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .spec-header__title {
    float: left;
    margin-right: 0px
}

#spec .spec-header__navi {
    float: left;
    margin-top: 40px;
    overflow: hidden;
    *zoom: 1
}

#spec .spec-header__navi li {
    float: left
}

#spec .pankuzu {
    margin-bottom: 35px;
    padding: 0 15px
}

#spec .spec-detail {
    width: 1024px;
    margin: 0 auto;
    font-size: 17px;
    padding: 0 15px 0px;
    margin-bottom: 40px;
    position: relative
}

@media (max-width: 640px) {
    #spec .spec-detail {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .spec-detail__table {
    overflow: hidden;
    *zoom: 1;
    font-size: 16px
}

#spec .spec-detail__table dt {
    float: left;
    clear: both;
    background: url(../img/spec/bg_spec_dt.png) left top no-repeat;
    width: 112px;
    height: 33px;
    line-height: 33px;
    text-align: center;
    margin-bottom: 10px
}

#spec .spec-detail__table dd {
    padding-left: 18px;
    float: left;
    padding-top: 4px;
    color: #fff;
    margin-bottom: 10px;
    line-height: 1.5
}

#spec .spec-detail__table dd a {
    color: #fff;
    text-decoration: underline
}

#spec .spec-detail .cero {
    position: absolute;
    left: 550px;
    bottom: 10px
}

#spec .hard {
    background: url(../img/spec/bg_select_hard.png) center top no-repeat
}

#spec .hard__wrap {
    width: 1024px;
    margin: 0 auto;
    position: relative
}

@media (max-width: 640px) {
    #spec .hard__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .hard__title {
    background: url(../img/spec/tab_select_hard.png) left top no-repeat;
    width: 240px;
    height: 29px;
    position: absolute;
    top: -29px;
    left: 13px;
    line-height: 33px;
    text-align: left;
    padding-left: 37px;
    color: #ffcf02
}

#spec .hard__title:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_select_menu.png) left top no-repeat;
    width: 7px;
    height: 7px;
    vertical-align: middle;
    margin-right: 6px
}

#spec .hard__menu {
    padding-top: 20px;
    padding-bottom: 48px
}

#spec .hard__list {
    overflow: hidden;
    *zoom: 1
}

#spec .hard__list li {
    float: left;
    margin-right: 35px
}

#spec .hard__list li:last-child {
    margin-right: 0
}

#spec .hard__list li a {
    display: block;
    position: relative;
    background: url(../img/spec/btn_bg_hard.png) left top no-repeat;
    width: 315px;
    height: 54px;
    line-height: 49px;
    text-align: center;
    padding-left: 30px
}

#spec .hard__list li a img {
    vertical-align: middle
}

#spec .hard__list li a:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_buy_button.png) left top no-repeat;
    width: 22px;
    height: 22px;
    vertical-align: text-bottom;
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%)
}

#spec .hard__list li a:hover {
    background: url(../img/spec/btn_bg_hard_on.png) left top no-repeat
}

#spec .hard__list li a:hover img {
    opacity: 1
}

#spec .hard__list li a.is-active {
    background: url(../img/spec/btn_bg_hard_on.png) left top no-repeat
}

#spec .lineup {
    background: url(../img/spec/bg_select_version.png) center top no-repeat #000
}

#spec .lineup__wrap {
    width: 1024px;
    margin: 0 auto;
    position: relative
}

@media (max-width: 640px) {
    #spec .lineup__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .lineup__title {
    background: url(../img/spec/tab_select_hard.png) left top no-repeat;
    width: 240px;
    height: 29px;
    position: absolute;
    top: -29px;
    left: 13px;
    line-height: 33px;
    text-align: left;
    padding-left: 37px;
    color: #ffcf02
}

#spec .lineup__title:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_select_menu.png) left top no-repeat;
    width: 7px;
    height: 7px;
    vertical-align: middle;
    margin-right: 6px
}

#spec .lineup__menu {
    padding-top: 20px;
    padding-bottom: 40px
}

#spec .lineup__menu .ps4 {
    display: none
}

#spec .lineup__menu .psvita {
    display: none
}

#spec .lineup__detail .ps4 {
    display: none
}

#spec .lineup__detail .psvita {
    display: none
}

#spec .lineup__list {
    overflow: hidden;
    *zoom: 1
}

#spec .lineup__list li {
    float: left;
    margin-right: 35px
}

#spec .lineup__list li.special a {
    box-sizing: border-box;
    padding-top: 0px;
    line-height: 1
}

#spec .lineup__list li.normal a {
    box-sizing: border-box;
    padding-top: 15px
}

#spec .lineup__list li.download a {
    box-sizing: border-box;
    padding-top: 15px
}

#spec .lineup__list li:last-child {
    margin-right: 0
}

#spec .lineup__list li a {
    color: #fff;
    display: block;
    background: url(../img/spec/btn_bg_lineup.png) left top no-repeat;
    width: 315px;
    height: 54px;
    text-align: center;
    font-size: 22px;
    position: relative
}

#spec .lineup__list li a span {
    font-size: 14px
}

#spec .lineup__list li a:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_buy_button.png) left top no-repeat;
    width: 22px;
    height: 22px;
    vertical-align: text-bottom;
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%)
}

#spec .lineup__list li a:hover {
    background: url(../img/spec/btn_bg_lineup_on.png) left top no-repeat
}

#spec .lineup__list li a.is-active {
    background: url(../img/spec/btn_bg_lineup_on.png) left top no-repeat
}

#spec .lineup-box {
    padding-bottom: 60px
}

#spec .lineup-box--special .lineup-box__image {
    margin-right: 45px
}

#spec .lineup-box__title {
    margin-bottom: 20px
}

#spec .lineup-box__body {
    *zoom: 1;
    padding-bottom: 70px
}

#spec .lineup-box__body:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#spec .lineup-box__zoom {
    position: absolute;
    top: -20px;
    right: -20px;
    z-index: 10
}

#spec .lineup-box__image {
    position: relative;
    float: left;
    margin-right: 25px
}

#spec .lineup-box__bottomimage {
    margin-top: 20px;
    text-align: center
}

#spec .lineup-box__detail {
    float: left;
    color: #fff;
    width: 423px;
    font-size: 20px
}

#spec .lineup-box__detail--wide {
    width: 523px
}

#spec .lineup-box__detail p {
    line-height: 1.5;
    font-size: 16px;
    margin-bottom: 15px;
    text-indent: -25px;
    padding-left: 25px
}

#spec .lineup-box__detail p.no-indent {
    padding-left: 0;
    text-indent: 0
}

#spec .lineup-box__detail p span {
    font-size: 12px
}

#spec .lineup-box__detail-button {
    margin-bottom: 60px
}

#spec .lineup-box__sbj {
    background: url(../img/spec/bg_sbj.png) left top no-repeat;
    width: 126px;
    margin-bottom: 12px;
    font-weight: bold;
    height: 26px;
    text-align: center;
    line-height: 26px;
    font-size: 16px;
    color: #000
}

#spec .lineup-box__sbj:not(:first-child) {
    margin-top: 20px
}

#spec .lineup-box__footer {
    border-top: 1px solid #febd04;
    line-height: 1.6;
    padding-top: 15px;
    color: #fff;
    font-size: 13px
}

#spec .lineup-box__footerbanner {
    margin-right: -14px;
    margin-top: 20px
}

#spec .early-present__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #spec .early-present__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .early-present__title {
    margin-left: -35px
}

#spec .early-present__text {
    margin-top: -34px;
    color: #fff;
    font-size: 18px;
    margin-left: 20px;
    line-height: 1.6;
    letter-spacing: -2px;
    margin-bottom: 0
}

#spec .early-present__image {
    position: relative;
    text-align: center;
    margin-top: -20px;
    margin-bottom: 25px;
    margin-left: -20px;
    padding-bottom: 130px
}

#spec .early-present__footer {
    border-top: 1px solid #febd04;
    line-height: 1.6;
    padding-top: 15px;
    color: #fff;
    font-size: 13px;
    padding-bottom: 65px
}

#spec .early-present .slide {
    overflow: visible;
    position: absolute;
    bottom: 0;
    left: 3px
}

#spec .early-present .slide__main {
    position: relative !important;
    width: 300px;
    text-align: center;
    overflow: hidden;
    margin: 0 0 30px 18px
}

#spec .early-present .slide__main img {
    display: block;
    width: 100%;
    height: auto
}

#spec .early-present .slide__photo {
    border: 1px solid #ffc601
}

#spec .early-present .slide__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    border-left: 1px solid #feb300;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#spec .early-present .slide__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #spec .early-present .slide__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#spec .early-present .slide__text--2row {
    margin-bottom: calc(1em + 30px)
}

#spec .early-present .slide__text .ruby {
    display: block;
    font-size: 12px;
    line-height: 1.2
}

#spec .early-present .slide__thumbs {
    display: block;
    width: 100%;
    margin: 0 0 0 18px
}

#spec .early-present .slide__thumbs li {
    display: block;
    float: left;
    width: 197px;
    margin-right: 9px;
    position: relative
}

#spec .early-present .slide__thumbs li .title-trailer {
    position: absolute;
    top: -20px;
    left: 0
}

#spec .early-present .slide__thumbs li .title-trailer img {
    width: 67px
}

#spec .early-present .slide__thumbs li .movie {
    display: block;
    position: relative
}

#spec .early-present .slide__thumbs li .movie:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: url(../img/spec/btn_play.png) left top no-repeat;
    width: 68px;
    height: 68px;
    z-index: 2
}

#spec .early-present .slide__thumbs img {
    display: block;
    width: 195px
}

#spec .early-present .slide__thumbs .zoom2:after {
    content: "";
    display: block;
    background: url(../img/character/ico_plus.png) left top no-repeat;
    width: 25px;
    height: 25px;
    position: absolute;
    top: -10px;
    right: -5px
}

#spec .early-present .slide__thumbs .zoom2.movie:before {
    content: "";
    display: block;
    background: url(../img/character/ico_plus.png) left top no-repeat;
    width: 25px;
    height: 25px;
    position: absolute;
    top: -10px;
    right: -5px;
    z-index: 3
}

#spec .early-present .slide__controls {
    position: absolute;
    width: 468px;
    overflow: hidden;
    left: -67px;
    top: 43px
}

#spec .early-present .slide__control--left {
    float: left
}

#spec .early-present .slide__control--right {
    float: right
}

#spec .store-present__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #spec .store-present__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .store-present__title {
    margin-left: -35px
}

#spec .store-present__lead {
    color: #FFF;
    margin: -50px 0 40px;
    padding-left: 27px
}

#spec .stores {
    margin-top: -10px
}

#spec .stores__list {
    overflow: hidden;
    *zoom: 1
}

#spec .stores__list li {
    float: left;
    margin-right: 50px
}

#spec .stores__list li:nth-child(3n) {
    margin-right: 0
}

#spec .stores__footer {
    margin-top: -40px;
    color: #fff;
    line-height: 1.6;
    padding-bottom: 45px;
    font-size: 13px
}

#spec .store-item {
    height: 654px
}

#spec .store-item__wrap {
    background: url(../img/spec/bg_store_item.png) left top no-repeat;
    width: 308px;
    height: 509px;
    text-align: center
}

#spec .store-item__store-name {
    padding: 48px 0 35px;
    font-size: 20px;
    line-height: 1.2;
    font-weight: bold
}

#spec .store-item__store-name--2 {
    padding: 34px 0 25px
}

#spec .store-item__image {
    position: relative
}

#spec .store-item__zoom {
    position: absolute;
    top: -15px;
    right: 8px;
    z-index: 10
}

#spec .store-item__title {
    font-size: 18px;
    padding: 16px 20px 0;
    line-height: 1.2;
    font-weight: bold
}

#spec .store-item__title small {
    font-size: 13px
}

#spec .store-item__button a {
    display: block;
    background: url(../img/spec/btn_bg_buy.png) left top no-repeat;
    width: 303px;
    height: 67px;
    color: #fff;
    font-size: 22px;
    line-height: 67px;
    text-align: center
}

#spec .store-item__button a:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_buy_button.png) left top no-repeat;
    width: 22px;
    height: 22px;
    vertical-align: middle;
    margin-right: 8px;
    position: relative;
    top: -2px
}

#spec .store-item__button--small a {
    width: 303px;
    height: 53px;
    color: #fff;
    font-size: 18px;
    line-height: 53px;
    text-align: center
}

#spec .store-item__button--small a:nth-child(2n-1) {
    background: url(../img/spec/btn_bg_buy_small1.png) left top no-repeat
}

#spec .store-item__button--small a:nth-child(2n) {
    background: url(../img/spec/btn_bg_buy_small2.png) left top no-repeat
}

#spec .store-item__button--small a:before {
    position: relative;
    top: -2px
}

#spec .zoom-modal {
    position: absolute;
    display: none;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    z-index: 1002
}

#spec .zoom-modal__close {
    position: absolute;
    top: -30px;
    right: -30px
}

#spec .zoom-modal__close a {
    background: url(../img/spec/btn_close.png) left top no-repeat;
    display: block;
    width: 60px;
    height: 60px
}

#spec .zoom-modal__prev {
    display: block;
    position: absolute;
    left: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#spec .zoom-modal__next {
    display: block;
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#spec .bg-layer {
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    z-index: 1001
}

#spec .buy-guide__wrap {
    width: 1024px;
    margin: 0 auto;
    padding-bottom: 150px
}

@media (max-width: 640px) {
    #spec .buy-guide__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#spec .buy-guide__title {
    margin-left: -20px
}

#spec .buy-guide__header-text {
    color: #fff;
    font-size: 17px;
    line-height: 1.6;
    margin-top: -130px;
    margin-left: 10px;
    margin-bottom: 30px;
    letter-spacing: 1px
}

#spec .buy-guide__footer {
    color: #fff
}

#spec .shop-list {
    overflow: hidden;
    *zoom: 1;
    padding-bottom: 20px
}

#spec .shop-list__item {
    float: left;
    margin-right: 10px;
    margin-bottom: 18px
}

#spec .shop-list__item:nth-child(4n) {
    margin-right: 0
}

#spec .shop-list__item:nth-child(4n+1) {
    clear: both
}

#spec .shop-list__button a {
    display: block;
    background: url(../img/spec/btn_bg_buy_guide.png) left top no-repeat;
    width: 245px;
    height: 55px;
    color: #fff;
    font-size: 22px;
    line-height: 54px;
    text-align: center
}

#spec .shop-list__button a:before {
    content: "";
    display: inline-block;
    background: url(../img/spec/ico_buy_button.png) left top no-repeat;
    width: 22px;
    height: 22px;
    vertical-align: middle;
    margin-right: 8px;
    margin-left: -8px;
    position: relative;
    top: -2px
}

#spec .shop-list__thum {
    background: url(../img/spec/bg_thum_guide.png) left top no-repeat;
    width: 248px;
    height: 137px;
    padding-top: 20px;
    padding-left: 11px
}

#spec .slide {
    overflow: visible;
    position: relative
}

#spec .slide__main {
    width: 620px;
    text-align: center;
    overflow: hidden;
    margin: 0 auto 7px
}

#spec .slide__main img {
    display: block;
    width: 100%;
    height: auto
}

#spec .slide__photo {
    border: 1px solid #ffc601
}

#spec .slide__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    border-left: 1px solid #feb300;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#spec .slide__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #spec .slide__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#spec .slide__text .ruby {
    display: block;
    font-size: 12px;
    line-height: 1.2
}

#spec .slide__thumbs {
    display: table;
    width: 634px;
    margin: 0 auto;
    border-spacing: 7px 0
}

#spec .slide__thumbs li {
    display: table-cell;
    border: 1px solid #ffc601
}

#spec .slide__thumbs img {
    display: block;
    width: 100%
}

#spec .slide__controls {
    position: absolute;
    width: 100%;
    padding: 0 35px;
    overflow: hidden;
    left: 0;
    top: 130px
}

#spec .slide__control--left {
    float: left
}

#spec .slide__control--right {
    float: right
}

#spec .data-share {
    display: none
}

#spec .data-share__top {
    overflow: hidden;
    *zoom: 1;
    margin-bottom: 40px
}

#spec .data-share__text {
    float: left;
    font-size: 15px;
    padding-left: 57px;
    width: calc(100% - 298px);
    line-height: 1.8
}

#spec .data-share__image {
    float: right;
    width: 288px
}

#spec .data-share__bottom {
    line-height: 1.8;
    font-size: 15px;
    padding-left: 57px;
    margin-bottom: 10px
}

#spec .data-share-title {
    margin-bottom: 20px
}

#spec .data-share-wrap {
    width: 818px;
    padding: 20px 20px 80px;
    background: url(../img/spec/share_bg.png) left top no-repeat #000;
    box-sizing: border-box;
    border: 1px solid #f1cb2e;
    color: #fff
}

@media (max-width: 640px) {
    #spec {
        background: url(../img/spec/bg_spec.png) center top no-repeat #000;
        background-size: contain
    }
    #spec .spec-header {
        padding-top: 24px;
        margin-bottom: 10px
    }
    #spec .spec-header__wrap {
        width: 1024px;
        margin: 0 auto;
        overflow: hidden;
        *zoom: 1
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #spec .spec-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #spec .spec-header__title {
        float: none;
        margin-right: 0px
    }
    #spec .spec-header__navi {
        float: none;
        margin-top: 20px;
        overflow: hidden;
        *zoom: 1
    }
    #spec .spec-header__navi li {
        float: left;
        margin-right: 3px
    }
    #spec .spec-header__navi li:last-child {
        margin-right: 0
    }
    #spec .pankuzu {
        margin-bottom: 50px;
        padding: 0 15px
    }
    #spec .spec-detail {
        margin-top: 30px;
        font-size: 20px;
        padding: 0 15px 0px;
        margin-bottom: 80px;
        position: relative
    }
    #spec .spec-detail__table {
        overflow: hidden;
        *zoom: 1
    }
    #spec .spec-detail__table dt {
        float: left;
        clear: both;
        background: url(../img/spec/bg_spec_dt.png) left top no-repeat;
        width: 112px;
        height: 33px;
        line-height: 33px;
        text-align: center;
        margin-bottom: 10px
    }
    #spec .spec-detail__table dd {
        padding-left: 18px;
        float: left;
        line-height: 33px;
        color: #fff;
        padding-top: 0;
        margin-bottom: 10px
    }
    #spec .spec-detail .cero {
        position: absolute;
        left: 540px;
        bottom: 10px
    }
    #spec .hard {
        background: url(../img/spec/bg_select_hard.png) -288px top no-repeat
    }
    #spec .hard__wrap {
        width: 1024px;
        margin: 0 auto;
        position: relative
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #spec .hard__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #spec .hard__title {
        background: url(../img/spec/tab_select_hard.png) left top no-repeat;
        width: 240px;
        height: 29px;
        position: absolute;
        top: -29px;
        left: 13px;
        line-height: 33px;
        text-align: left;
        padding-left: 22px;
        color: #ffcf02;
        font-size: 17px
    }
    #spec .hard__title:before {
        content: "";
        display: inline-block;
        background: url(../img/spec/ico_select_menu.png) left top no-repeat;
        width: 7px;
        height: 7px;
        vertical-align: middle;
        margin-right: 6px
    }
    #spec .hard__menu {
        padding-top: 36px;
        padding-bottom: 70px
    }
    #spec .hard__list {
        overflow: hidden;
        *zoom: 1
    }
    #spec .hard__list li {
        float: left;
        margin-right: 18px
    }
    #spec .hard__list li:last-child {
        margin-right: 0
    }
    #spec .hard__list li.ps4psvita img {
        width: 151px
    }
    #spec .hard__list li.ps4 img {
        width: 75px
    }
    #spec .hard__list li.psvita img {
        width: 100px
    }
    #spec .hard__list li a {
        display: block;
        position: relative;
        background: url(../img/spec/sp/btn_bg_hard.png) left top no-repeat;
        width: 194px;
        height: 64px;
        line-height: 62px;
        text-align: center;
        padding-left: 30px
    }
    #spec .hard__list li a img {
        vertical-align: middle
    }
    #spec .hard__list li a:before {
        content: "";
        display: inline-block;
        background: url(../img/spec/ico_buy_button.png) left top no-repeat;
        width: 22px;
        height: 22px;
        vertical-align: text-bottom;
        position: absolute;
        top: 50%;
        left: 7px;
        transform: translateY(-50%)
    }
    #spec .hard__list li a:hover {
        background: url(../img/spec/sp/btn_bg_hard_on.png) left top no-repeat
    }
    #spec .hard__list li a.is-active {
        background: url(../img/spec/sp/btn_bg_hard_on.png) left top no-repeat
    }
    #spec .lineup {
        background: url(../img/spec/bg_select_version.png) -288px top no-repeat #000
    }
    #spec .lineup__wrap {
        width: 1024px;
        margin: 0 auto;
        position: relative
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #spec .lineup__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #spec .lineup__title {
        background: url(../img/spec/tab_select_hard.png) left top no-repeat;
        width: 240px;
        height: 29px;
        position: absolute;
        top: -29px;
        left: 13px;
        line-height: 33px;
        text-align: left;
        padding-left: 37px;
        color: #ffcf02;
        font-size: 17px
    }
    #spec .lineup__title:before {
        content: "";
        display: inline-block;
        background: url(../img/spec/ico_select_menu.png) left top no-repeat;
        width: 7px;
        height: 7px;
        vertical-align: middle;
        margin-right: 6px
    }
    #spec .lineup__menu {
        padding-top: 36px;
        padding-bottom: 50px
    }
    #spec .lineup__menu .ps4 {
        display: none
    }
    #spec .lineup__menu .psvita {
        display: none
    }
    #spec .lineup__detail .ps4 {
        display: none
    }
    #spec .lineup__detail .psvita {
        display: none
    }
    #spec .lineup__list {
        overflow: hidden;
        *zoom: 1
    }
    #spec .lineup__list li {
        float: left;
        margin-right: 23px;
        width: 190px
    }
    #spec .lineup__list li.special a {
        box-sizing: border-box;
        padding-top: 2px;
        line-height: 1.2;
        background: url(../img/spec/sp/bg_regalia.png) left top no-repeat
    }
    #spec .lineup__list li.special a:hover {
        background: url(../img/spec/sp/bg_regalia_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li.special a.is-active {
        background: url(../img/spec/sp/bg_regalia_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li.normal a {
        box-sizing: border-box;
        padding-top: 21px;
        background: url(../img/spec/sp/bg_normal.png) left top no-repeat
    }
    #spec .lineup__list li.normal a:hover {
        background: url(../img/spec/sp/bg_normal_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li.normal a.is-active {
        background: url(../img/spec/sp/bg_normal_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li.download a {
        box-sizing: border-box;
        padding-top: 21px;
        background: url(../img/spec/sp/bg_download.png) left top no-repeat
    }
    #spec .lineup__list li.download a:hover {
        background: url(../img/spec/sp/bg_download_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li.download a.is-active {
        background: url(../img/spec/sp/bg_download_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup__list li:last-child {
        margin-right: 0
    }
    #spec .lineup__list li a {
        line-height: 1;
        color: #fff;
        display: block;
        background-size: cover;
        width: 190px;
        height: 64px;
        text-align: center;
        font-size: 22px;
        padding-left: 16px
    }
    #spec .lineup__list li a span {
        font-size: 13px;
        margin-bottom: 3px
    }
    #spec .lineup__list li a:before {
        display: none
    }
    #spec .lineup__list li a:hover {
        background: url(../img/spec/btn_bg_lineup_on.png) left top no-repeat
    }
    #spec .lineup__list li a.is-active {
        background: url(../img/spec/btn_bg_lineup_on.png) left top no-repeat;
        background-size: cover
    }
    #spec .lineup-box {
        padding-bottom: 60px
    }
    #spec .lineup-box--special .lineup-box__image {
        margin-right: 0px
    }
    #spec .lineup-box__detail-button {
        margin-bottom: 20px
    }
    #spec .lineup-box__title {
        margin-bottom: 20px
    }
    #spec .lineup-box__title img {
        max-width: 100%
    }
    #spec .lineup-box__body {
        *zoom: 1;
        padding-bottom: 20px
    }
    #spec .lineup-box__body:after {
        content: "\0020";
        display: block;
        height: 0;
        clear: both;
        overflow: hidden;
        visibility: hidden
    }
    #spec .lineup-box__zoom {
        position: absolute;
        top: -20px;
        right: -20px;
        z-index: 10;
        display: none
    }
    #spec .lineup-box__image {
        position: relative;
        float: none;
        margin-right: 0px;
        margin-bottom: 25px
    }
    #spec .lineup-box__image a img {
        width: 100%
    }
    #spec .lineup-box__detail {
        clear: both;
        float: none;
        color: #fff;
        width: auto;
        font-size: 22px
    }
    #spec .lineup-box__detail p {
        line-height: 1.5;
        font-size: 20px;
        margin-bottom: 15px;
        text-indent: -25px;
        padding-left: 25px;
        max-height: 100%
    }
    #spec .lineup-box__sbj {
        background: url(../img/spec/bg_sbj.png) left top no-repeat;
        width: 126px;
        margin-bottom: 12px;
        font-weight: bold;
        height: 26px;
        text-align: center;
        line-height: 26px;
        font-size: 16px;
        color: #000;
        text-indent: -5px
    }
    #spec .lineup-box__sbj:not(:first-child) {
        margin-top: 20px
    }
    #spec .lineup-box__footer {
        border-top: 2px solid #febd04;
        line-height: 1.6;
        padding-top: 30px;
        color: #fff;
        font-size: 16px;
        max-height: 100%
    }
    #spec .lineup-box__footer--no-border {
        border: none;
        padding-top: 0;
        margin-top: 0
    }
    #spec .lineup-box__footerbanner {
        margin-right: 0;
        margin-top: 0px;
        margin-bottom: 20px
    }
    #spec .early-present__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #spec .early-present__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #spec .early-present__title {
        margin-left: -10px;
        margin-right: -10px
    }
    #spec .early-present__text {
        margin-top: -17px;
        color: #fff;
        font-size: 22px;
        margin-left: 0px;
        line-height: 1.6;
        letter-spacing: -2px;
        margin-bottom: 0
    }
    #spec .early-present__image {
        text-align: center;
        margin-top: 0;
        margin-bottom: 20px;
        margin-left: 0px;
        padding-bottom: 0
    }
    #spec .early-present__footer {
        border-top: 2px solid #febd04;
        line-height: 1.6;
        padding-top: 40px;
        color: #fff;
        font-size: 16px;
        padding-bottom: 65px;
        max-height: 100%
    }
    #spec .early-present .slide {
        width: auto;
        margin: 0 0 0;
        position: static
    }
    #spec .early-present .slide__title {
        text-align: center;
        margin-bottom: 700px;
        padding-left: 0
    }
    #spec .early-present .slide__main {
        width: 480px;
        margin: 0 auto 28px
    }
    #spec .early-present .slide__thumbs {
        width: 630px;
        margin: 0 -7px 0;
        display: table;
        display: -webkit-box;
        -webkit-overflow-scrolling: touch;
        display: box;
        overflow-x: scroll
    }
    #spec .early-present .slide__thumbs li {
        display: table-cell;
        width: 202px;
        float: none;
        margin-right: 7px
    }
    #spec .early-present .slide__thumbs li img {
        width: 202px
    }
    #spec .early-present .slide__thumbs .zoom2:after {
        content: "";
        display: block;
        background: url(../img/character/sp/ico_plus.png) left top no-repeat;
        width: 36px;
        height: 36px;
        position: absolute;
        top: -10px;
        right: -5px
    }
    #spec .early-present .slide__thumbs .zoom2.movie:before {
        content: "";
        display: block;
        background: url(../img/character/sp/ico_plus.png) left top no-repeat;
        width: 36px;
        height: 36px;
        position: absolute;
        top: -10px;
        right: -5px
    }
    #spec .early-present .slide__controls {
        top: auto;
        bottom: 260px;
        width: 600px;
        left: 50%;
        transform: translateX(-50%)
    }
    #spec .early-present .slide__control--left {
        margin-left: 0
    }
    #spec .early-present .slide__control--right {
        margin-right: 0
    }
    #spec .store-present__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #spec .store-present__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #spec .store-present__title {
        margin-left: -10px;
        margin-right: -10px;
        margin-bottom: 40px
    }
    #spec .store-present__lead {
        margin: -30px 0 40px;
        padding-left: 0
    }
    #spec .stores {
        margin-top: -10px
    }
    #spec .stores__list {
        overflow: hidden;
        *zoom: 1
    }
    #spec .stores__list li {
        float: left;
        margin-right: 4px;
        margin-bottom: 20px
    }
    #spec .stores__list li:nth-child(2n) {
        margin-right: 0
    }
    #spec .stores__list li:nth-child(2n-1) {
        clear: both
    }
    #spec .stores__list li:nth-child(3n) {
        margin-right: 4px
    }
    #spec .stores__list li:nth-child(6n) {
        margin-right: 0
    }
    #spec .stores__footer {
        margin-top: 10px;
        color: #fff;
        line-height: 1.6;
        padding-bottom: 45px;
        font-size: 16px;
        max-height: 100%
    }
    #spec .store-item {
        height: auto
    }
    #spec .store-item__wrap {
        background: url(../img/spec/bg_store_item.png) left top no-repeat;
        width: 308px;
        height: 509px;
        text-align: center
    }
    #spec .store-item__store-name {
        padding: 48px 0 35px;
        font-size: 20px;
        line-height: 1.2;
        font-weight: bold
    }
    #spec .store-item__store-name--2 {
        padding: 34px 0 25px
    }
    #spec .store-item__image {
        position: relative
    }
    #spec .store-item__zoom {
        position: absolute;
        top: -15px;
        right: 8px;
        z-index: 10
    }
    #spec .store-item__title {
        font-size: 18px;
        padding-top: 16px;
        line-height: 1.2;
        font-weight: bold
    }
    #spec .store-item__button a {
        display: block;
        background: url(../img/spec/btn_bg_buy.png) left top no-repeat;
        width: 303px;
        height: 67px;
        color: #fff;
        font-size: 22px;
        line-height: 67px;
        text-align: center
    }
    #spec .store-item__button a:before {
        content: "";
        display: inline-block;
        background: url(../img/spec/ico_buy_button.png) left top no-repeat;
        width: 22px;
        height: 22px;
        vertical-align: middle;
        margin-right: 8px
    }
    #spec .store-item__button--small a {
        width: 303px;
        height: 53px;
        color: #fff;
        font-size: 18px;
        line-height: 53px;
        text-align: center
    }
    #spec .store-item__button--small a:nth-child(2n-1) {
        background: url(../img/spec/btn_bg_buy_small1.png) left top no-repeat
    }
    #spec .store-item__button--small a:nth-child(2n) {
        background: url(../img/spec/btn_bg_buy_small2.png) left top no-repeat
    }
    #spec .store-item__button--small a:before {
        position: relative;
        top: -2px
    }
    #spec .zoom-modal {
        position: absolute;
        display: none;
        left: 50%;
        top: 0;
        transform: translate(-50%, -50%);
        z-index: 1002
    }
    #spec .zoom-modal__close {
        position: absolute;
        top: -115px;
        right: 0px
    }
    #spec .zoom-modal__close a {
        background: url(../img/spec/sp/btn_modal_close.png) left top no-repeat;
        display: block;
        width: 106px;
        height: 106px
    }
    #spec .zoom-modal__prev {
        display: block;
        position: absolute;
        left: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #spec .zoom-modal__next {
        display: block;
        position: absolute;
        right: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #spec .bg-layer {
        background: rgba(0, 0, 0, 0.8);
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        display: none;
        z-index: 1001
    }
    #spec .buy-guide__title {
        margin-left: -10px
    }
    #spec .buy-guide__wrap {
        padding-bottom: 50px
    }
    #spec .buy-guide__header-text {
        color: #fff;
        font-size: 16px;
        line-height: 1.6;
        margin-top: -100px;
        margin-left: 10px;
        margin-bottom: 30px;
        letter-spacing: 1px
    }
    #spec .buy-guide__footer {
        width: 562px;
        margin: 0 auto
    }
    #spec .shop-list {
        overflow: hidden;
        *zoom: 1;
        width: 562px;
        margin: 0 auto 0px;
        padding-bottom: 0px
    }
    #spec .shop-list__item {
        float: left;
        margin-right: 66px;
        margin-bottom: 36px
    }
    #spec .shop-list__item:nth-child(2n) {
        margin-right: 0
    }
    #spec .shop-list__item:nth-child(2n+1) {
        clear: both
    }
    #spec .shop-list__button a {
        display: block;
        background: url(../img/spec/btn_bg_buy_guide.png) left top no-repeat;
        width: 245px;
        height: 55px;
        color: #fff;
        font-size: 22px;
        line-height: 54px;
        text-align: center
    }
    #spec .shop-list__button a:before {
        content: "";
        display: inline-block;
        background: url(../img/spec/ico_buy_button.png) left top no-repeat;
        width: 22px;
        height: 22px;
        vertical-align: middle;
        margin-right: 8px;
        margin-left: -8px;
        position: relative;
        top: -2px
    }
    #spec .shop-list__thum {
        background: url(../img/spec/bg_thum_guide.png) left top no-repeat;
        width: 248px;
        height: 137px;
        padding-top: 20px;
        padding-left: 11px
    }
    #spec .data-share {
        display: none
    }
    #spec .data-share__top {
        overflow: hidden;
        *zoom: 1;
        margin-bottom: 40px
    }
    #spec .data-share__text {
        float: none;
        font-size: 20px;
        padding-left: 0px;
        width: auto;
        line-height: 1.8
    }
    #spec .data-share__image {
        float: none;
        width: auto;
        margin-bottom: 20px
    }
    #spec .data-share__bottom {
        line-height: 1.8;
        font-size: 20px;
        padding-left: 0;
        margin-bottom: 20px
    }
    #spec .data-share-title {
        margin-bottom: 20px
    }
    #spec .data-share-wrap {
        width: calc(100vw - 20px);
        margin: 0 auto;
        padding: 20px 30px 40px;
        background: url(../img/spec/sp/share_bg.png) left top no-repeat #000;
        box-sizing: border-box;
        border: 1px solid #f1cb2e;
        color: #fff
    }
    #spec .slide__main {
        width: 564px
    }
    #spec .slide__thumbs {
        width: 578px;
        margin: 0 -7px
    }
    #spec .slide__controls {
        padding: 0;
        bottom: 204px;
        overflow: visible
    }
    #spec .slide__control--left {
        margin-left: -30px
    }
    #spec .slide__control--right {
        margin-right: -30px
    }
}

#top {
    background-color: #000;
    overflow-x: hidden
}

#top #bg1 {
    background-image: url(../img/top/bg1.jpg)
}

#top #bg2 {
    background-image: url(../img/top/bg3.jpg)
}

#top #bg3 {
    background-image: url(../img/top/bg2.jpg)
}

#top #bg4 {
    background-image: url(../img/top/bg4.png)
}

#top .bg {
    background-position: center top;
    background-size: cover;
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 100
}

#top .container {
    display: none;
    min-width: 1024px;
    position: relative;
    z-index: 101
}

#top .splash {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 900;
    background-color: #000
}

#top .splash__logo {
    position: absolute;
    top: 50%;
    left: 50%;
    overflow: visible
}

#top .splash__logo img {
    margin-left: -400px;
    margin-top: -160px
}

#top .flash {
    position: fixed;
    top: 0;
    left: 0;
    display: none;
    width: 100%;
    height: 100%;
    z-index: 901;
    background-color: #FFF
}

#top .main {
    background: #000;
    margin-top: -10px;
    position: relative
}

#top .main #v_target {
    background: none !important
}

#top .main__extention {
    background: url(../img/top/main_bg2.png) center center no-repeat;
    background-size: auto 100%
}

#top .main__wrap {
    width: 1024px;
    margin: 0 auto;
    height: 660px;
    position: relative
}

@media (max-width: 640px) {
    #top .main__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .main__splash {
    display: none;
    width: 100%;
    height: 100%;
    z-index: 902;
    background-color: #FFF;
    position: absolute;
    top: 0;
    left: 0
}

#top .main__particles {
    display: none;
    width: 100%;
    height: 100%;
    z-index: 900;
    background: url(../img/top/main_particles.gif) top center no-repeat;
    background-size: cover;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0
}

#top .main__top {
    display: none;
    position: absolute;
    top: 55%;
    left: 50%;
    margin: 0 0 0 0;
    transform: translate(-105%, -134%);
    z-index: 901
}

#top .main__btm {
    position: absolute;
    bottom: 20px;
    left: 260px;
    z-index: 1201
}

#top .main__spmovies {
    display: none
}

#top .main__movies {
    display: none;
    position: absolute;
    bottom: 23px;
    left: 0px;
    z-index: 902
}

#top .main__limited__release {
    display: none
}

#top .main__limited__stars {
    display: none
}

#top .main__limited__play {
    display: none
}

#top .main__limited__meteor {
    display: none
}

#top .main .movie__title {
    position: absolute;
    left: -40px;
    top: -38px;
    z-index: 1
}

#top .main .movie__thum a {
    display: block;
    position: relative
}

#top .main .movie__thum a:after {
    z-index: 2;
    content: "";
    display: block;
    background: url(../img/top/btn_play.png) left top no-repeat;
    width: 99px;
    height: 99px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: opacity 0.3s
}

#top .main .movie__thum a:hover img {
    opacity: 1
}

#top .main .movie__thum a:hover:after {
    opacity: 0.7
}

#top .main__catch {
    display: none;
    position: absolute;
    top: 0px;
    left: 0;
    width: 95%;
    height: 100%;
    margin: 0px auto 0;
    z-index: 901
}

#top .main__catch img {
    transition: transform 8s ease-out;
    transform-origin: top;
    position: absolute;
    top: calc(50% - 110px);
    right: 20px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: auto;
    height: auto;
    margin: 0 auto
}

#top .main__catch img.is-anime {
    transform: scale(1.1) translateY(-50%)
}

#top .main__catch2 {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 95%;
    height: 100%;
    margin: 0 auto;
    z-index: 901;
    opacity: 0;
    transition: opacity 1s ease-out
}

#top .main__catch2.is-show {
    opacity: 1
}

#top .main__catch2 img {
    transition: transform 8s ease-out;
    transform-origin: top;
    position: absolute;
    top: 50%;
    right: 80px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: auto;
    height: auto;
    margin: 0 auto
}

#top .main__catch2 img.is-anime {
    transform: scale(1.1) translateY(-50%)
}

#top .main__release {
    z-index: 901;
    display: none;
    position: absolute;
    left: 562px;
    bottom: -100px;
    width: auto;
    overflow: visible
}

#top .main .sns__btns {
    overflow: hidden;
    position: absolute;
    top: 20px;
    right: 0;
    z-index: 901
}

#top .main .sns__btns li {
    float: left;
    margin-right: 6px
}

#top .main .YTPOverlay.raster {
    background: url(../img/top/main_video_raster.png) top left repeat
}

#top .main-bottom-banner {
    background: url(../img/top/main_border_btm.png) top center repeat-x;
    padding-top: 34px;
    margin-top: -15px;
    line-height: 0;
    margin-bottom: 0px;
    position: relative;
    top: 0;
    left: 0;
    z-index: 1103
}

#top .main-bottom-banner--sp {
    display: none
}

#top .main-bottom-banner__wrap {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden
}

/*20170529*/
.block--banner {
  margin: 0 auto;
  max-width: 1050px;
  text-align: center;
}
@media (max-width: 640px) {
    .block--banner {
        display: none;
    }
}



@media (max-width: 640px) {
    #top .main-bottom-banner__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .main-bottom-banner__wrap a {
    margin-right: 6px
}

#top .main-bottom-banner__wrap a:last-child {
    margin-right: 0px
}

#top .main-bottom-banner__wrap--center {
    text-align: center
}

#top .main-bottom-banner__wrap--center a {
    margin-right: 48px
}

#top .main-bottom-banner__wrap--top {
    margin-bottom: 10px
}

#top .main-bottom-banner__wrap--large {
    position: relative;
    left: -4px
}

#top .main-bottom-banner__wrap .trial {
    float: left;
    display: block;
    width: 675px;
    height: 96px;
    margin-right: 10px;
    position: relative
}

#top .main-bottom-banner__wrap .trial__under {
    display: block;
    width: 675px;
    height: 96px;
    position: absolute;
    top: 0;
    left: 0
}

#top .main-bottom-banner__wrap .trial__btns {
    overflow: hidden;
    position: absolute;
    top: 34px;
    left: 186px
}

#top .main-bottom-banner__wrap .trial__btns li {
    float: left
}

#top .main-bottom-banner__wrap .trial__btns a {
    display: block;
    width: 162px;
    height: 60px
}

#top .main-bottom-banner__wrap .trial__btns a img {
    margin: 8px 0 0 8px
}

#top .main-bottom-banner__wrap .doublecamp {
    float: left
}

#top .topics {
    margin-bottom: 30px;
    position: relative;
    top: 0;
    left: 0;
    z-index: 906;
}

#top .topics__wrap {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden
}

@media (max-width: 640px) {
    #top .topics__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .topics .news {
    background: url(../img/top/news_bg.png) top center no-repeat;
    width: 493px;
    height: 229px;
    position: relative;
    float: left
}

#top .topics .news__more {
    position: absolute;
    top: 0;
    right: 0
}

#top .topics .news__pane {
    opacity: 0.9;
    position: absolute;
    left: 13px;
    top: 33px;
    width: 460px;
    height: 180px;
    overflow-y: scroll;
    line-height: 18px
}

#top .topics .news__pane dl {
    padding: 15px 15px 0;
    overflow: hidden;
    font-size: 14px
}

#top .topics .news__pane dl dt {
    float: left;
    width: 100px;
    color: #ffbb04
}

#top .topics .news__pane dl dd {
    float: left;
    width: 300px;
    color: #FFF
}

#top .topics .news__pane dl a {
    color: #FFF;
    text-decoration: underline
}

#top .topics .news__pane dl a:hover {
    text-decoration: none
}

#top .topics .twitter {
    background: url(../img/top/twitter_bg.png) top center no-repeat;
    width: 493px;
    height: 229px;
    position: relative;
    float: right
}

#top .topics .twitter__btn {
    position: absolute;
    top: 0;
    right: 0
}

#top .topics .twitter__pane {
    position: absolute;
    left: 6px;
    top: 29px;
    width: 482px;
    height: 196px;
    overflow: hidden
}

#top .tokuten {
    margin-bottom: 110px
}

#top .tokuten__wrap {
    width: 1024px;
    margin: 0 auto;
    position: relative
}

@media (max-width: 640px) {
    #top .tokuten__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .tokuten-senchaku__btn {
    position: absolute;
    top: 37px;
    left: 362px
}

#top .tokuten-senchaku__illust {
    padding-bottom: 50px
}

#top .tokuten-senchaku__mov {
    position: absolute;
    bottom: 0;
    left: 170px
}

#top .tokuten-senchaku__mov a:after {
    z-index: 2;
    content: "";
    display: block;
    background: url(../img/top/btn_play.png) left top no-repeat;
    width: 99px;
    height: 99px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: opacity 0.3s
}

#top .tokuten-shop__photo {
    position: absolute;
    top: 36px;
    right: 0
}

#top .tokuten-shop__title {
    position: absolute;
    top: 380px;
    right: 0
}

#top .tokuten-shop__btn {
    position: absolute;
    top: 418px;
    right: 0
}

#top .premium {
    background: url(../img/top/premium_bg.png) center 330px no-repeat;
    padding-bottom: 100px;
}

#top .premium__title {
    text-align: center
}

#top .premium__subtitle {
    text-align: center
}

#top .premium__price {
    width: 1049px;
    color: #FFF;
    font-size: 16px;
    margin: -40px auto 10px;
    text-align: right;
    padding-right: 50px
}

#top .premium__price span {
    color: #fec500
}

#top .premium__photo {
    text-align: center;
    margin-bottom: 28px
}

#top .premium__btn {
    display: block;
    width: 421px;
    margin: 0 auto
}

#top .limited {
    margin-bottom: 0px;
    margin-top:100px;
}

#top .limited__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #top .limited__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .limited__block {
    position: relative;
    float: left;
    width: 510px;
    overflow: visible
}

#top .limited__block--ps4 .limited__chara {
    top: -90px;
    right: -120px
}

#top .limited__block--psvita .limited__title img {
    margin-top: 0px
}

#top .limited__block--psvita .limited__chara {
    top: -70px;
    right: -30px
}

#top .limited__chara {
    position: absolute;
    top: 0;
    right: 0
}

#top .limited__title {
    height: 280px;
    overflow: visible;
    position: relative
}

#top .limited__price {
    color: #FFF;
    font-size: 16px;
    padding-left: 9px;
    margin-bottom: 10px;
    position: relative
}

#top .limited__price span {
    color: #fec500
}

#top .limited__photo {
    padding-left: 15px;
    margin-bottom: 17px;
    position: relative;
    height: 227px;
    overflow: visible
}

#top .limited__btn {
    display: block;
    position: relative;
    margin-left: 15px
}

#top .limited__top {
    *zoom: 1;
    padding-bottom: 45px
}

#top .limited__top:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

/*20170111=========================================================*/

#top .normal {
    margin-bottom: 50px;
    /*margin-top:100px;*/
    
}

#top .normal__wrap {
    width: 1024px;
    margin: 0 auto;
    border-bottom: 1px solid #fec500;
}

@media (max-width: 640px) {
    #top .normal__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .normal__block {
    position: relative;
    float: left;
    width: 510px;
    overflow: visible
}


#top .normal__title {
    height: 120px;
    overflow: visible;
    position: relative
}

#top .normal__price {
    color: #FFF;
    font-size: 16px;
    padding-left: 9px;
    margin-bottom: 10px;
    position: absolute;
    bottom: 80px;
    right: 66px;
}

#top .normal__price span {
    color: #fec500
}

#top .normal__photo {
    padding-left: 15px;
    margin-bottom: 17px;
    position: relative;
    height: 227px;
    overflow: visible
}

#top .normal__btn {
    display: block;
    position: absolute;
    bottom: 10px;
    right: 10px;
}

#top .normal__top {
    *zoom: 1;
    padding-bottom: 45px
}

#top .normal__top:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

/*end20170111=========================================================*/

#top .download-special {
    width: 1024px;
    margin: -50px auto 15px
}

#top .download-special__title {
    text-align: center
}

#top .download-special__body {
    position: relative;
    text-align: center;
    margin-top: -60px
}

#top .download-special__movie {
    position: absolute;
    top: 360px;
    left: 174px
}

#top .download-special__movie a {
    display: block
}

#top .download-special__movie a:after {
    z-index: 2;
    content: "";
    display: block;
    background: url(../img/top/btn_play.png) left top no-repeat;
    width: 99px;
    height: 99px;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: opacity 0.3s
}

#top .download-special__movie a:hover img {
    opacity: 1
}

#top .download-special__movie a:hover:after {
    opacity: 0.7
}

#top .download-special__button {
    text-align: center;
    margin: 5px 0 35px
}

/*20161111====================*/
#top .downloadver {

    width:1024px;
    margin: 0 auto;
    position: relative;

}

#top .download__title {
    text-align: center
}

#top .download__subtitle {
    text-align: center
}

#top .download__price {
    width: 1049px;
    color: #FFF;
    font-size: 16px;
    margin: -40px auto 10px;
    text-align: right;
    padding-right: 50px
}

#top .download__price span {
    color: #fec500
}

#top .download__photo {
    text-align: left;
    margin-bottom: 28px
}

#top .download__btn {
    display: block;
    width: 421px;
    margin: 0 auto;
    position: absolute;
	top: 440px;
    left: 522px;
}

.download__tokuten-senchaku__mov{

	position: absolute;
	top: 233px;
    left: 610px;

}

@media (max-width: 640px) {
    #top .downloadver {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }

   #top .download__tokuten-senchaku__mov{

	position: static;
    text-align: center;
    margin-bottom: 20px;

	}

	#top .download__btn {
    position: static;
    text-align: center;
    margin-bottom: 20px;
  
}
}
/* end 20161111====================*/
.manual {
    width: 1040px;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 50px
}

@media (max-width: 640px) {
    .manual {
        width: 60%;
        padding: 0 10px;
        margin: 0 auto
    }
}

.manual a {
    margin: 0 18px;
}

@media (max-width: 640px) {
    .manual a{
        display: block;
        margin: 0 18px 10px 18px
    }
}
.limited-btm {
    width: 1024px;
    margin: 0 auto;
    padding-top: 40px;
    margin-top: -10px;
    border-top: 1px solid #fec500;
    color: #FFF;
    margin-bottom: 40px;
    font-size: 13px;
    line-height: 24px
}

@media (max-width: 640px) {
    .limited-btm {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #top img {
        max-width: 100%;
		margin: 0;
    }
    #top #bg1 {
        background-image: url(../img/top/sp/bg1.jpg)
    }
    #top #bg2 {
        background-image: url(../img/top/sp/bg2.jpg)
    }
    #top #bg3 {
        background-image: url(../img/top/sp/bg4.jpg)
    }
    #top #bg4 {
        background-image: url(../img/top/sp/bg3.jpg)
    }
    #top #bg5 {
        background-image: url(../img/top/sp/bg5.png)
    }
    #top .bg {
        background-position: center top;
        background-size: cover;
        position: fixed;
        top: 0;
        left: 0;
        display: block;
        width: 100%;
        height: 100%;
        z-index: 100
    }
    #top .container {
        min-width: 0;
        position: relative;
        z-index: 101;
        overflow: hidden
    }
    #top .main {
        background: none
    }
    #top .main__extention {
        background: url(../img/top/sp/main_bg2.png) center center no-repeat;
        background-position: center top;
        background-size: 100% auto
    }
    #top .main__wrap {
        padding: 0 0;
        background: url(../img/top/sp/title_copy_2.png) 480px 20px no-repeat;
        height: auto
    }
    #top .main__btm {
        display: block;
        bottom: auto;
        top: 428px;
        left: 50%;
        transform: translateX(-50%)
    }
    #top .main__top {
        width: 100%;
        text-align: center;
        position: relative;
        top: 0;
        left: 0;
        padding-top: 450px;
        z-index: 902;
        transform: translate(0, 0)
    }
    #top .main__top img {
        margin-left: 20px
    }
    #top .main__release {
        width: 100%;
        bottom: 100px;
        left: auto;
        right: 0;
        text-align: center;
        position: relative;
        height: 100px;
        overflow: visible;
        margin-bottom: -30px
    }
    #top .main__release img {
        position: absolute;
        top: -110px;
        left: -20px
    }
    #top .main__catch {
        display: none
    }
    #top .main__catch2 {
        display: none
    }
    #top .main__banner {
        display: block;
        text-align: center;
        position: relative;
        bottom: 0px;
        left: 0px;
        background: none;
        z-index: 902;
        margin-bottom: 30px
    }
    #top .main__banner a {
        margin-bottom: 10px;
        display: block
    }
    #top .main__banner a:first-child {
        margin-right: 0
    }
    #top .main.limited .main__wrap {
        background: none
    }
    #top .main.limited .main__extention {
        background: url(../img/top/sp/main_bg_limited.png) center top no-repeat;
        background-size: auto 597px
    }
    #top .main.limited .main__catch {
        display: none !important
    }
    #top .main.limited .main__catch2 {
        display: none !important
    }
    #top .main.limited .main__particles {
        display: none !important
    }
    #top .main.limited .main__top {
        padding-top: 550px
    }
    #top .main.limited .main__limited__meteor {
        background: url(../img/top/sp/main_bg_limited_meteor.png) center top no-repeat;
        background-size: auto 597px
    }
    #top .main.limited .main__limited__stars {
        display: block
    }
    #top .main .sns__btns {
        position: static;
        text-align: center;
        overflow: hidden
    }
    #top .main .sns__btns li {
        float: none;
        display: inline;
        margin: 0 9px
    }
    #top .main .sns__btns li a {
        background-color: #17a1d0;
        display: inline-block
    }
    #top .main__spmovies {
        display: block;
        position: relative;
        margin-top: 16px;
        margin-bottom: 20px
    }
    #top .main__spmovies .movie {
        padding: 10px
    }
    #top .main__spmovies .movie__thum img {
        width: 100%;
        height: auto
    }
    #top .main__spmovies .movie__thum a {
        display: block;
        position: relative
    }
    #top .main__spmovies .movie__thum a:after {
        z-index: 2;
        content: "";
        display: block;
        background: url(../img/top/sp/btn_play.png) left top no-repeat;
        width: 222px;
        height: 221px;
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%)
    }
    #top .main-bottom-banner {
        display: none;
        background: none;
        padding-top: 0;
        margin-top: 0;
        line-height: 0;
        margin-bottom: 20px;
        position: relative;
        top: 0;
        left: 0;
        z-index: 902;
        text-align: center
    }
    #top .main-bottom-banner--sp {
        display: block
    }
    #top .main-bottom-banner__wrap {
        width: 1024px;
        margin: 0 auto;
        overflow: hidden
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #top .main-bottom-banner__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #top .main-bottom-banner a {
        display: block;
        margin-right: 0px;
        margin-bottom: 10px
    }
    #top .main-bottom-banner a:last-child {
        margin-right: 0px;
        margin-bottom: 0
    }
    #top .main-bottom-banner .trial {
        float: none;
        width: 606px;
        height: 87px;
        margin: 0 auto 10px;
        position: relative
    }
    #top .main-bottom-banner .trial__under {
        display: block;
        width: 606px;
        height: 87px;
        position: absolute;
        top: 0;
        left: 0
    }
    #top .main-bottom-banner .trial__btns {
        overflow: hidden;
        position: absolute;
        top: 30px;
        left: 168px
    }
    #top .main-bottom-banner .trial__btns li {
        float: left
    }
    #top .main-bottom-banner .trial__btns a {
        width: 144px;
        height: 52px;
        margin: 0
    }
    #top .main-bottom-banner .trial__btns a img {
        margin: 8px 0 0 8px
    }
    #top .main-bottom-banner .doublecamp {
        float: left
    }
    #top .topics {
        background: none
    }
    #top .topics .news {
        width: 100%;
        height: 225px;
        background: url(../img/top/sp/news_bg.png) top center no-repeat;
        margin-bottom: 20px;
        float: none
    }
    #top .topics .news__pane {
        left: 2%;
        height: 180px;
        width: 96% !important;
        overflow-y: scroll;
        line-height: 18px
    }
    #top .topics .news__pane dl {
        display: table;
        border-spacing: 0 10px
    }
    #top .topics .news__pane dl dt {
        display: table-cell;
        width: 100px;
        float: none
    }
    #top .topics .news__pane dl dd {
        display: table-cell;
        float: none;
        width: auto
    }
    #top .topics .news__pane .jspContainer,
    #top .topics .news__pane .jspPane {
        width: 100% !important
    }
    #top .topics .twitter {
        width: 100%;
        height: 225px;
        background: url(../img/top/sp/twitter_bg.png) top center no-repeat;
        margin-bottom: 20px;
        float: none
    }
    #top .topics .twitter__pane {
        position: absolute;
        left: 6px;
        top: 35px;
        width: 600px;
        height: 180px;
        overflow: hidden
    }
    #top .topics .twitter__pane iframe {
        width: 600px !important
    }
    #top .tokuten {
        margin-bottom: 40px
    }
    #top .tokuten .tokuten-senchaku__btn {
        width: 304px;
        margin: 0 auto;
        position: static;
        display: block
    }
    #top .tokuten .tokuten-senchaku__illust {
        text-align: center;
        padding-bottom: 0
    }
    #top .tokuten .tokuten-senchaku__mov {
        position: static;
        text-align: center;
        margin-bottom: 20px
    }
    #top .tokuten .tokuten-senchaku__mov a:after {
        background: none
    }
    #top .tokuten .tokuten-shop__title {
        position: static
    }
    #top .tokuten .tokuten-shop__photo {
        position: static;
        width: 100%;
        text-align: center;
        margin-bottom: 20px
    }
    #top .tokuten .tokuten-shop__btn {
        width: 304px;
        margin: 0 auto;
        position: static;
        display: block
    }
    #top .premium {
        padding-bottom: 0;
        margin-bottom: 40px;
        background: url(../img/top/sp/premium_bg.png) center center no-repeat
    }
    #top .premium__btn {
        width: 304px;
        margin: 0 auto;
        position: static;
        display: block
    }
    #top .premium__price {
        display: none
    }
    #top .limited {
        margin-top: 40px
    }
    #top .limited__block {
        width: 100%
    }
    #top .limited__block--ps4 .limited__chara {
        top: 20px;
        right: -155px;
        z-index: 1
    }
    #top .limited__block--psvita .limited__chara {
        top: 20px;
        right: -15px;
        z-index: 1
    }
    #top .limited__block--psvita .limited__title img {
        margin-top: 0
    }
    #top .limited__chara img {
        width: 90%;
        height: auto
    }
    #top .limited__title {
        height: 270px
    }
    #top .limited__price {
        margin-bottom: 20px
    }
    #top .limited__photo {
        margin-bottom: 20px;
        height: auto;
        z-index: 2
    }
    #top .limited__btn {
        width: 304px;
        margin: 0 auto;
        position: static;
        display: block;
        margin-bottom: 40px
    }
    #top .limited__top {
        border-bottom: none;
        padding-bottom: 0
    }
    #top .limited__btm {
        display: none
    }
    #top .download-special {
        width: auto;
        margin: 0px auto 15px
    }
    #top .download-special__title {
        text-align: center
    }
    #top .download-special__body {
        margin-top: -40px;
        position: relative;
        text-align: center
    }
    #top .download-special__movie {
        position: relative;
        top: 0;
        left: 0;
        margin-bottom: 20px
    }
    #top .download-special__movie a {
        display: block
    }
    #top .download-special__movie a:after {
        display: none
    }
    #top .download-special__text {
        margin-bottom: 10px
    }
    #top .download-special__button {
        text-align: center;
        position: static;
        right: 0;
        bottom: 0;
        margin: 10px 0 60px
    }
    .limited-btm {
        margin: 0 15px 20px;
        padding-top: 10px
    }
    .manual {
        text-align: center;
        margin-top: 40px;
        margin-bottom: 50px
    }
    .manual a {
        margin-left: 0;
        margin-right: 7px
    }
    .manual a:last-child {
        margin-right: 0
    }



/*20170111======================================*/
    #top .normal {
        margin-top: 40px
    }
    #top .normal__block {
        width: 100%
    }
    #top .normal__photo {
        
    height: auto;
}
/*end20170111======================================*/
}

.bg-layer {
    display: none;
    background: rgba(0, 0, 0, 0.5);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000
}
.movie-layer {
    display: none;
    position: absolute;
    top: 155px;
    left: 50%;
    z-index: 1001;
    transform: translateX(-50%)
}

.movie-layer__close {
    margin-top: 17px;
    text-align: center
}

#character .header-l {
    margin-bottom: -9px
}

#character .pankuzu {
    padding-left: 15px;
    margin-bottom: 45px;
    position: relative;
    z-index: 2
}

#character .character {
    padding-top: 9px;
    overflow: hidden
}

#character .character--index {
    background: url(../img/character/bg_top.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--index-1 {
    background: url(../img/character/bg_character_list_01.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--index-2 {
    background: url(../img/character/bg_character_list_02.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--index-3 {
    background: url(../img/character/bg_character_list_03.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--index-4 {
    background: url(../img/character/bg_character_list_04.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--index-master {
    background: url(../img/character/bg_top_master.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--nero {
    background: url(../img/character/c01_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--tamamonomae {
    background: url(../img/character/c02_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--attlia {
    background: url(../img/character/c03_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--attlia .character-image {
    margin-left: 0
}

#character .character--attlia .character-image__voice {
    left: 119px
}

#character .character--attlia .character-image__movie {
    left: 123px
}

#character .character--attlia .character-image__text {
    margin-left: -487px
}

#character .character--altria {
    background: url(../img/character/c04_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--mumei {
    background: url(../img/character/c05_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--gilgamesh {
    background: url(../img/character/c06_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--gilgamesh .character-footer {
    margin-top: -50px
}

#character .character--elizabeth {
    background: url(../img/character/c07_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--elizabeth .character-footer {
    margin-top: 10px
}

#character .character--jeanne {
    background: url(../img/character/c08_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--gawein {
    background: url(../img/character/c09_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--gawein .character-image__text {
    top: 757px;
    left: 50%;
    margin-left: -449px
}

#character .character--gawein .character-image {
    margin-bottom: -10px
}

#character .character--karna {
    background: url(../img/character/c10_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--karna .character-image__text {
    margin-left: -448px
}

#character .character--ryofu {
    background: url(../img/character/c11_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--ryofu .character-image {
    margin-left: -210px;
    margin-bottom: -150px
}

#character .character--ryofu .character-image__voice {
    left: 329px
}

#character .character--ryofu .character-image__movie {
    left: 333px
}

#character .character--ryofu .character-image__text {
    margin-left: -418px;
    margin-top: 0px
}

#character .character--iskandar {
    background: url(../img/character/c12_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--iskandar .character-image {
    margin-left: 10px;
    margin-bottom: -216px
}

#character .character--iskandar .character-image__text {
    top: 758px;
    margin-left: -482px
}

#character .character--iskandar .character-image__voice {
    left: 109px
}

#character .character--iskandar .character-image__movie {
    left: 113px
}

#character .character--iskandar .character-footer {
    margin-bottom: 50px
}

#character .character--cuchulainn {
    background: url(../img/character/c13_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--cuchulainn .character-image {
    margin-bottom: -40px
}

#character .character--cuchulainn .character-image__text {
    top: 755px;
    margin-left: -450px
}

#character .character--lishuwen {
    background: url(../img/character/c14_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--lishuwen .character-image {
    margin-bottom: -180px
}

#character .character--lishuwen .character-image__text {
    top: 754px;
    margin-left: -462px
}

#character .character--lishuwen .character-footer {
    margin-top: 160px
}

#character .character--medusa {
    background: url(../img/character/c15_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--archimedes {
    background: url(../img/character/c16_bg.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--archimedes .character-image__text {
    top: 708px;
    margin-left: -422px
}

#character .character--master {
    background: url(../img/character/bg_master.png) center top no-repeat #000;
    background-size: cover;
    background-attachment: fixed
}

#character .character--master .character-image {
    margin-top: -40px;
    margin-left: -200px;
    margin-left: -200px
}

#character .character--master .character-footer {
    margin-top: -160px
}

#character .character--master .back {
    margin-top: 74px
}

#character .character-header {
    margin-bottom: 10px
}

#character .character-header__wrap {
    width: 1024px;
    margin: 0 auto;
    padding-top: 20px
}

@media (max-width: 640px) {
    #character .character-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#character .character-index {
    width: 1024px;
    margin: 0 auto;
    *zoom: 1;
    padding-bottom: 100px;
    position: relative;
    min-height: 646px
}

@media (max-width: 640px) {
    #character .character-index {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#character .character-index:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#character .character-index__logo {
    position: absolute;
    right: -280px;
    top: -164px
}

#character .character-index__logo--4 {
    top: -124px
}

#character .character-navi {
    float: left;
    margin-right: 52px
}

#character .character-navi__title {
    margin-left: -10px
}

#character .character-navi__list {
    margin-bottom: 40px
}

#character .character-navi li {
    position: relative;
    margin-bottom: 9px
}

#character .character-navi li.navi-1 a {
    background: url(../img/character/btn_character_navi_nero.png) left top no-repeat
}

#character .character-navi li.navi-1 a:hover {
    background: url(../img/character/btn_character_navi_nero_on.png) left top no-repeat
}

#character .character-navi li.navi-1 a.is-active {
    background: url(../img/character/btn_character_navi_nero_on.png) left top no-repeat
}

#character .character-navi li.navi-2 a {
    background: url(../img/character/btn_character_navi_tama.png) left top no-repeat
}

#character .character-navi li.navi-2 a:hover {
    background: url(../img/character/btn_character_navi_tama_on.png) left top no-repeat
}

#character .character-navi li.navi-2 a.is-active {
    background: url(../img/character/btn_character_navi_tama_on.png) left top no-repeat
}

#character .character-navi li.navi-3 a {
    background: url(../img/character/btn_character_navi_attila.png) left top no-repeat
}

#character .character-navi li.navi-3 a:hover {
    background: url(../img/character/btn_character_navi_attila_on.png) left top no-repeat
}

#character .character-navi li.navi-3 a.is-active {
    background: url(../img/character/btn_character_navi_attila_on.png) left top no-repeat
}

#character .character-navi li.navi-4 a {
    background: url(../img/character/btn_character_navi_other.png) left top no-repeat
}

#character .character-navi li.navi-4 a:hover {
    background: url(../img/character/btn_character_navi_other_on.png) left top no-repeat
}

#character .character-navi li.navi-4 a.is-active {
    background: url(../img/character/btn_character_navi_other_on.png) left top no-repeat
}

#character .character-navi li.navi--new a:after {
    content: "";
    background: url(../img/character/ico_new.png) left top no-repeat;
    background-size: 50px auto;
    width: 50px;
    height: 16px;
    top: -4px;
    right: -4px;
    display: block;
    position: absolute
}

#character .character-navi a {
    width: 241px;
    height: 67px;
    display: block;
    background: url(../img/character/btn_character_navi.png) left top no-repeat;
    padding-left: 33px;
    color: #fff;
    line-height: 60px;
    font-size: 16px
}

#character .character-navi a span {
    font-size: 13px
}

#character .character-navi a:hover {
    background: url(../img/character/btn_character_navi_on.png) left top no-repeat
}

#character .character-navi a.is-active {
    background: url(../img/character/btn_character_navi_on.png) left top no-repeat
}

#character .character-list {
    float: left;
    position: relative;
    z-index: 2;
    margin-top: 10px;
    margin-right: -20px
}

#character .character-list li a {
    display: block
}

#character .character-list li.new a {
    position: relative
}

#character .character-list li.new a:after {
    content: "";
    background: url(../img/character/ico_new.png) left top no-repeat;
    width: 60px;
    height: 20px;
    display: block;
    position: absolute;
    top: 37px;
    left: 292px
}

#character .character-detail {
    width: 1024px;
    margin: 0 auto;
    position: relative;
    padding-bottom: 25px
}

@media (max-width: 640px) {
    #character .character-detail {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#character .character-image {
    margin-top: -130px;
    margin-left: -100px;
    text-align: center;
    position: relative;
    z-index: 1
}

#character .character-image__voice {
    position: absolute;
    top: 201px;
    left: 219px;
    text-align: left
}

#character .character-image__movie {
    position: absolute;
    top: 267px;
    left: 223px
}

#character .character-image__movie .trailer-title {
    text-align: left;
    position: absolute;
    top: -25px;
    left: -2px
}

#character .character-image__movie a {
    display: block;
    position: relative
}

#character .character-image__movie a:after {
    content: "";
    display: block;
    background: url(../img/character/btn_play2.png) left top no-repeat;
    width: 74px;
    height: 74px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%)
}

#character .character-image__text {
    text-align: left;
    color: #fff;
    position: absolute;
    top: 760px;
    left: 50%;
    margin-left: -437px;
    line-height: 2;
    font-size: 15px
}

#character .character-image__text--master-1 {
    margin-left: -398px;
    top: 370px
}

#character .character-image__text--master-2 {
    margin-left: -354px;
    top: 480px
}

#character .character-image__text--master-3 {
    margin-left: -398px;
    top: 533px
}

#character .character-footer {
    *zoom: 1;
    padding-bottom: 30px;
    margin-bottom: 50px;
    position: relative;
    z-index: 2
}

#character .character-footer:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#character .character-thums {
    position: relative;
    float: left;
    margin-left: 30px
}

#character .character-thums ul {
    *zoom: 1
}

#character .character-thums ul:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#character .character-thums ul li {
    position: relative;
    float: left;
    margin-right: 4px;
    margin-bottom: 10px
}

#character .character-thums ul.col-3 li:nth-child(3n) {
    margin-right: 0
}

#character .character-thums ul.col-3 li:nth-child(3n+1) {
    clear: both
}

#character .character-thums ul a {
    display: block;
    position: relative
}

#character .character-thums ul a.movie:before {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    display: block;
    content: "";
    background: url(../img/character/btn_play.png) left top no-repeat;
    width: 50px;
    height: 50px;
    z-index: 2
}

#character .character-thums .zoom:after {
    content: "";
    display: block;
    background: url(../img/character/ico_plus.png) left top no-repeat;
    width: 25px;
    height: 25px;
    position: absolute;
    top: -10px;
    right: -5px
}

#character .character-subnavi {
    float: right;
    margin-bottom: 20px
}

#character .character-subnavi ul {
    overflow: hidden;
    *zoom: 1
}

#character .character-subnavi ul li {
    float: left;
    margin-right: -4px;
    background: url(../img/character/bg_character_thum.png) center center no-repeat
}

#character .character-subnavi ul li a {
    transition: opacity 0.2s;
    opacity: 0.3
}

#character .character-subnavi ul li a:hover {
    opacity: 1
}

#character .character-subnavi ul li a:hover img {
    opacity: 1
}

#character .character-subnavi ul li.is-active a {
    opacity: 1
}

#character .back {
    clear: both;
    float: right
}

#character .navi-left {
    position: absolute;
    top: 300px;
    left: 0;
    z-index: 2
}

#character .navi-right {
    position: absolute;
    top: 300px;
    right: 0;
    z-index: 2
}

#character .zoom-modal {
    position: absolute;
    display: none;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    z-index: 1002
}

#character .zoom-modal__close {
    position: absolute;
    top: -55px;
    right: -55px;
    z-index: 101
}

#character .zoom-modal__close a {
    background: url(../img/spec/btn_modal_close.png) left top no-repeat;
    display: block;
    width: 106px;
    height: 106px
}

#character .zoom-modal__image {
    width: 939px;
    height: 528px
}

#character .zoom-modal__prev {
    display: block;
    position: absolute;
    left: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#character .zoom-modal__next {
    display: block;
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#character .bg-layer {
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    z-index: 1001
}

@media (max-width: 640px) {
    #character .character--index {
        background: url(../img/character/sp/bg_top.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: scroll
    }
    #character .character--nero {
        background: url(../img/character/sp/c01_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: scroll
    }
    #character .character--tamamonomae {
        background: url(../img/character/sp/c02_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--tamamonomae .character-image {
        padding-bottom: 60px
    }
    #character .character--tamamonomae .character-image__text {
        top: 1080px
    }
    #character .character--attlia {
        background: url(../img/character/sp/c03_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--attlia .character-image__text {
        top: 980px;
        margin-left: -286px
    }
    #character .character--altria {
        background: url(../img/character/sp/c04_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--altria .character-image__text {
        top: 970px
    }
    #character .character--mumei {
        background: url(../img/character/sp/c05_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--mumei .character-image {
        padding-bottom: 30px
    }
    #character .character--mumei .character-footer {
        margin-top: 0px
    }
    #character .character--mumei .character-image__text {
        top: 1030px
    }
    #character .character--gilgamesh {
        background: url(../img/character/sp/c06_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--gilgamesh .character-image {
        padding-bottom: 110px
    }
    #character .character--gilgamesh .character-image__text {
        top: 980px
    }
    #character .character--elizabeth {
        background: url(../img/character/sp/c07_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--elizabeth .character-image {
        padding-bottom: 190px
    }
    #character .character--elizabeth .character-image__text {
        top: 1120px
    }
    #character .character--jeanne {
        background: url(../img/character/sp/c08_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--jeanne .character-image {
        padding-bottom: 20px
    }
    #character .character--jeanne .character-image__text {
        top: 1010px
    }
    #character .character--gawein {
        background: url(../img/character/sp/c09_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--gawein .character-image {
        padding-top: 20px;
        padding-bottom: 100px
    }
    #character .character--gawein .character-image__text {
        top: 1010px;
        margin-left: -286px
    }
    #character .character--karna {
        background: url(../img/character/sp/c10_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--karna .character-image {
        padding-top: 0px;
        padding-bottom: 0px;
        margin-bottom: -40px
    }
    #character .character--karna .character-image__text {
        top: 980px;
        margin-left: -286px
    }
    #character .character--ryofu {
        background: url(../img/character/sp/c11_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--ryofu .character-image {
        padding-top: 0px;
        padding-bottom: 0px;
        margin-bottom: -190px;
        margin-left: 0
    }
    #character .character--ryofu .character-image img {
        margin-top: -70px
    }
    #character .character--ryofu .character-image__text {
        top: 1000px;
        margin-left: -286px
    }
    #character .character--ryofu .character-image__voice {
        top: 175px
    }
    #character .character--ryofu .character-image__zoom {
        top: 100px
    }
    #character .character--iskandar {
        background: url(../img/character/sp/c11_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--iskandar .character-image {
        padding-top: 0px;
        padding-bottom: 0px;
        margin-bottom: -530px;
        margin-left: 0;
        margin-top: 64px
    }
    #character .character--iskandar .character-image img {
        margin-top: -70px
    }
    #character .character--iskandar .character-image__text {
        top: 860px;
        margin-left: -286px
    }
    #character .character--iskandar .character-image__zoom {
        top: 16px
    }
    #character .character--iskandar .character-image__voice {
        top: 91px
    }
    #character .character--iskandar .navi-left {
        top: 186px
    }
    #character .character--iskandar .navi-right {
        top: 186px
    }
    #character .character--iskandar .character-footer {
        margin-bottom: 0
    }
    #character .character--cuchulainn {
        background: url(../img/character/sp/c13_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--cuchulainn .character-image {
        padding-top: 0px;
        padding-bottom: 0px;
        margin-bottom: -40px;
        margin-left: 0
    }
    #character .character--cuchulainn .character-image__text {
        top: 980px;
        margin-left: -286px
    }
    #character .character--cuchulainn .character-image__footer {
        margin-top: 40px
    }
    #character .character--cuchulainn .character-footer {
        margin-top: 20px
    }
    #character .character--lishuwen {
        background: url(../img/character/sp/c14_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--lishuwen .character-image {
        padding-top: 0px;
        padding-bottom: 0px;
        margin-bottom: -40px
    }
    #character .character--lishuwen .character-image__text {
        top: 980px;
        margin-left: -286px
    }
    #character .character--lishuwen .character-image__footer {
        margin-top: 40px
    }
    #character .character--lishuwen .character-footer {
        margin-top: 40px
    }
    #character .character--medusa {
        background: url(../img/character/sp/c15_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--medusa .character-image {
        margin-bottom: 20px
    }
    #character .character--medusa .character-image__text {
        top: 970px;
        margin-left: -286px
    }
    #character .character--archimedes {
        background: url(../img/character/sp/c16_bg.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--archimedes .character-image {
        margin-bottom: 0px
    }
    #character .character--archimedes .character-image__text {
        top: 990px;
        margin-left: -286px
    }
    #character .character--master {
        background: url(../img/character/sp/bg_master.png) center top no-repeat #000;
        background-size: cover;
        background-attachment: fixed
    }
    #character .character--master .character-image {
        margin-top: 40px;
        margin-left: 0px
    }
    #character .character--master .character-image__zoom {
        top: -40px
    }
    #character .character--master .character-footer {
        margin-top: -60px
    }
    #character .character--master .back {
        margin-top: 0px
    }
    #character .character-header {
        padding-top: 20px;
        margin-bottom: 0px;
        position: relative;
        z-index: 2
    }
    #character .character-header__wrap {
        width: 1024px;
        margin: 0 auto;
        padding-top: 20px
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #character .character-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #character .character-index {
        min-height: 0px;
        padding: 0 0 120px
    }
    #character .character-index__logo {
        display: none
    }
    #character .character-navi {
        display: none
    }
    #character .character-list {
        float: none;
        margin-top: 10px;
        margin-right: 0px;
        margin-bottom: 10px
    }
    #character .character-list__title {
        padding: 0 5px;
        margin-bottom: 5px
    }
    #character .character-list li {
        margin-top: -5px
    }
    #character .character-list li a {
        display: block;
        padding-left: 5px
    }
    #character .character-list li a img {
        width: 100%
    }
    #character .character-list li.new a {
        position: relative
    }
    #character .character-list li.new a:after {
        top: 29px;
        left: 244px
    }
    #character .character-detail {
        position: relative;
        padding: 0 0 40px
    }
    #character .character-image {
        margin-top: -20px;
        margin-left: 0px;
        margin-bottom: 40px;
        text-align: center;
        position: relative
    }
    #character .character-image__zoom {
        position: absolute;
        top: 40px;
        right: 18px
    }
    #character .character-image__voice {
        position: absolute;
        top: 120px;
        left: auto;
        right: 24px;
        text-align: right
    }
    #character .character-image__movie {
        display: none
    }
    #character .character-image__text {
        text-align: left;
        color: #fff;
        position: absolute;
        top: 1010px;
        left: 50%;
        margin-left: -286px;
        line-height: 2;
        font-size: 22px
    }
    #character .character-image__text--master-1 {
        margin-left: -286px;
        top: 470px;
        line-height: 1.8
    }
    #character .character-image__text--master-2 {
        margin-left: -236px;
        top: 612px;
        line-height: 1.8
    }
    #character .character-image__text--master-3 {
        margin-left: -286px;
        top: 672px;
        line-height: 1.8
    }
    #character .character-footer {
        *zoom: 1;
        margin-top: 0px;
        padding-bottom: 50px
    }
    #character .character-footer:after {
        content: "\0020";
        display: block;
        height: 0;
        clear: both;
        overflow: hidden;
        visibility: hidden
    }
    #character .character-thums {
        position: relative;
        float: none;
        margin-left: 0px;
        margin-bottom: 45px;
        padding: 0 10px
    }
    #character .character-thums ul {
        *zoom: 1
    }
    #character .character-thums ul:after {
        content: "\0020";
        display: block;
        height: 0;
        clear: both;
        overflow: hidden;
        visibility: hidden
    }
    #character .character-thums ul.v-sp {
        display: -webkit-box;
        -webkit-overflow-scrolling: touch;
        display: box;
        overflow-x: scroll
    }
    #character .character-thums ul li {
        float: none;
        display: block;
        margin-right: 7px;
        margin-bottom: 10px
    }
    #character .character-thums ul.col-3 li:nth-child(3n) {
        margin-right: 0
    }
    #character .character-thums ul.col-3 li:nth-child(3n+1) {
        clear: both
    }
    #character .character-thums ul a {
        display: block;
        position: relative
    }
    #character .character-thums ul a.movie:before {
        background: url(../img/character/btn_play2.png) left top no-repeat;
        width: 74px;
        height: 74px
    }
    #character .character-thums .zoom:after {
        content: "";
        display: block;
        background: url(../img/character/sp/ico_plus.png) left top no-repeat;
        width: 36px;
        height: 36px;
        position: absolute;
        top: -10px;
        right: -5px
    }
    #character .character-subnavi {
        float: none;
        position: static;
        margin-bottom: 35px;
        width: auto
    }
    #character .character-subnavi ul {
        overflow: visible
    }
    #character .character-subnavi ul.v-sp {
        display: box;
        display: -webkit-box;
        overflow: scroll;
        -webkit-overflow-scrolling: touch;
        padding: 0 0
    }
    #character .character-subnavi ul li {
        float: none;
        margin: 0;
        padding: 0 13px;
        background: url(../img/character/sp/bg_character_thum.png) center center no-repeat
    }
    #character .character-subnavi ul li a {
        transition: opacity 0.2s;
        opacity: 0.3
    }
    #character .character-subnavi ul li a:hover {
        opacity: 1
    }
    #character .character-subnavi ul li a:hover img {
        opacity: 1
    }
    #character .character-subnavi ul li.is-active a {
        opacity: 1
    }
    #character .back {
        position: static;
        clear: both;
        float: none;
        text-align: center
    }
    #character .navi-left {
        position: absolute;
        top: 270px;
        left: 0
    }
    #character .navi-right {
        position: absolute;
        top: 270px;
        right: 0
    }
    #character .zoom-modal {
        position: absolute;
        display: none;
        left: 50%;
        top: 0;
        transform: translate(-50%, -50%);
        z-index: 1002;
        min-width: 100%
    }
    #character .zoom-modal__close {
        position: absolute;
        top: -115px;
        right: 10px
    }
    #character .zoom-modal__close a {
        background: url(../img/spec/sp/btn_modal_close.png) left top no-repeat;
        display: block;
        width: 106px;
        height: 106px
    }
    #character .zoom-modal__image {
        text-align: center;
        width: 640px;
        height: 360px
    }
    #character .zoom-modal__prev {
        display: block;
        position: absolute;
        left: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #character .zoom-modal__next {
        display: block;
        position: absolute;
        right: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #character .bg-layer {
        background: rgba(0, 0, 0, 0.8);
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        display: none;
        z-index: 1001
    }
}

#introduction {
    background-color: #000;
    overflow-x: hidden
}

#introduction .zoom-modal {
    position: absolute;
    display: none;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    z-index: 102
}

#introduction .zoom-modal__close {
    position: absolute;
    top: -55px;
    right: -55px;
    z-index: 101
}

#introduction .zoom-modal__close a {
    background: url(../img/spec/btn_modal_close.png) left top no-repeat;
    display: block;
    width: 106px;
    height: 106px
}

#introduction .zoom-modal__prev {
    display: block;
    position: absolute;
    left: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#introduction .zoom-modal__next {
    display: block;
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#introduction .bg-layer {
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    z-index: 101
}

#introduction #bg1 {
    background-image: url(../img/introduction/bg1.jpg)
}

#introduction #bg2 {
    background-image: url(../img/introduction/bg2.jpg)
}

#introduction #bg3 {
    background-image: url(../img/introduction/bg3.jpg)
}

#introduction .bg {
    background-position: center top;
    background-size: cover;
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 100
}

#introduction .container {
    min-width: 1024px;
    position: relative;
    z-index: 101
}

#introduction .introduction-header {
    margin-bottom: 10px
}

#introduction .introduction-header__wrap {
    width: 1024px;
    margin: 0 auto;
    padding-top: 20px
}

@media (max-width: 640px) {
    #introduction .introduction-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#introduction .pankuzu {
    padding-left: 15px;
    margin-bottom: 45px;
    position: relative;
    z-index: 2
}

#introduction .introduction__content {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden;
    *zoom: 1;
    padding-bottom: 100px;
    overflow: visible
}

@media (max-width: 640px) {
    #introduction .introduction__content {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#introduction .introduction .allstar__title {
    height: 135px;
    overflow: visible;
    position: relative
}

#introduction .introduction .allstar__title img {
    position: absolute;
    top: -65px;
    left: 0
}

#introduction .introduction .allstar__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    position: relative;
    padding-left: 5px
}

@media (max-width: 640px) {
    #introduction .introduction .allstar__text {
        font-size: 25px;
        max-height: 10000px
    }
}

#introduction .introduction .allstar__triangle {
    text-align: center;
    height: 400px;
    overflow: visible;
    position: relative
}

#introduction .introduction .allstar__triangle img {
    position: absolute;
    left: -20px;
    top: -100px
}

#introduction .introduction .stage {
    position: relative;
    margin-bottom: 50px
}

#introduction .introduction .stage__title {
    height: 260px;
    overflow: visible
}

#introduction .introduction .stage__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 10px
}

@media (max-width: 640px) {
    #introduction .introduction .stage__text {
        font-size: 25px;
        max-height: 10000px
    }
}

#introduction .introduction .stage__text span {
    color: #ffc600
}

#introduction .introduction .stage__thumbs {
    padding-top: 45px;
    overflow: hidden
}

#introduction .introduction .stage__thumbs li {
    float: left;
    margin-right: 4px
}

#introduction .introduction .stage__thumbs li.last {
    margin-right: 0
}

#introduction .introduction .message__title {
    height: 170px;
    overflow: visible
}

#introduction .introduction .message__block {
    padding: 40px 0;
    overflow: hidden
}

#introduction .introduction .message__block--scenario {
    background: url(../img/introduction/block03_border.png) center bottom no-repeat
}

#introduction .introduction .message__name {
    float: left;
    width: 320px;
    text-align: center
}

#introduction .introduction .message__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    float: left;
    width: 700px
}

@media (max-width: 640px) {
    #introduction .introduction .message__text {
        font-size: 25px;
        max-height: 10000px
    }
}

#introduction .introduction .about__title {
    height: 220px;
    overflow: hidden
}

#introduction .introduction .about__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px
}

@media (max-width: 640px) {
    #introduction .introduction .about__text {
        font-size: 25px;
        max-height: 10000px
    }
}

@media (max-width: 640px) {
    #introduction .zoom-modal {
        width: 100%
    }
    #introduction .zoom-modal__close {
        top: -110px;
        right: 0
    }
    #introduction .zoom-modal__prev {
        display: block;
        position: absolute;
        left: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #introduction .zoom-modal__next {
        display: block;
        position: absolute;
        right: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #introduction img {
        max-width: 100%
    }
    #introduction #bg1 {
        background-image: url(../img/introduction/sp/bg1.jpg)
    }
    #introduction #bg2 {
        background-image: url(../img/introduction/sp/bg2.jpg)
    }
    #introduction #bg3 {
        background-image: url(../img/introduction/sp/bg3.jpg)
    }
    #introduction .bg {
        background-position: center top;
        background-size: cover;
        position: fixed;
        top: 0;
        left: 0;
        display: block;
        width: 100%;
        height: 100%;
        z-index: 100
    }
    #introduction .container {
        min-width: 0;
        position: relative;
        z-index: 101;
        overflow: hidden
    }
    #introduction .introduction .allstar {
        margin-bottom: 20px
    }
    #introduction .introduction .allstar__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #introduction .introduction .allstar__title img {
        position: static !important
    }
    #introduction .introduction .allstar__triangle {
        height: 250px
    }
    #introduction .introduction .allstar__triangle img {
        top: -40px;
        left: 0
    }
    #introduction .introduction__content {
        padding: 0 10px 180px
    }
    #introduction .introduction .stage__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #introduction .introduction .stage__title img {
        position: static !important
    }
    #introduction .introduction .stage__thumbs li {
        float: left;
        margin-bottom: 10px;
        margin-right: 10px
    }
    #introduction .introduction .stage__thumbs li img {
        width: 200px;
        height: auto
    }
    #introduction .introduction .stage__thumbs--corner {
        margin-right: 0 !important
    }
    #introduction .introduction .message__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #introduction .introduction .message__title img {
        position: static !important
    }
    #introduction .introduction .message__name {
        width: 100%;
        float: none;
        margin-bottom: 40px
    }
    #introduction .introduction .message__block {
        padding: 0 0;
        margin-bottom: 60px
    }
    #introduction .introduction .message__block--scenario {
        background: url(../img/introduction/sp/block03_border.png) center bottom no-repeat;
        padding-bottom: 60px
    }
    #introduction .introduction .message__text {
        width: 100%
    }
    #introduction .introduction .about__title {
        height: auto;
        position: static;
        margin-bottom: 15px;
        height: 120px;
        overflow: visible
    }
    #introduction .introduction .about__title img {
        position: static !important
    }
    #introduction .introduction-header {
        padding-top: 20px;
        margin-bottom: 0px
    }
    #introduction .introduction-header__wrap {
        width: 1024px;
        margin: 0 auto;
        padding-top: 20px
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #introduction .introduction-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#system {
    background-color: #000;
    overflow-x: hidden
}

#system #bg1.highspeed {
    background-image: url(../img/system/highspeed_bg1.jpg)
}

#system #bg1.special {
    background-image: url(../img/system/special_bg1.jpg)
}

#system #bg1.form {
    background-image: url(../img/system/form_bg1.jpg)
}

#system #bg1.hougu {
    background-image: url(../img/system/hougu_bg1.png)
}

#system #bg1.reijyu {
    background-image: url(../img/system/reijyu_bg1.png)
}

#system #bg1.codecast {
    background-image: url(../img/system/codecast_bg1.png)
}

#system #bg1.reisou {
    background-image: url(../img/system/reisou_bg1.png)
}

#system #bg1.stage {
    background-image: url(../img/system/stage_bg1.png)
}

#system #bg1.lvup {
    background-image: url(../img/system/lvup_bg1.png)
}

#system #bg1.freemode {
    background-image: url(../img/system/bg_freemode.png)
}

#system #bg2.highspeed {
    background-image: url(../img/system/highspeed_bg2.jpg)
}

#system #bg2.special {
    background-image: url(../img/system/special_bg2.jpg)
}

#system #bg2.form {
    background-image: url(../img/system/form_bg2.jpg)
}

#system #bg3.highspeed {
    background-image: url(../img/system/highspeed_bg3.jpg)
}

#system #bg3.special {
    background-image: url(../img/system/special_bg3.jpg)
}

#system #bg3.form {
    background-image: url(../img/system/form_bg3.png)
}

#system .bg {
    background-position: center top;
    background-size: cover;
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 100
}

#system .container {
    min-width: 1024px;
    position: relative;
    z-index: 101
}

#system .system-header {
    margin-bottom: 10px
}

#system .system-header__wrap {
    width: 1024px;
    margin: 0 auto;
    padding-top: 20px
}

@media (max-width: 640px) {
    #system .system-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#system .pankuzu {
    padding-left: 15px;
    margin-bottom: 45px
}

#system .system__content {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden;
    *zoom: 1;
    padding-bottom: 100px;
    overflow: visible
}

@media (max-width: 640px) {
    #system .system__content {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#system .system .menu {
    background: url(../img/system/menu_bg.png) left top no-repeat;
    overflow: hidden;
    padding: 28px 0;
    height: 405px;
    margin-bottom: 20px
}

#system .system .menu__box {
    float: right;
    width: 832px
}

#system .system .menu__box--2 {
    margin-top: 30px
}

#system .system .menu__btn {
    float: left;
    margin-left: 6px;
    margin-bottom: 6px;
    position: relative
}

#system .system .menu__btn--new:after {
    content: "";
    position: absolute;
    top: 5px;
    right: 9px;
    display: block;
    background: url(../img/system/ico_new.png) left top no-repeat;
    width: 35px;
    height: 12px
}

#system .system .menu__btn:nth-child(4n+1) {
    clear: both
}

#system .system .menu__btn a {
    padding-left: 20px;
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    width: 202px;
    height: 75px;
    color: #fff;
    font-size: 14px;
    line-height: 1.8;
    background: url(../img/system/menu_btn.png) left top no-repeat
}

#system .system .menu__btn a.is-active {
    background: url(../img/system/menu_btn_on.png) left top no-repeat
}

#system .system .menu__btn a:hover {
    background: url(../img/system/menu_btn_on.png) left top no-repeat
}

#system .system .menu__btn--small a {
    font-size: 14px
}

#system .system .slide {
    overflow: visible;
    position: relative
}

#system .system .slide__main {
    width: 950px;
    text-align: center;
    overflow: hidden;
    margin: 0 auto 1px
}

#system .system .slide__main img {
    display: block;
    width: 100%;
    height: auto
}

#system .system .slide__photo {
    border: 1px solid #ffc601
}

#system .system .slide__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    border-left: 1px solid #feb300;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#system .system .slide__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .slide__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .slide__text--2row {
    margin-bottom: calc(1em + 30px)
}

#system .system .slide__text .ruby {
    display: block;
    font-size: 12px;
    line-height: 1.2
}

#system .system .slide__thumbs {
    display: table;
    width: 965px;
    margin: 0 auto;
    border-spacing: 7px 0
}

#system .system .slide__thumbs li {
    display: table-cell;
    border: 1px solid #ffc601
}

#system .system .slide__thumbs img {
    display: block;
    width: 100%
}

#system .system .slide__controls {
    position: absolute;
    width: 100%;
    overflow: hidden;
    left: 0;
    top: 230px
}

#system .system .slide__control--left {
    float: left
}

#system .system .slide__control--right {
    float: right
}

#system .system .action {
    margin-bottom: 70px
}

#system .system .action__title {
    height: 160px;
    overflow: visible
}

#system .system .action__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .action__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .action__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .action .slide__thumbs {
    margin-top: 12px
}

#system .system .sector {
    margin-bottom: 70px
}

#system .system .sector__title {
    height: 160px;
    overflow: visible
}

#system .system .sector__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .sector__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .sector__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .sector .slide__thumbs {
    margin-top: 40px
}

#system .system .freemode {
    margin-bottom: 70px
}

#system .system .freemode__title {
    height: 130px;
    overflow: visible
}

#system .system .freemode__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 50px
}

#system .system .freemode__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .freemode__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .freemode .slide__thumbs {
    margin-top: 40px
}

#system .system .program {
    margin-bottom: 70px
}

#system .system .program__title {
    height: 125px;
    overflow: visible
}

#system .system .program__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .program__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .program__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .program .slide__text table th,
#system .system .program .slide__text table td {
    vertical-align: top
}

#system .system .program .slide__thumbs {
    margin-top: 40px
}

#system .system .level__title {
    height: 125px;
    overflow: visible
}

#system .system .level__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .level__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .level__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .level .slide__text table th,
#system .system .level .slide__text table td {
    vertical-align: top
}

#system .system .level .slide__thumbs {
    margin-top: 40px
}

#system .system .extra {
    margin-bottom: 70px
}

#system .system .extra__title {
    height: 160px;
    overflow: visible
}

#system .system .extra__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .extra__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .extra__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .extra .slide__thumbs {
    margin-top: 12px
}

#system .system .attribution {
    margin-bottom: 0px
}

#system .system .attribution__title {
    height: 125px;
    overflow: visible
}

#system .system .attribution__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 15px;
    margin-bottom: 20px
}

#system .system .attribution__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .attribution__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .attribution .slide__thumbs {
    margin-top: 12px
}

#system .system .attribution .slide__thumbs img {
    backface-visibility: hidden;
    line-height: 0
}

#system .system .change {
    margin-bottom: 70px
}

#system .system .change__title {
    height: 130px;
    overflow: visible
}

#system .system .change__title--2 {
    height: 150px
}

#system .system .change__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    padding-left: 10px;
    margin-bottom: 20px
}

#system .system .change__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #system .system .change__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#system .system .change__text span {
    font-size: 13px;
    line-height: 13px;
    display: block
}

#system .system .change__nero {
    overflow: visible;
    padding: 70px 0 0;
    position: relative;
    margin-bottom: 20px
}

#system .system .change__nero .character {
    position: absolute;
    top: 0;
    left: -102px;
    height: 490px
}

#system .system .change__nero .character__change-thum {
    position: absolute;
    top: 540px;
    left: 240px;
    z-index: 2
}

#system .system .change__nero .character__change-thum a {
    opacity: 0.5
}

#system .system .change__nero .character__change-thum a.is-active {
    opacity: 1
}

#system .system .change__nero .slide {
    margin-left: 370px
}

#system .system .change__tamamo {
    overflow: visible;
    padding: 160px 0 0;
    position: relative;
    margin-bottom: 150px
}

#system .system .change__tamamo .character {
    position: absolute;
    top: 0;
    right: -110px
}

#system .system .change .slide {
    width: 640px
}

#system .system .change .slide__main {
    width: 550px;
    margin: 0 auto 1px
}

#system .system .change .slide__main li {
    float: left
}

#system .system .change .slide__title {
    padding-left: 40px;
    margin-bottom: 5px
}

#system .system .change .slide__controls {
    top: 160px
}

#system .system .change .slide__thumbs {
    margin-top: 0;
    border-spacing: 6px;
    width: 562px
}

#system .system .change__moon-drive .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system .change__moon-drive .slide__main {
    width: 940px
}

#system .system .change__moon-drive .slide__controls {
    top: 220px
}

#system .system .change__moon-drive .slide__thumbs {
    width: 952px
}

#system .system__hougu .change__hougu .slider-for {
    width: 939px;
    margin: 0 auto;
    position: relative
}

#system .system__hougu .change__hougu .slider-for .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    left: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    margin-top: -40px;
    outline: none;
    cursor: pointer
}

#system .system__hougu .change__hougu .slider-for .slick-prev:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#system .system__hougu .change__hougu .slider-for .slick-prev:hover {
    opacity: 0.8
}

#system .system__hougu .change__hougu .slider-for .slick-prev:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#system .system__hougu .change__hougu .slider-for .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    right: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    outline: none;
    margin-top: -40px;
    cursor: pointer
}

#system .system__hougu .change__hougu .slider-for .slick-next:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#system .system__hougu .change__hougu .slider-for .slick-next:hover {
    opacity: 0.8
}

#system .system__hougu .change__hougu .slider-for .slick-next:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#system .system__hougu .change__hougu .sp-image {
    width: 100%;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box
}

#system .system__hougu .change__hougu .sp-thumbnail {
    width: 148px;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box;
    margin: 0 auto
}

#system .system__hougu .change__hougu .slider-nav-wrap {
    width: 948px;
    height: 126px;
    background: url(../img/gallery/bg_thum_list.png) center top no-repeat;
    margin: 26px auto 0;
    padding-top: 20px
}

#system .system__hougu .change__hougu .slider-nav {
    width: 782px;
    margin: 0 auto
}

#system .system__hougu .change__hougu .slider-nav .slick-slide {
    opacity: 0.7;
    outline: none;
    cursor: pointer
}

#system .system__hougu .change__hougu .slider-nav .slick-slide.slick-current {
    opacity: 1
}

#system .system__hougu .change__hougu .slider-nav .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
    width: 39px;
    height: 45px;
    left: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    margin-top: -22px;
    outline: none;
    cursor: pointer
}

#system .system__hougu .change__hougu .slider-nav .slick-prev:hover {
    opacity: 0.8
}

#system .system__hougu .change__hougu .slider-nav .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
    width: 39px;
    height: 45px;
    right: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    outline: none;
    margin-top: -22px;
    cursor: pointer
}

#system .system__hougu .change__hougu .slider-nav .slick-next:hover {
    opacity: 0.8
}

#system .system__reijyu .change__text {
    margin-bottom: 70px
}

#system .system__reijyu .change__reijyu .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system__reijyu .change__reijyu .slide__main {
    width: 940px
}

#system .system__reijyu .change__reijyu .slide__controls {
    top: 220px
}

#system .system__reijyu .change__reijyu .slide__thumbs {
    width: 952px
}

#system .system__codecast .change__text {
    margin-bottom: 30px
}

#system .system__codecast .change__codecast .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system__codecast .change__codecast .slide__main {
    width: 940px;
    margin-bottom: 20px
}

#system .system__codecast .change__codecast .slide__controls {
    top: 220px
}

#system .system__codecast .change__codecast .slide__thumbs {
    width: 952px
}

#system .system__reisou .change__text {
    margin-bottom: 30px
}

#system .system__reisou .change__reisou .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system__reisou .change__reisou .slide__main {
    width: 940px
}

#system .system__reisou .change__reisou .slide__controls {
    top: 220px
}

#system .system__reisou .change__reisou .slide__thumbs {
    width: 952px
}

#system .system__reisou .change__reisou .slide__thumbs img {
    backface-visibility: hidden
}

#system .system__stage .change__text {
    margin-bottom: 30px
}

#system .system__stage .change__title2 {
    overflow: visible;
    height: 154px
}

#system .system__stage .slide__thum-title {
    margin-bottom: 8px
}

#system .system__stage .slider-for {
    width: 939px;
    margin: 0 auto;
    position: relative
}

#system .system__stage .slider-for .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    left: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    margin-top: -40px;
    outline: none;
    cursor: pointer
}

#system .system__stage .slider-for .slick-prev:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#system .system__stage .slider-for .slick-prev:hover {
    opacity: 0.8
}

#system .system__stage .slider-for .slick-prev:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#system .system__stage .slider-for .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    right: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    outline: none;
    margin-top: -40px;
    cursor: pointer
}

#system .system__stage .slider-for .slick-next:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#system .system__stage .slider-for .slick-next:hover {
    opacity: 0.8
}

#system .system__stage .slider-for .slick-next:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#system .system__stage .sp-image {
    width: 100%;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box
}

#system .system__stage .sp-thumbnail {
    width: 148px;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box;
    margin: 0 auto
}

#system .system__stage .slider-nav-wrap {
    width: 948px;
    height: 126px;
    background: url(../img/gallery/bg_thum_list.png) center top no-repeat;
    margin: 26px auto 0;
    padding-top: 20px
}

#system .system__stage .slider-nav {
    width: 782px;
    margin: 0 auto
}

#system .system__stage .slider-nav .slick-slide {
    opacity: 0.7;
    outline: none;
    cursor: pointer
}

#system .system__stage .slider-nav .slick-slide.slick-current {
    opacity: 1
}

#system .system__stage .slider-nav .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
    width: 39px;
    height: 45px;
    left: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    margin-top: -22px;
    outline: none;
    cursor: pointer
}

#system .system__stage .slider-nav .slick-prev:hover {
    opacity: 0.8
}

#system .system__stage .slider-nav .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
    width: 39px;
    height: 45px;
    right: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    outline: none;
    margin-top: -22px;
    cursor: pointer
}

#system .system__stage .slider-nav .slick-next:hover {
    opacity: 0.8
}

#system .system__stage .change__stage .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system__stage .change__stage .slide__main {
    width: 940px
}

#system .system__stage .change__stage .slide__controls {
    top: 220px
}

#system .system__stage .change__stage .slide__thumbs {
    width: 952px
}

#system .system__stage .change__stage .slide__thumbs img {
    backface-visibility: hidden
}

#system .system__lvup .change__text {
    margin-bottom: 30px
}

#system .system__lvup .change__lvup .slide {
    width: 1024px;
    margin: 0 auto
}

#system .system__lvup .change__lvup .slide__main {
    width: 940px
}

#system .system__lvup .change__lvup .slide__controls {
    top: 220px
}

#system .system__lvup .change__lvup .slide__thumbs {
    width: 952px
}

#system .system__lvup .change__lvup .slide__thumbs img {
    backface-visibility: hidden
}

@media (max-width: 640px) {
    #system img {
        max-width: 100%
    }
    #system #bg1.highspeed {
        background-image: url(../img/system/sp/highspeed_bg1.jpg)
    }
    #system #bg1.special {
        background-image: url(../img/system/sp/special_bg1.jpg)
    }
    #system #bg1.form {
        background-image: url(../img/system/sp/form_bg1.jpg)
    }
    #system #bg1.hougu {
        background-image: url(../img/system/sp/hougu_bg1.png)
    }
    #system #bg1.reijyu {
        background-image: url(../img/system/sp/reijyu_bg1.png)
    }
    #system #bg1.codecast {
        background-image: url(../img/system/sp/codecast_bg1.png)
    }
    #system #bg1.reisou {
        background-image: url(../img/system/sp/reisou_bg1.png)
    }
    #system #bg1.stage {
        background-image: url(../img/system/sp/stage_bg1.png)
    }
    #system #bg1.lvup {
        background-image: url(../img/system/sp/lvup_bg1.png)
    }
    #system #bg2.highspeed {
        background-image: url(../img/system/sp/highspeed_bg2.jpg)
    }
    #system #bg2.special {
        background-image: url(../img/system/sp/special_bg2.jpg)
    }
    #system #bg2.form {
        background-image: url(../img/system/sp/form_bg2.jpg)
    }
    #system #bg3.highspeed {
        background-image: url(../img/system/sp/highspeed_bg3.jpg)
    }
    #system #bg3.special {
        background-image: url(../img/system/sp/special_bg3.jpg)
    }
    #system #bg3.form {
        background-image: url(../img/system/sp/form_bg3.png)
    }
    #system .bg {
        background-position: center top;
        background-size: cover;
        position: fixed;
        top: 0;
        left: 0;
        display: block;
        width: 100%;
        height: 100%;
        z-index: 100
    }
    #system .container {
        min-width: 0;
        position: relative;
        z-index: 101;
        overflow: hidden
    }
    #system .system {
        padding-top: 20px
    }
    #system .system .menu {
        display: table;
        width: 100%;
        height: auto;
        background: url(../img/system/sp/menu_bg.png) left top no-repeat;
        padding: 34px 0 30px
    }
    #system .system .menu__box--2 {
        margin-top: 36px
    }
    #system .system .menu__btn {
        float: left;
        margin-left: 6px
    }
    #system .system .menu__btn a {
        padding-top: 3px;
        font-size: 15px
    }
    #system .system .menu__btn--new:after {
        content: "";
        position: absolute;
        top: 0px;
        right: auto;
        left: 1px;
        display: block;
        background: url(../img/system/ico_new.png) left top no-repeat;
        width: 35px;
        height: 12px
    }
    #system .system .menu__btn:nth-child(4n+1) {
        clear: none
    }
    #system .system .menu__btn:nth-child(3n+1) {
        clear: both;
        margin-left: 0
    }
    #system .system .slide {
        padding: 0 30px
    }
    #system .system .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system .slide__controls {
        top: 120px
    }
    #system .system__content {
        padding: 0 10px 180px;
        overflow: visible
    }
    #system .system .action__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system .action__title img {
        position: static !important
    }
    #system .system .sector {
        margin-bottom: 70px
    }
    #system .system .sector__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system .sector__title img {
        position: static !important
    }
    #system .system .program {
        margin-bottom: 70px
    }
    #system .system .program__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system .program__title img {
        position: static !important
    }
    #system .system .program .slide__text th,
    #system .system .program .slide__text td {
        display: block
    }
    #system .system .program .slide__thumbs {
        margin-top: 20px
    }
    #system .system .level {
        margin-bottom: 0
    }
    #system .system .level__title {
        height: 125px;
        overflow: visible
    }
    #system .system .level__text {
        color: #fff;
        line-height: 2;
        font-size: 18px;
        padding-left: 15px;
        margin-bottom: 20px
    }
    #system .system .level__text .font-small {
        font-size: 16px;
        line-height: 1.9;
        display: inline
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #system .system .level__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

@media (max-width: 640px) {
    #system .system .level__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system .level__title img {
        position: static !important
    }
    #system .system .level .slide__text th,
    #system .system .level .slide__text td {
        display: block
    }
    #system .system .level .slide__thumbs {
        margin-top: 20px
    }
    #system .system .freemode {
        margin-bottom: 0px
    }
    #system .system .freemode__title {
        height: 125px;
        overflow: visible;
        margin: 0
    }
    #system .system .freemode__text {
        color: #fff;
        line-height: 2;
        font-size: 18px;
        padding-left: 15px;
        margin-bottom: 20px;
        margin-top: -30px
    }
    #system .system .freemode__text .font-small {
        font-size: 16px;
        line-height: 1.9;
        display: inline
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #system .system .freemode__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

@media (max-width: 640px) {
    #system .system .freemode__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system .freemode__title img {
        position: static !important
    }
    #system .system .freemode .slide__text th,
    #system .system .freemode .slide__text td {
        display: block
    }
    #system .system .freemode .slide__thumbs {
        margin-top: 20px
    }
    #system .system .extra {
        margin-bottom: 70px
    }
    #system .system .extra__title {
        height: auto;
        position: static;
        margin-bottom: 15px;
        height: 140px
    }
    #system .system .extra__title img {
        position: static !important
    }
    #system .system .attribution {
        margin-bottom: 0px
    }
    #system .system .attribution__title {
        height: auto;
        position: static;
        margin-bottom: 15px;
        height: 140px
    }
    #system .system .attribution__title img {
        position: static !important
    }
    #system .system .change {
        margin-bottom: 0
    }
    #system .system .change .submenu {
        display: block;
        text-align: center
    }
    #system .system .change__title {
        height: auto;
        position: static;
        margin-bottom: 15px;
        height: 140px
    }
    #system .system .change__title img {
        position: static !important
    }
    #system .system .change__title--auto {
        height: auto;
        margin-bottom: 17px
    }
    #system .system .change__title--auto2 {
        height: auto
    }
    #system .system .change .character {
        position: static;
        height: 20px;
        overflow: visible;
        text-align: center
    }
    #system .system .change .character img {
        margin-top: 100px
    }
    #system .system .change .character img.v-pc {
        display: none !important
    }
    #system .system .change .slide {
        width: auto;
        margin: 0 auto
    }
    #system .system .change .slide__title {
        text-align: center;
        margin-bottom: 700px;
        padding-left: 0
    }
    #system .system .change .slide__thumbs {
        margin: 0 auto
    }
    #system .system .change .slide__controls {
        top: auto;
        bottom: 180px
    }
    #system .system .change__nero {
        padding-top: 0
    }
    #system .system .change__nero .character__change-thum {
        display: none
    }
    #system .system .change__tamamo {
        padding-top: 0
    }
    #system .system .change__tamamo .character img {
        margin-top: 0;
        margin-left: -100px;
        max-width: none
    }
    #system .system .change__tamamo .slide__title {
        margin-bottom: 400px
    }
    #system .system .change__moon-drive .slide {
        padding: 0 30px
    }
    #system .system .change__moon-drive .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system .change__moon-drive .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system .change__moon-drive .slide__controls {
        top: 120px
    }
    #system .system__hougu .change__hougu .slider-for {
        width: 552px;
        margin: 0 auto;
        position: relative
    }
    #system .system__hougu .change__hougu .slider-for .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_left.png) left top no-repeat;
        width: 80px;
        height: 80px;
        left: -40px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -40px;
        outline: none
    }
    #system .system__hougu .change__hougu .slider-for .slick-prev:hover {
        opacity: 0.8
    }
    #system .system__hougu .change__hougu .slider-for .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_right.png) left top no-repeat;
        width: 80px;
        height: 80px;
        right: -40px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -40px
    }
    #system .system__hougu .change__hougu .slider-for .slick-next:hover {
        opacity: 0.8
    }
    #system .system__hougu .change__hougu .sp-image {
        width: 100%;
        height: auto;
        border: 2px solid #f9c138;
        box-sizing: border-box
    }
    #system .system__hougu .change__hougu .sp-thumbnail {
        width: 114px;
        height: auto;
        border: 1px solid #f9c138;
        box-sizing: border-box;
        margin: 0 auto
    }
    #system .system__hougu .change__hougu .slider-nav-wrap {
        width: 553px;
        height: 132px;
        background: url(../img/gallery/sp/bg_thum_list.png) center top no-repeat;
        margin: 26px auto 0;
        padding-top: 33px
    }
    #system .system__hougu .change__hougu .slider-nav {
        width: 471px;
        margin: 0 auto
    }
    #system .system__hougu .change__hougu .slider-nav .slick-slide {
        opacity: 0.7
    }
    #system .system__hougu .change__hougu .slider-nav .slick-slide.slick-current {
        opacity: 1
    }
    #system .system__hougu .change__hougu .slider-nav .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
        width: 39px;
        height: 45px;
        left: -50px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -22px;
        outline: none
    }
    #system .system__hougu .change__hougu .slider-nav .slick-prev:hover {
        opacity: 0.8
    }
    #system .system__hougu .change__hougu .slider-nav .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
        width: 39px;
        height: 45px;
        right: -50px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -22px
    }
    #system .system__hougu .change__hougu .slider-nav .slick-next:hover {
        opacity: 0.8
    }
    #system .system__reijyu .change__text {
        margin-bottom: 70px
    }
    #system .system__reijyu .change__reijyu .slide {
        padding: 0 30px
    }
    #system .system__reijyu .change__reijyu .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system__reijyu .change__reijyu .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system__reijyu .change__reijyu .slide__controls {
        top: 120px
    }
    #system .system__codecast .change__text {
        margin-bottom: 30px
    }
    #system .system__codecast .change__codecast .slide {
        padding: 0 30px
    }
    #system .system__codecast .change__codecast .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system__codecast .change__codecast .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system__codecast .change__codecast .slide__controls {
        top: 120px
    }
    #system .system__reisou .change__text {
        margin-bottom: 30px
    }
    #system .system__reisou .change__reisou .slide {
        padding: 0 30px
    }
    #system .system__reisou .change__reisou .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system__reisou .change__reisou .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system__reisou .change__reisou .slide__controls {
        top: 120px
    }
    #system .system__stage .change {
        margin-bottom: 70px
    }
    #system .system__stage .change:last-child {
        margin-bottom: 0
    }
    #system .system__stage .slider-for {
        width: 552px;
        margin: 0 auto;
        position: relative
    }
    #system .system__stage .slider-for .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_left.png) left top no-repeat;
        width: 80px;
        height: 80px;
        left: -40px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -40px;
        outline: none
    }
    #system .system__stage .slider-for .slick-prev:hover {
        opacity: 0.8
    }
    #system .system__stage .slider-for .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_right.png) left top no-repeat;
        width: 80px;
        height: 80px;
        right: -40px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -40px
    }
    #system .system__stage .slider-for .slick-next:hover {
        opacity: 0.8
    }
    #system .system__stage .sp-image {
        width: 100%;
        height: auto;
        border: 2px solid #f9c138;
        box-sizing: border-box
    }
    #system .system__stage .sp-thumbnail {
        width: 114px;
        height: auto;
        border: 1px solid #f9c138;
        box-sizing: border-box;
        margin: 0 auto
    }
    #system .system__stage .slider-nav-wrap {
        width: 553px;
        height: 132px;
        background: url(../img/gallery/sp/bg_thum_list.png) center top no-repeat;
        margin: 26px auto 0;
        padding-top: 33px
    }
    #system .system__stage .slider-nav {
        width: 471px;
        margin: 0 auto
    }
    #system .system__stage .slider-nav .slick-slide {
        opacity: 0.7
    }
    #system .system__stage .slider-nav .slick-slide.slick-current {
        opacity: 1
    }
    #system .system__stage .slider-nav .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
        width: 39px;
        height: 45px;
        left: -50px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -22px;
        outline: none
    }
    #system .system__stage .slider-nav .slick-prev:hover {
        opacity: 0.8
    }
    #system .system__stage .slider-nav .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
        width: 39px;
        height: 45px;
        right: -50px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -22px
    }
    #system .system__stage .slider-nav .slick-next:hover {
        opacity: 0.8
    }
    #system .system__stage .change__title {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system__stage .change__title img {
        position: static !important
    }
    #system .system__stage .change__title2 {
        height: auto;
        position: static;
        margin-bottom: 15px
    }
    #system .system__stage .change__title2 img {
        position: static !important
    }
    #system .system__stage .change__text {
        margin-bottom: 30px
    }
    #system .system__stage .change__stage .slide {
        padding: 0 30px
    }
    #system .system__stage .change__stage .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system__stage .change__stage .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system__stage .change__stage .slide__controls {
        top: 120px
    }
    #system .system__lvup .change__text {
        margin-bottom: 30px
    }
    #system .system__lvup .change__lvup .slide {
        padding: 0 30px
    }
    #system .system__lvup .change__lvup .slide__main {
        width: 100%;
        height: auto !important
    }
    #system .system__lvup .change__lvup .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #system .system__lvup .change__lvup .slide__controls {
        top: 120px
    }
}

@keyframes loop {
    0% {
        opacity: 1
    }
    15% {
        opacity: 0
    }
    50% {
        opacity: 0
    }
    65% {
        opacity: 1
    }
    100% {
        opacity: 1
    }
}

@keyframes loop2 {
    0% {
        opacity: 0
    }
    15% {
        opacity: 1
    }
    50% {
        opacity: 1
    }
    65% {
        opacity: 0
    }
    100% {
        opacity: 0
    }
}

#story .zoom-modal {
    position: absolute;
    display: none;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    z-index: 1002
}

#story .zoom-modal__close {
    position: absolute;
    top: -55px;
    right: -55px;
    z-index: 101
}

#story .zoom-modal__close a {
    background: url(../img/spec/btn_modal_close.png) left top no-repeat;
    display: block;
    width: 106px;
    height: 106px
}

#story .zoom-modal__prev {
    display: block;
    position: absolute;
    left: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#story .zoom-modal__next {
    display: block;
    position: absolute;
    right: -100px;
    top: 50%;
    transform: translatey(-50%)
}

#story .bg-layer {
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    z-index: 1001
}

#story .story {
    margin-top: -9px;
    background: url(../img/story/bg.png) center top no-repeat #000;
    background-attachment: fixed;
    background-size: 100% auto
}

#story .story--2 {
    background: url(../img/story/bg2.png) center top no-repeat #000;
    background-attachment: fixed;
    background-size: 100% auto
}

#story .story--3 {
    background: url(../img/story/bg3.png) center bottom no-repeat #000;
    background-attachment: fixed;
    background-size: 100% auto
}

#story .story-header {
    padding-top: 9px;
    margin-bottom: 10px
}

#story .story-header__wrap {
    width: 1024px;
    margin: 0 auto;
    position: relative;
    padding-top: 20px
}

@media (max-width: 640px) {
    #story .story-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story-header__banner {
    position: absolute;
    top: 50px;
    right: 0px
}

#story .pankuzu {
    padding-left: 15px;
    margin-bottom: 45px;
    position: relative;
    z-index: 2
}

#story .story1 {
    margin-top: -60px;
    margin-bottom: 55px
}

#story .story1.jinei .story1__img {
    margin-top: 90px
}

#story .story1.jinei .story__jinei {
    text-align: center
}

#story .story1__wrap {
    position: relative;
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #story .story1__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story1__wrap:first-child {
    margin-bottom: 60px
}

#story .story1__bg {
    position: absolute;
    right: 0;
    top: 110px;
    z-index: 1;
    width: 533px;
    height: 767px
}

#story .story1__bg .before {
    opacity: 1;
    position: absolute;
    animation: loop 13s linear 4.5s infinite
}

#story .story1__bg .after {
    opacity: 0;
    position: absolute;
    animation: loop2 13s linear 4.5s infinite
}

#story .story1__img img {
    margin-left: -12px
}

#story .story1__text {
    position: relative;
    margin-top: -70px;
    z-index: 2
}

#story .story1__thumbs {
    padding-top: 55px;
    overflow: hidden
}

#story .story1__thumbs li {
    float: left;
    margin-right: 5px
}

#story .story1__thumbs li.last {
    margin-right: 0
}

#story .story2 {
    margin-top: -120px;
    margin-bottom: 90px
}

#story .story2__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #story .story2__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story2__title {
    margin-left: -16px
}

#story .story2__text {
    color: #fff;
    font-size: 16px;
    margin-top: -35px;
    margin-bottom: 30px
}

#story .story3 {
    margin-top: -60px;
    margin-bottom: 55px
}

#story .story3__wrap {
    width: 1024px;
    margin: 0 auto;
    margin-bottom: 80px
}

@media (max-width: 640px) {
    #story .story3__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story3__title {
    margin-left: -16px
}

#story .story3__text {
    margin-top: -107px;
    color: #fff;
    line-height: 2;
    font-size: 18px;
    margin-bottom: 24px
}

#story .story3__chara {
    text-align: center;
    margin-bottom: 35px
}

#story .story3__button {
    text-align: center
}

#story .story3 .slide {
    overflow: visible;
    position: relative
}

#story .story3 .slide__main {
    width: 950px;
    text-align: center;
    overflow: hidden;
    margin: 0 auto 6px
}

#story .story3 .slide__main img {
    display: block;
    width: 100%;
    height: auto
}

#story .story3 .slide__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#story .story3 .slide__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #story .story3 .slide__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#story .story3 .slide__thumbs {
    display: table;
    width: 965px;
    margin: 0 auto;
    border-spacing: 7px 0
}

#story .story3 .slide__thumbs li {
    display: table-cell
}

#story .story3 .slide__thumbs img {
    display: block;
    width: 100%
}

#story .story3 .slide__controls {
    position: absolute;
    width: 100%;
    overflow: hidden;
    left: 0;
    top: 230px
}

#story .story3 .slide__control--left {
    float: left
}

#story .story3 .slide__control--right {
    float: right
}

#story .story3 .slide__main .slide__photo {
    border: 1px solid #f0bb2b
}

#story .story3 .slide__thumbs li {
    backface-visibility: hidden
}

#story .story3 .slide__thumbs img {
    border: 1px solid #f0bb2b;
    max-width: 310px
}

#story .story3 .slide__thumbs--center {
    text-align: center;
    display: block
}

#story .story3 .slide__thumbs--center li {
    display: inline-block;
    margin: 0 1px
}

#story .story4 {
    margin-top: 0px;
    margin-bottom: 120px
}

#story .story4__wrap {
    width: 1024px;
    margin: 0 auto;
    width: 940px
}

@media (max-width: 640px) {
    #story .story4__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story4 .keyword__movie {
    position: relative;
    background: url(../img/gallery/bg_movie.png) left top no-repeat;
    width: 952px;
    height: 565px;
    margin: 0 auto 80px;
    padding: 25px 0 0 15px
}

#story .story4 .keyword-box {
    position: relative;
    left: 11px;
    border: 1px solid #8f8549;
    padding: 20px 44px 44px;
    margin-bottom: 50px
}

#story .story4 .keyword-box:before {
    content: "";
    position: absolute;
    top: -7px;
    left: -7px;
    width: 100%;
    height: 100%;
    border: 2px solid #fee26f
}

#story .story4 .keyword-box:after {
    content: "";
    background: url(../img/story/keyword_box.png) left top no-repeat;
    position: absolute;
    bottom: -29px;
    left: -29px;
    width: 399px;
    height: 132px
}

#story .story4 .keyword-box__title {
    margin-left: -8px
}

#story .story4 .keyword-box__text {
    color: #fff;
    text-align: justify;
    font-size: 18px;
    line-height: 1.8
}

#story .slider-for {
    width: 939px;
    margin: 0 auto;
    position: relative
}

#story .slider-for .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    left: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    margin-top: -40px;
    outline: none;
    cursor: pointer
}

#story .slider-for .slick-prev:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#story .slider-for .slick-prev:hover {
    opacity: 0.8
}

#story .slider-for .slick-prev:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#story .slider-for .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    right: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    outline: none;
    margin-top: -40px;
    cursor: pointer
}

#story .slider-for .slick-next:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#story .slider-for .slick-next:hover {
    opacity: 0.8
}

#story .slider-for .slick-next:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#story .sp-image {
    width: 100%;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box
}

#story .sp-thumbnail {
    width: 148px;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box;
    margin: 0 auto
}

#story .slider-nav-wrap {
    width: 948px;
    height: 126px;
    background: url(../img/gallery/bg_thum_list.png) center top no-repeat;
    margin: 26px auto 0;
    padding-top: 20px
}

#story .slider-nav {
    width: 782px;
    margin: 0 auto
}

#story .slider-nav .slick-slide {
    opacity: 0.7;
    outline: none;
    cursor: pointer
}

#story .slider-nav .slick-slide.slick-current {
    opacity: 1
}

#story .slider-nav .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
    width: 39px;
    height: 45px;
    left: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    margin-top: -22px;
    outline: none;
    cursor: pointer
}

#story .slider-nav .slick-prev:hover {
    opacity: 0.8
}

#story .slider-nav .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
    width: 39px;
    height: 45px;
    right: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    outline: none;
    margin-top: -22px;
    cursor: pointer
}

#story .slider-nav .slick-next:hover {
    opacity: 0.8
}

#story .story-footer {
    width: 1024px;
    margin: 0 auto;
    padding-bottom: 80px
}

@media (max-width: 640px) {
    #story .story-footer {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#story .story-footer ul {
    overflow: hidden;
    *zoom: 1
}

#story .story-footer li {
    float: left;
    margin-right: 6px
}

#story .story-footer li a img {
    opacity: 0.5
}

#story .story-footer li a:hover img {
    transition: none;
    -webkit-transition: none;
    opacity: 1
}

#story .story-footer li:last-child {
    margin-right: 0
}

#story .story-footer li.is-active a img {
    opacity: 1
}

@media (max-width: 640px) {
    #story .zoom-modal {
        width: 100%
    }
    #story .zoom-modal__close {
        top: -110px;
        right: 0
    }
    #story .zoom-modal__prev {
        display: block;
        position: absolute;
        left: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #story .zoom-modal__next {
        display: block;
        position: absolute;
        right: 5px;
        top: 50%;
        transform: translatey(-50%)
    }
    #story .story {
        margin-top: -5px;
        background: url(../img/story/sp/bg.png) center top no-repeat #000;
        background-attachment: scroll
    }
    #story .story--2 {
        background: url(../img/story/sp/bg2.png) center top no-repeat #000;
        background-attachment: scroll
    }
    #story .story-header {
        padding-top: 20px;
        margin-bottom: 10px
    }
    #story .story-header__wrap {
        width: 1024px;
        margin: 0 auto;
        padding-top: 20px
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #story .story-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #story .story-header__banner {
        position: static;
        top: 0;
        right: 0;
        display: block;
        text-align: center;
        margin: 10px auto 20px
    }
    #story .pankuzu {
        padding-left: 15px;
        margin-bottom: 45px;
        position: relative;
        z-index: 2
    }
    #story .story1 {
        margin-top: -20px;
        margin-bottom: 50px
    }
    #story .story1.jinei .story1__img {
        margin-top: 60px
    }
    #story .story1.jinei .story__jinei {
        text-align: center
    }
    #story .story1__wrap {
        width: 1024px;
        margin: 0 auto;
        text-align: center
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #story .story1__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #story .story1__wrap:first-child {
        margin-bottom: 60px
    }
    #story .story1__bg {
        text-align: left;
        position: relative;
        right: 0;
        left: 0;
        top: 0px;
        z-index: 1;
        width: auto;
        height: 388px;
        margin-top: -70px;
        margin-bottom: 20px
    }
    #story .story1__bg .before {
        opacity: 1;
        position: absolute;
        animation: loop 13s linear 4.5s infinite
    }
    #story .story1__bg .after {
        opacity: 0;
        position: absolute;
        animation: loop2 13s linear 4.5s infinite
    }
    #story .story1__img img {
        margin-left: -10px
    }
    #story .story1__text {
        position: relative;
        margin-top: 10px;
        text-align: center;
        z-index: 2
    }
    #story .story1__thumbs li {
        float: left;
        margin-bottom: 10px;
        margin-right: 3px
    }
    #story .story1__thumbs li img {
        width: 100px;
        height: auto
    }
    #story .story1__thumbs--corner {
        margin-right: 0 !important
    }
    #story .story2 {
        margin-top: -22px;
        margin-bottom: 30px
    }
    #story .story2__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #story .story2__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #story .story2__title {
        margin-left: -6px
    }
    #story .story2__text {
        color: #fff;
        font-size: 24px;
        margin-top: 16px;
        margin-bottom: 30px;
        line-height: 1.5;
        padding-left: 15px
    }
    #story .story2 .slider-for {
        width: 552px;
        margin: 0 auto;
        position: relative
    }
    #story .story2 .slider-for .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_left.png) left top no-repeat;
        width: 80px;
        height: 80px;
        left: -40px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -40px;
        outline: none
    }
    #story .story2 .slider-for .slick-prev:hover {
        opacity: 0.8
    }
    #story .story2 .slider-for .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_right.png) left top no-repeat;
        width: 80px;
        height: 80px;
        right: -40px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -40px
    }
    #story .story2 .slider-for .slick-next:hover {
        opacity: 0.8
    }
    #story .story2 .sp-image {
        width: 100%;
        height: auto;
        border: 2px solid #f9c138;
        box-sizing: border-box
    }
    #story .story2 .sp-thumbnail {
        width: 114px;
        height: auto;
        border: 1px solid #f9c138;
        box-sizing: border-box;
        margin: 0 auto
    }
    #story .story2 .slider-nav-wrap {
        width: 553px;
        height: 132px;
        background: url(../img/gallery/sp/bg_thum_list.png) center top no-repeat;
        margin: 26px auto 0;
        padding-top: 33px
    }
    #story .story2 .slider-nav {
        width: 471px;
        margin: 0 auto
    }
    #story .story2 .slider-nav .slick-slide {
        opacity: 0.7
    }
    #story .story2 .slider-nav .slick-slide.slick-current {
        opacity: 1
    }
    #story .story2 .slider-nav .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
        width: 39px;
        height: 45px;
        left: -50px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -22px;
        outline: none
    }
    #story .story2 .slider-nav .slick-prev:hover {
        opacity: 0.8
    }
    #story .story2 .slider-nav .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
        width: 39px;
        height: 45px;
        right: -50px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -22px
    }
    #story .story2 .slider-nav .slick-next:hover {
        opacity: 0.8
    }
    #story .slide {
        padding: 0 30px
    }
    #story .slide__main {
        width: 100%;
        height: auto !important;
        margin-bottom: 0
    }
    #story .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #story .slide__controls {
        top: 120px
    }
    #story .story3 {
        margin-top: -60px;
        margin-bottom: 55px
    }
    #story .story3 .story3__wrap:first-of-type {
        margin-top: 50px
    }
    #story .story3 .story3__wrap:first-of-type .story3__text {
        margin-top: 16px
    }
    #story .story3__wrap {
        margin-bottom: 40px
    }
    #story .story3__title {
        margin-left: -6px
    }
    #story .story3__text {
        max-height: 1000000px;
        color: #fff;
        font-size: 24px;
        margin-top: -20px;
        margin-bottom: 30px;
        line-height: 1.5;
        padding-left: 15px
    }
    #story .story3__chara {
        text-align: center;
        margin-bottom: 35px;
        margin-left: -10px
    }
    #story .story3__button {
        text-align: center
    }
    #story .story3 .slide {
        padding: 0 30px
    }
    #story .story3 .slide__main {
        width: 100%;
        height: auto !important
    }
    #story .story3 .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 7px);
        width: calc(100% + 14px);
        margin-left: -7px;
        border-spacing: 7px
    }
    #story .story3 .slide__controls {
        top: 120px
    }
    #story .story3 .slide__thumbs img {
        border: 1px solid #f0bb2b;
        max-width: 136px
    }
    #story .story3 .slide__thumbs--center {
        text-align: center;
        display: block;
        margin-left: 0
    }
    #story .story3 .slide__thumbs--center li {
        display: inline-block;
        margin: 0 1px
    }
    #story .story4 {
        margin-top: 0px;
        margin-bottom: 120px
    }
    #story .story4__wrap {
        width: 1024px;
        margin: 0 auto;
        width: auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #story .story4__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #story .story4 .keyword__movie {
        position: relative;
        background: url(../img/gallery/bg_movie.png) left top no-repeat;
        background-size: cover;
        width: 620px;
        height: 368px;
        margin: 0 auto 45px;
        padding: 15px 0 0 10px
    }
    #story .story4 .keyword__movie iframe {
        width: 600px;
        height: 338px
    }
    #story .story4 .keyword-box {
        position: relative;
        left: 5px;
        border: 1px solid #8f8549;
        padding: 10px 20px 20px;
        margin: 0 20px 30px
    }
    #story .story4 .keyword-box:before {
        content: "";
        position: absolute;
        top: -7px;
        left: -7px;
        width: 100%;
        height: 100%;
        border: 2px solid #fee26f
    }
    #story .story4 .keyword-box:after {
        content: "";
        background: url(../img/story/keyword_box.png) left top no-repeat;
        background-size: cover;
        position: absolute;
        bottom: -14px;
        left: -20px;
        width: 200px;
        height: 66px
    }
    #story .story4 .keyword-box__title {
        margin-left: -8px
    }
    #story .story4 .keyword-box__text {
        color: #fff;
        text-align: left;
        font-size: 25px;
        line-height: 1.8;
        text-align: justify
    }
    #story .story-footer {
        padding-bottom: 60px
    }
    #story .story-footer ul {
        overflow: hidden;
        *zoom: 1
    }
    #story .story-footer li {
        float: left;
        margin-right: 0px;
        margin-bottom: 12px
    }
    #story .story-footer li a {
        display: block
    }
    #story .story-footer li a img {
        opacity: 0.5;
        max-width: 100%
    }
    #story .story-footer li a:hover img {
        transition: none;
        -webkit-transition: none;
        opacity: 1
    }
    #story .story-footer li:last-child {
        margin-right: 0
    }
    #story .story-footer li.is-active a img {
        opacity: 1
    }
}

#gallery {
    background: url(../img/gallery/bg_gallery.png) center top no-repeat #000;
    background-attachment: fixed;
    background-size: cover
}

#gallery .gallery-header {
    padding-top: 20px;
    margin-bottom: 10px
}

#gallery .gallery-header__wrap {
    width: 1024px;
    margin: 0 auto;
    overflow: hidden;
    *zoom: 1
}

@media (max-width: 640px) {
    #gallery .gallery-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery-header__title {
    float: left;
    margin-right: -10px
}

#gallery .gallery-header__navi {
    float: left;
    margin-top: 40px;
    overflow: hidden;
    *zoom: 1
}

#gallery .gallery-header__navi li {
    float: left
}

#gallery .gallery-header__navi li.clear {
    clear: both
}

#gallery .gallery-header__navi li.new {
    position: relative
}

#gallery .gallery-header__navi li.new:after {
    content: "";
    background: url(../img/common/header_ico_new.png) left top no-repeat;
    width: 35px;
    height: 12px;
    top: 4px;
    left: 4px;
    position: absolute
}

#gallery .pankuzu {
    margin-top: -30px;
    margin-bottom: 35px;
    padding: 0 15px
}

#gallery .gallery1,
#gallery .gallery-anime {
    padding-top: 30px;
    padding-bottom: 130px
}

#gallery .gallery1__wrap,
#gallery .gallery-anime__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #gallery .gallery1__wrap,
    #gallery .gallery-anime__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery2 {
    padding-top: 30px;
    padding-bottom: 130px
}

#gallery .gallery2__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #gallery .gallery2__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery6 {
    padding-top: 30px;
    padding-bottom: 130px
}

#gallery .gallery6__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #gallery .gallery6__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery4 {
    padding-top: 30px;
    padding-bottom: 130px
}

#gallery .gallery4__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #gallery .gallery4__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery4 .slide {
    overflow: visible;
    position: relative
}

#gallery .gallery4 .slide__main {
    width: 950px;
    text-align: center;
    overflow: hidden;
    margin: 0 auto 28px
}

#gallery .gallery4 .slide__main img {
    display: block;
    width: 100%;
    height: auto
}

#gallery .gallery4 .slide__photo {
    border: 1px solid #ffc601
}

#gallery .gallery4 .slide__text {
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    border-left: 1px solid #feb300;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#gallery .gallery4 .slide__text .font-small {
    font-size: 16px;
    line-height: 1.9;
    display: inline
}

@media (max-width: 640px) {
    #gallery .gallery4 .slide__text {
        font-size: 25px;
        max-height: 99999px;
        line-height: 1.5
    }
}

#gallery .gallery4 .slide__thumbs {
    display: table;
    width: 1006px;
    margin: 0 auto;
    border-spacing: 28px 0
}

#gallery .gallery4 .slide__thumbs li {
    display: table-cell;
    border: 1px solid #ffc601
}

#gallery .gallery4 .slide__thumbs img {
    display: block;
    width: 100%
}

#gallery .gallery4 .slide__controls {
    position: absolute;
    width: 100%;
    overflow: hidden;
    left: 0;
    top: 230px
}

#gallery .gallery4 .slide__control--left {
    float: left
}

#gallery .gallery4 .slide__control--right {
    float: right
}

#gallery .movie-text {
    width: 952px;
    margin: 0 auto
}

#gallery .movie-text li {
    display: none;
    color: #fff;
    line-height: 2;
    font-size: 18px;
    text-align: left;
    border-left: 1px solid #feb300;
    padding-left: 20px;
    margin: 20px 0;
    line-height: 30px
}

#gallery .movie-box {
    position: relative;
    background: url(../img/gallery/bg_movie.png) left top no-repeat;
    width: 952px;
    height: 565px;
    margin: 0 auto 20px
}

#gallery .movie-box__title {
    position: absolute;
    right: -30px;
    top: -48px
}

#gallery .movie-box__movie {
    padding: 25px 0 0 15px
}

#gallery .thumnail-box {
    width: 952px;
    margin: 0 auto;
    text-align: center;
    display: block
}

#gallery .thumnail-box .thumnail-box__title-thum {
    text-align: left;
    margin-bottom: 2px
}

#gallery .thumnail-box li {
    display: inline-block;
    margin: 0 48px
}

#gallery .thumnail-box li a {
    position: relative;
    display: block
}

#gallery .thumnail-box li a:after {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    display: block;
    content: "";
    background: url(../img/gallery/btn_play2.png) left top no-repeat;
    width: 74px;
    height: 74px
}

#gallery .thumnail-box--3-columns {
    margin-bottom: 37px
}

#gallery .thumnail-box--3-columns li {
    margin: 0 20px
}

#gallery .thumnail-box--3-columns li.ico-new {
    position: relative
}

#gallery .thumnail-box--3-columns li.ico-new:after {
    content: "";
    display: block;
    width: 35px;
    height: 12px;
    background: url(../img/gallery/ico_new.png) left top no-repeat;
    position: absolute;
    top: -2px;
    left: 0
}

#gallery .thumnail-box--4-columns {
    *zoom: 1;
    margin-bottom: 37px
}

#gallery .thumnail-box--4-columns:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#gallery .thumnail-box--4-columns li {
    display: block;
    float: left;
    margin: 0 20px 0 0
}

#gallery .thumnail-box--4-columns li:last-child {
    margin-right: 0
}

#gallery .thumnail-box--4-columns li.ico-new {
    position: relative
}

#gallery .thumnail-box--4-columns li.ico-new:after {
    content: "";
    display: block;
    width: 35px;
    height: 12px;
    background: url(../img/gallery/ico_new.png) left top no-repeat;
    position: absolute;
    top: -2px;
    left: 0
}

#gallery .thumnail-box--5-columns {
    *zoom: 1;
    margin-bottom: 37px
}

#gallery .thumnail-box--5-columns:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}

#gallery .thumnail-box--5-columns li {
    display: block;
    float: left;
    margin: 0 10px 0 0
}

#gallery .thumnail-box--5-columns li:last-child {
    margin-right: 0
}

#gallery .thumnail-box--5-columns li.ico-new {
    position: relative
}

#gallery .thumnail-box--5-columns li.ico-new:after {
    content: "";
    display: block;
    width: 35px;
    height: 12px;
    background: url(../img/gallery/ico_new.png) left top no-repeat;
    position: absolute;
    top: -2px;
    left: 0
}

#gallery .material-lineup {
    margin-top: 10px
}

#gallery .material-lineup__title {
    margin-bottom: -150px
}

#gallery .material-lineup__list {
    position: relative;
    z-index: 2;
    overflow: hidden;
    *zoom: 1
}

#gallery .material-lineup__item {
    float: left;
    margin-right: 20px
}

#gallery .material-lineup__item:last-child {
    margin-right: 0
}

#gallery .gallery3 {
    padding-top: 30px;
    padding-bottom: 150px
}

#gallery .gallery3__wrap {
    width: 1024px;
    margin: 0 auto
}

@media (max-width: 640px) {
    #gallery .gallery3__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#gallery .gallery3 .slider-for {
    width: 939px;
    margin: 0 auto;
    position: relative
}

#gallery .gallery3 .slider-for .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    left: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    margin-top: -40px;
    outline: none;
    cursor: pointer
}

#gallery .gallery3 .slider-for .slick-prev:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#gallery .gallery3 .slider-for .slick-prev:hover {
    opacity: 0.8
}

#gallery .gallery3 .slider-for .slick-prev:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_left.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#gallery .gallery3 .slider-for .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    right: -40px;
    text-indent: -9999px;
    border: none;
    z-index: 2;
    outline: none;
    margin-top: -40px;
    cursor: pointer
}

#gallery .gallery3 .slider-for .slick-next:before {
    transition: transform 0.4s, opacity 0.4s;
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1);
    z-index: 0;
    opacity: 1
}

#gallery .gallery3 .slider-for .slick-next:hover {
    opacity: 0.8
}

#gallery .gallery3 .slider-for .slick-next:active:before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    background: url(../img/gallery/ico_right.png) left top no-repeat;
    width: 80px;
    height: 80px;
    transform: translate(-50%, -50%) scale(1.2);
    z-index: 0;
    opacity: 0
}

#gallery .gallery3 .sp-image {
    width: 100%;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box
}

#gallery .gallery3 .sp-thumbnail {
    width: 148px;
    height: auto;
    border: 1px solid #f9c138;
    box-sizing: border-box;
    margin: 0 auto;
    opacity: 0
}

#gallery .gallery3 .slider-nav-wrap {
    width: 948px;
    height: 126px;
    background: url(../img/gallery/bg_thum_list.png) center top no-repeat;
    margin: 26px auto 0;
    padding-top: 20px
}

#gallery .gallery3 .slider-nav {
    width: 782px;
    margin: 0 auto
}

#gallery .gallery3 .slider-nav .slick-slide {
    opacity: 0.7;
    outline: none;
    cursor: pointer
}

#gallery .gallery3 .slider-nav .slick-slide.slick-current {
    opacity: 1
}

#gallery .gallery3 .slider-nav .slick-prev {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
    width: 39px;
    height: 45px;
    left: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    margin-top: -22px;
    outline: none;
    cursor: pointer
}

#gallery .gallery3 .slider-nav .slick-prev:hover {
    opacity: 0.8
}

#gallery .gallery3 .slider-nav .slick-next {
    position: absolute;
    top: 50%;
    background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
    width: 39px;
    height: 45px;
    right: -50px;
    text-indent: -1000px;
    border: none;
    overflow: hidden;
    z-index: 2;
    outline: none;
    margin-top: -22px;
    cursor: pointer
}

#gallery .gallery3 .slider-nav .slick-next:hover {
    opacity: 0.8
}

@media (max-width: 640px) {
    #gallery {
        background: url(../img/gallery/bg_gallery.png) center top no-repeat #000;
        background-attachment: fixed
    }
    #gallery .gallery-header {
        padding-top: 20px;
        margin-bottom: 20px
    }
    #gallery .gallery-header__wrap {
        width: 1024px;
        margin: 0 auto;
        overflow: hidden;
        *zoom: 1
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #gallery .gallery-header__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #gallery .gallery-header__title {
        float: none;
        margin-right: 0px
    }
    #gallery .gallery-header__navi {
        float: none;
        margin-top: 10px;
        overflow: hidden;
        *zoom: 1
    }
    #gallery .gallery-header__navi li {
        float: left
    }
    #gallery .gallery-header__navi li.clear {
        clear: none
    }
    #gallery .pankuzu {
        margin-bottom: 35px;
        padding: 0 15px
    }
    #gallery .gallery1,
    #gallery .gallery-anime {
        padding-top: 30px;
        padding-bottom: 60px;
        overflow: hidden
    }
    #gallery .gallery1__wrap,
    #gallery .gallery-anime__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #gallery .gallery1__wrap,
    #gallery .gallery-anime__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #gallery .gallery1 .movie-box {
        margin-bottom: 10px
    }
    #gallery .gallery1 .thumnail-box__title-thum {
        height: 38px;
        display: table-cell;
        vertical-align: bottom;
        line-height: 0
    }
    #gallery .gallery1 .thumnail-box__title-thum img {
        vertical-align: bottom
    }
    #gallery .gallery2 {
        padding-top: 30px;
        padding-bottom: 60px;
        overflow: hidden
    }
    #gallery .gallery2__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #gallery .gallery2__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #gallery .gallery6 {
        padding-top: 30px;
        padding-bottom: 60px;
        overflow: hidden
    }
    #gallery .gallery6__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #gallery .gallery6__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #gallery .movie-text {
        width: auto;
        margin: 0 auto
    }
    #gallery .movie-text li {
        display: none;
        color: #fff;
        line-height: 2;
        font-size: 18px;
        text-align: left;
        border-left: 1px solid #feb300;
        padding-left: 20px;
        margin: 20px 0;
        line-height: 30px
    }
    #gallery .movie-box {
        position: relative;
        background: url(../img/gallery/bg_movie.png) left top no-repeat;
        background-size: cover;
        width: 620px;
        height: 368px;
        margin: 0 auto 20px
    }
    #gallery .movie-box__title {
        position: absolute;
        right: -30px;
        top: -48px
    }
    #gallery .movie-box__movie {
        padding: 15px 0 0 10px
    }
    #gallery .thumnail-box {
        text-align: center;
        display: block;
        width: auto
    }
    #gallery .thumnail-box .thumnail-box__title-thum img {
        width: auto
    }
    #gallery .thumnail-box li {
        display: inline-block;
        margin: 0 40px
    }
    #gallery .thumnail-box--3-columns {
        overflow: hidden;
        *zoom: 1;
        margin-bottom: 18px
    }
    #gallery .thumnail-box--3-columns li {
        float: left;
        margin-left: 0;
        margin-right: 13px;
        width: 198px
    }
    #gallery .thumnail-box--3-columns li img {
        width: 100%
    }
    #gallery .thumnail-box--3-columns li:last-child {
        margin-right: 0
    }
    #gallery .thumnail-box--4-columns {
        overflow: hidden;
        *zoom: 1;
        margin-bottom: 18px
    }
    #gallery .thumnail-box--4-columns li {
        float: left;
        margin-left: 0;
        margin-right: 13px;
        width: 144px
    }
    #gallery .thumnail-box--4-columns li img {
        width: 100%
    }
    #gallery .thumnail-box--4-columns li:last-child {
        margin-right: 0
    }
    #gallery .thumnail-box--5-columns {
        overflow: hidden;
        *zoom: 1;
        margin-bottom: 18px
    }
    #gallery .thumnail-box--5-columns li {
        float: none;
        display: inline-block;
        margin-right: 1px;
        margin-left: 1px;
        width: 145px;
        margin-bottom: 14px
    }
    #gallery .thumnail-box--5-columns li img {
        width: 100%
    }
    #gallery .gallery4 .slide {
        padding: 0 30px
    }
    #gallery .gallery4 .slide__main {
        width: 100%;
        height: auto !important;
        margin-bottom: 0px
    }
    #gallery .gallery4 .slide__thumbs {
        width: 100%;
        width: -webkit-calc(100% + 14px);
        width: calc(100% + 28px);
        margin-left: -14px;
        border-spacing: 14px
    }
    #gallery .gallery4 .slide__controls {
        top: 120px
    }
    #gallery .material-lineup {
        margin-top: 10px
    }
    #gallery .material-lineup__title {
        margin-bottom: -100px
    }
    #gallery .material-lineup__title img {
        width: 100%
    }
    #gallery .material-lineup__list {
        position: relative;
        z-index: 2;
        overflow: hidden;
        *zoom: 1;
        text-align: center
    }
    #gallery .material-lineup__item {
        float: none;
        margin-right: 0px
    }
    #gallery .material-lineup__item:last-child {
        margin-right: 0
    }
    #gallery .gallery3 {
        padding-top: 10px;
        padding-bottom: 150px
    }
    #gallery .gallery3__wrap {
        width: 1024px;
        margin: 0 auto
    }
}

@media (max-width: 640px) and (max-width: 640px) {
    #gallery .gallery3__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

@media (max-width: 640px) {
    #gallery .gallery3 .slider-for {
        width: 552px;
        margin: 0 auto;
        position: relative
    }
    #gallery .gallery3 .slider-for .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_left.png) left top no-repeat;
        width: 80px;
        height: 80px;
        left: -40px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -40px;
        outline: none
    }
    #gallery .gallery3 .slider-for .slick-prev:hover {
        opacity: 0.8
    }
    #gallery .gallery3 .slider-for .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/ico_right.png) left top no-repeat;
        width: 80px;
        height: 80px;
        right: -40px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -40px
    }
    #gallery .gallery3 .slider-for .slick-next:hover {
        opacity: 0.8
    }
    #gallery .gallery3 .sp-image {
        width: 100%;
        height: auto;
        border: 2px solid #f9c138;
        box-sizing: border-box
    }
    #gallery .gallery3 .sp-thumbnail {
        width: 114px;
        height: auto;
        border: 1px solid #f9c138;
        box-sizing: border-box;
        margin: 0 auto
    }
    #gallery .gallery3 .slider-nav-wrap {
        width: 553px;
        height: 132px;
        background: url(../img/gallery/sp/bg_thum_list.png) center top no-repeat;
        margin: 26px auto 0;
        padding-top: 33px
    }
    #gallery .gallery3 .slider-nav {
        width: 471px;
        margin: 0 auto
    }
    #gallery .gallery3 .slider-nav .slick-slide {
        opacity: 0.7
    }
    #gallery .gallery3 .slider-nav .slick-slide.slick-current {
        opacity: 1
    }
    #gallery .gallery3 .slider-nav .slick-prev {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_left.png) left top no-repeat;
        width: 39px;
        height: 45px;
        left: -50px;
        text-indent: -9999px;
        border: none;
        overflow: hidden;
        z-index: 2;
        margin-top: -22px;
        outline: none
    }
    #gallery .gallery3 .slider-nav .slick-prev:hover {
        opacity: 0.8
    }
    #gallery .gallery3 .slider-nav .slick-next {
        position: absolute;
        top: 50%;
        background: url(../img/gallery/btn_thum_right.png) left top no-repeat;
        width: 39px;
        height: 45px;
        right: -50px;
        text-indent: -1000px;
        border: none;
        overflow: hidden;
        z-index: 2;
        outline: none;
        margin-top: -22px
    }
    #gallery .gallery3 .slider-nav .slick-next:hover {
        opacity: 0.8
    }
}


/* 20171018====================*/


#top .main__btm.switch01 {
    display: none;
    position: absolute;
    bottom: 0px;
    left: 0px;
    z-index: 1920;
}
#top .topics {
	margin-top: 30px;
}
#top .main-bottom-banner div{
	display: none;
}
#top .btn_for_switch{
	width: 100%;
}
#top .btn_for_switch img{
	width: 100%;
}
footer .footer-bottom2 ul li:last-child:after {
    display: none;
}
footer .copyright img.v-pc{
	height: 132px;
}
.header-l__top {
    width: 1077px;
}
.header_spec170529{
	background-image: url("/assets/img/common/header_spec_bg.png");
	width: 1077px;
	height: 72px;
    position: relative;
}

.header_spec170529_ps{

display: block;
position: absolute;
top: 18px;
left: 90px;

}
.header_spec170529_switch{
display: block;
position: absolute;
top: 18px;
left: 280px;
}


@media (max-width: 640px) {
.header_spec170529{
	   background: url("/assets/img/common/sp/header_spec_bg.png") no-repeat;
    width: 100%;
    height: 72px;
    position: relative;
}
	.header_spec170529_ps{

display: block;
position: absolute;
top: 13px;
left: 110px;

}
.header_spec170529_switch{
display: block;
position: absolute;
top: 13px;
left: 300px;
}


	.header-l__reserve{
display: inline-grid;
	}
	.header-l__reserve.v-pc{
	display: none;
	}
}


#top .best {
    margin-bottom: 50px;
    /*margin-top:100px;*/
    
}

#top .best__wrap {
    width: 1024px;
    margin: 0 auto;
    border-bottom: 1px solid #fec500;
}

@media (max-width: 640px) {
    #top .best__wrap {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}

#top .best__block {
    position: relative;
    float: left;
    width: 340px;
    overflow: visible
}


#top .best__title {
    height: 120px;
    overflow: visible;
    position: relative
}

#top .best__price {
    color: #FFF;
    font-size: 16px;
    padding-left: 9px;
    margin-bottom: 10px;
    width: 329px;
    text-align: center;

}

#top .best__price span {
    color: #fec500
}

#top .best__photo {
    padding-left: 0px;
    margin-bottom: 17px;
    position: relative;
    height: 255px;
    overflow: visible;
    width: 329px;
    text-align: center;
}

#top .best__btn {
    display: block;
    width: 329px;
    text-align: center;
}
@media (max-width: 640px){

    #top .best__price {
        width: auto;
        text-align: left;
    }
    #top .best__photo {
        padding-left: 15px;
        width: auto;
        text-align: left;
    }
    #top .best__btn {
        width: auto;
        text-align: left;
    }
}

#top .best__top {
    *zoom: 1;
    padding-bottom: 45px
}

#top .best__top:after {
    content: "\0020";
    display: block;
    height: 0;
    clear: both;
    overflow: hidden;
    visibility: hidden
}


.spec-box .price__dl dt {
    color: #fff;
    float: left;
    width: 137px;
    font-size: 15px;
    background: url(../img/common/bg_footer_dt.png) left top no-repeat;
    height: 26px;
    line-height: 26px;
    text-align: center;
    clear: both;
    margin-bottom: 10px;
    text-indent: -5px;
}

.spec-box .price__dl dt.price_best{
    color: #fff;
    float: left;
    width: 202px;
    font-size: 14px;
    background: url(../img/common/bg_footer_dt_b.png) left top no-repeat;
    height: 26px;
    line-height: 26px;
    text-align: center;
    clear: both;
    margin-bottom: 10px;
    text-indent: -5px;
}

.spec-box .price__dl dt.price_switch ,
.spec-box .price__dl dt.price_switch_best,
.spec-box .price__dl dt.price_sp{
    color: #fff;
    float: left;
    width: 160px;
    font-size: 14px;
    background: url(../img/common/bg_footer_dt_r.png) left top no-repeat;
    height: 26px;
    line-height: 22px;
    text-align: center;
    clear: both;
    margin-bottom: 10px;
    text-indent: -18px;
    position: relative;
}
.spec-box .price__dl dt.price_switch_best,
.spec-box .price__dl dt.price_sp{
    width: 265px;
    background-color: #000;
    position: relative;
    background-image: none;
    text-indent: 2px;
}
.spec-box .price__dl dt.price_sp{
    line-height: 26px;
    width: 137px;
}
.spec-box .price__dl dt.price_switch_best:after,
.spec-box .price__dl dt.price_sp:after
{
    display: inline-block;
    height: 26px;
    position: absolute;
    background: url(../img/common/bg_footer_dt_b.png) left top no-repeat;
    right: -18px;
    width: 20px;
    background-position: right;
    content: "";
    
}

.spec-box .price__dl dt.price_switch sup,
.spec-box .price__dl dt.price_switch_best sup{


    font-size: 10px;
   top: -5px;
    right: 12px;
}


@media (max-width: 640px) {
#top .best__block {
    width: 100%;
}


#top .best__price {
    color: #FFF;
    font-size: 16px;
    padding-left: 9px;
    margin-bottom: 10px;
    position: absolute;
    bottom: 80px;
    right: 66px;
}

#top .best__btn {
    display: block;
    position: absolute;
    bottom: 10px;
    right: 10px;
}

#top .best__photo {

    height: 336px;
    overflow: visible;
}


#top .best__block--psvita .best__price, #top .best__block--ps4 .best__price{



     bottom: 80px;
}


}

/*20181002*/

@media (max-width: 640px) {
    .header-l__top {
        width: auto;
        padding: 0 10px;
        margin: 0 auto
    }
}
@media (max-width: 640px) and (max-width: 640px) {
    #story .story1__wrap {
        width: auto;
        padding: 0 0px;
        margin: 0 auto
    }
}
/*20200622*/
.block--lineup{
    margin: 0 auto;
    max-width: 1050px;
    text-align: center;
    border: none !important;
    outline: none !important;
}
.block--lineup h3{
    margin: 30px 10px 12px 10px;
    text-align: center;
    display: inline-block;
    position: relative;
}
.block--lineup h3 span{
    text-align: center;
    display: inline-block;
}
.block--lineup h3 span.txt{
    position: relative;
    text-align: center;
    display: inline-block;
    z-index: 3;
    color: #FFD800;
    line-height: 130%;
    text-shadow:0px 0px 4px #ff5e00, 0px 0px 3px #ff5e00, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000;
    font-size: 24px;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.block--lineup h3 span.txt_bg::before{
    content: "";
    background: url(../img/top/lineup_bg_l.png) left top no-repeat;
    width: 90px;
    height: 38px;
    display: block;
    position: absolute;
    z-index: 2;
    top: 50%;
    margin-top: -20px;
    left: -67px;
}
.block--lineup h3 span.txt_bg::after{
    content: "";
    background: url(../img/top/lineup_bg_r.png) left top no-repeat;
    width: 90px;
    height: 38px;
    display: block;
    position: absolute;
    z-index: 2;
    top:50%;
    margin-top: -20px;
    right: -67px;
}
.block--lineup .lineup-flex{
    display: flex;
    justify-content: center;
    width: fit-content;
    margin: 0 auto;
    border: solid 2px #fec500;
    padding: 2px;
}
.block--lineup .lineup-flex .lineup-clm-switch,
.block--lineup .lineup-flex .lineup-clm-ps,
.block--lineup .lineup-flex .lineup-clm-app{
    padding: 10px 15px;
}
.block--lineup .lineup-flex .lineup-clm-switch{
background-color: #a300006b;
border: solid 1px #df0000;
}
.block--lineup .lineup-flex .lineup-clm-app{
    background-color: #080808a8;
    border: solid 1px #c2c2c2;
}
.block--lineup .lineup-flex .lineup-clm-ps{
    background-color: #0033a16b;
    border: solid 1px #0050fd;
}
.block--lineup .lineup-flex img{
    height:  100%;
    max-height: 50px;
}
.block--lineup .lineup-flex ul{
    display: flex;
    justify-content: center;
}
.block--lineup .lineup-flex ul.list-app{
    display: block;
    justify-content: center;
}
.block--lineup .lineup-flex .margin_r{
    margin-right: 3px;
}
.block--lineup .lineup-flex .margin_l{
    margin-left: 3px;
}
.block--lineup .lineup-flex ul .margin_r{
    margin-right: 10px;
}
.block--lineup .lineup-flex ul .margin_l{
    margin-left: 10px;
}
.block--lineup .lineup-flex a{
    display: block;
    background: url(../img/top/seriesDL_linkbtn_bg_off.png) left top repeat-x;
    background-size: auto 100%;
    border: solid 1px #0224e2;
    padding: 10px 0;
    margin-top: 5px;
    text-align: center;
    color: #fff;

}
.block--lineup .lineup-flex a:hover{
    background: url(../img/top/seriesDL_linkbtn_bg_on.png) left top repeat-x;
    background-size: auto 100%;
}

.block--lineup .lineup-flex .lineup-clm-app a{
    background-image: none;
    border: none;
    margin-top: 0px;
    padding: 0px 0;
}
.block--lineup .lineup-flex .lineup-clm-app a:hover{
}



.block--lineup .lineup-flex a span.icon-arrow{
    background: url(../img/top/icon-arrow.png) left top repeat-x;
    width: 17px;
    height: 17px;
    display: inline-block;
    background-size: 100% 100%;
    vertical-align: bottom;
    margin-right: 8px;
}
.block--lineup .lineup-link-flex{
    margin: 0 auto 30px auto;
}
.block--lineup .lineup-flex.lineup-link-flex .lineup-clm-app,
.block--lineup .lineup-flex.lineup-link-flex .lineup-clm-ps,
.block--lineup .lineup-flex.lineup-link-flex .lineup-clm-switch{
    padding:10px 23px;
}


@media (max-width: 640px) and (max-width: 640px) {
    .block--lineup{
        margin:3vw auto 0 auto;
    }
    .block--lineup .lineup-flex{
        display: block;
    }
    .block--lineup .lineup-flex img {
        max-height: 67px;
    }
    .block--lineup .lineup-flex a{
        font-size: 200%;
        padding: 20px 0;
    }
    .block--lineup h3 span.txt{
        font-size: 200%;
    }
    .block--lineup .lineup-flex a span.icon-arrow{
        width: 25px;
        height: 25px;
        vertical-align: top;
    }
    .block--lineup .lineup-flex ul.list-app{
        display: flex;
        justify-content: center;
    }
    .block--lineup .lineup-flex ul.list-app li:first-child{
        margin-right: 10px;
    }
}



#top .release_platform {
    position: absolute;
    top: 24%;
    left: 54%;
    margin: 0 0 0 0;
    transform: translate(-105%, -134%);
    z-index: 901
}
#top .release_platform img{
    width: 88%;
}
@media (max-width: 640px) and (max-width: 640px) {
    #top .main__top{
        padding-top: 522px;
    }
    #top .release_platform {
        width: 100%;
        text-align: center;
        position: relative;
        top: 0;
        left: 0;
        padding-top: 438px;
        z-index: 902;
        transform: translate(0, 0);
        position: absolute;
    }
#top .release_platform img{
    width: 80%;
    display: block;
    margin: 0 auto;
}
.spec-box .price__dl dd{
padding-left: 0 !important;
}
.spec__dl dd{
    text-align: left;
}
}

footer .footer-bottom2 {
    text-align: center;
    padding:20px 10px;
    font-size: 85%;
    line-height: 180%;
}
footer .footer-bottom2 a{
    color: #4a87ec;
}
footer .footer-bottom2 a:hover{
    color: #3db2ff;
    text-decoration: underline;
}
footer .footer-bottom2 ul li {
    display: inline-block;
}
footer .footer-bottom2 ul li:after {
    content: "|";
    color: #4a87ec;
    margin: 0 10px;
    display: inline-block;
}
@media (max-width: 640px) and (max-width: 640px) {
    footer .footer-bottom2 {
        text-align: left;
        padding:20px 10px;
        font-size: 120%;
    }
    footer .footer-bottom2 ul li {
        display: block;
        margin: 0 0 0px 0;
    }
    footer .footer-bottom2 a{
        margin: 0 0 20px 0;
    }
    footer .footer-bottom2 ul li:after {
        display: none;
    }
}