@charset "UTF-8";
@font-face {
  font-family: "Apercu Pro";
  src: url("../../dest/font/apercu-regular-pro.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap; }
@font-face {
  font-family: "Apercu Pro";
  src: url("../../dest/font/apercu-medium-pro.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap; }
/*====================================================================
	body＆HTML
=====================================================================*/
html, body {
  height: 100%;
  position: relative; }

html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%; }

body {
  width: 100%;
  margin: 0;
  padding: 0;
  position: relative;
  background-color: #efefef;
  color: #333;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  letter-spacing: .1em;
  word-spacing: inherit;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.2);
  tap-highlight-color: rgba(0, 0, 0, 0.2); }

/*==================== basic styles ====================*/
*, ::before, ::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }
  *::selection {
    background-color: rgba(0, 0, 0, 0.75); }
  *::-moz-selection {
    background-color: rgba(0, 0, 0, 0.75); }

main {
  display: block; }

div, p, ol, ul, li, dl, dt, dd, figure, figcaption {
  font-size: 1.4rem;
  line-height: 1.8;
  -webkit-font-feature-settings: "palt";
  -moz-font-feature-settings: "palt";
  font-feature-settings: "palt"; }

div, p, figure {
  margin: 0; }

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: 1; }

strong {
  color: #000; }

a {
  color: inherit;
  text-decoration: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -webkit-touch-callout: none;
  cursor: pointer;
  opacity: 1; }

img, a img {
  display: block;
  width: 100%;
  height: auto;
  border: none;
  border-style: none;
  outline: none;
  vertical-align: bottom; }

/*====================================================================
	common styles
=====================================================================*/
.btn {
  display: inline-block;
  width: 100%;
  max-width: 260px;
  position: relative;
  /* &::after {
  	display: block;
  	width: $full;
  	height: $full;
  	position: absolute;
  	bottom: -4px;
  	left: 0;
  	background-color: $theme-color;
  	border-radius: 4px;
  	content: "";
  	z-index: 1;
  } */ }
  .btn span {
    display: block;
    width: 100%;
    padding: .8em .8em .6em;
    position: relative;
    background: #000;
    border-radius: 4px;
    font-family: "Apercu Pro", sans-serif;
    font-weight: 500;
    letter-spacing: .2em;
    color: #fff;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: .16em;
    text-transform: uppercase;
    z-index: 10;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-transition: all 0.1s ease 0s;
    transition: all 0.1s ease 0s; }
  .btn.-line {
    /* &::after {
    	background-color: #777;
    } */ }
    .btn.-line span {
      background: #fff;
      border: #777 thin solid;
      color: #333; }
    .btn.-line::before {
      display: block;
      width: 1.4em;
      height: 1.4em;
      position: absolute;
      top: 50%;
      right: 1.5em;
      background: url("../../dest/img/ico_dl.svg") center/contain no-repeat;
      content: "";
      z-index: 11;
      -webkit-transform: translate3d(0, -60%, 0);
      transform: translate3d(0, -60%, 0); }

/*==================== loading ====================*/
#load {
  width: 100%;
  min-height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  background-color: #fff;
  opacity: 1;
  -webkit-transition: opacity 0.6s ease 0s;
  transition: opacity 0.6s ease 0s; }

.loadWrap {
  display: block;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  text-align: center;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0); }

.loadLogo {
  width: 260px;
  margin: 0 auto 1.2em; }

/*==================== loading ====================*/
#alert {
  display: none;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 90;
  background-color: rgba(0, 0, 0, 0.85);
  opacity: 1;
  -webkit-transition: opacity 0.3s ease 0s;
  transition: opacity 0.3s ease 0s; }

.alertBox {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  position: absolute;
  top: 50%;
  left: 50%;
  background-color: #fff;
  border-radius: 8px;
  text-align: center;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0); }
  .alertBox::before {
    display: block;
    width: 100%;
    padding-top: 100%;
    content: ""; }
  .alertBox p {
    -webkit-flex: 0 0 auto;
    flex: 0 0 auto;
    padding: 0 3.2em;
    position: relative;
    font-family: "Apercu Pro", sans-serif;
    font-weight: 500;
    letter-spacing: .2em;
    font-size: min(4.8vw, 1.8rem);
    line-height: 1.4;
    text-transform: uppercase; }

/*====================================================================
	contents
=====================================================================*/
.container {
  display: block;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  position: relative;
  border-top: #ccc thin solid;
  text-align: center;
  overflow-x: hidden;
  touch-action: pan-y; }

.page {
  width: auto;
  max-width: 100%;
  height: 100%;
  position: relative;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch; }

