15 CSS Flexbox Layouts 11 / 15

CSS Flexbox Timeline Layout

A vertical event timeline where each entry is a flex row — a narrow connector column with a dot and line, and an expanding content card — creating a clean left-rail chronology.

Pure CSS MIT licensed
Live Demo Open in tab
Open in playground

The code

<div class="fl-11">
  <div class="fl-11__header">
    <div class="fl-11__eyebrow">Flexbox Pattern</div>
    <h2 class="fl-11__title">CSS Flexbox Timeline Layout</h2>
    <p class="fl-11__sub">Each row is a flex container: connector column + content area</p>
  </div>

  <div class="fl-11__timeline">

    <div class="fl-11__event">
      <div class="fl-11__connector">
        <div class="fl-11__dot" style="background:#0284c7">🚀</div>
        <div class="fl-11__line"></div>
      </div>
      <div class="fl-11__content">
        <div class="fl-11__event-meta">
          <div class="fl-11__date">Jan 2024</div>
          <div class="fl-11__event-tag" style="background:#dbeafe;color:#1d4ed8">Launch</div>
        </div>
        <div class="fl-11__event-title">Project Kickoff</div>
        <div class="fl-11__event-desc">Initial CSS Flexbox design system established. Team aligned on layout patterns and naming conventions for all 15 demo types.</div>
        <div class="fl-11__event-card">
          <div class="fl-11__card-row">
            <div class="fl-11__card-icon" style="background:#dbeafe">👥</div>
            <div>
              <div class="fl-11__card-text">Team onboarded</div>
              <div class="fl-11__card-sub">8 contributors</div>
            </div>
            <div class="fl-11__card-value">8 devs</div>
          </div>
        </div>
      </div>
    </div>

    <div class="fl-11__event">
      <div class="fl-11__connector">
        <div class="fl-11__dot" style="background:#d97706">⚡</div>
        <div class="fl-11__line"></div>
      </div>
      <div class="fl-11__content">
        <div class="fl-11__event-meta">
          <div class="fl-11__date">Mar 2024</div>
          <div class="fl-11__event-tag" style="background:#fef3c7;color:#b45309">Milestone</div>
        </div>
        <div class="fl-11__event-title">v1.0 Layout System Released</div>
        <div class="fl-11__event-desc">First stable release of the flexbox layout library. Included holy grail, sidebar dashboard, and card grid patterns.</div>
        <div class="fl-11__event-card">
          <div class="fl-11__card-row">
            <div class="fl-11__card-icon" style="background:#fef3c7">📦</div>
            <div>
              <div class="fl-11__card-text">Components shipped</div>
              <div class="fl-11__card-sub">npm install flexlayout</div>
            </div>
            <div class="fl-11__card-value" style="color:#d97706">24 patterns</div>
          </div>
        </div>
      </div>
    </div>

    <div class="fl-11__today">
      <div class="fl-11__today-line"></div>
      <div class="fl-11__today-label">Today</div>
      <div class="fl-11__today-line"></div>
    </div>

    <div class="fl-11__event">
      <div class="fl-11__connector">
        <div class="fl-11__dot" style="background:#059669">✓</div>
        <div class="fl-11__line"></div>
      </div>
      <div class="fl-11__content">
        <div class="fl-11__event-meta">
          <div class="fl-11__date">Jun 2025</div>
          <div class="fl-11__event-tag" style="background:#d1fae5;color:#065f46">Current</div>
        </div>
        <div class="fl-11__event-title">Flexbox Gallery Collection</div>
        <div class="fl-11__event-desc">15 production-grade CSS Flexbox demos published. Covers every major layout pattern from holy grail to kanban board.</div>
        <div class="fl-11__event-card">
          <div class="fl-11__card-row">
            <div class="fl-11__card-icon" style="background:#d1fae5">🎨</div>
            <div>
              <div class="fl-11__card-text">Demos live</div>
              <div class="fl-11__card-sub">All SEO-targeted</div>
            </div>
            <div class="fl-11__card-value">15 demos</div>
          </div>
        </div>
      </div>
    </div>

    <div class="fl-11__event">
      <div class="fl-11__connector">
        <div class="fl-11__dot" style="background:#7c3aed;opacity:0.5">→</div>
        <div class="fl-11__line"></div>
      </div>
      <div class="fl-11__content">
        <div class="fl-11__event-meta">
          <div class="fl-11__date">Q3 2025</div>
          <div class="fl-11__event-tag" style="background:#ede9fe;color:#5b21b6">Planned</div>
        </div>
        <div class="fl-11__event-title">Grid + Subgrid Expansion</div>
        <div class="fl-11__event-desc" style="opacity:0.6">Next phase: 15 CSS Grid layout demos with subgrid, named areas, and masonry support.</div>
      </div>
    </div>

  </div>
