30 CSS Keyframe Animations 14 / 30

CSS Stagger Animation List Items

Three stagger animation patterns: slide-from-left list items, scale-and-fade cards and cascade drop timeline entries using nth-child animation-delay.

Pure CSS MIT licensed
Live Demo Open in tab

This is a full-page demo — interact inside the frame above, or open it in the playground for the full-screen experience.

Open in playground

The code

<div class="kf-14">

  <div class="kf-14__col">
    <div class="kf-14__col-title">Slide from Left</div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--1">🎨</div><div class="kf-14__info"><b>UI Design</b><span>Figma · 24 components</span></div></div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--2">⚡</div><div class="kf-14__info"><b>Animation</b><span>CSS keyframes</span></div></div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--3">🧪</div><div class="kf-14__info"><b>Testing</b><span>Coverage 94%</span></div></div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--4">🚀</div><div class="kf-14__info"><b>Deploy</b><span>CI/CD pipeline</span></div></div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--5">📊</div><div class="kf-14__info"><b>Analytics</b><span>Live dashboard</span></div></div>
    <div class="kf-14__item"><div class="kf-14__icon kf-14__icon--6">🔐</div><div class="kf-14__info"><b>Security</b><span>Auth + tokens</span></div></div>
  </div>

  <div class="kf-14__cards">
    <div class="kf-14__col-title">Scale + Fade</div>
    <div class="kf-14__card"><h3>Motion Design</h3><p>Spring-based animations for delightful micro-interactions.</p><span class="kf-14__card-tag">CSS</span></div>
    <div class="kf-14__card"><h3>Glassmorphism</h3><p>Frosted glass layers with backdrop-filter blur.</p><span class="kf-14__card-tag">DESIGN</span></div>
    <div class="kf-14__card"><h3>Dark Mode</h3><p>Adaptive color palettes with CSS custom properties.</p><span class="kf-14__card-tag">THEME</span></div>
    <div class="kf-14__card"><h3>Accessibility</h3><p>prefers-reduced-motion and focus management.</p><span class="kf-14__card-tag">A11Y</span></div>
  </div>

  <div class="kf-14__timeline">
    <div class="kf-14__col-title">Cascade Drop</div>
    <div class="kf-14__titem"><div class="kf-14__dot"></div><div class="kf-14__tbody"><b>Project Kickoff</b><span>Jan 2025 · Initial scope</span></div></div>
    <div class="kf-14__titem"><div class="kf-14__dot"></div><div class="kf-14__tbody"><b>Design Sprint</b><span>Feb 2025 · 12 screens</span></div></div>
    <div class="kf-14__titem"><div class="kf-14__dot"></div><div class="kf-14__tbody"><b>Dev Phase</b><span>Mar 2025 · Component library</span></div></div>
    <div class="kf-14__titem"><div class="kf-14__dot"></div><div class="kf-14__tbody"><b>Beta Launch</b><span>Apr 2025 · 500 users</span></div></div>
    <div class="kf-14__titem"><div class="kf-14__dot"></div><div class="kf-14__tbody"><b>Go Live</b><span>May 2025 · Public release</span></div></div>
  </div>

</div>
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;700;800&display=swap');
.kf-14,.kf-14 *,.kf-14 *::before,.kf-14 *::after{box-sizing:border-box;margin:0;padding:0}
.kf-14 ::selection{background:#f72585;color:#fff}
.kf-14{
  --bg:#0f0f23;
  --pink:#f72585;
  --cyan:#4cc9f0;
  --green:#80ffdb;
  --gold:#ffd60a;
  --white:#e8e8ff;
  --card:#16162a;
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--bg);
  min-height:100vh;
  display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:center;
  padding:60px 24px;gap:48px;
  color:var(--white);
}

