Sugerencia de CSS rápida Texto gradiente animado

Hagamos ese efecto de texto con gradiente animado con propiedades personalizadas centradas y recorte de fondo

Ve a CodePen y crea un nuevo editor.

Crea el marcado para tu texto. Usemos un encabezado con la palabra “Rápido”:

<h1 class="boujee-text">Hello!</h1>

Luego, le daremos a nuestro body un background-color más oscuro:

body {
  display: grid;
  place-items: center;
  min-height: 100vh;
  background: hsl(0 0% 20%);
}

Aumenta el font-size en nuestro texto. Usa clamp para que sea responsivo:

.boujee-text {
  font-size: clamp(3rem, 25vmin, 8rem);
}

Crea dos propiedades personalizadas para los colores que usaremos. Aplica un linear-gradient al background con esos colores y rótalo 90 grados:

.boujee-text {
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / 100% 100%;
}

Crea una propiedad personalizada que puedas usar para el tamaño de fondo horizontal. Úsalo para background-size-x:

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
}

Para recortar el fondo en el texto, establece color en transparent y configura background-clip: text:

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
  color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
}

En este punto, puedes dejarlo así y experimentar con background-position y el gradiente que se usa en background-image. También puedes animar ese gradiente en el texto. Primero, define un fotograma clave para la animación. Se usará la propiedad personalizada --bg-size que definiste antes. Un buen ejemplo de propiedades personalizadas centradas que te facilitan el mantenimiento.

@keyframes move-bg {
  to {
    background-position: var(--bg-size) 0;
  }
}

Luego, aplica la animación con animation:

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
  color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
  animation: move-bg 8s infinite linear;
}

Para ir más allá, puedes unir tu código de animación en una consulta de contenido multimedia para respetar las preferencias de movimiento del usuario:

@media (prefers-reduced-motion: no-preference) {
  .boujee-text {
    animation: move-bg 8s linear infinite;
  }
  @keyframes move-bg {
    to {
      background-position: var(--bg-size) 0;
    }
  }
}

¡Listo! 🎉 Creaste texto con gradiente animado con CSS usando propiedades personalizadas con alcance y background-clip.

Aquí tienes esta sugerencia en forma de video rápido. ⚡️

¿Prefieres esto mediante formato de tweet? 🐦

Que tengas un buen día. ʕ •ᴥ•ʔ

Imagen hero de Vladislav Klapin en Unsplash