@charset "UTF-8";
/* 継承元css */
/* flex-flow: row nowrap; */
/* FontFamily */
/* FontSize */
/* Color */
html {
  font-size: 62.5%; }

/*
font-size: 62.5%
以降rem指定 1rem:10px相当, 2rem:20px相当
*/
body, html, header, footer, section, article, aside, fieldset, div, form, p, address, h1, h2, h3, h4, h5, h6, dl, dt, dd, ul, ol, li {
  margin: 0px;
  padding: 0px;
  border: none;
  box-sizing: border-box;
  color: #0d0015;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-style: normal; }

ul, dl {
  margin: 0px;
  padding: 0px; }

img {
  vertical-align: bottom; }

input[type="text"], input[type="password"] {
  width: 16rem; }

.clearfix:after {
  content: "";
  clear: both;
  display: block; }

.auto_width {
  width: 100%;
  height: auto;
  max-height: 100%; }

.auto_height {
  width: 100%;
  height: auto;
  max-width: 100%; }

.auto_size {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100% ；; }

.invisible {
  width: 0px !important;
  height: 0px !important;
  display: none !important; }

a, *:visited {
  color: #333;
  text-decoration: none; }

*:hover {
  text-decoration: none; }

html, body {
  width: 100%; }

html {
  position: relative; }

body {
  min-height: 100vh;
  overflow-x: hidden;
  background-color: #172A88; }

body#sp {
  background-color: white; }

#pc #wrap {
  width: 100%;
  margin: 0px;
  position: relative;
  background-color: white; }
#pc header {
  width: 100%;
  height: 50vw;
  background: url(../image/header.png) transparent no-repeat top left;
  background-size: 100vw; }
#pc main {
  padding-top: calc(40 / 1280 * 100vw);
  padding-left: calc(100 / 1280 * 100vw);
  width: calc(605 / 1280 * 100vw); }
  #pc main h2 {
    height: calc(48 / 1280 * 100vw);
    color: #172A88;
    font-size: calc(22 / 1280 * 100vw);
    line-height: calc(26 / 1280 * 100vw);
    letter-spacing: calc(2 / 1280 * 100vw);
    padding-left: calc(5 / 1280 * 100vw);
    border-left: calc(48 / 1280 * 100vw) #172A88 solid; }
  #pc main .ex1 {
    padding-top: 15px;
    color: #172A88;
    font-size: calc(13.8 / 1280 * 100vw);
    line-height: calc(20 / 1280 * 100vw);
    letter-spacing: calc(0.9 / 1280 * 100vw);
    font-weight: 600; }
  #pc main .ex2 {
    margin-top: calc(15 / 1280 * 100vw);
    padding: calc(3 / 1280 * 100vw) calc(6 / 1280 * 100vw);
    border: calc(1 / 1280 * 100vw) #898989 solid;
    border-radius: calc(2 / 1280 * 100vw);
    color: #231815;
    font-size: calc(13.8 / 1280 * 100vw);
    line-height: calc(16 / 1280 * 100vw);
    letter-spacing: calc(0.9 / 1280 * 100vw);
    font-weight: 600; }
  #pc main .ex3 {
    padding-top: calc(15 / 1280 * 100vw);
    color: #000000;
    font-size: calc(13.3 / 1280 * 100vw);
    line-height: calc(20 / 1280 * 100vw);
    letter-spacing: calc(0.9 / 1280 * 100vw);
    font-weight: 500; }
#pc #demo {
  width: calc(208 / 1280 * 100vw);
  position: absolute;
  z-index: 50;
  left: calc(654 / 1280 * 100vw);
  top: calc(524 / 1280 * 100vw);
  opacity: 0.7; }
#pc #click {
  width: calc(202 / 1280 * 100vw);
  position: absolute;
  z-index: 20;
  left: calc(994 / 1280 * 100vw);
  top: calc(367 / 1280 * 100vw); }
#pc #slot {
  width: calc(270 / 1280 * 100vw);
  position: absolute;
  z-index: 40;
  left: calc(783 / 1280 * 100vw);
  top: calc(75 / 1280 * 100vw); }
  #pc #slot #slotbg {
    z-index: 5; }
#pc .slotwin {
  height: calc(627 / 1280 * 100vw); }