.mainContent {
  width: 100%;
  max-width: 520px;
  height: auto;
  min-height: 100%;
  margin: 0 auto;
  padding: 40px 20px 20px;
  padding-bottom: calc(20px + constant(safe-area-inset-bottom));
  padding-bottom: calc(20px + env(safe-area-inset-bottom));
  position: relative;
  background-color: #fff; }

/*========== index ==========*/
.intro_logo {
  width: 80%;
  margin: 0 auto 40px; }
.intro_title {
  margin-bottom: .8em;
  font-size: 1.6rem;
  font-weight: 600; }
.intro_text {
  margin-bottom: .6em;
  font-size: 1.2rem; }
.intro_note {
  color: #999;
  font-size: 1.2rem; }

.startButton {
  margin-top: 50px;
  text-align: center; }
  .startButton_title {
    margin-bottom: 2em;
    position: relative;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em; }
    .startButton_title::after {
      display: block;
      width: 0;
      height: 0;
      position: absolute;
      bottom: -150%;
      left: 50%;
      border-style: solid;
      border-width: .6em .6em 0 .6em;
      border-color: #333 transparent transparent transparent;
      content: "";
      -webkit-transform: translate3d(-50%, 0, 0);
      transform: translate3d(-50%, 0, 0); }

.choiceBtn {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  text-align: center; }
  .choiceBtn_item {
    -webkit-flex: 0 0 48%;
    flex: 0 0 48%; }
  .choiceBtn_text {
    margin-bottom: .4em;
    font-size: 1.2rem; }
  .choiceBtn_img {
    margin-bottom: .8em;
    border: #CDCDCE thin solid; }

.explain {
  margin-top: 60px;
  padding: 0 0;
  text-align: left; }

.explainList {
  margin-bottom: 2em; }
  .explainList_title {
    margin-bottom: .4em;
    padding-bottom: .1em;
    border-bottom: #555 thin solid;
    font-family: "Apercu Pro", sans-serif;
    font-weight: 500;
    letter-spacing: .2em;
    font-size: 1.6rem;
    text-transform: uppercase; }
  .explainList_detail {
    padding-right: .6em; }
    .explainList_detail p {
      margin-bottom: .4em;
      padding-left: .6em;
      font-size: 1.2rem;
      text-align: justify;
      line-height: 1.6;
      text-indent: -0.6em; }
      .explainList_detail p a {
        color: #419EFC; }

/*========== game screen ==========*/
.-gameScreen {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  @inlude justify-content(space-between);
  padding: 50px 0 0;
  padding-bottom: constant(safe-area-inset-bottom);
  padding-bottom: env(safe-area-inset-bottom); }

.controls {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  align-items: flex-end;
  padding: 0 20px 1em;
  position: relative; }

.controlBtn {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  position: relative; }
  .controlBtn_text {
    display: inline-block;
    font-family: "Apercu Pro", sans-serif;
    font-weight: 400;
    letter-spacing: .2em;
    font-size: 1.4rem;
    line-height: 1;
    vertical-align: middle; }
  .controlBtn_icon {
    display: inline-block;
    width: 1em;
    vertical-align: middle; }
  .controlBtn:last-of-type {
    margin-left: 1em; }

.gameTime {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  margin-left: auto;
  position: relative;
  text-align: right; }
  .gameTime_time {
    font-family: "Apercu Pro", sans-serif;
    font-weight: 400;
    letter-spacing: .2em;
    font-size: 1.8rem;
    line-height: 1;
    letter-spacing: .1em;
    vertical-align: middle; }
    .gameTime_time span {
      display: inline-block;
      width: 1.8em;
      margin-right: .04em;
      letter-spacing: .1em;
      font-size: 2.8rem;
      font-weight: 500; }
  .gameTime_icon {
    display: block;
    width: 1.5em;
    position: absolute;
    bottom: 0;
    left: -1em;
    -webkit-transform: translate3d(0, -20%, 0);
    transform: translate3d(0, -20%, 0); }

.gameBoard {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  position: relative; }

.gameSpace {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0); }

.countWrap {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.75);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  z-index: 100; }
  .countWrap.active {
    -webkit-animation: fadeBg 0.8s ease-in-out forwards 3s;
    animation: fadeBg 0.8s ease-in-out forwards 3s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both; }

.count {
  display: none;
  width: 260px;
  height: 240px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0); }
  .count.active {
    display: block; }
  .count_item {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    width: 110px;
    height: 110px;
    position: absolute;
    background: rgba(0, 0, 0, 0.85);
    border-radius: 100%;
    opacity: 0;
    z-index: 1; }
    .count_item p {
      margin-top: .1em;
      font-family: "Apercu Pro", sans-serif;
      font-weight: 500;
      letter-spacing: .2em;
      color: #fff;
      font-size: 6.4rem;
      line-height: 1;
      letter-spacing: 0;
      text-transform: uppercase; }
    .count_item.-count3 {
      top: 0;
      left: 0;
      -webkit-animation: count3 2.8s ease-in-out forwards;
      animation: count3 2.8s ease-in-out forwards;
      -webkit-animation-fill-mode: both;
      animation-fill-mode: both; }
    .count_item.-count2 {
      top: 0;
      right: 0;
      -webkit-animation: count2 1.8s ease-in-out forwards 1s;
      animation: count2 1.8s ease-in-out forwards 1s;
      -webkit-animation-fill-mode: both;
      animation-fill-mode: both; }
    .count_item.-count1 {
      width: 160px;
      height: 160px;
      bottom: 0;
      left: 50%;
      -webkit-transform: translate3d(-50%, 0, 0);
      transform: translate3d(-50%, 0, 0);
      -webkit-animation: count1 1s ease-in-out forwards 2s;
      animation: count1 1s ease-in-out forwards 2s;
      -webkit-animation-fill-mode: both;
      animation-fill-mode: both; }
  .count_start {
    position: absolute;
    top: 50%;
    left: 50%;
    font-family: "Apercu Pro", sans-serif;
    font-weight: 500;
    letter-spacing: .2em;
    color: #333;
    font-size: 5.8rem;
    line-height: 1;
    text-transform: uppercase;
    opacity: 0;
    z-index: 10;
    -webkit-transform: translate3d(-48%, -50%, 0) scale(1);
    transform: translate3d(-48%, -50%, 0) scale(1);
    -webkit-animation: start 0.8s ease-in-out forwards 2.8s;
    animation: start 0.8s ease-in-out forwards 2.8s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both; }

