
/* ========================================
   INTRO SCREEN
   ======================================== */

.intro-wrap{
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 16px;
  text-wrap: balance;
  padding: 24px;
  text-align: center;
}

.intro-text{
  text-align: center;
  line-height: 1.15;
  font-size: clamp(22px, 5vw, 44px);

  padding: 24px 16px;
  max-width: 28ch;
}

.intro-word{
  display: inline-block;
  opacity: 0;
  transform: translateY(14px) rotate(-2deg) scale(0.96);
  filter: blur(6px);
  will-change: transform, opacity, filter;
}

.intro-word.on{
  opacity: 1;
  filter: blur(0);
  animation:
    popIn 520ms cubic-bezier(.2, .9, .2, 1) forwards,
    wiggle 900ms ease-in-out 1 120ms;
}

.intro-text.breathe{ animation: breathe 1400ms ease-in-out infinite; }

@keyframes popIn{
  0%{ transform: translateY(14px) rotate(-2deg) scale(.96); opacity: 0; }
  60%{ transform: translateY(-2px) rotate(1deg) scale(1.02); opacity: 1; }
  100%{ transform: translateY(0) rotate(0deg) scale(1); }
}

@keyframes wiggle{
  0%{ transform: translateY(0) rotate(0deg) scale(1); }
  25%{ transform: translateY(-1px) rotate(1.2deg) scale(1.01); }
  55%{ transform: translateY(0) rotate(-1.0deg) scale(1.0); }
  100%{ transform: translateY(0) rotate(0deg) scale(1); }
}

@keyframes breathe{
  0%,100%{ transform: scale(1); }
  50%{ transform: scale(1.01); }
}

#introText{
  transform-origin: center;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
  transform: translateZ(0);
}

#introText.blast{
  animation: introBlast 720ms cubic-bezier(.22, .61, .36, 1) forwards;
}

@keyframes introBlast{
  0%{ transform: translateZ(0) scale(1); opacity: 1; filter: blur(0); }
  60%{ transform: translateZ(0) scale(1.8); opacity: 1; filter: blur(0); }
  100%{ transform: translateZ(0) scale(2.6); opacity: 0; filter: blur(2px); }
}

.intro-skip{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  padding: 12px 16px;
  border-radius: 14px;

  background: color-mix(in srgb, var(--p-cloud-dancer) 7.5%, transparent);
  border: 1px solid color-mix(in srgb, var(--p-cloud-dancer) 18%, transparent);
  color: color-mix(in srgb, var(--p-cloud-dancer) 92%, transparent);

  text-shadow: 0 1px 0 rgba(0, 0, 0, .35);
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;

  box-shadow:
    0 10px 22px rgba(0, 0, 0, .28),
    0 0 0 1px rgba(255, 255, 255, .05) inset;

  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease;
}

.intro-skip:hover{
  background: color-mix(in srgb, var(--p-cloud-dancer) 10%, transparent);
  border-color: color-mix(in srgb, var(--p-cloud-dancer) 26%, transparent);
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.intro-skip:active{
  background: color-mix(in srgb, var(--p-cloud-dancer) 6%, transparent);
  transform: translateY(0);
  filter: brightness(.98);
}
