@charset "UTF-8";

* {
  box-sizing: border-box;
}

body {
  font-family: sans-serif;
  text-align: center;
  margin: 0;
  background-color: #c83838;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 56 28' width='56' height='28'%3E%3Cpath fill='%23de5959' fill-opacity='0.4' d='M56 26v2h-7.75c2.3-1.27 4.94-2 7.75-2zm-26 2a2 2 0 1 0-4 0h-4.09A25.98 25.98 0 0 0 0 16v-2c.67 0 1.34.02 2 .07V14a2 2 0 0 0-2-2v-2a4 4 0 0 1 3.98 3.6 28.09 28.09 0 0 1 2.8-3.86A8 8 0 0 0 0 6V4a9.99 9.99 0 0 1 8.17 4.23c.94-.95 1.96-1.83 3.03-2.63A13.98 13.98 0 0 0 0 0h7.75c2 1.1 3.73 2.63 5.1 4.45 1.12-.72 2.3-1.37 3.53-1.93A20.1 20.1 0 0 0 14.28 0h2.7c.45.56.88 1.14 1.29 1.74 1.3-.48 2.63-.87 4-1.15-.11-.2-.23-.4-.36-.59H26v.07a28.4 28.4 0 0 1 4 0V0h4.09l-.37.59c1.38.28 2.72.67 4.01 1.15.4-.6.84-1.18 1.3-1.74h2.69a20.1 20.1 0 0 0-2.1 2.52c1.23.56 2.41 1.2 3.54 1.93A16.08 16.08 0 0 1 48.25 0H56c-4.58 0-8.65 2.2-11.2 5.6 1.07.8 2.09 1.68 3.03 2.63A9.99 9.99 0 0 1 56 4v2a8 8 0 0 0-6.77 3.74c1.03 1.2 1.97 2.5 2.79 3.86A4 4 0 0 1 56 10v2a2 2 0 0 0-2 2.07 28.4 28.4 0 0 1 2-.07v2c-9.2 0-17.3 4.78-21.91 12H30zM7.75 28H0v-2c2.81 0 5.46.73 7.75 2zM56 20v2c-5.6 0-10.65 2.3-14.28 6h-2.7c4.04-4.89 10.15-8 16.98-8zm-39.03 8h-2.69C10.65 24.3 5.6 22 0 22v-2c6.83 0 12.94 3.11 16.97 8zm15.01-.4a28.09 28.09 0 0 1 2.8-3.86 8 8 0 0 0-13.55 0c1.03 1.2 1.97 2.5 2.79 3.86a4 4 0 0 1 7.96 0zm14.29-11.86c1.3-.48 2.63-.87 4-1.15a25.99 25.99 0 0 0-44.55 0c1.38.28 2.72.67 4.01 1.15a21.98 21.98 0 0 1 36.54 0zm-5.43 2.71c1.13-.72 2.3-1.37 3.54-1.93a19.98 19.98 0 0 0-32.76 0c1.23.56 2.41 1.2 3.54 1.93a15.98 15.98 0 0 1 25.68 0zm-4.67 3.78c.94-.95 1.96-1.83 3.03-2.63a13.98 13.98 0 0 0-22.4 0c1.07.8 2.09 1.68 3.03 2.63a9.99 9.99 0 0 1 16.34 0z'%3E%3C/path%3E%3C/svg%3E");
}

h1 {
  color: #d0b36b;
  margin-top: 0;
}

img {
  max-width: 100%;
}

.container {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

#tapme {
  height: 100%;
  width: 100%;
  max-height: 120px;
  max-width: 120px;
  top: 55%;
  left: 48.5%;
  transform: translate(-50%, -50%);
}

.row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}

.col {
  flex-basis: 100%;
  max-width: 100%;
  padding: 0;
  text-align: center;
  position: relative;
}

.map {
  position: relative;
  display: inline-block;
}

.map a {
  position: absolute;
  display: block;
}

