oh-my-design-cli 1.6.7 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (224) hide show
  1. package/README.md +6 -6
  2. package/data/reference-fingerprints.json +1318 -10
  3. package/package.json +1 -1
  4. package/web/references/11st/DESIGN.md +400 -0
  5. package/web/references/17live/DESIGN.md +43 -0
  6. package/web/references/29cm/DESIGN.md +41 -0
  7. package/web/references/91app/DESIGN.md +31 -0
  8. package/web/references/ably/DESIGN.md +54 -0
  9. package/web/references/airbnb/DESIGN.md +58 -0
  10. package/web/references/airtable/DESIGN.md +39 -0
  11. package/web/references/alipay/DESIGN.md +50 -0
  12. package/web/references/amazingtalker/DESIGN.md +434 -0
  13. package/web/references/appier/DESIGN.md +45 -0
  14. package/web/references/apple/DESIGN.md +47 -0
  15. package/web/references/baemin/DESIGN.md +142 -43
  16. package/web/references/banksalad/DESIGN.md +67 -0
  17. package/web/references/bilibili/DESIGN.md +45 -0
  18. package/web/references/bithumb/DESIGN.md +38 -0
  19. package/web/references/bmw/DESIGN.md +37 -0
  20. package/web/references/brandi/DESIGN.md +414 -0
  21. package/web/references/bunjang/DESIGN.md +47 -0
  22. package/web/references/cakeresume/DESIGN.md +29 -0
  23. package/web/references/cal/DESIGN.md +52 -0
  24. package/web/references/catchtable/DESIGN.md +79 -19
  25. package/web/references/cathay/DESIGN.md +432 -0
  26. package/web/references/channeltalk/DESIGN.md +48 -0
  27. package/web/references/class101/DESIGN.md +51 -0
  28. package/web/references/classting/DESIGN.md +41 -0
  29. package/web/references/classum/DESIGN.md +43 -0
  30. package/web/references/claude/DESIGN.md +157 -70
  31. package/web/references/clay/DESIGN.md +56 -0
  32. package/web/references/clickhouse/DESIGN.md +50 -0
  33. package/web/references/cloudflare/DESIGN.md +637 -0
  34. package/web/references/cohere/DESIGN.md +48 -0
  35. package/web/references/coinbase/DESIGN.md +139 -5
  36. package/web/references/coinone/DESIGN.md +39 -0
  37. package/web/references/composio/DESIGN.md +46 -0
  38. package/web/references/cookpad/DESIGN.md +37 -0
  39. package/web/references/coupang/DESIGN.md +57 -2
  40. package/web/references/cursor/DESIGN.md +44 -0
  41. package/web/references/dabang/DESIGN.md +57 -19
  42. package/web/references/dcard/DESIGN.md +57 -0
  43. package/web/references/dell/DESIGN.md +636 -0
  44. package/web/references/devsisters/DESIGN.md +29 -0
  45. package/web/references/discord/DESIGN.md +604 -0
  46. package/web/references/dji/DESIGN.md +39 -0
  47. package/web/references/drnow/DESIGN.md +52 -0
  48. package/web/references/duolingo/DESIGN.md +563 -0
  49. package/web/references/elevenlabs/DESIGN.md +39 -0
  50. package/web/references/expo/DESIGN.md +39 -0
  51. package/web/references/fastcampus/DESIGN.md +50 -0
  52. package/web/references/ferrari/DESIGN.md +47 -0
  53. package/web/references/figma/DESIGN.md +44 -0
  54. package/web/references/finda/DESIGN.md +413 -0
  55. package/web/references/flex/DESIGN.md +28 -0
  56. package/web/references/flo/DESIGN.md +43 -0
  57. package/web/references/framer/DESIGN.md +38 -0
  58. package/web/references/freee/DESIGN.md +48 -0
  59. package/web/references/fugle/DESIGN.md +41 -1
  60. package/web/references/gangnamunni/DESIGN.md +57 -1
  61. package/web/references/genie/DESIGN.md +415 -0
  62. package/web/references/github/DESIGN.md +727 -0
  63. package/web/references/gmarket/DESIGN.md +51 -0
  64. package/web/references/gogolook/DESIGN.md +25 -1
  65. package/web/references/gogoro/DESIGN.md +38 -0
  66. package/web/references/grip/DESIGN.md +39 -0
  67. package/web/references/hahow/DESIGN.md +26 -0
  68. package/web/references/hashicorp/DESIGN.md +42 -0
  69. package/web/references/hogangnono/DESIGN.md +41 -0
  70. package/web/references/hp/DESIGN.md +563 -0
  71. package/web/references/hyperconnect/DESIGN.md +393 -0
  72. package/web/references/hyundaicard/DESIGN.md +24 -0
  73. package/web/references/ibm/DESIGN.md +44 -0
  74. package/web/references/ichef/DESIGN.md +44 -0
  75. package/web/references/ikala/DESIGN.md +400 -0
  76. package/web/references/inflearn/DESIGN.md +38 -0
  77. package/web/references/intercom/DESIGN.md +38 -0
  78. package/web/references/jandi/DESIGN.md +382 -0
  79. package/web/references/jkopay/DESIGN.md +35 -1
  80. package/web/references/jobkorea/DESIGN.md +39 -0
  81. package/web/references/jumpit/DESIGN.md +37 -0
  82. package/web/references/kakao/DESIGN.md +64 -0
  83. package/web/references/kakaobank/DESIGN.md +55 -1
  84. package/web/references/kakaopay/DESIGN.md +59 -0
  85. package/web/references/kakaot/DESIGN.md +53 -0
  86. package/web/references/karrot/DESIGN.md +49 -0
  87. package/web/references/kbank/DESIGN.md +39 -0
  88. package/web/references/kdan/DESIGN.md +34 -1
  89. package/web/references/kintone/DESIGN.md +586 -0
  90. package/web/references/kkbox/DESIGN.md +22 -0
  91. package/web/references/kkday/DESIGN.md +47 -0
  92. package/web/references/kmong/DESIGN.md +427 -0
  93. package/web/references/krafton/DESIGN.md +37 -0
  94. package/web/references/kraken/DESIGN.md +44 -0
  95. package/web/references/krds/DESIGN.md +63 -0
  96. package/web/references/kream/DESIGN.md +32 -0
  97. package/web/references/kurly/DESIGN.md +38 -1
  98. package/web/references/laftel/DESIGN.md +40 -0
  99. package/web/references/lamborghini/DESIGN.md +54 -0
  100. package/web/references/layerx/DESIGN.md +615 -0
  101. package/web/references/lezhin/DESIGN.md +47 -0
  102. package/web/references/line/DESIGN.md +36 -0
  103. package/web/references/linear.app/DESIGN.md +182 -88
  104. package/web/references/loom/DESIGN.md +396 -0
  105. package/web/references/lovable/DESIGN.md +38 -0
  106. package/web/references/lunit/DESIGN.md +47 -19
  107. package/web/references/mastercard/DESIGN.md +587 -0
  108. package/web/references/meituan/DESIGN.md +42 -0
  109. package/web/references/melon/DESIGN.md +26 -0
  110. package/web/references/mercari/DESIGN.md +41 -0
  111. package/web/references/mercury/DESIGN.md +589 -0
  112. package/web/references/meta/DESIGN.md +615 -0
  113. package/web/references/millie/DESIGN.md +51 -0
  114. package/web/references/minimax/DESIGN.md +53 -0
  115. package/web/references/mintlify/DESIGN.md +45 -0
  116. package/web/references/miro/DESIGN.md +47 -0
  117. package/web/references/mistral.ai/DESIGN.md +37 -0
  118. package/web/references/momoshop/DESIGN.md +43 -0
  119. package/web/references/money-forward/DESIGN.md +42 -0
  120. package/web/references/mongodb/DESIGN.md +44 -0
  121. package/web/references/muji/DESIGN.md +605 -0
  122. package/web/references/musinsa/DESIGN.md +48 -0
  123. package/web/references/mustit/DESIGN.md +47 -1
  124. package/web/references/myrealtrip/DESIGN.md +49 -0
  125. package/web/references/naver/DESIGN.md +50 -1
  126. package/web/references/naverwebtoon/DESIGN.md +48 -0
  127. package/web/references/netflix/DESIGN.md +572 -0
  128. package/web/references/nexon/DESIGN.md +389 -0
  129. package/web/references/nhncloud/DESIGN.md +33 -0
  130. package/web/references/nike/DESIGN.md +588 -0
  131. package/web/references/note/DESIGN.md +28 -0
  132. package/web/references/notion/DESIGN.md +48 -0
  133. package/web/references/nvidia/DESIGN.md +50 -0
  134. package/web/references/ohouse/DESIGN.md +56 -0
  135. package/web/references/oliveyoung/DESIGN.md +47 -1
  136. package/web/references/ollama/DESIGN.md +40 -0
  137. package/web/references/openai/DESIGN.md +641 -0
  138. package/web/references/opencode.ai/DESIGN.md +37 -0
  139. package/web/references/payco/DESIGN.md +40 -0
  140. package/web/references/paypay/DESIGN.md +656 -0
  141. package/web/references/pchome/DESIGN.md +439 -0
  142. package/web/references/perplexity/DESIGN.md +546 -0
  143. package/web/references/piccollage/DESIGN.md +43 -0
  144. package/web/references/pinkoi/DESIGN.md +55 -0
  145. package/web/references/pinterest/DESIGN.md +44 -0
  146. package/web/references/pixiv/DESIGN.md +613 -0
  147. package/web/references/pixnet/DESIGN.md +430 -0
  148. package/web/references/posthog/DESIGN.md +50 -0
  149. package/web/references/publy/DESIGN.md +52 -0
  150. package/web/references/qanda/DESIGN.md +49 -1
  151. package/web/references/ragic/DESIGN.md +444 -0
  152. package/web/references/ramp/DESIGN.md +634 -0
  153. package/web/references/rayark/DESIGN.md +22 -0
  154. package/web/references/raycast/DESIGN.md +45 -0
  155. package/web/references/remember/DESIGN.md +44 -0
  156. package/web/references/renault/DESIGN.md +42 -0
  157. package/web/references/replicate/DESIGN.md +39 -0
  158. package/web/references/resend/DESIGN.md +44 -0
  159. package/web/references/retool/DESIGN.md +645 -0
  160. package/web/references/revolut/DESIGN.md +46 -0
  161. package/web/references/richart/DESIGN.md +465 -0
  162. package/web/references/ridi/DESIGN.md +47 -0
  163. package/web/references/riiid/DESIGN.md +32 -0
  164. package/web/references/robinhood/DESIGN.md +604 -0
  165. package/web/references/runwayml/DESIGN.md +45 -0
  166. package/web/references/sanity/DESIGN.md +50 -0
  167. package/web/references/sansan/DESIGN.md +631 -0
  168. package/web/references/sendbird/DESIGN.md +46 -0
  169. package/web/references/sentry/DESIGN.md +48 -0
  170. package/web/references/shinhancard/DESIGN.md +421 -0
  171. package/web/references/shopline/DESIGN.md +431 -0
  172. package/web/references/slack/DESIGN.md +635 -0
  173. package/web/references/smarthr/DESIGN.md +48 -0
  174. package/web/references/smartnews/DESIGN.md +29 -0
  175. package/web/references/socar/DESIGN.md +35 -0
  176. package/web/references/soomgo/DESIGN.md +326 -0
  177. package/web/references/spacex/DESIGN.md +27 -0
  178. package/web/references/spoon/DESIGN.md +46 -0
  179. package/web/references/spotify/DESIGN.md +49 -0
  180. package/web/references/starbucks/DESIGN.md +597 -0
  181. package/web/references/stripe/DESIGN.md +46 -0
  182. package/web/references/studio/DESIGN.md +602 -0
  183. package/web/references/supabase/DESIGN.md +41 -0
  184. package/web/references/superhuman/DESIGN.md +39 -0
  185. package/web/references/surveycake/DESIGN.md +442 -0
  186. package/web/references/tada/DESIGN.md +51 -0
  187. package/web/references/tesla/DESIGN.md +36 -0
  188. package/web/references/theverge/DESIGN.md +500 -0
  189. package/web/references/together.ai/DESIGN.md +33 -0
  190. package/web/references/toss/DESIGN.md +43 -0
  191. package/web/references/toss-securities/DESIGN.md +54 -19
  192. package/web/references/tossbank/DESIGN.md +57 -0
  193. package/web/references/trenbe/DESIGN.md +41 -0
  194. package/web/references/triple/DESIGN.md +47 -0
  195. package/web/references/tumblbug/DESIGN.md +48 -0
  196. package/web/references/tving/DESIGN.md +40 -0
  197. package/web/references/uber/DESIGN.md +36 -0
  198. package/web/references/ubie/DESIGN.md +615 -0
  199. package/web/references/uniqlo/DESIGN.md +575 -0
  200. package/web/references/upbit/DESIGN.md +42 -0
  201. package/web/references/upstage/DESIGN.md +38 -0
  202. package/web/references/velog/DESIGN.md +28 -0
  203. package/web/references/vercel/DESIGN.md +44 -0
  204. package/web/references/voicetube/DESIGN.md +39 -0
  205. package/web/references/voltagent/DESIGN.md +44 -0
  206. package/web/references/wadiz/DESIGN.md +71 -19
  207. package/web/references/wanted/DESIGN.md +46 -0
  208. package/web/references/warp/DESIGN.md +37 -0
  209. package/web/references/watcha/DESIGN.md +40 -0
  210. package/web/references/wavve/DESIGN.md +43 -1
  211. package/web/references/wconcept/DESIGN.md +45 -0
  212. package/web/references/webflow/DESIGN.md +49 -0
  213. package/web/references/wired/DESIGN.md +572 -0
  214. package/web/references/wise/DESIGN.md +41 -0
  215. package/web/references/x.ai/DESIGN.md +31 -0
  216. package/web/references/xiaohongshu/DESIGN.md +39 -0
  217. package/web/references/yanolja/DESIGN.md +45 -0
  218. package/web/references/yeogiotte/DESIGN.md +42 -1
  219. package/web/references/yogiyo/DESIGN.md +50 -0
  220. package/web/references/yourator/DESIGN.md +453 -0
  221. package/web/references/zapier/DESIGN.md +41 -0
  222. package/web/references/zigbang/DESIGN.md +33 -0
  223. package/web/references/zigzag/DESIGN.md +62 -0
  224. package/web/references/zozotown/DESIGN.md +578 -0
