html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
address,
cite,
code,
dfn,
em,
img,
ins,
q,
strong,
small,
sub,
sup,
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;
  vertical-align: baseline;
  border: 0;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
}
table {
  border-spacing: 0;
  border-collapse: collapse;
}
caption,
th,
td {
  text-align: left;
}
q::before,
q::after {
  content: '';
}
object,
embed {
  vertical-align: top;
}
img,
abbr,
acronym,
fieldset {
  border: 0;
}
li {
  list-style-type: none;
}
a,
label {
  cursor: pointer;
}
a {
  text-decoration: none;
}
a:active,
a:focus {
  outline: none;
}
button-moz-focus-inner,
input-moz-focus-inner {
  padding: 0;
  border: 0;
}
*::before,
*::after {
  pointer-events: none;
}
html {
  overflow-y: scroll;
  text-size-adjust: 100%;
  font-size: 16px;
  height: 100%;
}
body {
  color: #000;
  text-size-adjust: 100%;
  font-family: 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, '游ゴシック', YuGothic, sans-serif;
  font-smooth: always;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.7;
  background-color: #000;
  height: 100%;
}
::selection {
  color: #fff;
  background: #000;
}
a {
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}
a:visited {
  color: #004098;
}
a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 768px) {
  a:hover {
    opacity: 1;
  }
}
.cursor-pointer {
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  cursor: pointer;
}
.cursor-pointer:hover {
  opacity: 0.7;
}
@media screen and (max-width: 768px) {
  .cursor-pointer:hover {
    opacity: 1;
  }
}
#wrapper img,
#modal img {
  max-width: 100%;
  width: 100%;
  vertical-align: bottom;
}
.js-modal {
  cursor: pointer;
}
.pcImg {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .pcImg {
    display: none;
  }
}
.spImg {
  display: none;
}
@media screen and (max-width: 768px) {
  .spImg {
    display: inline-block;
  }
}
.annotation {
  font-size: 10px;
  color: #fff;
}
#wrapper {
  width: 100%;
  margin: 0 auto;
  background-color: #000;
  overflow: hidden;
  position: relative;
}
.main-visual-wrapper {
  width: 100%;
  background-image: url("../images/bg.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  z-index: ;
}
.main-visual-wrapper:before {
  content: " ";
  width: 100%;
  height: 100%;
  background-image: url("../images/bg-front.png");
  background-size: contain;
  background-repeat: repeat-x;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .main-visual-wrapper:before {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .main-visual-wrapper {
    background-image: url("../images/bg_sp.png");
    background-size: 100%;
    background-position: top;
  }
}
.main-visual-wrapper .main-visual-inner {
  z-index: 11;
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  position: relative;
}
.main-visual-wrapper .main-visual-inner .js-fadein,
.main-visual-wrapper .main-visual-inner .js-fadein-scroll {
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
}
.main-visual-wrapper .main-visual-inner .js-fadein.show,
.main-visual-wrapper .main-visual-inner .js-fadein-scroll.show {
  -webkit-animation: fadein forwards 0.3s ease-in-out;
          animation: fadein forwards 0.3s ease-in-out;
}
.title-bar {
  padding-top: 130px;
  width: 92.578125%;
  max-width: 948px;
  margin: 0 auto 0.48828125%;
}
@media screen and (max-width: 1024px) {
  .title-bar {
    padding-top: 12.6953125%;
  }
}
@media screen and (max-width: 768px) {
  .title-bar {
    padding-top: 12.5%;
    width: 96.09375%;
  }
}
.normal-image {
  width: 90.33203125%;
  max-width: 925px;
  margin: 0 auto;
  padding-bottom: 15px;
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 1024px) {
  .normal-image {
    padding-bottom: 1.46484375%;
  }
}
@media screen and (max-width: 768px) {
  .normal-image {
    width: 93.75%;
    padding-bottom: 3.125%;
  }
}
.bonus-image {
  width: 49.609375%;
  margin-left: 4.8828125%;
  margin-top: -7.8125%;
  position: relative;
  z-index: 2;
}
.rt-image {
  width: 47.94921875%;
  margin-left: 47.8515625%;
  margin-top: -85.83984375%;
  position: relative;
  z-index: 1;
}
.js-slidein-under {
  opacity: 0;
}
.js-slidein-under.show {
  -webkit-animation: slidein-under forwards 0.2s ease-in;
          animation: slidein-under forwards 0.2s ease-in;
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}
.js-slidein-top {
  opacity: 0;
}
.js-slidein-top.show {
  -webkit-animation: slidein-top forwards 0.1s ease-in;
          animation: slidein-top forwards 0.1s ease-in;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}
.js-slidein-left {
  opacity: 0;
}
.js-slidein-left.show {
  -webkit-animation: slidein-left forwards 0.1s ease-in;
          animation: slidein-left forwards 0.1s ease-in;
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}
@-webkit-keyframes fadein {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@-webkit-keyframes slidein-under {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@keyframes slidein-under {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@-webkit-keyframes slidein-top {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@keyframes slidein-top {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}
@-webkit-keyframes slidein-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100px);
            transform: translateX(-100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
@keyframes slidein-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100px);
            transform: translateX(-100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
.header-inner .menu-btn {
  display: none;
}
@media screen and (max-width: 768px) {
  .header-inner .menu-btn {
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 27.1875%;
    padding-top: 3.125%;
    margin-right: 2.8125%;
  }
}
@media screen and (max-width: 768px) {
  .footer {
    background-image: url("../../common/images/footer-bg_sp.png");
    background-size: 100%;
  }
}
@media screen and (max-width: 768px) {
  .menu-feature-inner {
    display: none;
  }
}
.footer {
  width: 100%;
  background-color: #000;
  position: relative;
  z-index: 15;
}
.footer .menu-wrapper {
  display: none;
}
@media screen and (max-width: 768px) {
  .footer .menu-wrapper {
    display: block;
    width: 93.75%;
    margin: 0 auto;
    padding-top: 3.125%;
    font-size: 0;
  }
  .footer .menu-wrapper .menu {
    font-size: 0;
    display: inline-block;
    width: 49%;
    margin-bottom: 1.5625%;
  }
  .footer .menu-wrapper .menu.menu-feature,
  .footer .menu-wrapper .menu.menu-bonus {
    margin-right: 1%;
  }
  .footer .menu-wrapper .menu.menu-top {
    display: block;
    margin: 0 auto;
  }
}
.footer .link-wrapper {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto 0.68359375%;
  padding-top: 14px;
}
@media screen and (max-width: 1024px) {
  .footer .link-wrapper {
    padding-top: 1.3671875%;
  }
}
.footer .link-wrapper .footer-banner {
  width: 31.25%;
  display: inline-block;
}
.footer .link-wrapper .footer-banner img {
  vertical-align: top;
}
@media screen and (max-width: 768px) {
  .footer .link-wrapper .footer-banner {
    width: 84.375%;
    margin: 3.125% auto 0;
    display: block;
  }
}
.footer .link-wrapper .footer-banner.banner02 {
  margin: 0 1.5625%;
}
@media screen and (max-width: 768px) {
  .footer .link-wrapper .footer-banner.banner02 {
    margin: 3.125% auto 0;
  }
}
.footer .footer-copyright {
  width: 100%;
  max-width: 1024px;
  margin: 0.48828125% auto 0;
  text-align: center;
  color: #fff;
  font-size: 10px;
}
@media screen and (max-width: 768px) {
  .footer .footer-copyright {
    width: 96.875%;
    margin: 4.6875% auto;
    text-align: center;
    letter-spacing: -0.5px;
    line-height: 14px;
  }
}
.footer .sns-wrapper {
  width: 100%;
  max-width: 1024px;
  margin: 8px auto 0;
}
@media screen and (max-width: 1024px) {
  .footer .sns-wrapper {
    margin: 0.78125% auto 0;
  }
}
@media screen and (max-width: 768px) {
  .footer .sns-wrapper {
    text-align: center;
    margin: 4.6875% auto;
  }
}
.footer .sns-wrapper .snsList {
  font-size: 0;
  text-align: center;
}
.footer .sns-wrapper .snsList__item {
  display: inline-block;
  margin-left: 0.9765625%;
}
#cmn-header {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 16;
}
#cmn-header .header-inner {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
}
#cmn-header .header-inner .logo {
  display: block;
  width: 10.3515625%;
  padding-top: 1.5625%;
  margin-left: 3.90625%;
}
@media screen and (max-width: 768px) {
  #cmn-header .header-inner .logo {
    width: 28.125%;
    padding-top: 2.8125%;
    margin-left: 2.8125%;
  }
}
#cmn-header .header-inner .menu-wrapper {
  width: 91.796875%;
  max-width: 940px;
  margin: 12px auto;
  text-align: center;
  font-size: 0;
}
@media screen and (max-width: 768px) {
  #cmn-header .header-inner .menu-wrapper {
    display: none;
  }
}
#cmn-header .header-inner .menu-wrapper .menu {
  opacity: 1 !important;
  display: inline-block;
  width: 19.148936170212764%;
  margin-right: 1.063829787234043%;
  vertical-align: top;
  border-radius: 10px;
  box-shadow: 3px 3px 3px rgba(0,0,0,0.4);
}
#cmn-header .header-inner .menu-wrapper .menu.menu-spec {
  margin-right: 0;
}
#cmn-header .header-inner .menu-wrapper .menu.menu-spec.menu-spec {
  margin-right: 0;
}
#cmn-header .header-inner .menu-wrapper .menu-feature-inner {
  margin-top: 8px;
  margin-left: 20.21276595744681%;
  width: 19.148936170212764%;
}
#cmn-header .header-inner .menu-wrapper .menu-feature-inner .menu-feature-grt,
#cmn-header .header-inner .menu-wrapper .menu-feature-inner .menu-feature-game {
  display: inline-block;
  width: 46%;
  font-size: 0;
  box-shadow: none;
}
#cmn-header .header-inner .menu-wrapper .menu-feature-inner .menu-feature-grt {
  margin-right: 1%;
}
