*, 
*::before, 
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  font-size: 10px;
}

@font-face {
  font-family: 'DB-Helvetica';
  src: url('/fonts/DB-Helvetica.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  font-family: 'DB-Helvetica';
}

ul {
  list-style-type: none;
}

a {
  color: inherit;
  text-decoration: none;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

.desktop {
  display: none;
}

body {
  min-height: 100vh;
  font-family: 'Poppins', sans-serif;
  background: url(img/background-mb.png) no-repeat center;
  background-size: 100% 100%;
  overflow-x: hidden;
}

.hero-wrapper {
  padding: 0;
}

.hero-header {
  display: flex;
  justify-content: center;
  position: absolute;
  top: 50px;
  padding: 0 5%;
  z-index: 1;
}

.hero-niki-container {
  display: flex;
  position: relative;
  max-width: 100%;
  min-height: 480px;
  overflow: hidden;
}

.hero-niki-container::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, 20%);
  background: url(img/chips-mb-1.png) no-repeat center;
  background-size: contain;
  width: 100%;
  height: 180px;
  animation: float-up-mid 2s ease-out infinite;
  z-index: 1;
}

.hero-niki-container::after {
  content: "";
  position: absolute;
  bottom: 10px;
  right: 25px;
  background: url(img/hand-mb.png) no-repeat center;
  background-size: contain;
  width: 90px;
  height: 90px;
  animation: float-left 2s ease-out infinite;
  z-index: 1;
}

.tablet {
  display: none;
}

.hero-bottom-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: -12px;
  padding: 0 5%;
  gap: 10px 0;
}

.hero-free-spin {
  position: relative;
  max-width: 100%;
  min-height: 100%;
}

.hero-free-spin::after {
  content: "";
  position: absolute;
  top: 30px;
  right: 10px;
  background: url(img/chips-mb-2.png) no-repeat center;
  background-size: contain;
  height: 100%;
  width: 50px;
  animation: float-up 3s ease-out infinite;
  z-index: -1;
}

.hero-cta-button {
  max-width: 75%;
  cursor: pointer;
}

.tnc-link-text {
	color: #fff;
	font-size: 3rem;
	font-family:  'Db-Helvetica', sans-serif;
}

.tnc-link-text:hover {
  color: #FEC701;
}

.tnc-container.modal {
  padding: 30px;
	color:  #fff;
	background-color: #06062C;
  border: 2px solid #7E0A71;
}

.tnc-header {
	color:  #f9b104;
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px;
}

.tnc-subheader {
  font-size: 1.6rem;
  margin-bottom: 10px;
}

.tnc-asterisk {
  margin: 5px;
}

.tnc-title {
  font-size: 1.5rem;
  margin-bottom: 5px;
}

.tnc-list li {
  font-size: 1.4rem;
}

.tnc-list p {
  font-size: 1.4rem ;
}

.footer {
  width: 100%;
}

.footer-wrapper {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 10px 2%;
  gap: 0 5px;
}

.footer-text {
	font-family: 'Db-Helvetica', sans-serif;
  font-size: 2rem;
  color: white;
}

.footer-icon {
  object-fit: contain;
  width: 20px;
  height: 20px;
}

/* Animations */
@keyframes float-up {
  50% {
    transform: translate(0, 20px);
  }
}

@keyframes float-up-mid {
  40% {
    transform: translate(-50%, 20%) translateY(12px);
  }
}

@keyframes float-left {
  50% {
    transform: translate(-12px, 0);
  }
}


/* Media Queries */
/* XS */
@media screen and (min-width: 375px) {
  .hero-niki-container::before {
    transform: translate(-50%, 5%);
    height: 200px;
  }

  @keyframes float-up-mid {
    40% {
      transform: translate(-50%, 5%) translateY(12px);
    }
  }

  .hero-niki-container::after {
    width: 100px;
    height: 100px;
  }
}

/* SM */
@media screen and (min-width: 425px) {
  .hero-niki-container::before {
    transform: translate(-50%, 5%);
    height: 250px;
  }

  @keyframes float-up-mid {
    40% {
      transform: translate(-50%, 5%) translateY(12px);
    }
  }

  .hero-niki-container::after {
    width: 110px;
    height: 110px;
  }
}