</div>
.fl-11, .fl-11 *, .fl-11 *::before, .fl-11 *::after {
  margin: 0; padding: 0; box-sizing: border-box;
}
.fl-11 ::selection { background: #059669; color: #fff; }

.fl-11 {
  --bg: #fafdf9;
  --surface: #fff;
  --ink: #0a1f13;
  --muted: #6b7c74;
  --accent: #059669;
  --accent-light: #d1fae5;
  --accent2: #0284c7;
  --accent3: #d97706;
  --accent4: #7c3aed;
  --timeline-line: #d1fae5;
  --border: #e2f0ea;
  font-family: 'IBM Plex Sans', sans-serif;
  background: var(--bg);
  padding: 28px;
  border-radius: 16px;
  min-height: 500px;
}

.fl-11__header {
  margin-bottom: 28px;
}
.fl-11__eyebrow {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 4px;
}
.fl-11__title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
}
.fl-11__sub {
  font-size: 0.78rem;
  color: var(--muted);
  margin-top: 4px;
}

/*
  TIMELINE TECHNIQUE:
  Each event = flex row with:
    - connector column (dot + line): flex-shrink: 0
    - content card: flex: 1
  The vertical line is a ::before pseudo on the connector
  that grows to fill the item height.
*/

.fl-11__timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.fl-11__event {
  display: flex;
  gap: 16px;
  position: relative;
}

/* Connector column */
.fl-11__connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  width: 32px;
}

.fl-11__dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  flex-shrink: 0;
  z-index: 1;
  border: 3px solid var(--bg);
  transition: transform 0.2s;
}
.fl-11__event:hover .fl-11__dot { transform: scale(1.15); }

.fl-11__line {
  flex: 1;
  width: 2px;
  background: var(--timeline-line);
  margin-top: 4px;
  margin-bottom: 0;
  min-height: 16px;
}
.fl-11__event:last-child .fl-11__line { display: none; }

/* Content */
.fl-11__content {
  flex: 1;
  padding-bottom: 24px;
}
.fl-11__event-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.fl-11__date {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}
.fl-11__event-tag {
  font-size: 0.62rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.fl-11__event-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 4px;
}
.fl-11__event-desc {
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 8px;
}
.fl-11__event-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
}
.fl-11__card-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.78rem;
}
.fl-11__card-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  flex-shrink: 0;
}
.fl-11__card-text { color: var(--ink); font-weight: 500; flex: 1; }
.fl-11__card-sub { font-size: 0.7rem; color: var(--muted); margin-top: 2px; }
.fl-11__card-value { font-weight: 700; color: var(--accent); font-size: 0.82rem; }

/* Today marker */
.fl-11__today {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 4px 0 0 0;
}
.fl-11__today-line {
  flex: 1;
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--accent) 0, var(--accent) 5px, transparent 5px, transparent 10px);
}
.fl-11__today-label {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-light);
  padding: 3px 8px;
  border-radius: 4px;
  flex-shrink: 0;
}

@media (prefers-reduced-motion: reduce) {
  .fl-11__dot { transition: none; }
}

How this works

Each timeline event uses display: flex; gap: 16px with a narrow 32px connector column (flex-shrink: 0) and a content card (flex: 1). The continuous vertical line is a width: 2px; flex: 1 block inside the connector column — it grows to fill the column height between the dot and the next event.

The connector column itself is a nested column flex container with align-items: center so the dot and line are horizontally centered. The last event hides the trailing line with .fl-11__event:last-child .fl-11__line { visibility: hidden }, preventing an orphan line below the final entry.

Customize

  • Change the connector line color and width by editing background and width on .fl-11__line.
  • Add alternating sides by giving even events flex-direction: row-reverse and adjusting connector positioning for a two-rail timeline.
  • Use icons instead of dots by replacing .fl-11__dot with an SVG or emoji element — the connector column accommodates any inline-size.
  • Animate events on scroll with the Intersection Observer API by adding a class that transitions opacity and translateX on each .fl-11__event.
  • Change the date label position by moving it inside the content card header row or into the connector column above the dot using a nested flex layout.

Watch out for

  • The line between events relies on the connector column height matching the gap between dots — if event cards have variable padding, gaps in the line may appear.
  • Setting visibility: hidden on the last line preserves layout space; use display: none only if no trailing gap is acceptable.
  • The flex: 1 line element collapses to zero if its parent connector column has no explicit height — ensure the parent is a flex container for the grow to work.

Browser support

ChromeSafariFirefoxEdge
29+ 9+ 28+ 29+

Pure baseline flexbox; no advanced features required. Accessible reading order matches visual order since it follows DOM flow.

Search CodeFronts

Loading…