.hero {
  display: grid;
  place-items: center;
  padding: 2rem;
  overflow-y: visible;

  /* Main scale driver */
  --logo-size: clamp(280px, 40vw, 800px);

  /* Shared sticker reference */
  --sticker-base: calc(var(--logo-size) * 0.5);

  --sticker-padding: calc(30000px / var(--logo-size) * 1px);

  --sticker-max: 1000px;
}

.hero-art {
  position: relative;
  width: min(100%, 1200px);
}

/* Center logo group */
.logo-wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--logo-size);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
}

.logo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  padding: 20%;
  display: flex;
  align-items: center;
}
.spinning-text {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.spinning-text {
  animation: spin 18s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.sticker {
  position: absolute;
  width: clamp(
    var(--sticker-min, 48px),
    calc(var(--sticker-base) * var(--scale, 1)),
    var(--sticker-max, 500px)
  );
  height: auto;
  z-index: 200;
}

.sticker.sticker-flag {
  width: clamp(
    var(--sticker-min, 50px),
    calc(var(--sticker-base) * var(--scale, 0.8)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) / 2);
  top: calc(var(--logo-size) / -2);
  transform: translateY(-50%);
  padding-bottom: calc(var(--sticker-padding) * 1.5);
}

.sticker.sticker-colab {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 1.8)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) / -1.35);
  top: calc(var(--logo-size) / -2.1);
  transform: translate(-60%, -55%);
  //padding-bottom: calc(var(--sticker-padding) * 0.5);
}

.sticker.sticker-drip {
  width: clamp(
    var(--sticker-min, 10px),
    calc(var(--sticker-base) * var(--scale, 0.15)),
    var(--sticker-max, 20px)
  );
  transform: translate(200%, -100%);
  top: calc(var(--logo-size) / -2);
  padding-bottom: calc(var(--sticker-padding) * 0.25);
}

.sticker.sticker-star-red {
  width: clamp(
    var(--sticker-min, 10px),
    calc(var(--sticker-base) * var(--scale, 0.15)),
    var(--sticker-max, 20px)
  );
  transform: translate(100%, -50%);
  top: calc(var(--logo-size) / -2);
  left: calc(var(--logo-size) * 1.4);
  padding-bottom: calc(var(--sticker-padding) * 0.5);
}

.sticker.sticker-smily {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.6)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) * -0.8);
  top: 0;
  transform: translate(-60%, -50%);
  padding-top: calc(var(--sticker-padding) * 0.5);
}

.sticker.sticker-star-yellow {
  width: clamp(
    var(--sticker-min, 10px),
    calc(var(--sticker-base) * var(--scale, 0.15)),
    var(--sticker-max, 20px)
  );
  transform: translate(100%, -50%);
  top: 0;
  left: calc(var(--logo-size) * -1.6);
  padding-top: calc(var(--sticker-padding) * 0.5);
}

.sticker.sticker-crane {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.9)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) * -1.2);
  top: calc(var(--logo-size) / 2);
  transform: translate(-60%, -80%);
  padding-top: calc(var(--sticker-padding) * 1.5);
}

.sticker.sticker-k {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.8)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) / -2);
  top: calc(var(--logo-size) / 1.6);
  transform: translate(-60%, -80%);
  padding-top: calc(var(--sticker-padding) * 1.7);
}

.sticker.sticker-crown {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.8)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) / 6);
  top: calc(var(--logo-size) / 3);
  transform: translate(0%, 0%);
  padding-top: calc(var(--sticker-padding) * 1);
}

.sticker.sticker-tower {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.6)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) / 2);
  top: calc(var(--logo-size) / 4);
  transform: translate(0%, -100%);
  padding-top: calc(var(--sticker-padding) * 0.3);
}

.sticker.sticker-video {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 0.9)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) * 1);
  top: calc(var(--logo-size) / 10);
  transform: translate(0%, -100%);
}

.sticker.sticker-bird {
  width: clamp(
    var(--sticker-min, 100px),
    calc(var(--sticker-base) * var(--scale, 1)),
    var(--sticker-max, 1000px)
  );
  left: calc(var(--logo-size) * 0.8);
  top: calc(var(--logo-size) * 0.8);
  transform: translate(0%, -100%);
}
@media (max-width: 479px) {
  .sticker.sticker-flag {
    left: calc(var(--logo-size) / 4);
  }
  .sticker.sticker-colab {
    left: calc(var(--logo-size) / -4);
    top: calc(var(--logo-size) / -1);
  }
  .sticker.sticker-drip {
    top: calc(var(--logo-size) / -2.6);
  }
  .sticker.sticker-smily {
    left: calc(var(--logo-size) * -0.4);
    top: calc(var(--logo-size) * -0.8 + var(--sticker-padding) * 0.5);
    transform: translate(-60%, -60%);
  }
  .sticker.sticker-crown {
    top: 0;
    left: calc(var(--logo-size) / 3);
  }
  .sticker.sticker-bird {
    top: calc(var(--logo-size) * 1.2);
    left: calc(var(--logo-size) / -3);
  }
}
