CSS-Zone

Onda expansiva

Onda que se expande desde el punto central. Ejemplo practico para efectos decorativos y acentos visuales con vista previa en vivo, estructura HTML y CSS listo para produccion que puedes integrar rapidamente.

Vista previa

HTML + CSS

<div class="ripple">
  <div class="ripple__circle ripple__circle_base"></div>
  <div class="ripple__circle ripple__circle_wave"></div>
</div>

<style>
.ripple {
  position: relative;
  width: 160px;
  height: 160px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, rgba(15, 23, 42, 0.96), rgba(59, 130, 246, 0.08));
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.ripple__circle {
  border-radius: 50%;
  border: 2px solid rgba(59, 130, 246, 0.5);
}

.ripple__circle_base {
  width: 40px;
  height: 40px;
  background: #3b82f6;
  box-shadow: 0 0 18px rgba(59, 130, 246, 0.6);
}

.ripple__circle_wave {
  position: absolute;
  width: 40px;
  height: 40px;
  animation: rippleWave 1.6s ease-out infinite;
}

@keyframes rippleWave {
  0% {
    transform: scale(0.6);
    opacity: 0.6;
  }
  100% {
    transform: scale(2);
    opacity: 0;
  }
}
</style>

Que demuestra el patron Onda expansiva

Onda expansiva es un patron reutilizable de animacion CSS que puede integrarse en interfaces modernas sin dependencias externas. El ejemplo incluye estructura HTML y estilos de movimiento faciles de escalar para componentes de produccion.

Cuando conviene usar este patron de animacion

Usa este efecto para indicar estado, reforzar el foco visual o anadir microinteracciones ligeras que apoyen la claridad del contenido. El movimiento debe reforzar la jerarquia, asi que manten velocidad, contraste y densidad alineados con los objetivos de tu interfaz.

Como implementarlo en produccion de forma segura

Copia el snippet, adapta espaciado y tiempos a los tokens de tu sistema y prueba el comportamiento en moviles y dispositivos de bajo consumo. Anade soporte para reduced-motion para mantener el componente accesible sin perder su funcion.