/* ——— 1: Slide-in from left ——— */
.kf-14__col{display:flex;flex-direction:column;gap:12px;min-width:240px;max-width:320px;flex:1}
.kf-14__col-title{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:#555;margin-bottom:4px}
.kf-14__item{
  background:var(--card);
  border-radius:12px;padding:16px 20px;
  display:flex;align-items:center;gap:14px;
  border:1px solid rgba(255,255,255,.05);
  opacity:0;transform:translateX(-30px);
  animation:kf-14-slide-in .5s cubic-bezier(.2,.8,.2,1) forwards;
}
.kf-14__item:nth-child(2){animation-delay:.1s}
.kf-14__item:nth-child(3){animation-delay:.2s}
.kf-14__item:nth-child(4){animation-delay:.3s}
.kf-14__item:nth-child(5){animation-delay:.4s}
.kf-14__item:nth-child(6){animation-delay:.5s}
@keyframes kf-14-slide-in{to{opacity:1;transform:translateX(0)}}
.kf-14__icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:1.1rem;flex:0 0 40px}
.kf-14__info{flex:1}
.kf-14__info b{display:block;font-size:.9rem;font-weight:700}
.kf-14__info span{font-size:.75rem;color:#888;margin-top:2px;display:block}

/* ——— 2: Fade + scale up ——— */
.kf-14__cards{display:flex;flex-direction:column;gap:12px;min-width:240px;max-width:320px;flex:1}
.kf-14__card{
  background:linear-gradient(135deg,rgba(247,37,133,.1),rgba(76,201,240,.08));
  border:1px solid rgba(247,37,133,.2);
  border-radius:16px;padding:20px;
  opacity:0;transform:scale(.88);
  animation:kf-14-pop .5s cubic-bezier(.34,1.56,.64,1) forwards;
}
.kf-14__card:nth-child(2){animation-delay:.12s}
.kf-14__card:nth-child(3){animation-delay:.24s}
.kf-14__card:nth-child(4){animation-delay:.36s}
@keyframes kf-14-pop{to{opacity:1;transform:scale(1)}}
.kf-14__card h3{font-size:.95rem;font-weight:800;margin-bottom:6px}
.kf-14__card p{font-size:.78rem;color:#888;line-height:1.4}
.kf-14__card-tag{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px;margin-top:10px}

/* ——— 3: Cascade drop ——— */
.kf-14__timeline{display:flex;flex-direction:column;gap:0;min-width:240px;max-width:300px;flex:1;position:relative}
.kf-14__timeline::before{content:'';position:absolute;left:19px;top:0;bottom:0;width:2px;background:rgba(128,255,219,.15)}
.kf-14__titem{
  display:flex;gap:16px;align-items:flex-start;padding:12px 0;
  opacity:0;transform:translateY(-20px);
  animation:kf-14-drop .4s cubic-bezier(.4,0,.2,1) forwards;
}
.kf-14__titem:nth-child(1){animation-delay:.05s}
.kf-14__titem:nth-child(2){animation-delay:.2s}
.kf-14__titem:nth-child(3){animation-delay:.35s}
.kf-14__titem:nth-child(4){animation-delay:.5s}
.kf-14__titem:nth-child(5){animation-delay:.65s}
@keyframes kf-14-drop{to{opacity:1;transform:translateY(0)}}
.kf-14__dot{width:16px;height:16px;border-radius:50%;flex:0 0 16px;margin-top:2px;border:2px solid}
.kf-14__tbody{flex:1}
.kf-14__tbody b{font-size:.88rem;font-weight:700;display:block}
.kf-14__tbody span{font-size:.72rem;color:#666;display:block;margin-top:2px}

/* Icon colors */
.kf-14__icon--1{background:rgba(247,37,133,.15);color:var(--pink)}
.kf-14__icon--2{background:rgba(76,201,240,.15);color:var(--cyan)}
.kf-14__icon--3{background:rgba(128,255,219,.15);color:var(--green)}
.kf-14__icon--4{background:rgba(255,214,10,.15);color:var(--gold)}
.kf-14__icon--5{background:rgba(247,37,133,.1);color:var(--pink)}
.kf-14__icon--6{background:rgba(76,201,240,.1);color:var(--cyan)}
.kf-14__card:nth-child(1) .kf-14__card-tag{background:rgba(247,37,133,.2);color:var(--pink)}
.kf-14__card:nth-child(2) .kf-14__card-tag{background:rgba(76,201,240,.2);color:var(--cyan)}
.kf-14__card:nth-child(3) .kf-14__card-tag{background:rgba(128,255,219,.2);color:var(--green)}
.kf-14__card:nth-child(4) .kf-14__card-tag{background:rgba(255,214,10,.2);color:var(--gold)}
.kf-14__dot:nth-child(1){border-color:var(--pink);background:rgba(247,37,133,.2)}
.kf-14__titem:nth-child(1) .kf-14__dot{border-color:var(--pink)}
.kf-14__titem:nth-child(2) .kf-14__dot{border-color:var(--cyan)}
.kf-14__titem:nth-child(3) .kf-14__dot{border-color:var(--green)}
.kf-14__titem:nth-child(4) .kf-14__dot{border-color:var(--gold)}
.kf-14__titem:nth-child(5) .kf-14__dot{border-color:var(--pink)}

@media(prefers-reduced-motion:reduce){.kf-14 *{animation:none!important;opacity:1!important;transform:none!important}}

How this works

Three stagger patterns share one technique: each child starts in an offset state (opacity: 0; transform: translateX(-30px)) and animates to its resting position via a forwards fill-mode keyframe. The cascade comes from sequential nth-child rules: nth-child(2) delays .1s, nth-child(3) delays .2s, and so on.

The slide-in uses cubic-bezier(.2, .8, .2, 1) for a snappy decelerate. The card pop uses cubic-bezier(.34, 1.56, 0.64, 1) — an overshoot curve that briefly scales past 1.0 before settling, producing the spring effect. The vertical timeline drop combines translateY(-20px → 0) with opacity fade, on a faster .4s duration so longer lists feel coherent.

Customize

  • Tighten the stagger by reducing animation-delay increments from .1s to .05s for a snappier reveal.
  • Swap the slide direction by changing translateX(-30px) to translateX(30px) for right-to-left entry.
  • Increase the spring overshoot by changing the bezier from .34, 1.56 to .34, 1.8 — more pronounced bounce.
  • Recolour the timeline dots via --pink, --cyan, --green, --gold custom properties on .kf-14.

Watch out for

  • Long lists with one keyframe per item compound delays — by item 12 you're at 1.2s wait, which feels broken. Cap delay around 0.5s total.
  • These animations run on every page load — they should only animate when the section enters the viewport. Pair with IntersectionObserver or a scroll-trigger class in production.
  • Without forwards fill-mode, items snap back to opacity: 0 after animating — items disappear.

Browser support

ChromeSafariFirefoxEdge
60+ 12+ 60+ 60+

Search CodeFronts

Loading…