* {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  min-height: 100%;
  margin: 0;
  overflow-x: hidden;
}

html {
  overflow-y: auto;
}

body {
  overflow-y: visible;
  background: #0e1224;
  color: #fff;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
}

button {
  font: inherit;
}

.giveaway {
  width: 100vw;
  min-height: 100dvh;
  display: grid;
  place-items: start center;
  overflow-x: hidden;
  overflow-y: visible;
  background: #0e1224;
}

.scale-frame {
  position: relative;
  width: 1920px;
  height: 1269px;
  flex: 0 0 auto;
  overflow: visible;
}

.stage {
  position: relative;
  width: 1920px;
  height: 1269px;
  margin: 0;
  overflow: hidden;
  background: #0e1224;
  transform: scale(var(--stage-scale, 1));
  transform-origin: 0 0;
}

.asset {
  position: absolute;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}

.asset img,
picture.asset > img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  user-select: none;
  -webkit-user-drag: none;
}

.scene {
  left: -99.7788px;
  top: -249px;
  width: 2121.78px;
  height: 2306.45px;
}

.scene--stars {
  z-index: 0;
  opacity: 0.5;
}

.scene--earth {
  z-index: 1;
}

.bottom-fade {
  position: absolute;
  z-index: 4;
  left: 0;
  top: 1070px;
  width: 100%;
  height: 199px;
  display: block;
  background: linear-gradient(
    180deg,
    rgba(14, 18, 36, 0) 0%,
    rgba(14, 18, 36, 0.2) 24%,
    rgba(14, 18, 36, 0.62) 58%,
    #0e1224 100%
  );
  pointer-events: none;
}