@-webkit-keyframes count3 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@keyframes count3 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@-webkit-keyframes count2 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@keyframes count2 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@-webkit-keyframes count1 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@keyframes count1 {
  0%, 100% {
    opacity: 0; }
  10%, 40% {
    opacity: 1; } }
@-webkit-keyframes start {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-48%, -50%, 0) scale(0.95);
    transform: translate3d(-48%, -50%, 0) scale(0.95); }
  30% {
    opacity: 1; }
  100% {
    -webkit-transform: translate3d(-48%, -50%, 0) scale(1.2);
    transform: translate3d(-48%, -50%, 0) scale(1.2); } }
@keyframes start {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-48%, -50%, 0) scale(0.95);
    transform: translate3d(-48%, -50%, 0) scale(0.95); }
  30% {
    opacity: 1; }
  100% {
    -webkit-transform: translate3d(-48%, -50%, 0) scale(1.2);
    transform: translate3d(-48%, -50%, 0) scale(1.2); } }
@-webkit-keyframes fadeBg {
  0% {
    opacity: 1; }
  100% {
    opacity: 0; } }
@keyframes fadeBg {
  0% {
    opacity: 1; }
  100% {
    opacity: 0; } }
.bottom {
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  height: 100px;
  position: relative; }

/*========== conversion ==========*/
.result_title {
  margin-bottom: 30px;
  font-size: 1.8rem;
  font-weight: 600; }
.result_time {
  margin-bottom: 20px;
  font-family: "Apercu Pro", sans-serif;
  font-weight: 400;
  letter-spacing: .2em;
  font-size: 2.6rem;
  letter-spacing: .1em;
  line-height: 1; }
  .result_time span {
    margin-right: .1em;
    font-size: 3.6rem; }
.result_message.-up {
  margin-bottom: .4em; }
.result_message.-bottom {
  margin-top: .4em; }

.collection {
  margin-top: 50px;
  text-align: center; }
  .collection_logo {
    width: 80%;
    margin: 0 auto; }
  .collection_link {
    display: block;
    height: auto;
    margin-top: 20px; }

.collectionText {
  display: block;
  padding: .6em 1em;
  position: relative;
  background-color: #000;
  color: #fff;
  font-weight: 600;
  line-height: 1;
  letter-spacing: .2em; }
  .collectionText span {
    display: inline-block;
    width: .8em;
    height: .8em;
    margin-left: .3em;
    position: relative;
    border-top: #fff 1px solid;
    border-right: #fff 1px solid;
    font-size: 1.2rem;
    font-weight: 500;
    vertical-align: middle;
    -webkit-transform: translate3d(0, -15%, 0) rotate(45deg);
    transform: translate3d(0, -15%, 0) rotate(45deg); }

.retry {
  margin-top: 40px; }
  .retry p {
    margin-bottom: .6em; }