/* SM TABLET */
@media screen and (min-width: 620px) {
  .mobile {
    display: none;
  }

  .tablet {
    display: block;
  }

  .desktop {
    display: block;
  }

  body {
    background: url(img/background.png) no-repeat fixed center;
    background-size: 100% 100%;
  }

  .hero {
    position: relative;
  }

  .hero-wrapper {
    padding: 100px 2% 30px; 
  }

  .hero-niki-desktop-image {
    display: none;
  }

  .hero-niki-container {
    min-height: 100%;
    margin: 0 auto;
  }

  .hero-niki-container::before,
  .hero-niki-container::after {
    content: none;
  }

  .hero-wrapper::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -250%);
    background: url(img/chips-tb.png) no-repeat center;
    background-size: contain;
    width: 100%;
    height: 120px;
    animation: float-up-mid 2s ease-out infinite;
    z-index: 1;
  }

  @keyframes float-up-mid {
    40% {
      transform: translate(-50%, -250%) translateY(12px);
    }
  }

  .hero-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(35vw, -65%);
    background: url(img/hand-mb.png) no-repeat center;
    background-size: contain;
    width: 100px;
    height: 100%;
    animation: float-left 2s ease-out infinite;
    z-index: 1;
  }

  @keyframes float-left {
    50% {
      transform: translate(35vw, -65%) translateX(-12px);
    }
  }

  .hero-free-spin {
    max-width: 90%;
  }

  .hero-free-spin::after  {
    top: 120px;
    right: 30px;
    width: 95px;
  }

  .hero-cta-button {
    max-width: 280px;
  }

  .footer-wrapper {
    gap: 0 10px;
  }

  .footer-text {
    font-size: 2.4rem;
  }

  .footer-icon {
    width: 30px;
    height: 30px;
  }

}

/* TABLET */
@media screen and (min-width: 768px) {
  .tnc-link-text {
    font-size: 4rem;
  }

}

/* LG */
@media screen and (min-width: 920px) {

  .hero-wrapper {
    position: relative;
  }

  .hero-wrapper::before {
    transform: translate(-45%, -75%);
    background: url(img/chips-desktop.png) no-repeat center;
    background-size: contain;
    width: 430px;
    height: 100%;
  }

  @keyframes float-up-mid {
    40% {
      transform: translate(-45%, -75%) translateY(12px);
    }
  }

  .hero-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(85%, -55%);
    background: url(img/hand-mb.png) no-repeat center;
    background-size: contain;
    width: 120px;
    height: 100%;
    animation: float-left 2s ease-out infinite;
    z-index: 1;
  }

  @keyframes float-left {
    50% {
      transform: translate(85%, -55%) translateX(-12px);
    }
  }

  .hero-niki-container {
    margin: 0;
    width: 65vw;
  }

  .hero-bottom-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, 32%);
    gap: 22px 0;
  }

  .hero-free-spin {
    max-width: 100%;
  }

  .hero-free-spin::after  {
    top: 4px;
    right: -25vw;
    width: 100%;
  }

  .hero-cta-button {
    max-width: 60%;
  }
}


@media screen and (min-width: 1024px) {

  .hero-wrapper::before {
    width: 480px;
  }

  .hero-cta-button {
    max-width: 40%;
  }

  .footer {
    position: absolute;
    bottom: 0;
    z-index: -1;
  }
}

/* XL */
@media screen and (min-width: 1280px) {

  .hero-wrapper {
    padding: 74px 10px 0;
  }

  .hero-wrapper::before {
    width: 40vw;
    transform: translate(-58%, -75%);
  }

  @keyframes float-up-mid {
    40% {
      transform: translate(-58%, -75%) translateY(12px);
    }
  }

  .hero-wrapper::after {
    width: 150px;
    height: 150px;
    transform: translate(40%, -50%);
  }

  @keyframes float-left {
    50% {
      transform: translate(40%, -50%) translateX(-15px);
    }
  }

  .hero-niki-container {
    width: 60vw;
    overflow: hidden;
  }

  .hero-niki  {
    height: 92vh;
    object-fit: contain;
  }
}

/* 2XL */
@media screen and (min-width: 1536px) {

}