.spotlight {
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.spotlight--tablet-landscape,
.spotlight--tablet-portrait,
.spotlight--mobile {
  display: none;
}

.phone {
  z-index: 3;
}

.phone--samsung {
  left: 666.199px;
  top: 165.067px;
  width: 255.742px;
  height: 458.204px;
  transform: rotate(-10.65deg);
  transform-origin: 0 0;
}

.phone--iphone {
  left: 965.279px;
  top: 116.257px;
  width: 279.444px;
  height: 500.671px;
  transform: rotate(8.6331deg);
  transform-origin: 0 0;
}

.logo {
  z-index: 5;
  left: 842px;
  top: 65.2947px;
  width: 236px;
  height: 58.7053px;
}

.device-label {
  position: absolute;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border: 0.750369px solid rgba(255, 255, 255, 0.88);
  background: rgba(14, 18, 36, 0.12);
  font-size: 20px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
  white-space: nowrap;
}

.device-label--iphone {
  left: 1057.93px;
  top: 201.424px;
  width: 304.65px;
  height: 60.7799px;
  border-radius: 11.6307px;
	z-index: 2 !important;
}

.device-label--samsung {
  left: 576.944px;
  top: 295.97px;
  width: 305.4px;
  height: 60.7799px;
  border-radius: 9.0284px;
}

.headline {
  position: absolute;
  z-index: 5;
  left: 0;
  width: 100%;
  margin: 0;
  color: #fff;
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: 0;
  text-align: center;
  text-shadow: 0 5px 14px rgba(0, 0, 0, 0.25);
}

.headline span,
.rules span {
  display: block;
}

.headline--desktop {
  top: 807px;
  font-size: 64px;
}

.headline--tablet-portrait,
.headline--mobile {
  display: none;
}

.cta {
  text-decoration: none;
  position: absolute;
  z-index: 6;
  left: 750px;
  top: 973px;
  width: 420px;
  height: 79px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0 28px;
  border: 0;
  border-radius: 40px;
  background: #fad901;
  color: #101222;
  cursor: pointer;
  font-size: 28px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-align: center;
}

.cta:focus-visible {
  outline: 4px solid #fff;
  outline-offset: 6px;
}

.rules {
  position: absolute;
  z-index: 5;
  left: 0;
  width: 100%;
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.18;
  letter-spacing: 0;
  text-align: center;
  text-shadow: 0 3px 12px rgba(0, 0, 0, 0.35);
}

.rules--desktop {
  top: 1155px;
}

.rules--mobile {
  display: none;
}

@media (max-width: 1200px) {
  .scale-frame,
  .stage {
    width: 1024px;
    height: 855px;
  }

  .scene {
    left: -168.148px;
    top: -139.823px;
    width: 1356.15px;
    height: 1474.18px;
  }

  .bottom-fade {
    top: 690px;
    height: 165px;
  }

  .spotlight--desktop {
    display: none;
  }

  .spotlight--tablet-landscape {
    display: block;
  }

  .phone--samsung {
    left: 268.807px;
    top: 110.593px;
    width: 181.949px;
    height: 325.992px;
    transform: rotate(-14.1835deg);
  }

  .phone--iphone {
    left: 524.396px;
    top: 66.1705px;
    width: 192.594px;
    height: 345.064px;
    transform: rotate(13.0933deg);
  }

  .logo {
    left: 417px;
    top: 40px;
    width: 190px;
    height: 47px;
  }

  .device-label {
    border-width: 0.873462px;
    font-size: 16px;
  }

  .device-label--iphone {
    left: 581.437px;
    top: 132.437px;
    width: 217.492px;
    height: 42.7996px;
    border-radius: 11.6497px;
  }

  .device-label--samsung {
    left: 221.437px;
    top: 202.437px;
    width: 217.492px;
    height: 42.7996px;
    border-radius: 10.5094px;
  }

  .headline--desktop {
    top: 499px;
    font-size: 48px;
    line-height: 56px;
  }

  .cta {
    left: 332px;
    top: 629px;
    width: 360px;
    height: 66px;
    border-radius: 33px;
    font-size: 29px;
  }

  .rules--desktop {
    top: 774px;
    font-size: 17px;
    line-height: 1.18;
  }
}

@media (max-width: 900px) and (orientation: portrait) {
  .scale-frame,
  .stage {
    width: 768px;
    height: 1017px;
  }

  .scene {
    left: -286px;
    top: -33px;
    width: 1340.47px;
    height: 1457.14px;
  }

  .bottom-fade {
    top: 860px;
    height: 157px;
  }

  .spotlight--tablet-landscape {
    display: none;
  }

  .spotlight--tablet-portrait {
    display: block;
  }

  .phone--samsung {
    left: 149.267px;
    top: 145.866px;
    width: 208.881px;
    height: 374.245px;
    transform: rotate(-10.65deg);
  }

  .phone--iphone {
    left: 393.544px;
    top: 106px;
    width: 228.241px;
    height: 408.931px;
    transform: rotate(8.6331deg);
  }

  .logo {
    left: 271px;
    top: 50px;
    width: 226px;
    height: 56px;
  }

  .device-label {
    border-width: 1px;
    font-size: 17px;
  }

  .device-label--iphone {
    left: 427.5px;
    top: 149.175px;
    width: 249px;
    height: 49px;
    border-radius: 13.3374px;
  }

  .device-label--samsung {
    left: 108.5px;
    top: 289.175px;
    width: 249px;
    height: 49px;
    border-radius: 12.0319px;
  }

  .headline--desktop {
    display: none;
  }

  .headline--tablet-portrait {
    display: block;
    top: 638px;
    font-size: 42px;
    line-height: 1.08;
  }

  .cta {
    left: 204px;
    top: 803px;
    width: 360px;
    height: 65px;
    border-radius: 33px;
    font-size: 28px;
  }

  .rules--desktop {
    top: 934px;
    font-size: 16px;
    line-height: 1.18;
  }
}

@media (max-width: 600px) {
  .scale-frame,
  .stage {
    width: 360px;
    height: 911px;
  }

  .stage {
    background: #101222;
  }

  .scene {
    left: -212.251px;
    top: 57.3321px;
    width: 784.251px;
    height: 852.51px;
  }

  .scene--stars {
    left: -212px;
    top: -49px;
    width: 784px;
    height: 959px;
  }

  .bottom-fade {
    z-index: 4;
    left: 0;
    top: 720px;
    width: 100%;
    height: 191px;
    background: linear-gradient(
      180deg,
      rgba(14, 18, 36, 0) 0%,
      rgba(14, 18, 36, 0.22) 22%,
      rgba(14, 18, 36, 0.66) 58%,
      #0e1224 100%
    );
  }

  .scene--earth {
    z-index: 2;
  }

  .spotlight--tablet-portrait,
  .spotlight--tablet-landscape {
    display: none;
  }

  .spotlight--mobile {
    z-index: 2;
    display: block;
  }

  .phone--samsung {
    left: 31px;
    top: 154.16px;
    width: 125.316px;
    height: 224.524px;
    transform: rotate(-10.65deg);
  }

  .phone--iphone {
    left: 174.07px;
    top: 123px;
    width: 137.839px;
    height: 246.961px;
    transform: rotate(8.6331deg);
  }

  .logo {
    left: 100px;
    top: 83px;
    width: 160px;
    height: 40px;
  }

  .device-label {
    border-width: 0.563925px;
    font-size: 9px;
  }

  .device-label--iphone {
    z-index: 2;
    left: 199.311px;
    top: 153.348px;
    width: 140.417px;
    height: 27.6323px;
    border-radius: 7.52128px;
  }

  .device-label--samsung {
    z-index: 6;
    left: 22.4189px;
    top: 235.297px;
    width: 140.417px;
    height: 27.6323px;
    border-radius: 6.78512px;
  }

  .headline--desktop,
  .headline--tablet-portrait {
    display: none;
  }

  .headline--mobile {
    z-index: 7;
    display: block;
    top: 458px;
    font-size: 28px;
    line-height: 30px;
  }

  .headline--mobile span {
    transform: scaleX(0.9);
    transform-origin: center;
  }

  .cta {
    z-index: 7;
    left: 20px;
    top: 590px;
    width: 320px;
    height: 59px;
    border-radius: 30px;
    font-size: 22px;
  }

  .rules--desktop {
    display: none;
  }

  .rules--mobile {
    z-index: 7;
    display: block;
    top: 777px;
    font-size: 12px;
    line-height: 1.1;
  }
}
