* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  background: #111;
  font-family: Arial, Helvetica, sans-serif;
}

button,
a {
  font: inherit;
}

.shell {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  min-height: 100vh;
  background: #111;
}

.page {
  position: relative;
  width: 100vw;
  max-width: 430px;
  height: 100svh;
  min-height: 760px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.95) 0 34%, rgba(248, 248, 246, 0.9) 58%, rgba(244, 244, 241, 0.95) 100%),
    #f8f8f6;
  color: #0a0a0a;
  isolation: isolate;
  container-type: inline-size;
}

.topbar {
  position: absolute;
  inset: 0 0 auto;
  height: 6.75%;
  display: grid;
  place-items: center;
  background: #1f1f1f;
  color: #fff;
}

.topbar p {
  margin: 0;
  font-size: clamp(13px, 3.36cqw, 28px);
  font-weight: 800;
  letter-spacing: 0;
  text-shadow: 0 1px 1px #777;
}

h1 {
  position: absolute;
  top: 9.55%;
  left: 3%;
  right: 3%;
  margin: 0;
  text-align: center;
  font-size: clamp(14px, 3.35cqw, 29px);
  line-height: 1.08;
  letter-spacing: 0;
}

.offer {
  position: absolute;
  top: 15.25%;
  left: 2.5%;
  right: 2.5%;
  margin: 0;
  text-align: center;
  font-size: clamp(10px, 2.56cqw, 20px);
  font-weight: 800;
  line-height: 1;
}

.prize {
  position: absolute;
  display: block;
  object-fit: contain;
  z-index: 1;
  user-select: none;
  -webkit-user-drag: none;
  border-radius: 2px;
  filter: contrast(1.02) saturate(0.98);
  mix-blend-mode: multiply;
}

.prize::selection {
  background: transparent;
}

.side-one {
  left: -2%;
  top: 17.2%;
  width: 27%;
}

.side-two {
  left: -3%;
  top: 37.6%;
  width: 29%;
}

.center-prize {
  left: 29%;
  top: 20.9%;
  width: 42%;
}

.side-three {
  right: -3%;
  top: 18.2%;
  width: 29%;
}

.side-four {
  right: -3%;
  top: 39.4%;
  width: 29%;
}

.question {
  position: absolute;
  top: 53.25%;
  left: 3%;
  right: 3%;
  z-index: 2;
  text-align: center;
}

.question h2 {
  margin: 0 0 1.15%;
  font-size: clamp(10px, 2.55cqw, 21px);
  line-height: 1.08;
  font-weight: 900;
  white-space: nowrap;
}

.buttons {
  display: flex;
  justify-content: center;
  gap: 7.4%;
}

.choice {
  display: grid;
  place-items: center;
  width: 40%;
  min-width: 0;
  height: clamp(28px, 6.6cqw, 55px);
  border: 0;
  border-radius: 14px;
  color: #fff;
  font-size: clamp(11px, 2.85cqw, 24px);
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  text-shadow: 0 2px 2px rgba(0, 0, 0, 0.45);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, 0.35),
    inset 0 -4px 0 rgba(0, 0, 0, 0.1),
    0 2px 2px rgba(0, 0, 0, 0.22);
}

.choice:active {
  transform: translateY(1px);
}

.no {
  background: #f60906;
}

.yes {
  width: 46%;
  background: #10b814;
}

.copy {
  position: absolute;
  top: 63.8%;
  left: 8%;
  right: 8%;
  z-index: 2;
  margin: 0;
  font-size: clamp(8px, 1.78cqw, 14px);
  line-height: 1.2;
  text-align: center;
}

.footer {
  position: absolute;
  inset: auto 0 0;
  height: 15.2%;
  padding-top: 2.65%;
  background: #202020;
  color: #fff;
  text-align: center;
  z-index: 3;
}

.footer nav {
  display: grid;
  gap: clamp(5px, 1.45cqw, 12px);
  margin-bottom: 2%;
}

.footer a {
  color: #fff;
  font-size: clamp(6px, 1.45cqw, 12px);
  text-decoration: none;
}

.footer p {
  margin: 0 auto;
  width: 80%;
  font-size: clamp(5px, 1.2cqw, 10px);
  line-height: 1.16;
}

.sparkle {
  position: absolute;
  width: 5.6%;
  aspect-ratio: 1;
  transform: rotate(45deg);
  opacity: 0.82;
}

.sparkle::before,
.sparkle::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  background: #efefef;
}

.sparkle::before {
  width: 100%;
  height: 35%;
  border-radius: 50%;
}

.sparkle::after {
  width: 35%;
  height: 100%;
  border-radius: 50%;
}

.sparkle-one {
  right: 4.5%;
  top: 52%;
}

.sparkle-two {
  right: 4.2%;
  top: 84%;
  width: 3.8%;
  opacity: 0.55;
}
