Best For
时间线 / 历程 / 里程碑
Vertical Timeline
Vertical timeline layout connecting time nodes through a connecting line. Ideal for displaying historical progress, project milestones, work experience, and process steps.
Best For
时间线 / 历程 / 里程碑
Primary Move
Use pseudo-elements or divs to create the central connecting line
Watch Out
Do not break or misalign the connecting line
Showcase Entry
Live preview of the showcase page. Click to explore the full experience.
Color Palette
Primary
#1e293b
Secondary
#f8fafc
Accent 1
#3b82f6
Accent 2
#10b981
AI Implementation
Use the Hard Prompt by default to generate UI. Use the Design Spec to understand, modify, and review the style. Use the Creative Brief for early exploration.
Use this by default: copy it, append the concrete requirement, and let AI generate consistent production UI.
When to use
How to use
STYLEKIT_STYLE_REFERENCE
style_name: Vertical Timeline
style_slug: timeline-vertical
style_source: /styles/timeline-vertical
# Hard Prompt
## When To Use
Use this when you want AI to generate code with strict style consistency. It is the safest default for production UI.
## How To Use
- Copy the full prompt into ChatGPT, Claude, Cursor, or another coding assistant.
- Append the concrete product/page requirement after the prompt.
- After generation, check the forbidden rules and interaction states before accepting the output.
Strictly follow the style rules below and maintain consistency. No style drift allowed.
## Requirements
- Prioritize style consistency first, then creative extension.
- When conflicts arise, treat prohibitions as the highest priority.
- Self-check before output: verify colors, typography, spacing, and interactions still match this style.
## Style Rules
You are a frontend expert specializing in Vertical Timeline layout. All generated code must strictly follow these constraints:
## Absolute Prohibitions
- Do NOT break the connecting line
- Do NOT use inconsistent node sizes
- Do NOT keep alternating layout on mobile
- Do NOT omit time/date labels
- Do NOT make content too long per node
## Must Follow
- Central line: absolute positioned pseudo-element or div
- Node dots: aligned with center line
- Mobile: single-side layout (all items on right)
- Desktop: can alternate left/right
- Consistent spacing between nodes
- Clear time/date indicators
## Structure
Container:
- relative positioning
- padding-left for line space (mobile)
- centered line (desktop alternating)
Central Line:
- Pseudo-element or div
- Absolute positioned
- 2px width, subtle color
Node:
- Circular dot (w-4 h-4)
- Aligned with line center
- Different colors for status
- White border for contrast
Content Card:
- Connected visually to node
- Date/time label
- Title and description
- Optional action button
## Responsive
Mobile:
- All items on one side
- Line on left
- Full-width cards
Desktop:
- Optional alternating sides
- Line in center
- Cards 50% width
## Animation
Scroll-triggered:
- Items fade in on scroll
- Stagger animation
- Node pulse on current
## Animation & Interaction Rules
- Node Synchronization: When hovering a card, the timeline node must synchronize with highlight, scale, or glow, establishing a strong connection.
- Pull-out Effect: Card hover can slightly lift and shift along the horizontal axis (translate-x), simulating a node being pulled out for examination.
- Sequential Smoothness: Transitions use duration-200 ease-out, supporting stable feedback during fast scrolling browsing.
- Connected Focus: Focused card border color must match the timeline main line, ensuring narrative continuity.
## Self-Check
After generating code, verify:
1. Line is continuous
2. Nodes are aligned
3. Mobile is single-side
4. All items have dates
5. Scroll animation worksComponent Templates
时间线节点中的操作按钮
Frontend Readiness
This layer tracks whether the style is ready for real websites: theme modes, state feedback, keyboard access, and performance constraints.
Overall
51%
Fallback
Dark Mode
0%
MissingUI States
79%
PartialMotion
70%
PartialA11y
70%
PartialPerformance
35%
FallbackButton
Default / Hover / Focus Visible / Active / Disabled
Input
Default / Hover / Focus Visible / Disabled / Error
Card
Default / Hover / Focus Visible / Loading / Skeleton
Form
Default / Focus Visible / Disabled / Loading / Error
/* Vertical Timeline Global Styles */
/* Timeline container */
.timeline {
position: relative;
padding-left: 2rem;
}
/* Central line */
.timeline::before {
content: '';
position: absolute;
left: 0.5rem;
top: 0;
bottom: 0;
width: 2px;
background: #e2e8f0;
}
/* Timeline item */
.timeline-item {
position: relative;
padding-left: 2rem;
padding-bottom: 2rem;
}
/* Node dot */
.timeline-item::before {
content: '';
position: absolute;
left: -0.5rem;
top: 0.5rem;
width: 1rem;
height: 1rem;
border-radius: 50%;
background: #3b82f6;
border: 4px solid white;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
/* Alternating layout for desktop */
@media (min-width: 768px) {
.timeline-alternating {
padding-left: 0;
}
.timeline-alternating::before {
left: 50%;
transform: translateX(-50%);
}
.timeline-alternating .timeline-item {
width: 50%;
padding-left: 0;
padding-right: 2rem;
}
.timeline-alternating .timeline-item:nth-child(even) {
margin-left: 50%;
padding-left: 2rem;
padding-right: 0;
}
.timeline-alternating .timeline-item::before {
left: auto;
right: -0.5rem;
}
.timeline-alternating .timeline-item:nth-child(even)::before {
left: -0.5rem;
right: auto;
}
}
/* Scroll animation */
.timeline-item {
opacity: 0;
transform: translateY(20px);
transition: opacity 0.5s ease, transform 0.5s ease;
}
.timeline-item.in-view {
opacity: 1;
transform: translateY(0);
}
/* Node color variants */
.timeline-item[data-status="complete"]::before {
background: #10b981;
}
.timeline-item[data-status="current"]::before {
background: #3b82f6;
box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2);
}
.timeline-item[data-status="upcoming"]::before {
background: #d1d5db;
}
/* Vertical Timeline Design Tokens */
:root {
--timeline-vertical-primary: #1e293b;
--timeline-vertical-secondary: #f8fafc;
--timeline-vertical-accent: #3b82f6;
--timeline-vertical-glow: rgba(30, 41, 59, 0.3);
}
@keyframes timeline-vertical-fade-in {
from { opacity: 0; transform: translateY(8px); }
to { opacity: 1; transform: translateY(0); }
}
@keyframes timeline-vertical-pulse {
0%, 100% { opacity: 1; }
50% { opacity: 0.7; }
}
.timeline-vertical-gradient {
background: linear-gradient(135deg, #1e293b, #3b82f6);
}
.timeline-vertical-gradient-text {
background: linear-gradient(135deg, #1e293b, #3b82f6);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.timeline-vertical-frosted {
backdrop-filter: blur(12px) saturate(180%);
-webkit-backdrop-filter: blur(12px) saturate(180%);
background: rgba(30, 41, 59, 0.08);
}
.timeline-vertical-accent-corner {
clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2rem), calc(100% - 2rem) 100%, 0 100%);
}
.timeline-vertical-animate-in {
animation: timeline-vertical-fade-in 0.5s ease-out both;
}Compatible Visual Styles
垂直时间线布局 is a layout pattern that can be paired with the following visual styles.
IDE Integration
Download configuration files for AI coding assistants to generate code in this style.
Style Pack
Get complete machine-readable style assets including design tokens, Tailwind presets, CSS variables, and shadcn/ui themes.
Metadata
Style metadata including version information
Design Tokens
Compatible with Figma / Style Dictionary / Tokens Studio
Tailwind Preset
Tailwind CSS theme preset, import directly in config
Global CSS
CSS variables and base styles
shadcn Theme
shadcn/ui theme configuration
CSS Variables
Pure CSS variables, works with any project
SKILL.md
Loadable skill pack for Cursor / Claude Code / VS Code
Vertical Timeline is a layout approach for displaying time sequences or process steps, guiding reading through visual connecting lines.
WCAG 2.1 compliance analysis based on color contrast and typography readability.
Overall Score
Grade: C - Fair
Contrast Ratios
| Context | Colors | Ratio | AA | AAA |
|---|---|---|---|---|
| Text on secondary background | /#18181b / #ffffff | 17.72:1 | ||
| Button primary | /#ffffff / #3b82f6 | 3.68:1 | ||
| Text on accent 1 | /#18181b / #3b82f6 | 4.82:1 | ||
| Text on accent 2 | /#18181b / #10b981 | 6.98:1 | ||
| Text on accent 3 | /#18181b / #f59e0b | 8.25:1 | ||
| Text on accent 4 | /#18181b / #ef4444 | 4.71:1 |
Readability
Score
77/100
Font Size
text-sm md:text-base
Font Weight
font-semibold tracking-tight
Line Height
default
Scoring is based on WCAG 2.1 standards. AA requires 4.5:1 contrast for normal text, 3:1 for large text; AAA requires 7:1 for normal text, 4.5:1 for large text.
Design Recipes
These curated recipes combine this style with layouts and animations, optimized for specific use cases.