@charset "utf-8";
/* CSS Document */

/* reset *************************************************************/
body {line-height:1; margin:0; font-family: 'Meiryo',"ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","Osaka", sans-serif;}
h1, h2, h3, h4, h5, h6, p {margin:0; font-weight:normal; display:block;}
article,footer,header {display:block;}
ul,li {list-style:none; padding:0;margin:0;}
dl,dt,dd {padding:0; margin:0;}
table,tr,td {border:0;padding:0;margin:0;}
a {color:#3c68c3;}
img {vertical-align:baseline; border:0; padding:0; margin:0;}
div {margin:0;padding:0;}
button {background: transparent;border: 0; outline: none;}
/* //reset *************************************************************/

*{
  box-sizing: border-box;
}
body,html {
  height: 100%;
  margin: 0;
}
html {
  font-size: 62.5%;
}
body {
    min-height: 100vh;
    font-size: 1.4rem;
    color: #343434;
    line-height: 1.7;
    -webkit-text-size-adjust: 100%;
     font-family:"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
    background: #333;
}
p {
  margin-top: 1rem;
}
img {
  max-width: 100%;
  width: auto;
  height: auto;
  margin: 0 auto;
  vertical-align: bottom;
}

#wrapper {
  position: relative;
  width: 100%;
    max-width: 750px;
    margin: 0 auto;
  overflow: hidden;
}



/***************************/

.inner {
  padding: 0 2.6666%;
}

em {
  font-weight: bold;
  color: #9241ad;
  font-style: normal;
}
.bg_video {
  max-width: 750px;
    width: 100%;
  position: fixed;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  /*background: url() no-repeat center center/cover;*/
    z-index: -999;
}
h1 {
    margin: 3%;
    position: fixed;
    top: 0;
    max-width: 34%;
    z-index: 999;
    transform: scale(0);
    animation: logo 1s ease 2s  alternate both;
}
.copy {
    position: absolute;
    top: 34%;
    z-index: 999;
}
.copy01 {
    width: 69.6%;
    margin-left: 2.666%;
    transform: translateX(-130%);
    animation: copy1 0.5s ease 1s 1 alternate both;
}
.copy02 {
    width: 69.6%;
    margin: 10px 0 0 14%;
    transform: translateX(-130%);
    animation: copy1 0.5s ease 1.5s 1 alternate both;
}
@keyframes logo {
  0% { transform: scale(0); }
  60% { transform: scale(1.2); }
  70% { transform: scale(0.9); }
  80% { transform: scale(1.2); }
  100% { transform: scale(1); }
}
@keyframes copy1 {
  0% { transform: translateX(-130%); }
  100% { transform: translateX(0); }
}

.scroll {
    animation: scroll 0.7s ease 0s 1 alternate both;
}
@keyframes scroll {
  0% { transform: translateY(0);}
  70% { transform: translateY(-10px);}
  100% { transform: translateY(0); }
}

video,
.video_slider img {
  min-width: 100%;
  min-height: 100vh;
  z-index: 1;
}
.video_slider li {
    position: relative;
}
.video_slider li span {
    position: absolute;
    top: 0;
    right: 0;
    background: #FFF;
}
.overlay {
  width: 100%;
  height: 100vh;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

.main {
    position: relative;
    width: 100%;
    margin-top: 100vh;
    transition: 0.3s;
}

.btn-top {
    position: absolute;
    bottom: 100%;
    right: 0;
    z-index: 0;
}
.btn-top img {
    width: 100%;
}
.app {
    position: relative;
    margin-top: -5%;
    background: #FFF;
    border-radius: 30px 30px 0 0;
    z-index: 999;
}
.store {
    position: relative;
    display: flex;
    padding-top: 2.6%;
    padding-bottom: 2.6%;
    align-items: center;
}
.app_header {
    margin-bottom: 6.2%;    
}
.app_header:after {
    display: block;
    content:"";
    position: absolute;
    width: 100px;
    height: 4px;
    background: #c7c7c7;
    bottom: -4px;
    border-radius: 2px;
    left: 50%;
    margin-left: -50px;
}
.store_icon {
    width: 17%;
}
.store_title {
    width: 65%;
    padding: 0 10px;
    font-size: 1.1rem;
}
.store_title h2 {
    font-size: 1.6rem;
    font-weight: bold;
}
.store_title dl {
    display: flex;
    flex-flow: wrap;
    line-height: 1.4;
}
.store_title dt {
    width: 35%;
    color: #505050;
}
.store_title dd {
    width: 65%;
    font-weight: bold;
}
.store_title dd span {
    color: #fe8503;
}
.store_btn {
    width: 18%;
    text-align: right;
}
.store_btn a {
    display: inline-block;
    padding: 1px 15px;
    text-decoration: none;
    color: #FFF;
    background: #1e82fe;
    border-radius: 40px;
    text-align: center;
}
.btn {
  margin: 8% 0 10.6666%;
  text-align: center;
}
.slide {
    margin-bottom: 5.2%;
}
.slider li {
    margin: 0 5px;
    border-radius: 10px;
    overflow: hidden;
}

.app_footer {
    margin-top: 6.2%;
    padding-top: 20px;
    padding-bottom: 20px;
    background: #eeeeee;
}

#footer {
    position: relative;
    width: 100%;
    padding: 6.2% 0;
    text-align: center;
}


@media screen and (min-width: 600px) {
  html { font-size: 80%; }
  .btn_fixed p {
    font-size: 1.4rem;
  }

}
@media screen and (min-width: 750px) {
  html { font-size: 100%; }
  #wrapper {width:750px;margin:auto;}
  .btn_fixed {
    padding: 20px 0 0 !important;
  }
  .btn_fixed img {
    margin: 20px auto;
  }
}

