@charset "utf-8";

html,body{
  width:100%;
  height:100%;
  padding:0;
  margin:0 auto;
  color:rgba(255,255,255,0.9);
  font-family: 'Jura', '游ゴシック体', 'YuGothic', 'ヒラギノ角ゴシック', Helvetica, 'Roboto', Arial, sans-serif;

}

body::before{
  content:"";
  display:block;
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:100vh;

  background-color:#02004C;
  background-image:url(../img/common/bg-tile-pattern.svg);
  background-position:center;
  background-repeat:repeat;
  background-size:100%;
}



a{
  color:rgba(255,255,255,0.9);
  text-decoration:none;
}
img{
  max-width:100%;
}

h1,h2,h3,h4{
  color:rgba(255,255,255,1);
  padding:30px 0 10px;
  text-align:center;
  font-weight:bold;
}
h1{
  font-size:28px;
}
h2{
  font-size:20px;
}



/************************************************
Layout
************************************************/

section{
  min-width:100%;
  min-height:100%;
  padding:20px 0;
  box-sizing:border-box;
  background-color:transparent !important;
  transition: all 0.3s 0 ease;
  text-align:center;
}
section .inner{
  text-align:center;
}


/************************************************
nav
************************************************/
nav{
  position:fixed;
  top:0;
  left:0;
  width:200px !important;
  height:100%;
  background-color:rgba(0,0,0,0.1) !important;
}

nav ul{
  padding:40px 0;
}

nav a{
  display:block;
  height:40px;
  line-height:40px;
  text-indent:1em;
  font-size:18px;
  font-weight:bold;
  color:#aaa;
  position:relative;
  top:0;
  left:0;
}
nav a.selected{
  color:#fff;
}

nav a:hover{
  display:block;
  height:40px;
  line-height:40px;
  font-size:18px;
  background-color:rgba(255,255,255,0.1);
}

nav a.selected:before{

  position:absolute;
  top:0;
  left:0;
  display:block;
  content:"";
  width:12px;
  height:40px;
  background-image:url(../img/common/nav-line.svg);
/*
  position:absolute;
  top:0;
  left:0;

  display:block;
  content:"";
  height:4px;
  width:calc(1em - 4px);
  margin-top:18px;
  background-color:rgba(255,0,0,0.5);
*/
}



.drawer-hamburger{
  transform:scale(.6);
  opacity:.7;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
  background-color: #eeeeee !important;
}
.drawer-open .drawer-hamburger-icon {
  background-color: transparent !important;
}
.drawer--left.drawer-open .drawer-hamburger {
  left: 200px !important;
}

/************************************************
header, footer
************************************************/

header img{
  display:block;
  width:200px;
  margin:0 auto;
  margin-top:20px;
}

footer{
  padding:20px 0;
  background-color:#000000;
  text-align:center;
  color:#aaaaaa;
  font-size: 10px;
}

footer li a{
  padding:4px;
  line-height:1.6em;
}

small{
  line-height:1.8em;
}


#error{
  height:200px;
  padding:80px;
}


/************************************************
Parts
************************************************/
.hide{
  display:none;
}


/************************************************
#top
************************************************/

#top{
  width:100%;
  max-height:100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top:-2vh;
  font-size:12px;
  font-family:'ヒラギノ角ゴシック';
}

#top img{
  display:block;
  width:80vw;
  max-width:640px;
  margin:0 auto;
}

#top info-area{
  padding-top:4em;
}

#top .info-area img.button{
  display:inline-block;
  width:160px;
  padding:1em;
  max-width:320px;
}


#game{
  background-color:#e50152;
  text-align:center;
}


/************************************************
#game
************************************************/
#game ul{
  max-width:320px;
  margin:12px auto;
}
#game li{
  position:relative;
  left:0;
  top:0;
  margin:10px;
  text-align:center;
  background-color:#000000;
}

#game .text{
  width:100%;
  position:absolute;
  left:0;
  top:calc(50% - 1em);
  text-align:center;
}

#game h3{
  margin:0;
  padding:0;
  font-size: 18px;
  line-height:1.2em;
  color:#ffffff;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
#game .app-icon{
  display:block;
  width:100%;
  opacity:0.6;
}


#game .store{
  display:flex;
  width:40%;
  height:54px;
  margin:0 auto;
  justify-content:center;
}
#game .store a{
  display:inline-block;
  width:28px;
  padding:12px;
  transition: transform 0.1s linear;
}

#game .store a:hover{
  transform:scale(1.2);
}


#game .store a[href^="https://apps.apple.com/"]:after,
#game .store a[href^="https://itunes.apple.com/"]:after{
  content: url(../img/common/icon-store-apple.svg);
}
#game .store a[href^="https://play.google.com/"]:after{
  content: url(../img/common/icon-store-google-play.svg);
}

.button.load-more-app{
  display:inline-block;
  margin:40px auto;
  padding:0.8em 3em;
  border:4px solid #ffffff;
  color:#ffffff;
  font-size:20px;
  cursor:pointer;
}

#allApps{
  display:none;
}


/************************************************
#company
************************************************/

#company dl{
  padding:12px;
}
#company dd{
  padding-top:6px;
  padding-bottom:12px;
}
#company dl img{
  width:200px;
}

#company .mail:after{
  content: "info@geishatokyo.com";
  display:inline;
}


/************************************************
#terms
************************************************/
#terms pre{
  max-width:720px;
  margin: 12px auto;
  padding: 20px;
  white-space: pre-wrap;
  word-wrap: break-word;
  text-align: left;
  box-sizing:border-box;
  border-radius:12px;
  font-weight: normal;
  line-height: 1.4em;
  font-size: 12px;
}


/************************************************
Slide lib slick
************************************************/

.slick-dotted.slick-slider {
  margin:0;
}
.slick-slide{
  font-size:0;
}

.slick-arrow{
  width:40px;
  height:40px;
  z-index:5;
}
.slick-prev{
  left:10px;
}
.slick-next{
  right:10px;
}
.slick-prev:before,
.slick-next:before{
  color:#aaaaaa;
  font-size:32px;
  opacity:0.5;
}
.slick-dots{
  bottom:20px;
}


/************************************************
for start up
************************************************/
/*
.load-more-app{
  display:none;
}
*/


/************************************************
PC
************************************************/

@media all and (min-width: 720px) {

  body{
    max-width:1600px;
  }
  header{
    max-height:360px;
    background-size:160%;
  }
  header .message{
    font-size:20px;
  }
  footer li{
    display:inline-block;
    padding:1em;
  }
  #game ul{
    max-width:800px;
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
  }
  #game li{
    width:calc(33.33% - 20px);
  }

}