@font-face {
  font-family: 'Font Awesome 5 Brands';
  src: url("fa-brands-400.eot");
  src: url("fa-brands-400.eot?#iefix") format("embedded-opentype"), url("fa-brands-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}

@font-face {
  font-family: 'Font Awesome 5 Free';
  src: url("fa-solid-900.eot");
  src: url("fa-solid-900.eot?#iefix") format("embedded-opentype"), url("fa-solid-900.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
}

.social {
  position: absolute;
  right: 15px;
  top: 0;
  list-style-type: none;
}

.social li {
  margin-bottom: 0.5rem;
}

.social li a {
  display: inline-block;
  padding: 0.5rem;
  background: #fd9500;
  border-radius: 5px;
  color: #ffffff;
  transition: all 0.3s;
}

.social li a:hover {
  background: linear-gradient(to bottom right, #fd4d00, #fd9b00);
}

.fab {
  font-family: 'Font Awesome 5 Brands';
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
  text-align: center;
  width: 1.25em;
}

.fab.fa-facebook-f::before {
  content: "";
}

.fab.fa-twitter::before {
  content: "";
}

.fab.fa-linkedin-in::before {
  content: "";
}

.fab.fa-instagram::before {
  content: "";
}

.fab.fa-youtube::before {
  content: "";
}

.fas {
  font-family: 'Font Awesome 5 Free';
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
  text-align: center;
  width: 1.25em;
}

[aria-label="music"].play .fas::before {
  content: "";
}

[aria-label="music"].pause .fas::before {
  content: "";
}

.lohei_sg {
  position: relative;
  height: 100%;
}

.footer {
  font-size: 0.8rem;
  padding: 0 0.5rem;
}

.footer img {
  max-height: 25px;
}

/* lucky god component */
.lucky-god {
  position: absolute;
  top: 5%;
  width: 100%;
  right: -33%;
}

/* lucky number component */
.lucky-number {
  position: absolute;
  bottom: 0;
  width: 100%;
  background-image: linear-gradient(0deg, #c83838, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* cny at both sides */
.cny_mascot {
  max-width: 100px;
  max-height: 90px;
}

/* luck number card in the middle */
.lucky-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-left: 1rem;
  margin-right: 1rem;
}

.lucky-number-bg {
  transition: transform 1s;
  transform-style: preserve-3d;
}

.lucky-number-flip {
  position: relative;
  width: 180px;
}

.lucky-number-flip-inner {
  position: absolute;
  width: 100%;
  height: 100%;
  transition: transform 1s;
  transform-style: preserve-3d;
  top: 0;
  cursor: pointer;
}

/* flip side A and then side B */
.lucky-number-flip-number {
  position: absolute;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  border-radius: 5px;
  backface-visibility: hidden;
}

.lucky-number-flip p {
  font-weight: bold;
  margin: 0;
  font-size: 0.75rem;
}

.lucky-number-flip p.number {
  font-size: 2rem;
}

.lucky-number-flip-message {
  font-size: 0.75rem;
  color: white;
  text-align: center;
}

@media (min-width: 540px) {
  #tapme {
    max-height: 160px;
    max-width: 160px;
  }
}

@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }

  .lucky-number-flip {
    width: 240px;
  }

  .lucky-number-flip p {
    font-size: 1rem;
  }

  .lucky-number-flip p.number {
    font-size: 2.5rem;
  }

  .lucky-number-flip-message {
    font-size: 1.1rem;
  }

  .footer {
    font-size: 1rem;
  }

  .footer img {
    max-height: 30px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 720px;
    height: 100vh;
  }

  .lucky-number-flip {
    width: 90%;
  }

  #tapme {
    max-height: 200px;
    max-width: 200px;
  }

  .lucky-god {
    right: -30%;
  }

  .cny_mascot {
    max-width: 25%;
    max-height: 100%;
  }

  .cny_god_mascot {
    max-width: 20%;
  }
}

@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }

  #tapme {
    max-height: 250px;
    max-width: 250px;
  }
}

@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }

  .social {
    right: -50px;
  }
}

@media (max-width: 425px) {
  .lohei_sg:not(:first-child) {
    height: 316px !important;
  }
}

@media (max-width: 1199px) {
  .social {
    position: relative;
    padding-top: 1rem;
    display: flex;
    justify-content: center;
  }

  .social li {
    margin: 0 0.25rem;
  }
}