#pc #qrcode {
  width: calc(434 / 1280 * 100vw);
  height: calc(373 / 1280 * 100vw);
  border: calc(1 / 1280 * 100vw) #898989 solid;
  border-radius: calc(1 / 1280 * 100vw);
  padding: calc(164 / 1280 * 100vw) calc(32 / 1280 * 100vw) 0px calc(32 / 1280 * 100vw);
  position: absolute;
  z-index: 10;
  left: calc(753 / 1280 * 100vw);
  top: calc(584 / 1280 * 100vw);
  background: url(../image/qrcode.png) transparent no-repeat;
  background-position: left calc(316 / 1280 * 100vw) top calc(20 / 1280 * 100vw);
  background-size: calc(87 / 1280 * 100vw); }
  #pc #qrcode h3 {
    width: calc(340 / 1280 * 100vw);
    height: calc(34 / 1280 * 100vw);
    margin: 0px calc(15 / 1280 * 100vw);
    color: #006934;
    font-size: calc(14 / 1280 * 100vw);
    font-weight: 600;
    line-height: calc(18 / 1280 * 100vw);
    text-align: center; }
#pc #link {
  margin-top: calc(56 / 1280 * 100vw);
  margin-bottom: calc(30 / 1280 * 100vw);
  text-align: center; }
  #pc #link a {
    width: calc(280 / 1280 * 100vw);
    height: calc(32 / 1280 * 100vw);
    margin: 0px auto;
    border-radius: calc(12 / 1280 * 100vw);
    background-color: #172A88;
    text-align: center;
    display: block;
    color: white;
    font-size: calc(19 / 1280 * 100vw);
    letter-spacing: calc(8 / 1280 * 100vw);
    line-height: calc(32 / 1280 * 100vw); }
#pc footer {
  width: 100%;
  height: calc(112 / 1280 * 100vw);
  padding-top: calc(26 / 1280 * 100vw);
  background-color: #172A88;
  text-align: center; }
  #pc footer a {
    color: white;
    font-size: calc(13 / 1280 * 100vw);
    font-weight: 500; }
  #pc footer #foot_logo {
    width: calc(136 / 1280 * 100vw);
    height: auto; }
#pc #slot-inner {
  width: calc(260 / 1280 * 100vw);
  height: calc(627 / 1280 *100vw);
  margin-right: calc(10 / 1280 * 100vw);
  padding: calc(425 / 960 * 627 / 270 * 100%) calc(60 / 960 * 100%) 0px calc(60 / 960 * 100%); }
#pc .slotbtn {
  width: calc(826 / 960 * 260 / 270 * 100%);
  position: absolute;
  top: calc(1510 / 2316 * 260 / 270 * 100%);
  left: calc(66 / 960* 260 / 270 * 100%);
  z-index: 20; }

#sp #wrap {
  width: 100%;
  position: relative; }
#sp main #slotbg {
  width: 100%;
  height: auto;
  overflow: hidden;
  z-index: 10; }
#sp main #demo {
  position: absolute;
  z-index: 20;
  left: calc(433 / 960 * 100vw);
  top: calc(578 / 960 * 100vw); }
#sp main img#dm {
  width: calc(454 / 960 * 100vw);
  height: auto;
  opacity: 0.75; }
#sp #slot-inner {
  width: 100vw;
  height: calc(2316 / 960 *100vw);
  margin-right: calc(10 / 1280 * 100vw);
  padding: calc(435 / 960 * 627 / 270 * 100%) calc(60 / 960 * 100%) 0px calc(60 / 960 * 100%); }
#sp .slotbtn {
  width: calc(860 / 960 * 260 / 270 * 100%);
  position: absolute;
  top: calc(1450 / 2316 * 100%);
  left: calc(66 / 960 * 100%);
  z-index: 20; }

#slotbg {
  position: absolute;
  top: 0;
  left: 0; }

#slot-inner {
  display: flex;
  top: 0;
  left: 0;
  overflow: hidden; }

.dram-reel {
  width: calc(100% / 3);
  position: relative; }

/*reel間8*/
.reel {
  position: absolute;
  width: 100%;
  z-index: 2; }

.reel img {
  width: 100%;
  height: auto; }

.slotbtn {
  cursor: pointer; }

/* 画像のパターン */
#pci #wrap {
  width: 100%;
  margin: 0px;
  position: relative;
  background-color: white; }
#pci main {
  width: 100%;
  height: calc(3000 / 3240 * 100vw); }
#pci #slotmain {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 5; }
#pci #slot-inner {
  width: calc(570 / 3240 * 100vw);
  height: calc(400 / 3000 * 100vw);
  padding-top: calc(850 / 3240 * 100vw);
  padding-left: calc(2018 / 3240 * 100vw);
  box-sizing: content-box; }
#pci .slotbtn {
  width: calc(600 / 3240 * 100%);
  position: absolute;
  top: calc(1175 / 3240 * 100vw);
  left: calc(2020 / 3240 * 100%);
  z-index: 20; }
