@font-face {
  font-family: "Industrial Gothic Single Std";
  src: url("../font/IndustrialGothicSingleStd.woff2") format("woff2"),
    url("../font/IndustrialGothicSingleStd.woff") format("woff");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

#loading {
  background-image: url("../img/main_bg.jpg");
  background-color: #1a1a1a;
  background-size: cover;
  z-index: 4000;
  height: 100vh;
  width: 100vw;
  position: absolute;
  top: 0;
  left: 0;
}

body {
  background-image: url("../img/main_bg.jpg");
  background-size: cover;
  background-color: #1a1a1a;
  height: 100vh;
  font-weight: 100;
  overflow: hidden;
  font-family: "Industrial Gothic Single Std";
  color: #f2eddf;
}

.hidden {
  opacity: 0;
  z-index: -1000;
}

.display_none {
  display: none;
}

.page {
  height: 100vh;
  width: 100vw;
  left: 0;
  top: 0;
  right: 0;
  position: absolute;
  max-width: 1024px;
  margin: 0 auto;
}

h1 {
  text-align: center;
  font-size: 4vh;
  font-weight: 100;
}

h2 {
  font-size: 8vw;
  font-weight: 100;
  text-align: center;
}

@media screen and (min-width: 1280px) {
  h2 {
    font-size: 75px;
  }
}

.end-text {
  font-weight: 100;
  position: absolute;
  width: 75vw;
  max-width: 900px;
  margin: 0 auto;
  left: 0;
  right: 0;
}

.evoke {
  position: absolute;
  left: 0;
  right: 0;
  height: 100vh;
  margin: auto;
}

.start-text {
  position: absolute;
  top: 10vh;
  width: 80vw;
  max-width: 900px;
  margin: 0 auto;
  left: 0;
  right: 0;
}

.evoke-text {
  font-weight: 100;
  position: absolute;
  top: 10vh;
  width: 80vw;
  max-width: 900px;
  margin: 0 auto;
  left: 0;
  right: 0;
}

.spacer {
  margin-top: 5vh;
}

#start_text2 {
  top: 30vh;
}

#start_text3 {
  top: 30vh;
}

#start_text4 {
  top: 20vh;
}

#start_text5 {
  top: 2vh;
  width: 95vw;
  color: #ffffff;
}

.start-image {
  background-image: url("../img/start.jpg");
  background-size: cover;
}

.evoke-image1 {
  background-image: url("../img/evoke1.jpg");
  background-size: cover;
}
.evoke-image2 {
  background-image: url("../img/evoke2.jpg");
  background-size: cover;
}
.evoke-image3 {
  background-image: url("../img/evoke3.jpg");
  background-size: cover;
}
.evoke-image4 {
  background-image: url("../img/evoke4.jpg");
  background-size: cover;
}
.evoke-image5 {
  background-image: url("../img/evoke5.jpg");
  background-size: cover;
}
.evoke-image6 {
  background-image: url("../img/evoke6.jpg");
  background-size: cover;
}

#evoke_text1 {
  top: 8vh;
  width: 50vw;
  color: #ffffff;
  letter-spacing: 0.1em;
}

#evoke_text2 {
  top: 55vh;
  width: 60vw;
  color: #ffffff;
  letter-spacing: 0.2em;
  line-height: 1.5em;
}

#evoke_text3 {
  top: 48vh;
  width: 70vw;
  color: #000000;
}

#evoke_text4 {
  top: 3vh;
  width: 70vw;
  color: #ffffff;
  left: 10vw;
  letter-spacing: 0.2em;
  line-height: 1.5em;
}

#evoke_text5 {
  top: 30vh;
  width: 60vw;
  color: #ffffff;
  left: 20vw;
  letter-spacing: 0.2em;
  line-height: 2em;
}

#evoke_text6 {
  top: 40vh;
  width: 50vw;
  color: #f2eddf;
}

#evoke-text6 > .fit {
  line-height: 0.9;
}

#ending_text1 {
  width: 70vw;
  top: 2vh;
}

#ending_text2 {
  top: 40vw;
}

#ending_text3 {
  top: 25vw;
}

.grid-text {
  width: 90%;
  left: 0;
  right: 0;
  margin: 38vh auto 0 auto;
  color: #ffffff;
  font-size: 19vw;
}

.play-text {
  width: 60%;
  left: 0;
  right: 0;
  margin: 5vh auto 0 auto;
  color: #ffffff;
  font-size: 10vw;
}