@@ -0,0 +1,637 @@
1
+ ---
2
+ id: cloudflare
3
+ name: Cloudflare
4
+ country: US
5
+ category: backend-devops
6
+ homepage: "https://www.cloudflare.com"
7
+ primary_color: "#F6821F"
8
+ logo:
9
+ type: simpleicons
10
+ slug: "cloudflare"
11
+ verified: "2026-06-06"
12
+ added: "2026-06-06"
13
+ omd: "0.1"
14
+ tokens:
15
+ source: design-system
16
+ extracted: "2026-06-08"
17
+ components_harvested: true
18
+ note: "Cloudflare Orange #F6821F is the singular brand + primary-action color; rationed to one or two places per screen. Warm near-black text, never pure #000."
19
+ colors:
20
+ primary: "#F6821F"
21
+ primary-hover: "#E2700B"
22
+ primary-pressed: "#D9700F"
23
+ brand: "#F6821F"
24
+ brand-gradient-end: "#FAAD3F"
25
+ canvas: "#FFFFFF"
26
+ surface: "#FFFFFF"
27
+ surface-alt: "#F7F7F7"
28
+ foreground: "#1D1F20"
29
+ body: "#36393A"
30
+ muted: "#717174"
31
+ placeholder: "#999999"
32
+ hairline: "#EDEDED"
33
+ border-strong: "#D9D9D9"
34
+ on-primary: "#FFFFFF"
35
+ orange-tint: "#FDF3E7"
36
+ success: "#2FB344"
37
+ error: "#BD2528"
38
+ warning: "#F6C549"
39
+ info: "#2C7CB0"
40
+ dark-bg: "#15171A"
41
+ dark-surface: "#262A2E"
42
+ dark-border: "#3A3F44"
43
+ dark-text: "#E4E6E7"
44
+ typography:
45
+ family: { sans: "Inter", mono: "JetBrains Mono" }
46
+ display-hero: { size: 56, weight: 700, lineHeight: 1.1, tracking: -0.02, use: "Marketing hero headline" }
47
+ display: { size: 40, weight: 700, lineHeight: 1.15, tracking: -0.02, use: "Major section headers" }
48
+ heading-1: { size: 32, weight: 700, lineHeight: 1.2, tracking: -0.01, use: "Page titles" }
49
+ heading-2: { size: 24, weight: 600, lineHeight: 1.3, tracking: -0.01, use: "Section / card group titles" }
50
+ heading-3: { size: 20, weight: 600, lineHeight: 1.4, use: "Card headings, panel titles" }
51
+ subtitle: { size: 18, weight: 600, lineHeight: 1.45, use: "Lead-in / dashboard section labels" }
52
+ body-large: { size: 16, weight: 400, lineHeight: 1.6, use: "Marketing paragraphs" }
53
+ body: { size: 14, weight: 400, lineHeight: 1.55, use: "Dashboard standard text" }
54
+ body-small: { size: 13, weight: 400, lineHeight: 1.5, use: "Table cells, secondary info" }
55
+ caption: { size: 12, weight: 400, lineHeight: 1.5, use: "Metadata, timestamps, helper text" }
56
+ label-eyebrow: { size: 12, weight: 600, lineHeight: 1.4, tracking: 0.06, use: "Section eyebrows, table headers, uppercase" }
57
+ code-mono: { size: 13, weight: 400, lineHeight: 1.6, use: "DNS records, IPs, API tokens, code" }
58
+ spacing: { xs: 4, sm: 8, md: 16, base: 16, lg: 24, xl: 32, xxl: 48, section: 64 }
59
+ rounded: { sm: 4, md: 6, lg: 8, xl: 12, full: 9999 }
60
+ shadow:
61
+ subtle: "rgba(0,0,0,0.06) 0px 1px 3px 0px"
62
+ raised: "rgba(0,0,0,0.08) 0px 4px 16px 0px"
63
+ floating: "rgba(0,0,0,0.12) 0px 8px 24px 0px"
64
+ modal: "rgba(0,0,0,0.18) 0px 12px 32px 0px"
65
+ components:
66
+ button-primary: { type: button, bg: "#f6821f", fg: "#ffffff", radius: "8px", height: "36px", padding: "0 12px", font: "14px / 600", hover: "#e2700b", active: "#d9700f", focus: "2px brand ring", disabled: "brand 50% opacity", use: "Primary action — Get started, Add site, Save, Deploy" }
67
+ button-secondary: { type: button, bg: "#ffffff", fg: "#36393a", border: "1px solid #d9d9d9", radius: "8px", hover: "bg #fafafa · border #a1a1a1", use: "Companion to a primary — Cancel, Back" }
68
+ button-ghost: { type: button, bg: "transparent", fg: "#f6821f", radius: "8px", padding: "0 12px", hover: "bg #fdf3e7", use: "Inline low-emphasis action, Learn more, text-link button" }
69
+ button-danger: { type: button, bg: "#bd2528", fg: "#ffffff", radius: "8px", hover: "#a11f22", use: "Delete zone, remove record, purge — confirmation contexts only" }
70
+ button-sm: { type: button, height: "26px", radius: "6px", padding: "0 8px", font: "12px / 600", use: "Toolbar and table-row inline actions where vertical space is tight" }
71
+ icon-button: { type: button, height: "36px", radius: "8px", padding: "0", use: "Close, kebab menu, copy-to-clipboard affordance" }
72
+ input: { type: input, bg: "#ffffff", fg: "#1d1f20", border: "1px solid #d9d9d9", radius: "8px", height: "40px", padding: "0 16px", font: "14px / 400", focus: "1.5px brand ring · 0 0 0 3px rgba(246,130,31,0.2)", use: "Standard form input, search, config values" }
73
+ input-mono: { type: input, bg: "#ffffff", fg: "#1d1f20", border: "1px solid #d9d9d9", radius: "8px", font: "13px / 400 JetBrains Mono", use: "DNS record values, IP entry, token paste fields" }
74
+ select: { type: input, bg: "#ffffff", fg: "#1d1f20", border: "1px solid #d9d9d9", radius: "8px", height: "40px", use: "Plan picker, record-type selector, region dropdown — #717174 chevron" }
75
+ switch: { type: toggle, active: "#f6821f", disabled: "#d9d9d9", radius: "5px", use: "Proxy on/off, feature flags, security toggles — white thumb with edge+drop shadow" }
76
+ checkbox: { type: toggle, bg: "#f6821f", border: "1px solid #d9d9d9", radius: "6px", use: "Multi-select rules, plan options, consent — brand fill + white glyph when checked" }
77
+ card: { type: card, bg: "#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" }
78
+ stat-card: { type: card, bg: "#ffffff", border: "1px solid #ededed", radius: "8px", padding: "20px", font: "32px / 700 #1d1f20 number · 12px / 600 uppercase #717174 label", use: "Analytics summary tiles (requests, bandwidth, threats blocked)" }
79
+ surface: { type: card, bg: "#ffffff", border: "1px solid #ededed", use: "kumo elevation roles — canvas #ffffff, recessed #f7f7f7, line/hairline #ededed" }
80
+ badge: { type: badge, radius: "9999px", padding: "2px 8px", font: "12px / 500", use: "NEW, Beta, version, plan, short metadata — neutral/success/error/warning/info/orange + dashed-brand + 7px status dot" }
81
+ status-pill: { type: badge, bg: "#e8f5d8", fg: "#3d6b14", radius: "9999px", padding: "2px 10px", font: "12px / 600", states: "green active #e8f5d8/#3d6b14 · red down #fbe2e2/#bd2528 · yellow pending #fcf3d6/#8a6d1b · grey #ededed/#4d4d4d · orange #fdf3e7/#c2670f", use: "Active, Proxied, Down, Pending status with colored dot" }
82
+ tabs: { type: tab, active: "text #1d1f20 + 2px bottom border #f6821f", border: "1px solid #ededed bottom rule", font: "14px / 600", disabled: "#717174 inactive label", use: "Dashboard section switching (Overview / Analytics / DNS / SSL)" }
83
+ table: { type: card, bg: "#ffffff", border: "1px solid #ededed", font: "13px / 400 #36393a body", padding: "12px 16px", hover: "#fafafa row", use: "DNS records, firewall rules, analytics logs — header bg #fafafa 12px/600 uppercase #717174" }
84
+ dialog: { type: dialog, bg: "#ffffff", fg: "#1d1f20", border: "1px solid #ededed", radius: "12px", padding: "32px", shadow: "0 12px 32px rgba(0,0,0,0.18)", use: "Confirmations, destructive double-checks, add-record flows — scrim rgba(29,31,32,0.5), scale-90 enter over 150ms" }
85
+ toast: { type: toast, bg: "#1d1f20", fg: "#ffffff", radius: "12px", padding: "16px", shadow: "0 8px 24px rgba(0,0,0,0.12)", states: "success #2fb344 · error #bd2528 · warning #f6c549 · info #2c7cb0", use: "Auto-dismissing confirmation, fixed bottom-right 340px, 4-5s dismiss" }
86
+ tooltip: { type: card, bg: "#ffffff", fg: "#1d1f20", border: "1px solid #ededed", radius: "6px", padding: "6px 10px", font: "13px / 400", shadow: "shadow-lg", use: "Icon labels, truncated-value reveal, glossary terms" }
87
+ code-block: { type: card, bg: "#f5f5f5", fg: "#1d1f20", border: "1px solid #ededed", radius: "6px", padding: "12px 16px", font: "13px / 400 JetBrains Mono", use: "API examples, Worker snippets, curl commands, DNS values" }
88
+ ---
89
+
90
+ # Design System Inspiration of Cloudflare
91
+
92
+ ## 1. Visual Theme & Atmosphere
93
+
94
+ 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.
95
+
96
+ 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.
97
+
98
+ 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.
99
+
100
+ **Key Characteristics:**
101
+ - Cloudflare Orange (`#F6821F`) as the singular brand and primary-action color — warm, energetic, instantly recognizable
102
+ - Inter typeface with a system-ui fallback stack — screen-optimized neo-grotesque
103
+ - Bright white marketing canvas; dense, table-heavy product dashboard with first-class dark mode
104
+ - Near-black charcoal text (`#36393A` / `#1D1F20`) — warm-neutral, never pure `#000`
105
+ - Orange used sparingly and intentionally — CTAs, links, active states, the logomark — not as decoration
106
+ - Perceptual color scales (orange, blue, grey, plus semantic red/green/yellow) for tokens
107
+ - Engineering-grade restraint: clean rules, subtle shadows, generous whitespace, no gratuitous gradients
108
+
109
+ ## 2. Color Palette & Roles
110
+
111
+ ### Primary
112
+ - **Cloudflare Orange** (`#F6821F`): The brand. Primary CTAs, the cloud logomark, links, active/selected states, focus accents. The one color that carries emotional weight.
113
+ - **Orange Hover** (`#E2700B` / approx `#D9700F`): Hover/pressed state for orange CTAs — a darker, denser orange.
114
+ - **Orange Tint** (`#FBE6CC` / `#FDF3E7`): Soft orange-tinted backgrounds for info banners, highlighted rows, and selected list items.
115
+ - **Brand Orange Alt** (`#F48120`): Logo-mark gradient orange (the icon is built from a warm orange gradient `#F6821F → #FAAD3F`). Marketing/logo contexts only.
116
+ - **Gradient Yellow-Orange** (`#FAAD3F`): The lighter stop in the logomark gradient. Decorative brand moments, never UI text.
117
+
118
+ ### Surface & Background
119
+ - **Pure White** (`#FFFFFF`): Marketing page background, card surfaces, dashboard panels (light mode).
120
+ - **Off-White** (`#F7F7F7` / `#F5F5F5`): Secondary background, page wash behind cards, zebra-stripe table rows.
121
+ - **Light Grey Surface** (`#EDEDED` / `#F0F0F0`): Input fills, disabled surfaces, subtle separators.
122
+
123
+ ### Text
124
+ - **Charcoal (Headings)** (`#1D1F20`): Strongest text — display headlines and key labels. Warm near-black.
125
+ - **Body Charcoal** (`#36393A`): Standard body copy and paragraph text.
126
+ - **Muted Grey** (`#666666` / `#717174`): Secondary labels, captions, metadata.
127
+ - **Placeholder Grey** (`#999999` / `#A1A1A1`): Input placeholders, disabled text.
128
+
129
+ ### Semantic
130
+ - **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.)
131
+ - **Error Red** (`#BD2528` / `#E1351D`): Errors, destructive actions, "Down"/"Blocked" status, attack indicators.
132
+ - **Warning Yellow** (`#F6C549` / `#FFC107`): Caution, "DNS only" / "Paused" states, attention banners.
133
+ - **Info Blue** (`#2C7CB0` / `#0073AA`): Informational accents, secondary links, neutral-technical highlights, chart series.
134
+
135
+ ### Neutral / Grey Scale
136
+ - **Grey 50** (`#FAFAFA`): Lightest wash.
137
+ - **Grey 100** (`#F5F5F5`): Card fill, page background.
138
+ - **Grey 200** (`#EDEDED`): Default borders, dividers.
139
+ - **Grey 300** (`#D9D9D9`): Strong borders, input outlines.
140
+ - **Grey 400** (`#A1A1A1`): Placeholder, disabled icon.
141
+ - **Grey 500** (`#717174`): Caption / secondary text.
142
+ - **Grey 600** (`#4D4D4D`): Emphasized secondary text.
143
+ - **Grey 700** (`#36393A`): Body text.
144
+ - **Grey 900** (`#1D1F20`): Headings, strongest text.
145
+
146
+ ### Dark Mode (Dashboard)
147
+ - **Dark Background** (`#1D1F20` / `#15171A`): App background.
148
+ - **Dark Surface** (`#262A2E` / `#23272B`): Card/panel surface.
149
+ - **Dark Border** (`#3A3F44`): Dividers and outlines.
150
+ - **Dark Text** (`#E4E6E7`): Primary text on dark; muted `#9BA1A6`.
151
+ - Orange stays `#F6821F` in dark mode — it is bright enough to hold against dark surfaces without adjustment.
152
+
153
+ ## 3. Typography Rules
154
+
155
+ ### Font Family
156
+ - **Primary**: `"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif`
157
+ - **Display/Marketing**: Inter (tight tracking on large sizes) — some hero moments use Inter Display optical sizing.
158
+ - **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.
159
+
160
+ ### Hierarchy
161
+
162
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
163
+ |------|------|------|--------|-------------|----------------|-------|
164
+ | Display Hero | Inter | 56px | 700 | 1.1 (62px) | -0.02em | Marketing hero headline |
165
+ | Display | Inter | 40px | 700 | 1.15 (46px) | -0.02em | Major section headers |
166
+ | Heading 1 | Inter | 32px | 700 | 1.2 (38px) | -0.01em | Page titles |
167
+ | Heading 2 | Inter | 24px | 600 | 1.3 (31px) | -0.01em | Section / card group titles |
168
+ | Heading 3 | Inter | 20px | 600 | 1.4 (28px) | normal | Card headings, panel titles |
169
+ | Subtitle | Inter | 18px | 600 | 1.45 (26px) | normal | Lead-in / dashboard section labels |
170
+ | Body Large | Inter | 16px | 400 | 1.6 (26px) | normal | Marketing paragraphs |
171
+ | Body | Inter | 14px | 400 | 1.55 (22px) | normal | Dashboard standard text |
172
+ | Body Small | Inter | 13px | 400 | 1.5 (20px) | normal | Table cells, secondary info |
173
+ | Caption | Inter | 12px | 400 | 1.5 (18px) | normal | Metadata, timestamps, helper text |
174
+ | Label / Eyebrow | Inter | 12px | 600 | 1.4 (17px) | 0.06em UPPER | Section eyebrows, table headers |
175
+ | Code / Mono | JetBrains Mono | 13px | 400 | 1.6 (21px) | normal | DNS records, IPs, API tokens, code |
176
+
177
+ ### Principles
178
+ - **Inter, three weights.** 400 (body), 600 (emphasis/sub-headings), 700 (headlines). Avoid 500 in UI text; reserve 800/900 for rare marketing display.
179
+ - **Negative tracking on large type.** Headlines ≥24px tighten to `-0.01em` to `-0.02em` for a confident, modern feel; body stays at normal tracking.
180
+ - **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.
181
+ - **Uppercase eyebrows.** Small 12px/600 uppercase labels with `0.06em` tracking mark sections and table headers — a quiet structural device, not decoration.
182
+
183
+ ## 4. Component Patterns
184
+
185
+ 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.
186
+
187
+ ### Actions
188
+
189
+ **Primary Button**
190
+ - Fill: `#F6821F` · Text: `#FFFFFF` · Border: none
191
+ - Radius: 8px (kumo `rounded-lg`)
192
+ - Sizes: medium `h-9` (36px, 12px horizontal padding), large `h-10` (40px, 16px horizontal padding)
193
+ - Font: 14px / 600 / Inter (kumo `text-base` 16px on large)
194
+ - Hover: `#E2700B` · Pressed: `#D9700F` · Disabled: brand at 50% opacity
195
+ - Focus: 2px brand ring (`focus-visible:ring-2 focus-visible:ring-kumo-brand`)
196
+ - Use: Primary action — "Get started", "Add site", "Save", "Deploy"
197
+
198
+ **Secondary Button (outline)**
199
+ - Fill: `#FFFFFF` · Text: `#36393A`
200
+ - Ring: 1px `#D9D9D9` hairline · Radius: 8px
201
+ - Hover: background `#FAFAFA`, ring `#A1A1A1`
202
+ - Use: Companion to a primary ("Cancel", "Back")
203
+
204
+ **Ghost Button**
205
+ - Fill: transparent · Text: `#F6821F` · Radius: 8px
206
+ - Padding: 0 12px · Hover: background `#FDF3E7` (kumo `bg-kumo-tint`)
207
+ - Use: Inline low-emphasis action, "Learn more", text-link button
208
+
209
+ **Destructive Button**
210
+ - Fill: `#BD2528` · Text: `#FFFFFF` · Radius: 8px
211
+ - Hover: `#A11F22` (kumo: danger at 70% opacity)
212
+ - Secondary destructive variant: white fill, `#BD2528` text, hairline ring
213
+ - Use: Delete zone, remove record, purge — confirmation contexts only
214
+
215
+ **Compact / Small Button**
216
+ - Size: `h-6.5` (26px) · Radius: 6px (`rounded-md`) · Padding: 0 8px · Font: 12px
217
+ - Use: Toolbar and table-row inline actions where vertical space is tight
218
+
219
+ **Icon Button**
220
+ - Square `h-9`/`h-10`, `p-0`, centered glyph; `rounded-full` or 8px radius
221
+ - Use: Close, kebab menu, copy-to-clipboard affordance
222
+
223
+ **Dark CTA (Marketing)**
224
+ - Fill: `#1D1F20` · Text: `#FFFFFF` · Radius: 8px · Padding: 0 24px
225
+ - Font: 16px / 600 / Inter · Height: 48px
226
+ - Use: Marketing-page secondary CTA where orange is already spent on the primary
227
+
228
+ ### Navigation
229
+
230
+ **Underline Tabs (default)**
231
+ - Container border-bottom: 1px solid `#EDEDED`
232
+ - Inactive: text `#717174`, 14px / 600 · Hover: text `#36393A`
233
+ - Active: text `#1D1F20`, 2px bottom border `#F6821F`
234
+ - Use: Dashboard section switching (Overview / Analytics / DNS / SSL)
235
+
236
+ **Sidebar / Left Nav**
237
+ - Persistent ~240px rail, white surface, 1px `#EDEDED` right hairline
238
+ - Item: 14px / 400, `#36393A`; active item orange-tinted `#FDF3E7` fill + `#F6821F` text/indicator
239
+ - Collapses to an icon rail, then a drawer on mobile (kumo `sidebar`)
240
+
241
+ **Breadcrumbs**
242
+ - 13px / 400 `#717174`, `#36393A` on current crumb, `/` or chevron separators in `#A1A1A1`
243
+ - Use: Zone → section → record deep paths
244
+
245
+ **Pagination**
246
+ - Numbered controls as compact buttons; current page brand-tinted; prev/next chevrons
247
+ - Use: Long DNS/log/audit tables (kumo `pagination`)
248
+
249
+ ### Forms
250
+
251
+ **Text Field**
252
+ - Fill: `#FFFFFF` · Text: `#1D1F20` · Placeholder: `#999999`
253
+ - Ring: 1px `#D9D9D9` (`ring-kumo-line`) · Radius: 8px
254
+ - Size: `h-10` (40px), 16px horizontal padding · Font: 14px / 400 / Inter
255
+ - 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)`
256
+ - Use: Standard form input, search, config values
257
+
258
+ **Mono Input (technical)**
259
+ - Fill: `#FFFFFF` · Text: `#1D1F20` · Ring: 1px `#D9D9D9` · Radius: 8px
260
+ - Font: 13px / 400 / JetBrains Mono
261
+ - Use: DNS record values, IP entry, token paste fields
262
+
263
+ **Input Error State**
264
+ - Ring: 1.5px `#BD2528` (`ring-kumo-danger`)
265
+ - Focus ring: `0 0 0 3px rgba(189,37,40,0.18)`
266
+ - Helper text below: `#BD2528`, 12px / 400 — one actionable sentence
267
+ - Use: Validation failure
268
+
269
+ **Select / Dropdown**
270
+ - Fill: `#FFFFFF` · Ring: 1px `#D9D9D9` · Radius: 8px · Size: `h-10`
271
+ - Chevron: `#717174`
272
+ - Use: Plan picker, record-type selector, region dropdown
273
+
274
+ **Switch / Toggle**
275
+ - DS sizes: track `h-4`/`h-4.5`/`h-5` (16/18/20px)
276
+ - Shape: `rounded-[5px]`, squircle-rounded to 10px where supported
277
+ - On: `#F6821F` (kumo library on-state = blue `#2C7CB0`) · Off: `#D9D9D9`
278
+ - Thumb: `#FFFFFF` circle with edge+drop shadow (`shadow-[0 0 1px .5px edge, 0 1px 2px drop]`)
279
+ - Use: Proxy on/off, feature flags, security toggles
280
+
281
+ **Checkbox / Radio**
282
+ - Square (checkbox) / circle (radio), ~6px / pill radius
283
+ - Checked: brand fill + white glyph · Unchecked: 1px `#D9D9D9` hairline ring
284
+ - Use: Multi-select rules, plan options, consent
285
+
286
+ ### Data display
287
+
288
+ **Standard Panel**
289
+ - Fill: `#FFFFFF` · Border: 1px solid `#EDEDED` · Radius: 8px · Padding: 24px
290
+ - Shadow: `0 1px 3px rgba(0,0,0,0.06)`
291
+ - Use: Dashboard config panels, analytics modules — the workhorse surface
292
+
293
+ **Marketing Feature Card**
294
+ - Fill: `#FFFFFF` · Border: none · Radius: 12px · Padding: 32px
295
+ - Shadow: `0 4px 16px rgba(0,0,0,0.08)`
296
+ - Use: Product/feature cards on the marketing site
297
+
298
+ **Stat / Metric Card**
299
+ - Fill: `#FFFFFF` · Border: 1px solid `#EDEDED` · Radius: 8px · Padding: 20px
300
+ - Big number: 32px / 700 / Inter, `#1D1F20`
301
+ - Label: 12px / 600 uppercase, `#717174`
302
+ - Use: Analytics summary tiles (requests, bandwidth, threats blocked)
303
+
304
+ **Data Table**
305
+ - Header row: background `#FAFAFA`, text 12px / 600 uppercase `#717174`, `0.04em` tracking
306
+ - Body cell: 13px / 400 `#36393A`, padding 12px 16px
307
+ - Row border: 1px solid `#EDEDED` · Hover row: background `#FAFAFA`
308
+ - Zebra (optional): alternate `#FFFFFF` / `#FAFAFA`
309
+ - Use: DNS records, firewall rules, analytics logs — the heart of the product
310
+
311
+ **Code Block**
312
+ - Background: `#F5F5F5` (light) / `#15171A` (dark) · Text: `#1D1F20` / `#E4E6E7`
313
+ - Border: 1px solid `#EDEDED` (light) · Radius: 6px · Padding: 12px 16px
314
+ - Font: 13px / 400 / JetBrains Mono · with copy-to-clipboard affordance
315
+ - Use: API examples, Worker snippets, curl commands, DNS values
316
+
317
+ **Meter / Progress**
318
+ - Track: `#EDEDED` rounded-full; fill brand `#F6821F` (or semantic for usage warnings)
319
+ - Use: Plan usage, bandwidth consumption, upload progress (kumo `meter`)
320
+
321
+ ### Overlays
322
+
323
+ **Dialog / Modal**
324
+ - Fill: `#FFFFFF` · Text: `#1D1F20` · Ring: 1px line · Radius: 12px (`rounded-xl`) · Padding: 32px (`p-8`)
325
+ - Shadow: `0 12px 32px rgba(0,0,0,0.18)`
326
+ - Scrim: `rgba(29,31,32,0.5)` (kumo recessed at ~80% opacity)
327
+ - Enter: scale from 90% + fade over 150ms
328
+ - Use: Confirmations, destructive double-checks, add-record flows
329
+
330
+ **Popover / Dropdown Menu**
331
+ - Fill: `#FFFFFF` · Ring: 1px `#EDEDED` · Radius: 8px · Shadow: floating `0 8px 24px rgba(0,0,0,0.12)`
332
+ - Item hover: `#FAFAFA` fill
333
+ - Use: Action menus, command palette, account switcher (kumo `popover`, `dropdown`, `command-palette`)
334
+
335
+ **Tooltip**
336
+ - Fill: `#FFFFFF` · Text: `#1D1F20`, 13px · Radius: 6px (`rounded-md`) · Padding: 6px 10px
337
+ - Shadow: `shadow-lg`, 1px outline
338
+ - Use: Icon labels, truncated-value reveal, glossary terms
339
+
340
+ ### Feedback & Status
341
+
342
+ **Toast**
343
+ - Fill: `#1D1F20` (live marketing) / `#FFFFFF` (kumo) · Text: `#FFFFFF` / `#1D1F20`
344
+ - Radius: 12px (`rounded-xl`) · Padding: 16px · Shadow: `shadow-lg`
345
+ - Accent: 4px brand left-border (marketing) or 0.3px semantic ring — success green `#2FB344`, error red `#BD2528`, warning yellow `#F6C549`, info blue `#2C7CB0`
346
+ - Position: fixed bottom-right, 340px wide; 4–5s auto-dismiss
347
+ - Use: Auto-dismissing confirmation ("Record added", "Settings saved")
348
+
349
+ **Banner / Alert**
350
+ - Full-width inline strip; tinted background by severity (info `#FDF3E7`-style tint, warning, danger, success)
351
+ - 1px hairline, 14px text, optional icon + dismiss
352
+ - Use: Account-level notices, plan upgrade prompts, incident banners (kumo `banner`)
353
+
354
+ **Badge**
355
+ - Shape: `rounded-full` · Padding: 2px 8px · Font: 12px / 500
356
+ - Variants: neutral, success, error, warning, info, orange, plus dashed-brand outline
357
+ - Optional 7px status dot (`size-1.75 rounded-full`)
358
+ - Use: "NEW", "Beta", version, plan, short metadata
359
+
360
+ **Status Pill — Active / Proxied (Green)**
361
+ - Background: `#E8F5D8` · Dot: `#2FB344` · Text: `#3D6B14`
362
+ - Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
363
+ - Use: "Active", "Proxied", healthy
364
+
365
+ **Status Pill — Error / Down (Red)**
366
+ - Background: `#FBE2E2` · Text: `#BD2528`
367
+ - Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
368
+ - Use: "Down", "Blocked", "Error"
369
+
370
+ **Status Pill — Pending / Paused (Yellow)**
371
+ - Background: `#FCF3D6` · Text: `#8A6D1B`
372
+ - Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
373
+ - Use: "Pending", "DNS only", "Paused"
374
+
375
+ **Status Pill — Neutral (Grey)**
376
+ - Background: `#EDEDED` · Text: `#4D4D4D`
377
+ - Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
378
+ - Use: "Inactive", neutral metadata
379
+
380
+ **Status Pill — Brand (Orange)**
381
+ - Background: `#FDF3E7` · Text: `#C2670F`
382
+ - Radius: 9999px · Padding: 2px 10px · Font: 12px / 600 / Inter
383
+ - Use: "NEW", "Beta", plan emphasis
384
+
385
+ **Loader / Spinner**
386
+ - Brand `#F6821F` ring spinner (inline) or top progress bar; existing data stays visible on refresh
387
+ - Use: In-button loading (label swaps for white spinner, width preserved), table refresh (kumo `loader`)
388
+
389
+ **Empty State**
390
+ - One line of `#36393A` body explaining the *why* + one orange-ghost or secondary action; no dashboard illustration
391
+ - Use: "No DNS records yet. Add your first record." (kumo `empty`)
392
+
393
+ ---
394
+
395
+
396
+ **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.
397
+
398
+ ## 5. Layout Principles
399
+
400
+ ### Spacing System
401
+ - Base unit: 4px; primary rhythm on 8px.
402
+ - Common values: 4px, 8px, 12px, 16px, 24px, 32px, 48px, 64px, 96px.
403
+ - Marketing sections: generous 64–96px vertical rhythm.
404
+ - Dashboard panels: tighter 16–24px internal padding for density.
405
+
406
+ ### Grid & Container
407
+ - Marketing max-width: ~1200px, centered, 24px gutters.
408
+ - Dashboard: persistent left nav (~240px) + fluid content area; tables go full-width within content.
409
+ - 12-column responsive grid on marketing; flexible flex/stack layout in product.
410
+
411
+ ### Whitespace Philosophy
412
+ - **Whitespace earns trust.** Marketing pages breathe — one idea per band, large headline, supporting paragraph, single orange CTA.
413
+ - **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.
414
+ - **Orange is rationed.** A screen typically shows orange in exactly one or two places. Scarcity is what makes it read as "the action."
415
+
416
+ ### Border Radius Scale
417
+ - Tight (4px): pills' inner chips, small inline tags
418
+ - Standard (6px): buttons, inputs, selects, code blocks
419
+ - Comfortable (8px): cards, panels, toasts
420
+ - Large (10–12px): modals, marketing feature cards
421
+ - Pill (9999px): status badges, toggles, avatars
422
+
423
+ ## 6. Depth & Elevation
424
+
425
+ | Level | Treatment | Use |
426
+ |-------|-----------|-----|
427
+ | Flat (0) | No shadow, 1px `#EDEDED` border | Inline elements, table rows, bordered panels |
428
+ | Subtle (1) | `0 1px 3px rgba(0,0,0,0.06)` | Standard dashboard cards |
429
+ | Raised (2) | `0 4px 16px rgba(0,0,0,0.08)` | Marketing feature cards, hover lift |
430
+ | Floating (3) | `0 8px 24px rgba(0,0,0,0.12)` | Dropdowns, popovers, tooltips |
431
+ | Modal (4) | `0 12px 32px rgba(0,0,0,0.18)` | Dialogs, command palette |
432
+
433
+ **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.
434
+
435
+ ### Dark Mode Elevation
436
+ - In dark mode, elevation is conveyed by **surface lightness**, not shadow: background `#15171A` → card `#262A2E` → popover `#2E3338`. Borders shift to `#3A3F44`.
437
+
438
+ ## 7. Do's and Don'ts
439
+
440
+ ### Do
441
+ - Use Cloudflare Orange (`#F6821F`) for the primary CTA and key interactive accents — and almost nowhere else.
442
+ - Set technical strings (IPs, DNS records, tokens, code) in JetBrains Mono / monospace.
443
+ - Use status pills with green/red/yellow + a colored dot for health and proxy state.
444
+ - Prefer 1px `#EDEDED` borders to define panels; keep shadows subtle and neutral.
445
+ - Use warm near-black (`#1D1F20`) for headings, never pure `#000`.
446
+ - Set headlines in Inter 700 with slightly negative letter-spacing.
447
+ - Ship parity in dark mode for any product UI, keeping orange unchanged.
448
+
449
+ ### Don't
450
+ - Don't flood screens with orange — it loses its meaning the moment it decorates instead of directing.
451
+ - Don't use blue as a primary brand color; blue is informational/secondary only (Cloudflare is deliberately not blue).
452
+ - Don't put API keys, IPs, or DNS values in a proportional font.
453
+ - Don't use heavy or colored drop shadows — borders and subtle neutral shadows only.
454
+ - Don't use radii above 12px except pills and avatars.
455
+ - Don't set body text in 700 — reserve bold for headings and emphasis.
456
+ - Don't mix the logomark gradient orange (`#FAAD3F`) into UI text or buttons.
457
+
458
+ ## 8. Responsive Behavior
459
+
460
+ ### Breakpoints
461
+ | Name | Width | Key Changes |
462
+ |------|-------|-------------|
463
+ | Mobile | <640px | Single column, stacked cards, hamburger nav, full-width buttons |
464
+ | Tablet | 640–1024px | 2-column feature grids, collapsible dashboard side nav |
465
+ | Desktop | 1024–1280px | Full marketing grid; dashboard left nav + content |
466
+ | Wide | >1280px | Centered 1200px marketing container; dashboard tables expand |
467
+
468
+ ### Touch Targets
469
+ - Buttons: ≥40px tall (≥44px on mobile).
470
+ - Table row actions: ≥40px tap height on touch.
471
+ - Toggle/switch: ≥32px hit area.
472
+
473
+ ### Collapsing Strategy
474
+ - Dashboard left nav collapses to an icon rail, then to a drawer on mobile.
475
+ - Wide data tables become horizontally scrollable or collapse to stacked key-value cards on small screens.
476
+ - Marketing multi-column feature bands stack to single column; CTAs go full-width.
477
+
478
+ ### Image / Asset Behavior
479
+ - Product/partner logos render in a consistent grayscale-or-mono treatment in logo walls.
480
+ - Analytics charts are full-width and responsive, maintaining aspect ratio.
481
+ - The orange cloud logomark scales but never recolors.
482
+
483
+ ## 9. Agent Prompt Guide
484
+
485
+ ### Quick Color Reference
486
+ - Primary CTA: Cloudflare Orange (`#F6821F`)
487
+ - CTA Hover: Dark Orange (`#E2700B`)
488
+ - Background: White (`#FFFFFF`) / Off-white (`#F7F7F7`)
489
+ - Heading text: Charcoal (`#1D1F20`)
490
+ - Body text: Body Charcoal (`#36393A`)
491
+ - Muted text: Grey (`#717174`)
492
+ - Placeholder: (`#999999`)
493
+ - Border: Grey 200 (`#EDEDED`) / Grey 300 (`#D9D9D9`)
494
+ - Success: Green (`#2FB344`)
495
+ - Error: Red (`#BD2528`)
496
+ - Warning: Yellow (`#F6C549`)
497
+ - Info: Blue (`#2C7CB0`)
498
+ - Dark surface: (`#262A2E`) on (`#15171A`)
499
+
500
+ ### Example Component Prompts
501
+ - "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)`."
502
+ - "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`."
503
+ - "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."
504
+ - "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."
505
+ - "Build a status pill: fully rounded, 12px weight 600 Inter, 2px 10px padding. Success green `#E8F5D8`/`#3D6B14`; error `#FBE2E2`/`#BD2528`; pending `#FCF3D6`/`#8A6D1B`."
506
+
507
+ ### Iteration Guide
508
+ 1. Use Inter with a system-ui fallback for all UI text; JetBrains Mono for any technical string.
509
+ 2. Orange (`#F6821F`) appears only on primary actions and key accents — ration it deliberately.
510
+ 3. Headings are warm charcoal `#1D1F20`, body `#36393A` — never pure black.
511
+ 4. Define surfaces with 1px `#EDEDED` borders first; add subtle neutral shadow only for floating layers.
512
+ 5. Radii: 6px buttons/inputs, 8px cards, 10–12px modals, pill for badges/toggles.
513
+ 6. Status uses colored pills + dots (green/red/yellow); blue is informational only, never primary.
514
+ 7. Provide a dark-mode mapping (`#15171A` bg, `#262A2E` surface, `#E4E6E7` text) with orange unchanged.
515
+
516
+ ---
517
+
518
+ ## 10. Voice & Tone
519
+
520
+ 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.
521
+
522
+ | Context | Tone |
523
+ |---|---|
524
+ | CTAs | Short imperative verb phrases — "Get started", "Add a site", "Sign up", "Talk to an expert". |
525
+ | Headlines | Confident, benefit-first, plain — "Make employees, applications and networks faster and more secure." |
526
+ | Product UI labels | Precise, technical, unambiguous — "Proxied", "DNS only", "Always Use HTTPS". |
527
+ | Success messages | Past-tense, specific — "DNS record added", "SSL certificate issued". |
528
+ | Error messages | Specific, blameless, actionable — name what failed and what to do next. |
529
+ | Blog / docs | Deep, candid, occasionally playful; explains the *why* behind the engineering. |
530
+ | Empty states | One line of why + one action — "No DNS records yet. Add your first record." |
531
+
532
+ **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.
533
+
534
+ ## 11. Brand Narrative
535
+
536
+ 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."*
537
+
538
+ 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.
539
+
540
+ 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.
541
+
542
+ 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.
543
+
544
+ ## 12. Principles
545
+
546
+ 1. **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.
547
+ 2. **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.
548
+ 3. **Monospace for truth.** Anything an operator must read exactly — IPs, DNS records, tokens, code — is monospace. Proportional fonts are for prose, not infrastructure.
549
+ 4. **Whitespace where you sell, density where you work.** Marketing breathes; the dashboard packs. Both are intentional, neither apologizes.
550
+ 5. **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.
551
+ 6. **Plain words, precise claims.** Copy is direct and benefit-led; technical labels are exact. No jargon for its own sake, no vague enterprise filler.
552
+ 7. **Parity in dark.** Product UI must work in light and dark with equal polish. Orange holds in both; surfaces shift, the brand doesn't.
553
+ 8. **Powerful but approachable.** Every screen must feel usable by a solo developer and trustworthy to an enterprise team simultaneously. That tension is the brand.
554
+
555
+ ## 13. Personas
556
+
557
+ *Personas below are fictional archetypes informed by publicly described Cloudflare user segments, not individual people.*
558
+
559
+ **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.
560
+
561
+ **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.
562
+
563
+ **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.
564
+
565
+ ## 14. States
566
+
567
+ | State | Treatment |
568
+ |---|---|
569
+ | **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. |
570
+ | **Empty (filtered)** | Single `#717174` caption ("No records match your filter.") with a "Clear filter" text button. |
571
+ | **Loading (first paint)** | Skeleton blocks at `#EDEDED` (light) / `#2A2E33` (dark) matching final layout. Metric values show `—` until resolved. |
572
+ | **Loading (refresh)** | Inline orange spinner or top progress bar; existing data stays visible, never blanked. |
573
+ | **Error (inline field)** | 1px `#BD2528` border, helper text below in `#BD2528` 12px, one actionable sentence ("Enter a valid IPv4 address."). |
574
+ | **Error (toast)** | `#1D1F20` bg, white text, 4px red left-border, 4–5s auto-dismiss, one sentence. |
575
+ | **Error (page-level)** | Centered message in `#1D1F20` 16px/600 + cause + retry button in orange. Reserved for outage/permission failures. |
576
+ | **Success (toast)** | `#1D1F20` bg, white text, 4px green left-border ("Record added."). |
577
+ | **Status: healthy** | Green pill + dot — "Active" / "Proxied" / "Healthy". |
578
+ | **Status: degraded/paused** | Yellow pill — "Pending" / "DNS only" / "Paused". |
579
+ | **Status: down/blocked** | Red pill — "Down" / "Blocked" / "Error". |
580
+ | **Disabled** | Control at 40–50% opacity; orange buttons keep hue but drop opacity; geometry unchanged. |
581
+ | **Focus** | 3px orange focus ring `rgba(246,130,31,0.2)` on inputs/buttons — visible for keyboard nav. |
582
+ | **Loading inside button** | Label swapped for a small white spinner; button width preserved; press committed, no double-submit. |
583
+
584
+ ## 15. Motion & Easing
585
+
586
+ **Durations** (named, not raw ms):
587
+
588
+ | Token | Value | Use |
589
+ |---|---|---|
590
+ | `motion-instant` | 0ms | Toggle flips, checkbox state |
591
+ | `motion-fast` | 120ms | Hover, focus ring, button press |
592
+ | `motion-standard` | 200ms | Dropdowns, tab switches, accordion expand |
593
+ | `motion-emphasis` | 300ms | Modal open, sheet, toast enter |
594
+ | `motion-page` | 350ms | Route/section transitions |
595
+
596
+ **Easings:**
597
+
598
+ | Token | Curve | Use |
599
+ |---|---|---|
600
+ | `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Appearing — modals, toasts, popovers |
601
+ | `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Leaving — dismissals, collapses |
602
+ | `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way — tabs, accordions, hover lift |
603
+ | `ease-out-soft` | `cubic-bezier(0.16, 1, 0.3, 1)` | Emphasized marketing reveals on scroll |
604
+
605
+ **Signature motions.**
606
+
607
+ 1. **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.
608
+ 2. **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.
609
+ 3. **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.
610
+ 4. **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.
611
+ 5. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all tokens collapse to `motion-instant`; slides become fades; the dashboard stays fully usable.
612
+
613
+ <!--
614
+ OmD v0.1 Sources — Cloudflare
615
+
616
+ Token grounding:
617
+ - Cloudflare Orange #F6821F is the documented primary brand color (hint + widely
618
+ published brand-color references: brandcolors.net/b/cloudflare, brandpalettes.com,
619
+ schemecolor.com). Logomark gradient #F6821F → #FAAD3F (#F48120 alt).
620
+ - Typography: Inter with system-ui fallback; JetBrains/mono for technical strings —
621
+ grounded in Cloudflare design-system docs (developers.cloudflare.com design-system,
622
+ cloudflare.github.io/cf-ui, color.cloudflare.design "Color by Cloudflare Design").
623
+ - Dark mode: confirmed shipped (blog.cloudflare.com/dark-mode).
624
+ - Founders/history (Prince, Holloway, Zatlyn, 2009; NYSE NET 2019; mission
625
+ "help build a better Internet") are widely documented public facts.
626
+
627
+ Web research (2026-06-06): WebSearch results for Cloudflare brand color / design
628
+ system / typography. color.cloudflare.design and cloudflare.com WebFetch were
629
+ unreachable at write time (ECONNREFUSED / classifier unavailable); token values
630
+ above are reconciled from multiple public brand-color references and the hint.
631
+
632
+ Neutral/grey, semantic, and dark-mode hex values, component geometry (radii,
633
+ padding, shadow tokens), motion tokens, and personas are interpretive
634
+ reconstructions consistent with Cloudflare's observed marketing site and
635
+ dashboard, not verbatim from a single published spec. Personas are fictional
636
+ archetypes informed by publicly described Cloudflare user segments.
637
+ -->