Design System Inspiration of Cloudflare
1. Visual Theme & Atmosphere
Cloudflare is the connectivity-cloud company that sits in front of a meaningful slice of the internet — CDN, DNS, DDoS mitigation, Zero Trust, Workers edge compute. Its visual identity has one job: make planet-scale infrastructure feel approachable and human in a category that defaults to cold, blue, enterprise seriousness. The answer is a single, unmistakable move — Cloudflare Orange (#F6821F) against generous white space and near-black charcoal text. In a backend-devops landscape where AWS, Azure, GCP, Datadog, and nearly every security vendor reach for navy and electric blue, Cloudflare's warm orange is a deliberate act of differentiation. The orange is the brand; everything else is restraint built to let it sing.
The marketing surface (cloudflare.com) is bright, airy, and optimistic — large charcoal headlines on white, orange reserved almost exclusively for calls-to-action and the cloud logomark. The product surface (the Cloudflare dashboard) is denser and more utilitarian: data tables, status pills, analytics graphs, config toggles, and code blocks, where orange becomes a precision accent rather than a field of color. Both surfaces share the same DNA — clarity first, decoration never, the orange as the one emotional note in an otherwise technical instrument.
Typography is Inter-led — a clean, highly-legible neo-grotesque optimized for screens — with a system-font fallback stack so the dashboard stays fast everywhere. Headings are set tight and confident; body copy is calm and explanatory. Cloudflare's published "Color by Cloudflare Design" system organizes hues into perceptual scales, and the dashboard ships a fully-realized dark mode, signalling a mature, token-driven design org rather than ad-hoc styling.
Key Characteristics:
- Cloudflare Orange (
#F6821F) as the singular brand and primary-action color — warm, energetic, instantly recognizable
- Inter typeface with a system-ui fallback stack — screen-optimized neo-grotesque
- Bright white marketing canvas; dense, table-heavy product dashboard with first-class dark mode
- Near-black charcoal text (
#36393A / #1D1F20) — warm-neutral, never pure #000
- Orange used sparingly and intentionally — CTAs, links, active states, the logomark — not as decoration
- Perceptual color scales (orange, blue, grey, plus semantic red/green/yellow) for tokens
- Engineering-grade restraint: clean rules, subtle shadows, generous whitespace, no gratuitous gradients
2. Color Palette & Roles
Primary
- Cloudflare Orange (
#F6821F): The brand. Primary CTAs, the cloud logomark, links, active/selected states, focus accents. The one color that carries emotional weight.
- Orange Hover (
#E2700B / approx #D9700F): Hover/pressed state for orange CTAs — a darker, denser orange.
- Orange Tint (
#FBE6CC / #FDF3E7): Soft orange-tinted backgrounds for info banners, highlighted rows, and selected list items.
- Brand Orange Alt (
#F48120): Logo-mark gradient orange (the icon is built from a warm orange gradient #F6821F → #FAAD3F). Marketing/logo contexts only.
- Gradient Yellow-Orange (
#FAAD3F): The lighter stop in the logomark gradient. Decorative brand moments, never UI text.
Surface & Background
- Pure White (
#FFFFFF): Marketing page background, card surfaces, dashboard panels (light mode).
- Off-White (
#F7F7F7 / #F5F5F5): Secondary background, page wash behind cards, zebra-stripe table rows.
- Light Grey Surface (
#EDEDED / #F0F0F0): Input fills, disabled surfaces, subtle separators.
Text
- Charcoal (Headings) (
#1D1F20): Strongest text — display headlines and key labels. Warm near-black.
- Body Charcoal (
#36393A): Standard body copy and paragraph text.
- Muted Grey (
#666666 / #717174): Secondary labels, captions, metadata.
- Placeholder Grey (
#999999 / #A1A1A1): Input placeholders, disabled text.
Semantic
- Success Green (
#9BCA3E / #2FB344): "Active", "Proxied", healthy status, success toasts. (Cloudflare's classic proxied/healthy green leans #9BCA3E; dashboards use a saturated #2FB344 for status dots.)
- Error Red (
#BD2528 / #E1351D): Errors, destructive actions, "Down"/"Blocked" status, attack indicators.
- Warning Yellow (
#F6C549 / #FFC107): Caution, "DNS only" / "Paused" states, attention banners.
- Info Blue (
#2C7CB0 / #0073AA): Informational accents, secondary links, neutral-technical highlights, chart series.
Neutral / Grey Scale
- Grey 50 (
#FAFAFA): Lightest wash.
- Grey 100 (
#F5F5F5): Card fill, page background.
- Grey 200 (
#EDEDED): Default borders, dividers.
- Grey 300 (
#D9D9D9): Strong borders, input outlines.
- Grey 400 (
#A1A1A1): Placeholder, disabled icon.
- Grey 500 (
#717174): Caption / secondary text.
- Grey 600 (
#4D4D4D): Emphasized secondary text.
- Grey 700 (
#36393A): Body text.
- Grey 900 (
#1D1F20): Headings, strongest text.
Dark Mode (Dashboard)
- Dark Background (
#1D1F20 / #15171A): App background.
- Dark Surface (
#262A2E / #23272B): Card/panel surface.
- Dark Border (
#3A3F44): Dividers and outlines.
- Dark Text (
#E4E6E7): Primary text on dark; muted #9BA1A6.
- Orange stays
#F6821F in dark mode — it is bright enough to hold against dark surfaces without adjustment.
3. Typography Rules
Font Family
- Primary:
"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif
- Display/Marketing: Inter (tight tracking on large sizes) — some hero moments use Inter Display optical sizing.
- Monospace:
"JetBrains Mono", "SFMono-Regular", Menlo, Consolas, "Liberation Mono", monospace — for code blocks, DNS records, IP addresses, API keys, and config snippets, which are everywhere in the product.
Hierarchy
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|---|
| Display Hero | Inter | 56px | 700 | 1.1 (62px) | -0.02em | Marketing hero headline |
| Display | Inter | 40px | 700 | 1.15 (46px) | -0.02em | Major section headers |
| Heading 1 | Inter | 32px | 700 | 1.2 (38px) | -0.01em | Page titles |
| Heading 2 | Inter | 24px | 600 | 1.3 (31px) | -0.01em | Section / card group titles |
| Heading 3 | Inter | 20px | 600 | 1.4 (28px) | normal | Card headings, panel titles |
| Subtitle | Inter | 18px | 600 | 1.45 (26px) | normal | Lead-in / dashboard section labels |
| Body Large | Inter | 16px | 400 | 1.6 (26px) | normal | Marketing paragraphs |
| Body | Inter | 14px | 400 | 1.55 (22px) | normal | Dashboard standard text |
| Body Small | Inter | 13px | 400 | 1.5 (20px) | normal | Table cells, secondary info |
| Caption | Inter | 12px | 400 | 1.5 (18px) | normal | Metadata, timestamps, helper text |
| Label / Eyebrow | Inter | 12px | 600 | 1.4 (17px) | 0.06em UPPER | Section eyebrows, table headers |
| Code / Mono | JetBrains Mono | 13px | 400 | 1.6 (21px) | normal | DNS records, IPs, API tokens, code |
Principles
- Inter, three weights. 400 (body), 600 (emphasis/sub-headings), 700 (headlines). Avoid 500 in UI text; reserve 800/900 for rare marketing display.
- Negative tracking on large type. Headlines ≥24px tighten to
-0.01em to -0.02em for a confident, modern feel; body stays at normal tracking.
- Monospace is a first-class citizen. Technical strings — IPs, DNS records, hashes, tokens, JSON — always render in mono so they are scannable and copy-safe. Never set an API key in a proportional font.
- Uppercase eyebrows. Small 12px/600 uppercase labels with
0.06em tracking mark sections and table headers — a quiet structural device, not decoration.
4. Component Patterns
Cloudflare maintains a public, open-source component library — kumo (github.com/cloudflare/kumo, built on Base UI primitives + Tailwind CSS v4), succeeding the earlier cf-ui styleguide (cloudflare.github.io/cf-ui) — plus a public docs Style Guide (developers.cloudflare.com/style-guide/components). The geometry below is lifted from kumo's actual source: a consistent four-step control-size scale (h-5/h-6.5/h-9/h-10 → 20/26/36/40px), a rounded-sm → rounded-md → rounded-lg → rounded-xl radius ladder (4/6/8/12px), and ring-based borders over solid borders. One honest nuance worth recording: kumo's interactive brand token (--color-kumo-brand) is a blue in the current library, while Cloudflare Orange #F6821F persists as the marketing/brand accent (--text-color-kumo-brand: #f6821f) and is what the live cloudflare.com surface renders for primary CTAs. The specs below keep the orange-led brand identity that the public marketing surface still ships, annotating where kumo diverges to blue.
Actions
Primary Button
- Fill:
#F6821F · Text: #FFFFFF · Border: none
- Radius: 8px (kumo
rounded-lg)
- Sizes: medium
h-9 (36px, 12px horizontal padding), large h-10 (40px, 16px horizontal padding)
- Font: 14px / 600 / Inter (kumo
text-base 16px on large)
- Hover:
#E2700B · Pressed: #D9700F · Disabled: brand at 50% opacity
- Focus: 2px brand ring (
focus-visible:ring-2 focus-visible:ring-kumo-brand)
- Use: Primary action — "Get started", "Add site", "Save", "Deploy"
Secondary Button (outline)
- Fill:
#FFFFFF · Text: #36393A
- Ring: 1px
#D9D9D9 hairline · Radius: 8px
- Hover: background
#FAFAFA, ring #A1A1A1
- Use: Companion to a primary ("Cancel", "Back")
Ghost Button
- Fill: transparent · Text:
#F6821F · Radius: 8px
- Padding: 0 12px · Hover: background
#FDF3E7 (kumo bg-kumo-tint)
- Use: Inline low-emphasis action, "Learn more", text-link button
Destructive Button
- Fill:
#BD2528 · Text: #FFFFFF · Radius: 8px
- Hover:
#A11F22 (kumo: danger at 70% opacity)
- Secondary destructive variant: white fill,
#BD2528 text, hairline ring
- Use: Delete zone, remove record, purge — confirmation contexts only
Compact / Small Button
- Size:
h-6.5 (26px) · Radius: 6px (rounded-md) · Padding: 0 8px · Font: 12px
- Use: Toolbar and table-row inline actions where vertical space is tight
Icon Button
- Square
h-9/h-10, p-0, centered glyph; rounded-full or 8px radius
- Use: Close, kebab menu, copy-to-clipboard affordance
Dark CTA (Marketing)
- Fill:
#1D1F20 · Text: #FFFFFF · Radius: 8px · Padding: 0 24px
- Font: 16px / 600 / Inter · Height: 48px
- Use: Marketing-page secondary CTA where orange is already spent on the primary
Navigation
Underline Tabs (default)
- Container border-bottom: 1px solid
#EDEDED
- Inactive: text
#717174, 14px / 600 · Hover: text #36393A
- Active: text
#1D1F20, 2px bottom border #F6821F
- Use: Dashboard section switching (Overview / Analytics / DNS / SSL)
Sidebar / Left Nav
- Persistent ~240px rail, white surface, 1px
#EDEDED right hairline
- Item: 14px / 400,
#36393A; active item orange-tinted #FDF3E7 fill + #F6821F text/indicator
- Collapses to an icon rail, then a drawer on mobile (kumo
sidebar)
Breadcrumbs
- 13px / 400
#717174, #36393A on current crumb, / or chevron separators in #A1A1A1
- Use: Zone → section → record deep paths
Pagination
- Numbered controls as compact buttons; current page brand-tinted; prev/next chevrons
- Use: Long DNS/log/audit tables (kumo
pagination)
Forms
Text Field
- Fill:
#FFFFFF · Text: #1D1F20 · Placeholder: #999999
- Ring: 1px
#D9D9D9 (ring-kumo-line) · Radius: 8px
- Size:
h-10 (40px), 16px horizontal padding · Font: 14px / 400 / Inter
- Focus: 1.5px brand ring (kumo
focus:ring-[1.5px]) — marketing/live surface renders the orange ring 0 0 0 3px rgba(246,130,31,0.2)
- Use: Standard form input, search, config values
Mono Input (technical)
- Fill:
#FFFFFF · Text: #1D1F20 · Ring: 1px #D9D9D9 · Radius: 8px
- Font: 13px / 400 / JetBrains Mono
- Use: DNS record values, IP entry, token paste fields
Input Error State
- Ring: 1.5px
#BD2528 (ring-kumo-danger)
- Focus ring:
0 0 0 3px rgba(189,37,40,0.18)
- Helper text below:
#BD2528, 12px / 400 — one actionable sentence
- Use: Validation failure
Select / Dropdown
- Fill:
#FFFFFF · Ring: 1px #D9D9D9 · Radius: 8px · Size: h-10
- Chevron:
#717174
- Use: Plan picker, record-type selector, region dropdown
Switch / Toggle
- DS sizes: track
h-4/h-4.5/h-5 (16/18/20px)
- Shape:
rounded-[5px], squircle-rounded to 10px where supported
- On:
#F6821F (kumo library on-state = blue #2C7CB0) · Off: #D9D9D9
- Thumb:
#FFFFFF circle with edge+drop shadow (shadow-[0 0 1px .5px edge, 0 1px 2px drop])
- Use: Proxy on/off, feature flags, security toggles
Checkbox / Radio
- Square (checkbox) / circle (radio), ~6px / pill radius
- Checked: brand fill + white glyph · Unchecked: 1px
#D9D9D9 hairline ring
- Use: Multi-select rules, plan options, consent
Data display
Standard Panel
- Fill:
#FFFFFF · Border: 1px solid #EDEDED · Radius: 8px · Padding: 24px
- Shadow:
0 1px 3px rgba(0,0,0,0.06)
- Use: Dashboard config panels, analytics modules — the workhorse surface
Marketing Feature Card
- Fill:
#FFFFFF · Border: none · Radius: 12px · Padding: 32px
- Shadow:
0 4px 16px rgba(0,0,0,0.08)
- Use: Product/feature cards on the marketing site
Stat / Metric Card
- Fill:
#FFFFFF · Border: 1px solid #EDEDED · Radius: 8px · Padding: 20px
- Big number: 32px / 700 / Inter,
#1D1F20
- Label: 12px / 600 uppercase,
#717174
- Use: Analytics summary tiles (requests, bandwidth, threats blocked)
Data Table
- Header row: background
#FAFAFA, text 12px / 600 uppercase #717174, 0.04em tracking
- Body cell: 13px / 400
#36393A, padding 12px 16px
- Row border: 1px solid
#EDEDED · Hover row: background #FAFAFA
- Zebra (optional): alternate
#FFFFFF / #FAFAFA
- Use: DNS records, firewall rules, analytics logs — the heart of the product
Code Block
- Background:
#F5F5F5 (light) / #15171A (dark) · Text: #1D1F20 / #E4E6E7
- Border: 1px solid
#EDEDED (light) · Radius: 6px · Padding: 12px 16px
- Font: 13px / 400 / JetBrains Mono · with copy-to-clipboard affordance
- Use: API examples, Worker snippets, curl commands, DNS values
Meter / Progress
- Track:
#EDEDED rounded-full; fill brand #F6821F (or semantic for usage warnings)
- Use: Plan usage, bandwidth consumption, upload progress (kumo
meter)
Overlays
Dialog / Modal
- Fill:
#FFFFFF · Text: #1D1F20 · Ring: 1px line · Radius: 12px (rounded-xl) · Padding: 32px (p-8)
- Shadow:
0 12px 32px rgba(0,0,0,0.18)
- Scrim:
rgba(29,31,32,0.5) (kumo recessed at ~80% opacity)
- Enter: scale from 90% + fade over 150ms
- Use: Confirmations, destructive double-checks, add-record flows
Popover / Dropdown Menu
- Fill:
#FFFFFF · Ring: 1px #EDEDED · Radius: 8px · Shadow: floating 0 8px 24px rgba(0,0,0,0.12)
- Item hover:
#FAFAFA fill
- Use: Action menus, command palette, account switcher (kumo
popover, dropdown, command-palette)
Tooltip
- Fill:
#FFFFFF · Text: #1D1F20, 13px · Radius: 6px (rounded-md) · Padding: 6px 10px
- Shadow:
shadow-lg, 1px outline
- Use: Icon labels, truncated-value reveal, glossary terms
Feedback & Status
Toast
- Fill:
#1D1F20 (live marketing) / #FFFFFF (kumo) · Text: #FFFFFF / #1D1F20
- Radius: 12px (
rounded-xl) · Padding: 16px · Shadow: shadow-lg
- Accent: 4px brand left-border (marketing) or 0.3px semantic ring — success green
#2FB344, error red #BD2528, warning yellow #F6C549, info blue #2C7CB0
- Position: fixed bottom-right, 340px wide; 4–5s auto-dismiss
- Use: Auto-dismissing confirmation ("Record added", "Settings saved")
Banner / Alert
- Full-width inline strip; tinted background by severity (info
#FDF3E7-style tint, warning, danger, success)
- 1px hairline, 14px text, optional icon + dismiss
- Use: Account-level notices, plan upgrade prompts, incident banners (kumo
banner)
Badge
- Shape:
rounded-full · Padding: 2px 8px · Font: 12px / 500
- Variants: neutral, success, error, warning, info, orange, plus dashed-brand outline
- Optional 7px status dot (
size-1.75 rounded-full)
- Use: "NEW", "Beta", version, plan, short metadata
Status Pill — Active / Proxied (Green)
- Background:
#E8F5D8 · Dot: #2FB344 · Text: #3D6B14
- Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
- Use: "Active", "Proxied", healthy
Status Pill — Error / Down (Red)
- Background:
#FBE2E2 · Text: #BD2528
- Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
- Use: "Down", "Blocked", "Error"
Status Pill — Pending / Paused (Yellow)
- Background:
#FCF3D6 · Text: #8A6D1B
- Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
- Use: "Pending", "DNS only", "Paused"
Status Pill — Neutral (Grey)
- Background:
#EDEDED · Text: #4D4D4D
- Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
- Use: "Inactive", neutral metadata
Status Pill — Brand (Orange)
- Background:
#FDF3E7 · Text: #C2670F
- Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
- Use: "NEW", "Beta", plan emphasis
Loader / Spinner
- Brand
#F6821F ring spinner (inline) or top progress bar; existing data stays visible on refresh
- Use: In-button loading (label swaps for white spinner, width preserved), table refresh (kumo
loader)
Empty State
- One line of
#36393A body explaining the why + one orange-ghost or secondary action; no dashboard illustration
- Use: "No DNS records yet. Add your first record." (kumo
empty)
Tier 1 sources: https://www.cloudflare.com (live production marketing site, verified via live DOM getComputedStyle); Cloudflare's public component library kumo (github.com/cloudflare/kumo — source TSX + theme-kumo.css design tokens), the legacy cf-ui styleguide (cloudflare.github.io/cf-ui), and the docs Style Guide (developers.cloudflare.com/style-guide/components). Component geometry (size scale, radius ladder, ring borders, dialog/toast/tooltip specs) is lifted from kumo source; the orange-led palette is grounded in the live marketing surface.
5. Layout Principles
Spacing System
- Base unit: 4px; primary rhythm on 8px.
- Common values: 4px, 8px, 12px, 16px, 24px, 32px, 48px, 64px, 96px.
- Marketing sections: generous 64–96px vertical rhythm.
- Dashboard panels: tighter 16–24px internal padding for density.
Grid & Container
- Marketing max-width: ~1200px, centered, 24px gutters.
- Dashboard: persistent left nav (~240px) + fluid content area; tables go full-width within content.
- 12-column responsive grid on marketing; flexible flex/stack layout in product.
Whitespace Philosophy
- Whitespace earns trust. Marketing pages breathe — one idea per band, large headline, supporting paragraph, single orange CTA.
- Density where work happens. The dashboard trades whitespace for information: data tables, log streams, and config grids are intentionally dense because operators want facts per pixel.
- Orange is rationed. A screen typically shows orange in exactly one or two places. Scarcity is what makes it read as "the action."
Border Radius Scale
- Tight (4px): pills' inner chips, small inline tags
- Standard (6px): buttons, inputs, selects, code blocks
- Comfortable (8px): cards, panels, toasts
- Large (10–12px): modals, marketing feature cards
- Pill (9999px): status badges, toggles, avatars
6. Depth & Elevation
| Level | Treatment | Use |
|---|
| Flat (0) | No shadow, 1px #EDEDED border | Inline elements, table rows, bordered panels |
| Subtle (1) | 0 1px 3px rgba(0,0,0,0.06) | Standard dashboard cards |
| Raised (2) | 0 4px 16px rgba(0,0,0,0.08) | Marketing feature cards, hover lift |
| Floating (3) | 0 8px 24px rgba(0,0,0,0.12) | Dropdowns, popovers, tooltips |
| Modal (4) | 0 12px 32px rgba(0,0,0,0.18) | Dialogs, command palette |
Shadow Philosophy: Cloudflare prefers borders over shadows for structure — a crisp 1px #EDEDED rule defines most surfaces, with soft neutral shadows reserved for genuinely floating layers. Shadows are pure-black low-opacity, never tinted. This keeps the dense dashboard legible: dozens of bordered panels read cleanly where dozens of shadowed cards would muddy. The brand's depth comes from clarity and alignment, not drop-shadow drama.
Dark Mode Elevation
- In dark mode, elevation is conveyed by surface lightness, not shadow: background
#15171A → card #262A2E → popover #2E3338. Borders shift to #3A3F44.
7. Do's and Don'ts
Do
- Use Cloudflare Orange (
#F6821F) for the primary CTA and key interactive accents — and almost nowhere else.
- Set technical strings (IPs, DNS records, tokens, code) in JetBrains Mono / monospace.
- Use status pills with green/red/yellow + a colored dot for health and proxy state.
- Prefer 1px
#EDEDED borders to define panels; keep shadows subtle and neutral.
- Use warm near-black (
#1D1F20) for headings, never pure #000.
- Set headlines in Inter 700 with slightly negative letter-spacing.
- Ship parity in dark mode for any product UI, keeping orange unchanged.
Don't
- Don't flood screens with orange — it loses its meaning the moment it decorates instead of directing.
- Don't use blue as a primary brand color; blue is informational/secondary only (Cloudflare is deliberately not blue).
- Don't put API keys, IPs, or DNS values in a proportional font.
- Don't use heavy or colored drop shadows — borders and subtle neutral shadows only.
- Don't use radii above 12px except pills and avatars.
- Don't set body text in 700 — reserve bold for headings and emphasis.
- Don't mix the logomark gradient orange (
#FAAD3F) into UI text or buttons.
8. Responsive Behavior
Breakpoints
| Name | Width | Key Changes |
|---|
| Mobile | <640px | Single column, stacked cards, hamburger nav, full-width buttons |
| Tablet | 640–1024px | 2-column feature grids, collapsible dashboard side nav |
| Desktop | 1024–1280px | Full marketing grid; dashboard left nav + content |
| Wide | >1280px | Centered 1200px marketing container; dashboard tables expand |
Touch Targets
- Buttons: ≥40px tall (≥44px on mobile).
- Table row actions: ≥40px tap height on touch.
- Toggle/switch: ≥32px hit area.
Collapsing Strategy
- Dashboard left nav collapses to an icon rail, then to a drawer on mobile.
- Wide data tables become horizontally scrollable or collapse to stacked key-value cards on small screens.
- Marketing multi-column feature bands stack to single column; CTAs go full-width.
Image / Asset Behavior
- Product/partner logos render in a consistent grayscale-or-mono treatment in logo walls.
- Analytics charts are full-width and responsive, maintaining aspect ratio.
- The orange cloud logomark scales but never recolors.
9. Agent Prompt Guide
Quick Color Reference
- Primary CTA: Cloudflare Orange (
#F6821F)
- CTA Hover: Dark Orange (
#E2700B)
- Background: White (
#FFFFFF) / Off-white (#F7F7F7)
- Heading text: Charcoal (
#1D1F20)
- Body text: Body Charcoal (
#36393A)
- Muted text: Grey (
#717174)
- Placeholder: (
#999999)
- Border: Grey 200 (
#EDEDED) / Grey 300 (#D9D9D9)
- Success: Green (
#2FB344)
- Error: Red (
#BD2528)
- Warning: Yellow (
#F6C549)
- Info: Blue (
#2C7CB0)
- Dark surface: (
#262A2E) on (#15171A)
Example Component Prompts
- "Create a primary button:
#F6821F bg, white text 14px weight 600 Inter, 40px tall, 6px radius, 0 20px padding. Hover #E2700B. Focus ring 0 0 0 3px rgba(246,130,31,0.2)."
- "Build a DNS record row: white bg, 1px
#EDEDED bottom border. Type pill (grey), name + value in 13px JetBrains Mono #36393A, proxy toggle (#F6821F on / #D9D9D9 off), status pill 'Proxied' green #E8F5D8/#3D6B14."
- "Design a stat card: white bg, 1px
#EDEDED border, 8px radius, 20px padding. Big number 32px weight 700 #1D1F20, uppercase label 12px weight 600 #717174 with 0.04em tracking."
- "Create a marketing hero: white bg, headline 56px weight 700 Inter
#1D1F20 tracking -0.02em, subhead 18px #36393A, single orange CTA #F6821F 48px tall 6px radius."
- "Build a status pill: fully rounded, 12px weight 600 Inter, 2px 10px padding. Success green
#E8F5D8/#3D6B14; error #FBE2E2/#BD2528; pending #FCF3D6/#8A6D1B."
Iteration Guide
- Use Inter with a system-ui fallback for all UI text; JetBrains Mono for any technical string.
- Orange (
#F6821F) appears only on primary actions and key accents — ration it deliberately.
- Headings are warm charcoal
#1D1F20, body #36393A — never pure black.
- Define surfaces with 1px
#EDEDED borders first; add subtle neutral shadow only for floating layers.
- Radii: 6px buttons/inputs, 8px cards, 10–12px modals, pill for badges/toggles.
- Status uses colored pills + dots (green/red/yellow); blue is informational only, never primary.
- Provide a dark-mode mapping (
#15171A bg, #262A2E surface, #E4E6E7 text) with orange unchanged.
10. Voice & Tone
Cloudflare's voice is technical but human — confident, plain-spoken, and quietly witty. It explains hard infrastructure to a broad audience (a solo developer on the free plan and a Fortune 100 security team) without dumbing it down or drowning it in jargon. The famous mission line — "to help build a better Internet" — sets the register: ambitious, optimistic, capital-I "Internet." Marketing copy is benefit-led and concrete; the blog (a beloved engineering channel) goes deep with precision and personality. Sentences are direct. Claims are specific and measurable.
| Context | Tone |
|---|
| CTAs | Short imperative verb phrases — "Get started", "Add a site", "Sign up", "Talk to an expert". |
| Headlines | Confident, benefit-first, plain — "Make employees, applications and networks faster and more secure." |
| Product UI labels | Precise, technical, unambiguous — "Proxied", "DNS only", "Always Use HTTPS". |
| Success messages | Past-tense, specific — "DNS record added", "SSL certificate issued". |
| Error messages | Specific, blameless, actionable — name what failed and what to do next. |
| Blog / docs | Deep, candid, occasionally playful; explains the why behind the engineering. |
| Empty states | One line of why + one action — "No DNS records yet. Add your first record." |
Forbidden moves. Vague enterprise filler ("synergy", "best-in-class") without substance; fear-mongering security FUD; over-promising 100% guarantees; burying the user in acronyms without a first-use expansion.
11. Brand Narrative
Cloudflare was founded in 2009 by Matthew Prince, Lee Holloway, and Michelle Zatlyn, growing out of Project Honey Pot — a system for tracking online attackers. The founding insight: the tools that protect and accelerate the internet were locked behind enterprise price tags, available only to the largest companies. Cloudflare's thesis was to democratize that infrastructure — give the same DDoS protection, CDN, and DNS that a bank uses to a hobbyist's blog, much of it free. The mission, repeated everywhere, is "to help build a better Internet."
That populist, pro-developer DNA explains the design. In a category dominated by navy-blue, suit-and-tie enterprise security branding, Cloudflare chose warm orange — friendly, energetic, human — to signal that powerful infrastructure could be approachable. The orange cloud logomark, built from a warm orange-to-yellow gradient, is both literal (a cloud) and emotional (warmth in a cold category). The generous whitespace and clean Inter typography say "this is easy"; the dense, monospace-heavy dashboard says "this is serious engineering." Both are true at once.
Cloudflare went public on the NYSE in 2019 (ticker NET) and has grown into a "connectivity cloud" — CDN, DNS (1.1.1.1), Zero Trust, Workers edge compute, R2 storage, and AI inference at the edge. The design system scaled with it: a published color system ("Color by Cloudflare Design"), the open-source cf-ui component library, a comprehensive style guide, and a fully-realized dashboard dark mode. Through every expansion the orange has stayed fixed — the one constant that makes a sprawling platform feel like a single, recognizable brand.
What Cloudflare refuses: the cold blue of incumbent security and cloud vendors, the fear-based marketing of the security industry, and gratuitous visual ornament. It occupies a deliberate middle — technically credible yet warm, massive in scale yet approachable in tone.
12. Principles
- Orange is the action.
#F6821F marks where the user should look and click. It is rationed to one or two places per screen. When orange decorates instead of directs, it has been misused.
- Borders before shadows. Structure comes from crisp 1px neutral rules and alignment. Shadows are reserved for genuinely floating layers. A dense dashboard stays legible because surfaces are outlined, not stacked in soft elevation.
- Monospace for truth. Anything an operator must read exactly — IPs, DNS records, tokens, code — is monospace. Proportional fonts are for prose, not infrastructure.
- Whitespace where you sell, density where you work. Marketing breathes; the dashboard packs. Both are intentional, neither apologizes.
- Warm, not cold. Near-black is warm charcoal, the accent is warm orange. Cloudflare deliberately rejects the cold blue of its category — humanity is a design requirement.
- Plain words, precise claims. Copy is direct and benefit-led; technical labels are exact. No jargon for its own sake, no vague enterprise filler.
- Parity in dark. Product UI must work in light and dark with equal polish. Orange holds in both; surfaces shift, the brand doesn't.
- Powerful but approachable. Every screen must feel usable by a solo developer and trustworthy to an enterprise team simultaneously. That tension is the brand.
13. Personas
Personas below are fictional archetypes informed by publicly described Cloudflare user segments, not individual people.
Devin, 29, Austin. Full-stack developer at a Series-B startup. Runs the company's marketing site and a handful of side projects through Cloudflare's free and Pro plans. Lives in the DNS and Workers sections of the dashboard. Wants the proxy toggle and DNS record table to be instant and unambiguous; copies API tokens and IPs constantly and is annoyed when they aren't in a monospace, click-to-copy field. Reads the Cloudflare blog for fun. Picked Cloudflare partly because the free tier let him do real things without a sales call.
Priya, 41, London. Security engineer at a mid-market fintech. Manages WAF rules, Zero Trust access policies, and bot mitigation across dozens of zones. Spends her day in dense data tables and log streams; values information density over whitespace and wants status (Proxied / Blocked / Down) legible at a glance via colored pills. Distrusts marketing fluff — judges the product by the precision of its labels and the speed of its analytics. Dark mode all day.
Marcus, 52, Chicago. VP of Infrastructure evaluating Cloudflare for an enterprise migration. Lands first on the marketing site, where the calm whitespace, confident headlines, and single orange CTA signal a mature, trustworthy vendor. Clicks "Talk to an expert." Cares that the brand reads as serious engineering and approachable enough that his whole team will actually adopt it. The warmth of the orange is, to him, a subtle promise that this won't feel like legacy enterprise software.
14. States
| State | Treatment |
|---|
| Empty (first use) | One line of #36393A body explaining the why ("No DNS records yet.") plus one orange-ghost or secondary action ("Add a record"). No illustration in the dashboard; marketing may use a light spot graphic. |
| Empty (filtered) | Single #717174 caption ("No records match your filter.") with a "Clear filter" text button. |
| Loading (first paint) | Skeleton blocks at #EDEDED (light) / #2A2E33 (dark) matching final layout. Metric values show — until resolved. |
| Loading (refresh) | Inline orange spinner or top progress bar; existing data stays visible, never blanked. |
| Error (inline field) | 1px #BD2528 border, helper text below in #BD2528 12px, one actionable sentence ("Enter a valid IPv4 address."). |
| Error (toast) | #1D1F20 bg, white text, 4px red left-border, 4–5s auto-dismiss, one sentence. |
| Error (page-level) | Centered message in #1D1F20 16px/600 + cause + retry button in orange. Reserved for outage/permission failures. |
| Success (toast) | #1D1F20 bg, white text, 4px green left-border ("Record added."). |
| Status: healthy | Green pill + dot — "Active" / "Proxied" / "Healthy". |
| Status: degraded/paused | Yellow pill — "Pending" / "DNS only" / "Paused". |
| Status: down/blocked | Red pill — "Down" / "Blocked" / "Error". |
| Disabled | Control at 40–50% opacity; orange buttons keep hue but drop opacity; geometry unchanged. |
| Focus | 3px orange focus ring rgba(246,130,31,0.2) on inputs/buttons — visible for keyboard nav. |
| Loading inside button | Label swapped for a small white spinner; button width preserved; press committed, no double-submit. |
15. Motion & Easing
Durations (named, not raw ms):
| Token | Value | Use |
|---|
motion-instant | 0ms | Toggle flips, checkbox state |
motion-fast | 120ms | Hover, focus ring, button press |
motion-standard | 200ms | Dropdowns, tab switches, accordion expand |
motion-emphasis | 300ms | Modal open, sheet, toast enter |
motion-page | 350ms | Route/section transitions |
Easings:
| Token | Curve | Use |
|---|
ease-enter | cubic-bezier(0.0, 0.0, 0.2, 1) | Appearing — modals, toasts, popovers |
ease-exit | cubic-bezier(0.4, 0.0, 1, 1) | Leaving — dismissals, collapses |
ease-standard | cubic-bezier(0.4, 0.0, 0.2, 1) | Two-way — tabs, accordions, hover lift |
ease-out-soft | cubic-bezier(0.16, 1, 0.3, 1) | Emphasized marketing reveals on scroll |
Signature motions.
- Hover lift. Marketing feature cards rise ~2px and deepen shadow (
motion-fast / ease-standard) on hover — a light, responsive cue that the surface is interactive.
- Orange focus ring. On keyboard focus, the 3px
rgba(246,130,31,0.2) ring fades in over motion-fast. Accessibility-first; never suppressed for aesthetics.
- Toast slide-in. Toasts enter from the top-right (or bottom) translating ~16px with
motion-emphasis / ease-enter, exit via motion-fast / ease-exit — leaving is quicker than arriving.
- Status transitions. When a zone flips state (Pending → Active), the pill cross-fades color over
motion-standard; never a hard swap, so operators perceive the change.
- Reduce motion. Under
prefers-reduced-motion: reduce, all tokens collapse to motion-instant; slides become fades; the dashboard stays fully usable.