.fit {
  display: inline-block;
  white-space: nowrap;
  margin: 0;
  line-height: 1;
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 12%;
  margin: 0 auto;
  max-width: 200px;
  padding: 8vw;
}

.grid > button {
  display: grid;
  position: relative;
  box-sizing: border-box;
  border-radius: 20px;
  border-color: white;
  box-shadow: none;
  border-style: solid;
  border-width: 3px;
  aspect-ratio: 1;
}

.grid > button::before {
  content: "";
  padding-top: 105%;
  display: block;
}

.grid .btn_avail {
  background-color: rgba(0, 0, 0, 0);
}

.grid .btn_unavail {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' style='background-color:%23f24726'%3E%3Cline x1='0' y1='100' x2='100' y2='0' stroke-width='3' stroke='%23FFFFFF'/%3E%3Cline x1='0' y1='0' x2='100' y2='100' stroke-width='3' stroke='%23FFFFFF'/%3E%3C/svg%3E");
}

.grid > button > img {
  position: absolute;
  top: 0;
  left: 0;
  height: 70%;
  width: 70%;
  margin: 15%;
  object-fit: contain;
}

.playing-container {
  margin-top: 50vh;
  text-align: center;
  height: 60%;
}

.icon_container {
  width: 20vw;
  height: 20vw;
  padding: 4vw;
  background-color: rgba(0, 0, 0, 0);
  border-style: solid;
  border-width: 3px;
  border-radius: 20px;
  border-color: white;
  box-shadow: none;
  position: relative;
  left: 0;
  right: 0;
  top: 50px;
  margin: auto;
}

.icon_container img {
  max-width: 100%;
  max-height: 100%;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

.playing_text {
  width: 80%;
  position: relative;
  left: 0;
  right: 0;
  margin: 20vh auto 0 auto;
}

.move_on_btn {
  width: 45vw;
  padding-top: 1%;
  max-width: 550px;
  height: 15vw;
  text-align: center;
  border-style: solid;
  border-width: 3px;
  border-color: white;
  position: absolute;
  left: 0;
  right: 0;
  top: auto;
  bottom: 17vh;
  margin: auto;
  background-color: rgba(0, 0, 0, 0);
  color: white;
  font-family: "Industrial Gothic Single Std";
  text-align: center;
  font-size: 8vw;
}

.continue_btn {
  width: 50vw;
  padding-top: 1%;
  letter-spacing: 0.1rem;
  height: 15vw;
  text-align: center;
  border-style: solid;
  border-width: 3px;
  border-color: #f2eddf;
  position: absolute;
  left: 0;
  right: 0;
  top: auto;
  bottom: 17vh;
  margin: auto;
  background-color: rgba(0, 0, 0, 0);
  background-image: url("../img/continue_bg.jpg");
  background-size: cover;
  color: #f2eddf;
  font-family: "Industrial Gothic Single Std";
  text-align: center;
  font-size: 8vw;
  max-width: 550px;
  max-height: 88px;
  z-index: 1000;
}

.btn_grey {
  border-color: #5a5853 !important;
  color: #5a5853 !important;
}

.start_btn {
  width: 70vw;
  padding-top: 1%;
  letter-spacing: 0.1rem;
  height: 15vw;
  text-align: center;
  border-style: solid;
  border-width: 3px;
  border-color: #f2eddf;
  position: absolute;
  left: 0;
  right: 0;
  top: auto;
  bottom: 17vh;
  margin: auto;
  background-color: rgba(0, 0, 0, 0);
  background-image: url("../img/start_bg.jpg");
  background-size: cover;
  color: #f2eddf;
  font-family: "Industrial Gothic Single Std";
  text-align: center;
  font-size: 8vw;
  max-width: 550px;
  max-height: 88px;
}

.pause_btn {
  background-color: transparent;
  width: 20vw;
  height: 20vw;
  position: relative;
  left: 0;
  right: 0;
  top: 40px;
  margin: auto;
  border: none;
  z-index: 50000;
}

.pause_btn img {
  max-width: 100%;
  max-height: 100%;
  width: 100%;
}

.end {
  width: 100vw;
  height: 20vw;
}

.start {
  width: 100vw;
  height: 20vw;
}

.status {
  width: 80vw;
  margin: 0 auto;
  text-align: center;
  font-size: 10vw;
}
