oh-my-design-cli 0.1.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 (317) hide show
  1. package/LICENSE +21 -0
  2. package/README.ja.md +145 -0
  3. package/README.ko.md +245 -0
  4. package/README.md +245 -0
  5. package/README.zh-TW.md +145 -0
  6. package/data/reference-tags.md +104 -0
  7. package/data/synonyms.json +79 -0
  8. package/data/vocabulary.json +516 -0
  9. package/dist/bin/oh-my-design.js +858 -0
  10. package/dist/bin/oh-my-design.js.map +1 -0
  11. package/dist/chunk-6YNSV3VY.js +35 -0
  12. package/dist/chunk-6YNSV3VY.js.map +1 -0
  13. package/dist/chunk-MHFYGZSO.js +337 -0
  14. package/dist/chunk-MHFYGZSO.js.map +1 -0
  15. package/dist/chunk-N2JG6N4Q.js +264 -0
  16. package/dist/chunk-N2JG6N4Q.js.map +1 -0
  17. package/dist/chunk-OOQQEUGX.js +46 -0
  18. package/dist/chunk-OOQQEUGX.js.map +1 -0
  19. package/dist/chunk-OR5DHENY.js +250 -0
  20. package/dist/chunk-OR5DHENY.js.map +1 -0
  21. package/dist/customizer-CM76752R.js +8 -0
  22. package/dist/customizer-CM76752R.js.map +1 -0
  23. package/dist/index.d.ts +559 -0
  24. package/dist/index.js +3113 -0
  25. package/dist/index.js.map +1 -0
  26. package/dist/init-STACB7E5.js +635 -0
  27. package/dist/init-STACB7E5.js.map +1 -0
  28. package/dist/install-skills-CM6VXFZJ.js +152 -0
  29. package/dist/install-skills-CM6VXFZJ.js.map +1 -0
  30. package/dist/learn-33LHKEJA.js +140 -0
  31. package/dist/learn-33LHKEJA.js.map +1 -0
  32. package/dist/reference-YMNAOXJQ.js +47 -0
  33. package/dist/reference-YMNAOXJQ.js.map +1 -0
  34. package/dist/reference-parser-TM3CJPNE.js +10 -0
  35. package/dist/reference-parser-TM3CJPNE.js.map +1 -0
  36. package/dist/remember-UAFA5B2O.js +78 -0
  37. package/dist/remember-UAFA5B2O.js.map +1 -0
  38. package/dist/sync-P7X4S2DK.js +404 -0
  39. package/dist/sync-P7X4S2DK.js.map +1 -0
  40. package/dist/templates/templates/design-md.hbs +44 -0
  41. package/dist/templates/templates/partials/agent-prompt-guide.hbs +28 -0
  42. package/dist/templates/templates/partials/color-palette.hbs +49 -0
  43. package/dist/templates/templates/partials/component-stylings.hbs +28 -0
  44. package/dist/templates/templates/partials/depth-elevation.hbs +31 -0
  45. package/dist/templates/templates/partials/dos-donts.hbs +13 -0
  46. package/dist/templates/templates/partials/layout.hbs +30 -0
  47. package/dist/templates/templates/partials/responsive.hbs +25 -0
  48. package/dist/templates/templates/partials/shadcn-tokens.hbs +64 -0
  49. package/dist/templates/templates/partials/typography.hbs +43 -0
  50. package/dist/templates/templates/partials/visual-theme.hbs +26 -0
  51. package/package.json +68 -0
  52. package/references/Claude-Design-Sys-Prompt.txt +421 -0
  53. package/references/airbnb/DESIGN.md +427 -0
  54. package/references/airbnb/README.md +23 -0
  55. package/references/airbnb/preview-dark.html +234 -0
  56. package/references/airbnb/preview.html +233 -0
  57. package/references/airtable/DESIGN.md +107 -0
  58. package/references/airtable/README.md +23 -0
  59. package/references/airtable/preview-dark.html +165 -0
  60. package/references/airtable/preview.html +164 -0
  61. package/references/apple/DESIGN.md +496 -0
  62. package/references/apple/README.md +24 -0
  63. package/references/apple/preview-dark.html +420 -0
  64. package/references/apple/preview.html +414 -0
  65. package/references/baemin/DESIGN.md +260 -0
  66. package/references/baemin/README.md +19 -0
  67. package/references/bmw/DESIGN.md +180 -0
  68. package/references/bmw/README.md +23 -0
  69. package/references/bmw/preview-dark.html +211 -0
  70. package/references/bmw/preview.html +210 -0
  71. package/references/cal/DESIGN.md +259 -0
  72. package/references/cal/README.md +23 -0
  73. package/references/cal/preview-dark.html +449 -0
  74. package/references/cal/preview.html +575 -0
  75. package/references/claude/DESIGN.md +455 -0
  76. package/references/claude/README.md +24 -0
  77. package/references/claude/preview-dark.html +803 -0
  78. package/references/claude/preview.html +826 -0
  79. package/references/clay/DESIGN.md +304 -0
  80. package/references/clay/README.md +23 -0
  81. package/references/clay/preview-dark.html +316 -0
  82. package/references/clay/preview.html +315 -0
  83. package/references/clickhouse/DESIGN.md +281 -0
  84. package/references/clickhouse/README.md +24 -0
  85. package/references/clickhouse/preview-dark.html +834 -0
  86. package/references/clickhouse/preview.html +786 -0
  87. package/references/cohere/DESIGN.md +266 -0
  88. package/references/cohere/README.md +24 -0
  89. package/references/cohere/preview-dark.html +803 -0
  90. package/references/cohere/preview.html +807 -0
  91. package/references/coinbase/DESIGN.md +129 -0
  92. package/references/coinbase/README.md +23 -0
  93. package/references/coinbase/preview-dark.html +164 -0
  94. package/references/coinbase/preview.html +163 -0
  95. package/references/composio/DESIGN.md +307 -0
  96. package/references/composio/README.md +24 -0
  97. package/references/composio/preview-dark.html +958 -0
  98. package/references/composio/preview.html +933 -0
  99. package/references/cursor/DESIGN.md +322 -0
  100. package/references/cursor/README.md +24 -0
  101. package/references/cursor/preview-dark.html +393 -0
  102. package/references/cursor/preview.html +383 -0
  103. package/references/dcard/DESIGN.md +302 -0
  104. package/references/dcard/README.md +12 -0
  105. package/references/dcard/_research/forum-1440px.png +0 -0
  106. package/references/dcard/_research.md +77 -0
  107. package/references/elevenlabs/DESIGN.md +265 -0
  108. package/references/elevenlabs/README.md +23 -0
  109. package/references/elevenlabs/preview-dark.html +252 -0
  110. package/references/elevenlabs/preview.html +251 -0
  111. package/references/expo/DESIGN.md +281 -0
  112. package/references/expo/README.md +24 -0
  113. package/references/expo/preview-dark.html +533 -0
  114. package/references/expo/preview.html +533 -0
  115. package/references/ferrari/DESIGN.md +314 -0
  116. package/references/ferrari/README.md +23 -0
  117. package/references/ferrari/preview-dark.html +1162 -0
  118. package/references/ferrari/preview.html +1122 -0
  119. package/references/figma/DESIGN.md +399 -0
  120. package/references/figma/README.md +24 -0
  121. package/references/figma/preview-dark.html +822 -0
  122. package/references/figma/preview.html +832 -0
  123. package/references/framer/DESIGN.md +246 -0
  124. package/references/framer/README.md +23 -0
  125. package/references/framer/preview-dark.html +902 -0
  126. package/references/framer/preview.html +883 -0
  127. package/references/freee/DESIGN.md +308 -0
  128. package/references/freee/README.md +12 -0
  129. package/references/freee/_research/vibes-storybook-1440px.png +0 -0
  130. package/references/freee/_research.md +77 -0
  131. package/references/hashicorp/DESIGN.md +278 -0
  132. package/references/hashicorp/README.md +24 -0
  133. package/references/hashicorp/preview-dark.html +1202 -0
  134. package/references/hashicorp/preview.html +1193 -0
  135. package/references/ibm/DESIGN.md +332 -0
  136. package/references/ibm/README.md +24 -0
  137. package/references/ibm/preview-dark.html +443 -0
  138. package/references/ibm/preview.html +428 -0
  139. package/references/intercom/DESIGN.md +146 -0
  140. package/references/intercom/README.md +23 -0
  141. package/references/intercom/preview-dark.html +185 -0
  142. package/references/intercom/preview.html +184 -0
  143. package/references/kakao/DESIGN.md +261 -0
  144. package/references/kakao/README.md +18 -0
  145. package/references/karrot/DESIGN.md +252 -0
  146. package/references/karrot/README.md +18 -0
  147. package/references/kraken/DESIGN.md +146 -0
  148. package/references/kraken/README.md +23 -0
  149. package/references/kraken/preview-dark.html +169 -0
  150. package/references/kraken/preview.html +168 -0
  151. package/references/lamborghini/DESIGN.md +288 -0
  152. package/references/lamborghini/README.md +23 -0
  153. package/references/lamborghini/preview-dark.html +303 -0
  154. package/references/lamborghini/preview.html +381 -0
  155. package/references/line/DESIGN.md +375 -0
  156. package/references/line/README.md +12 -0
  157. package/references/line/_research/home-1440px.png +0 -0
  158. package/references/line/_research.md +65 -0
  159. package/references/linear.app/DESIGN.md +526 -0
  160. package/references/linear.app/README.md +24 -0
  161. package/references/linear.app/preview-dark.html +383 -0
  162. package/references/linear.app/preview.html +373 -0
  163. package/references/lovable/DESIGN.md +298 -0
  164. package/references/lovable/README.md +24 -0
  165. package/references/lovable/preview-dark.html +349 -0
  166. package/references/lovable/preview.html +348 -0
  167. package/references/mercari/DESIGN.md +294 -0
  168. package/references/mercari/README.md +12 -0
  169. package/references/mercari/_research/home-1440px.png +0 -0
  170. package/references/mercari/_research.md +77 -0
  171. package/references/minimax/DESIGN.md +257 -0
  172. package/references/minimax/README.md +24 -0
  173. package/references/minimax/preview-dark.html +1262 -0
  174. package/references/minimax/preview.html +1248 -0
  175. package/references/mintlify/DESIGN.md +341 -0
  176. package/references/mintlify/README.md +24 -0
  177. package/references/mintlify/preview-dark.html +409 -0
  178. package/references/mintlify/preview.html +398 -0
  179. package/references/miro/DESIGN.md +108 -0
  180. package/references/miro/README.md +23 -0
  181. package/references/miro/preview-dark.html +174 -0
  182. package/references/miro/preview.html +173 -0
  183. package/references/mistral.ai/DESIGN.md +261 -0
  184. package/references/mistral.ai/README.md +24 -0
  185. package/references/mistral.ai/preview-dark.html +806 -0
  186. package/references/mistral.ai/preview.html +805 -0
  187. package/references/mongodb/DESIGN.md +266 -0
  188. package/references/mongodb/README.md +23 -0
  189. package/references/mongodb/preview-dark.html +260 -0
  190. package/references/mongodb/preview.html +259 -0
  191. package/references/notion/DESIGN.md +492 -0
  192. package/references/notion/README.md +24 -0
  193. package/references/notion/preview-dark.html +372 -0
  194. package/references/notion/preview.html +364 -0
  195. package/references/nvidia/DESIGN.md +308 -0
  196. package/references/nvidia/README.md +24 -0
  197. package/references/nvidia/preview-dark.html +374 -0
  198. package/references/nvidia/preview.html +366 -0
  199. package/references/ollama/DESIGN.md +267 -0
  200. package/references/ollama/README.md +24 -0
  201. package/references/ollama/preview-dark.html +678 -0
  202. package/references/ollama/preview.html +678 -0
  203. package/references/opencode.ai/DESIGN.md +295 -0
  204. package/references/opencode.ai/README.md +24 -0
  205. package/references/opencode.ai/preview-dark.html +366 -0
  206. package/references/opencode.ai/preview.html +357 -0
  207. package/references/pinkoi/DESIGN.md +309 -0
  208. package/references/pinkoi/README.md +12 -0
  209. package/references/pinkoi/_research/browse-1440px.png +0 -0
  210. package/references/pinkoi/_research.md +115 -0
  211. package/references/pinterest/DESIGN.md +230 -0
  212. package/references/pinterest/README.md +23 -0
  213. package/references/pinterest/preview-dark.html +233 -0
  214. package/references/pinterest/preview.html +232 -0
  215. package/references/posthog/DESIGN.md +256 -0
  216. package/references/posthog/README.md +23 -0
  217. package/references/posthog/preview-dark.html +699 -0
  218. package/references/posthog/preview.html +749 -0
  219. package/references/raycast/DESIGN.md +268 -0
  220. package/references/raycast/README.md +23 -0
  221. package/references/raycast/preview-dark.html +606 -0
  222. package/references/raycast/preview.html +688 -0
  223. package/references/renault/DESIGN.md +311 -0
  224. package/references/renault/README.md +23 -0
  225. package/references/renault/preview-dark.html +406 -0
  226. package/references/renault/preview.html +606 -0
  227. package/references/replicate/DESIGN.md +261 -0
  228. package/references/replicate/README.md +24 -0
  229. package/references/replicate/preview-dark.html +828 -0
  230. package/references/replicate/preview.html +831 -0
  231. package/references/resend/DESIGN.md +303 -0
  232. package/references/resend/README.md +23 -0
  233. package/references/resend/preview-dark.html +355 -0
  234. package/references/resend/preview.html +354 -0
  235. package/references/revolut/DESIGN.md +185 -0
  236. package/references/revolut/README.md +23 -0
  237. package/references/revolut/preview-dark.html +234 -0
  238. package/references/revolut/preview.html +233 -0
  239. package/references/runwayml/DESIGN.md +244 -0
  240. package/references/runwayml/README.md +24 -0
  241. package/references/runwayml/preview-dark.html +664 -0
  242. package/references/runwayml/preview.html +665 -0
  243. package/references/sanity/DESIGN.md +357 -0
  244. package/references/sanity/README.md +24 -0
  245. package/references/sanity/preview-dark.html +990 -0
  246. package/references/sanity/preview.html +1135 -0
  247. package/references/sentry/DESIGN.md +262 -0
  248. package/references/sentry/README.md +24 -0
  249. package/references/sentry/preview-dark.html +626 -0
  250. package/references/sentry/preview.html +951 -0
  251. package/references/spacex/DESIGN.md +205 -0
  252. package/references/spacex/README.md +23 -0
  253. package/references/spacex/preview-dark.html +221 -0
  254. package/references/spacex/preview.html +220 -0
  255. package/references/spotify/DESIGN.md +246 -0
  256. package/references/spotify/README.md +23 -0
  257. package/references/spotify/preview-dark.html +231 -0
  258. package/references/spotify/preview.html +230 -0
  259. package/references/stripe/DESIGN.md +473 -0
  260. package/references/stripe/README.md +24 -0
  261. package/references/stripe/preview-dark.html +428 -0
  262. package/references/stripe/preview.html +419 -0
  263. package/references/supabase/DESIGN.md +255 -0
  264. package/references/supabase/README.md +24 -0
  265. package/references/supabase/preview-dark.html +977 -0
  266. package/references/supabase/preview.html +955 -0
  267. package/references/superhuman/DESIGN.md +252 -0
  268. package/references/superhuman/README.md +23 -0
  269. package/references/superhuman/preview-dark.html +973 -0
  270. package/references/superhuman/preview.html +951 -0
  271. package/references/tesla/DESIGN.md +286 -0
  272. package/references/tesla/README.md +23 -0
  273. package/references/tesla/preview-dark.html +947 -0
  274. package/references/tesla/preview.html +925 -0
  275. package/references/together.ai/DESIGN.md +263 -0
  276. package/references/together.ai/README.md +24 -0
  277. package/references/together.ai/preview-dark.html +892 -0
  278. package/references/together.ai/preview.html +897 -0
  279. package/references/toss/DESIGN.md +387 -0
  280. package/references/toss/README.md +19 -0
  281. package/references/uber/DESIGN.md +295 -0
  282. package/references/uber/README.md +24 -0
  283. package/references/uber/preview-dark.html +1120 -0
  284. package/references/uber/preview.html +1119 -0
  285. package/references/vercel/DESIGN.md +456 -0
  286. package/references/vercel/README.md +24 -0
  287. package/references/vercel/preview-dark.html +368 -0
  288. package/references/vercel/preview.html +367 -0
  289. package/references/voltagent/DESIGN.md +323 -0
  290. package/references/voltagent/README.md +24 -0
  291. package/references/voltagent/preview-dark.html +487 -0
  292. package/references/voltagent/preview.html +766 -0
  293. package/references/warp/DESIGN.md +253 -0
  294. package/references/warp/README.md +23 -0
  295. package/references/warp/preview-dark.html +500 -0
  296. package/references/warp/preview.html +533 -0
  297. package/references/webflow/DESIGN.md +109 -0
  298. package/references/webflow/README.md +23 -0
  299. package/references/webflow/preview-dark.html +147 -0
  300. package/references/webflow/preview.html +146 -0
  301. package/references/wise/DESIGN.md +173 -0
  302. package/references/wise/README.md +23 -0
  303. package/references/wise/preview-dark.html +230 -0
  304. package/references/wise/preview.html +229 -0
  305. package/references/x.ai/DESIGN.md +267 -0
  306. package/references/x.ai/README.md +24 -0
  307. package/references/x.ai/preview-dark.html +356 -0
  308. package/references/x.ai/preview.html +407 -0
  309. package/references/zapier/DESIGN.md +328 -0
  310. package/references/zapier/README.md +24 -0
  311. package/references/zapier/preview-dark.html +380 -0
  312. package/references/zapier/preview.html +372 -0
  313. package/skills/omd-apply/SKILL.md +85 -0
  314. package/skills/omd-init/SKILL.md +167 -0
  315. package/skills/omd-learn/SKILL.md +81 -0
  316. package/skills/omd-remember/SKILL.md +44 -0
  317. package/skills/omd-sync/SKILL.md +38 -0
@@ -0,0 +1,427 @@
1
+ ---
2
+ omd: 0.1
3
+ brand: Airbnb
4
+ ---
5
+
6
+ # Design System Inspiration of Airbnb
7
+
8
+ ## 1. Visual Theme & Atmosphere
9
+
10
+ Airbnb's website is a warm, photography-forward marketplace that feels like flipping through a travel magazine where every page invites you to book. The design operates on a foundation of pure white (`#ffffff`) with the iconic Rausch Red (`#ff385c`) — named after Airbnb's first street address — serving as the singular brand accent. The result is a clean, airy canvas where listing photography, category icons, and the red CTA button are the only sources of color.
11
+
12
+ The typography uses Airbnb Cereal VF — a custom variable font that's warm and approachable, with rounded terminals that echo the brand's "belong anywhere" philosophy. The font operates in a tight weight range: 500 (medium) for most UI, 600 (semibold) for emphasis, and 700 (bold) for primary headings. Slight negative letter-spacing (-0.18px to -0.44px) on headings creates a cozy, intimate reading experience rather than the compressed efficiency of tech companies.
13
+
14
+ What distinguishes Airbnb is its palette-based token system (`--palette-*`) and multi-layered shadow approach. The primary card shadow uses a three-layer stack (`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`) that creates a subtle, warm lift. Combined with generous border-radius (8px–32px), circular navigation controls (50%), and a category pill bar with horizontal scrolling, the interface feels tactile and inviting — designed for browsing, not commanding.
15
+
16
+ **Key Characteristics:**
17
+ - Pure white canvas with Rausch Red (`#ff385c`) as singular brand accent
18
+ - Airbnb Cereal VF — custom variable font with warm, rounded terminals
19
+ - Palette-based token system (`--palette-*`) for systematic color management
20
+ - Three-layer card shadows: border ring + soft blur + stronger blur
21
+ - Generous border-radius: 8px buttons, 14px badges, 20px cards, 32px large elements
22
+ - Circular navigation controls (50% radius)
23
+ - Photography-first listing cards — images are the hero content
24
+ - Near-black text (`#222222`) — warm, not cold
25
+ - Luxe Purple (`#460479`) and Plus Magenta (`#92174d`) for premium tiers
26
+
27
+ ## 2. Color Palette & Roles
28
+
29
+ ### Primary Brand
30
+ - **Rausch Red** (`#ff385c`): `--palette-bg-primary-core`, primary CTA, brand accent, active states
31
+ - **Deep Rausch** (`#e00b41`): `--palette-bg-tertiary-core`, pressed/dark variant of brand red
32
+ - **Error Red** (`#c13515`): `--palette-text-primary-error`, error text on light
33
+ - **Error Dark** (`#b32505`): `--palette-text-secondary-error-hover`, error hover
34
+
35
+ ### Premium Tiers
36
+ - **Luxe Purple** (`#460479`): `--palette-bg-primary-luxe`, Airbnb Luxe tier branding
37
+ - **Plus Magenta** (`#92174d`): `--palette-bg-primary-plus`, Airbnb Plus tier branding
38
+
39
+ ### Text Scale
40
+ - **Near Black** (`#222222`): `--palette-text-primary`, primary text — warm, not cold
41
+ - **Focused Gray** (`#3f3f3f`): `--palette-text-focused`, focused state text
42
+ - **Secondary Gray** (`#6a6a6a`): Secondary text, descriptions
43
+ - **Disabled** (`rgba(0,0,0,0.24)`): `--palette-text-material-disabled`, disabled state
44
+ - **Link Disabled** (`#929292`): `--palette-text-link-disabled`, disabled links
45
+
46
+ ### Interactive
47
+ - **Legal Blue** (`#428bff`): `--palette-text-legal`, legal links, informational
48
+ - **Border Gray** (`#c1c1c1`): Border color for cards and dividers
49
+ - **Light Surface** (`#f2f2f2`): Circular navigation buttons, secondary surfaces
50
+
51
+ ### Surface & Shadows
52
+ - **Pure White** (`#ffffff`): Page background, card surfaces
53
+ - **Card Shadow** (`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`): Three-layer warm lift
54
+ - **Hover Shadow** (`rgba(0,0,0,0.08) 0px 4px 12px`): Button hover elevation
55
+
56
+ ## 3. Typography Rules
57
+
58
+ ### Font Family
59
+ - **Primary**: `Airbnb Cereal VF`, fallbacks: `Circular, -apple-system, system-ui, Roboto, Helvetica Neue`
60
+ - **OpenType Features**: `"salt"` (stylistic alternates) on specific caption elements
61
+
62
+ ### Hierarchy
63
+
64
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
65
+ |------|------|------|--------|-------------|----------------|-------|
66
+ | Section Heading | Airbnb Cereal VF | 28px (1.75rem) | 700 | 1.43 | normal | Primary headings |
67
+ | Card Heading | Airbnb Cereal VF | 22px (1.38rem) | 600 | 1.18 (tight) | -0.44px | Category/card titles |
68
+ | Card Heading Medium | Airbnb Cereal VF | 22px (1.38rem) | 500 | 1.18 (tight) | -0.44px | Lighter variant |
69
+ | Sub-heading | Airbnb Cereal VF | 21px (1.31rem) | 700 | 1.43 | normal | Bold sub-headings |
70
+ | Feature Title | Airbnb Cereal VF | 20px (1.25rem) | 600 | 1.20 (tight) | -0.18px | Feature headings |
71
+ | UI Medium | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Nav, emphasized text |
72
+ | UI Semibold | Airbnb Cereal VF | 16px (1.00rem) | 600 | 1.25 (tight) | normal | Strong emphasis |
73
+ | Button | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Button labels |
74
+ | Body / Link | Airbnb Cereal VF | 14px (0.88rem) | 400 | 1.43 | normal | Standard body |
75
+ | Body Medium | Airbnb Cereal VF | 14px (0.88rem) | 500 | 1.29 (tight) | normal | Medium body |
76
+ | Caption Salt | Airbnb Cereal VF | 14px (0.88rem) | 600 | 1.43 | normal | `"salt"` feature |
77
+ | Small | Airbnb Cereal VF | 13px (0.81rem) | 400 | 1.23 (tight) | normal | Descriptions |
78
+ | Tag | Airbnb Cereal VF | 12px (0.75rem) | 400–700 | 1.33 | normal | Tags, prices |
79
+ | Badge | Airbnb Cereal VF | 11px (0.69rem) | 600 | 1.18 (tight) | normal | `"salt"` feature |
80
+ | Micro Uppercase | Airbnb Cereal VF | 8px (0.50rem) | 700 | 1.25 (tight) | 0.32px | `text-transform: uppercase` |
81
+
82
+ ### Principles
83
+ - **Warm weight range**: 500–700 dominate. No weight 300 or 400 for headings — Airbnb's type is always at least medium weight, creating a warm, confident voice.
84
+ - **Negative tracking on headings**: -0.18px to -0.44px letter-spacing on display creates intimate, cozy headings rather than cold, compressed ones.
85
+ - **"salt" OpenType feature**: Stylistic alternates on specific UI elements (badges, captions) create subtle glyph variations that add visual interest.
86
+ - **Variable font precision**: Cereal VF enables continuous weight interpolation, though the design system uses discrete stops at 500, 600, and 700.
87
+
88
+ ## 4. Component Stylings
89
+
90
+ ### Buttons
91
+
92
+ **Primary Dark**
93
+ - Background: `#222222` (near-black, not pure black)
94
+ - Text: `#ffffff`
95
+ - Padding: 0px 24px
96
+ - Radius: 8px
97
+ - Hover: transitions to error/brand accent via `var(--accent-bg-error)`
98
+ - Focus: `0 0 0 2px var(--palette-grey1000)` ring + scale(0.92)
99
+
100
+ **Circular Nav**
101
+ - Background: `#f2f2f2`
102
+ - Text: `#222222`
103
+ - Radius: 50% (circle)
104
+ - Hover: shadow `rgba(0,0,0,0.08) 0px 4px 12px` + translateX(50%)
105
+ - Active: 4px white border ring + focus shadow
106
+ - Focus: scale(0.92) shrink animation
107
+
108
+ ### Cards & Containers
109
+ - Background: `#ffffff`
110
+ - Radius: 14px (badges), 20px (cards/buttons), 32px (large)
111
+ - Shadow: `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px` (three-layer)
112
+ - Listing cards: full-width photography on top, details below
113
+ - Carousel controls: circular 50% buttons
114
+
115
+ ### Inputs
116
+ - Search: `#222222` text
117
+ - Focus: `var(--palette-bg-primary-error)` background tint + `0 0 0 2px` ring
118
+ - Radius: depends on context (search bar uses pill-like rounding)
119
+
120
+ ### Navigation
121
+ - White sticky header with search bar centered
122
+ - Airbnb logo (Rausch Red) left-aligned
123
+ - Category filter pills: horizontal scroll below search
124
+ - Circular nav controls for carousel navigation
125
+ - "Become a Host" text link, avatar/menu right-aligned
126
+
127
+ ### Image Treatment
128
+ - Listing photography fills card top with generous height
129
+ - Image carousel with dot indicators
130
+ - Heart/wishlist icon overlay on images
131
+ - 8px–14px radius on contained images
132
+
133
+ ## 5. Layout Principles
134
+
135
+ ### Spacing System
136
+ - Base unit: 8px
137
+ - Scale: 2px, 3px, 4px, 6px, 8px, 10px, 11px, 12px, 15px, 16px, 22px, 24px, 32px
138
+
139
+ ### Grid & Container
140
+ - Full-width header with centered search
141
+ - Category pill bar: horizontal scrollable row
142
+ - Listing grid: responsive multi-column (3–5 columns on desktop)
143
+ - Full-width footer with link columns
144
+
145
+ ### Whitespace Philosophy
146
+ - **Travel-magazine spacing**: Generous vertical padding between sections creates a leisurely browsing pace — you're meant to scroll slowly, like browsing a magazine.
147
+ - **Photography density**: Listing cards are packed relatively tightly, but each image is large enough to feel immersive.
148
+ - **Search bar prominence**: The search bar gets maximum vertical space in the header — finding your destination is the primary action.
149
+
150
+ ### Border Radius Scale
151
+ - Subtle (4px): Small links
152
+ - Standard (8px): Buttons, tabs, search elements
153
+ - Badge (14px): Status badges, labels
154
+ - Card (20px): Feature cards, large buttons
155
+ - Large (32px): Large containers, hero elements
156
+ - Circle (50%): Nav controls, avatars, icons
157
+
158
+ ## 6. Depth & Elevation
159
+
160
+ | Level | Treatment | Use |
161
+ |-------|-----------|-----|
162
+ | Flat (Level 0) | No shadow | Page background, text blocks |
163
+ | Card (Level 1) | `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px` | Listing cards, search bar |
164
+ | Hover (Level 2) | `rgba(0,0,0,0.08) 0px 4px 12px` | Button hover, interactive lift |
165
+ | Active Focus (Level 3) | `rgb(255,255,255) 0px 0px 0px 4px` + focus ring | Active/focused elements |
166
+
167
+ **Shadow Philosophy**: Airbnb's three-layer shadow system creates a warm, natural lift. Layer 1 (`0px 0px 0px 1px` at 0.02 opacity) is an ultra-subtle border. Layer 2 (`0px 2px 6px` at 0.04) provides soft ambient shadow. Layer 3 (`0px 4px 8px` at 0.1) adds the primary lift. This graduated approach creates shadows that feel like natural light rather than CSS effects.
168
+
169
+ ## 7. Do's and Don'ts
170
+
171
+ ### Do
172
+ - Use `#222222` (warm near-black) for text — never pure `#000000`
173
+ - Apply Rausch Red (`#ff385c`) only for primary CTAs and brand moments — it's the singular accent
174
+ - Use Airbnb Cereal VF at weight 500–700 — the warm weight range is intentional
175
+ - Apply the three-layer card shadow for all elevated surfaces
176
+ - Use generous border-radius: 8px for buttons, 20px for cards, 50% for controls
177
+ - Use photography as the primary visual content — listings are image-first
178
+ - Apply negative letter-spacing (-0.18px to -0.44px) on headings for intimacy
179
+ - Use circular (50%) buttons for carousel/navigation controls
180
+
181
+ ### Don't
182
+ - Don't use pure black (`#000000`) for text — always `#222222` (warm)
183
+ - Don't apply Rausch Red to backgrounds or large surfaces — it's an accent only
184
+ - Don't use thin font weights (300, 400) for headings — 500 minimum
185
+ - Don't use heavy shadows (>0.1 opacity as primary layer) — keep them warm and graduated
186
+ - Don't use sharp corners (0–4px) on cards — the generous rounding (20px+) is core
187
+ - Don't introduce additional brand colors beyond the Rausch/Luxe/Plus system
188
+ - Don't override the palette token system — use `--palette-*` variables consistently
189
+
190
+ ## 8. Responsive Behavior
191
+
192
+ ### Breakpoints
193
+ | Name | Width | Key Changes |
194
+ |------|-------|-------------|
195
+ | Mobile Small | <375px | Single column, compact search |
196
+ | Mobile | 375–550px | Standard mobile listing grid |
197
+ | Tablet Small | 550–744px | 2-column listings |
198
+ | Tablet | 744–950px | Search bar expansion |
199
+ | Desktop Small | 950–1128px | 3-column listings |
200
+ | Desktop | 1128–1440px | 4-column grid, full header |
201
+ | Large Desktop | 1440–1920px | 5-column grid |
202
+ | Ultra-wide | >1920px | Maximum grid width |
203
+
204
+ *Note: Airbnb has 61 detected breakpoints — one of the most granular responsive systems observed, reflecting their obsession with layout at every possible screen size.*
205
+
206
+ ### Touch Targets
207
+ - Circular nav buttons: adequate 50% radius sizing
208
+ - Listing cards: full-card tap target on mobile
209
+ - Search bar: prominently sized for thumb interaction
210
+ - Category pills: horizontally scrollable with generous padding
211
+
212
+ ### Collapsing Strategy
213
+ - Listing grid: 5 → 4 → 3 → 2 → 1 columns
214
+ - Search: expanded bar → compact bar → overlay
215
+ - Category pills: horizontal scroll at all sizes
216
+ - Navigation: full header → mobile simplified
217
+ - Map: side panel → overlay/toggle
218
+
219
+ ### Image Behavior
220
+ - Listing photos: carousel with swipe on mobile
221
+ - Responsive image sizing with aspect ratio maintained
222
+ - Heart overlay positioned consistently across sizes
223
+ - Photo quality adjusts based on viewport
224
+
225
+ ## 9. Agent Prompt Guide
226
+
227
+ ### Quick Color Reference
228
+ - Background: Pure White (`#ffffff`)
229
+ - Text: Near Black (`#222222`)
230
+ - Brand accent: Rausch Red (`#ff385c`)
231
+ - Secondary text: `#6a6a6a`
232
+ - Disabled: `rgba(0,0,0,0.24)`
233
+ - Card border: `rgba(0,0,0,0.02) 0px 0px 0px 1px`
234
+ - Card shadow: full three-layer stack
235
+ - Button surface: `#f2f2f2`
236
+
237
+ ### Example Component Prompts
238
+ - "Create a listing card: white background, 20px radius. Three-layer shadow: rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px. Photo area on top (16:10 ratio), details below: 16px Airbnb Cereal VF weight 600 title, 14px weight 400 description in #6a6a6a."
239
+ - "Design search bar: white background, full card shadow, 32px radius on container. Search text at 14px Cereal VF weight 400. Red search button (#ff385c, 50% radius, white icon)."
240
+ - "Build category pill bar: horizontal scrollable row. Each pill: 14px Cereal VF weight 600, #222222 text, bottom border on active. Circular prev/next arrows (#f2f2f2 bg, 50% radius)."
241
+ - "Create a CTA button: #222222 background, white text, 8px radius, 16px Cereal VF weight 500, 0px 24px padding. Hover: brand red accent."
242
+ - "Design a heart/wishlist button: transparent background, 50% radius, white heart icon with dark shadow outline."
243
+
244
+ ### Iteration Guide
245
+ 1. Start with white — the photography provides all the color
246
+ 2. Rausch Red (#ff385c) is the singular accent — use sparingly for CTAs only
247
+ 3. Near-black (#222222) for text — the warmth matters
248
+ 4. Three-layer shadows create natural, warm lift — always use all three layers
249
+ 5. Generous radius: 8px buttons, 20px cards, 50% controls
250
+ 6. Cereal VF at 500–700 weight — no thin weights for any heading
251
+ 7. Photography is hero — every listing card is image-first
252
+
253
+ ---
254
+
255
+ ## 10. Voice & Tone
256
+
257
+ Airbnb's voice is hospitality made legible — warm, unhurried, grounded in human scale. The anchor phrase is *"Belong Anywhere,"* adopted as the company's official tagline in July 2014 at the same time the **Bélo** logo launched. That phrase locates the entire voice: not transactional ("Book a room"), not distantly aspirational ("Luxury redefined"), but universal and present-tense. Headlines read like invitations. Error messages read like apologies from someone who genuinely cares. Even legal and safety surfaces preserve the Host-Guest metaphor rather than slipping into corporate passive voice.
258
+
259
+ | Context | Tone |
260
+ |---|---|
261
+ | Hero headlines | Warm, inviting, second-person. "Find a place to stay." |
262
+ | Listing descriptions | Specific, human-scale. "Sleeps 4" not "Max occupancy: 4". |
263
+ | CTAs | Gentle imperative. "Continue", "Reserve", "Send message". Never "Buy now". |
264
+ | Host-facing copy | Partnered, respectful. Hosts are capitalized (Host, Superhost), not "providers" or "suppliers". |
265
+ | Error messages | Apologetic-but-specific. Explains what happened and how to recover. |
266
+ | Onboarding (guest) | Encouraging without being sycophantic. Walks first-time guests through trust features. |
267
+ | Trust & Safety copy | Serious but warm. Reads like a thoughtful letter, not a legal document. |
268
+ | Marketing long-form | Travel-magazine-editorial. Stories of specific Hosts and Guests. |
269
+
270
+ **Forbidden phrases.** "Revolutionary", "disrupt", "next-generation", "game-changer" — the voice is human, not tech-industry. "Book now!" with exclamation — Airbnb treats booking as a trust decision, not a shopping impulse. "Unlock" (as in "Unlock amazing stays") — unlocking is a transactional metaphor and this product is about belonging. Cold-booking vocabulary: "accommodations", "units", "properties" where "homes" works. Scarcity pressure ("Only 2 left!") on product surfaces — this would betray the hospitality thesis.
271
+
272
+ ## 11. Brand Narrative
273
+
274
+ Airbnb was founded in 2008 in San Francisco by Brian Chesky, Joe Gebbia, and Nathan Blecharczyk. The founding was famously accidental: Chesky and Gebbia couldn't make rent, a design conference was in town, hotels were full, and they put air mattresses in their living room. The first three guests each paid $80 a night. That origin — a home, a Host, a Guest who could not find a traditional place to stay — stayed the company's center of gravity as it grew into a global platform.
275
+
276
+ In **July 2014**, Airbnb launched its first major rebrand: the **Bélo** logo (a universal symbol intended to evoke belonging) and the tagline *"Belong Anywhere."* Brian Chesky's launch essay framed the thesis directly: *"A house is just a space, but a home is where you belong. And what makes this global community so special is that for the very first time, you can belong anywhere."* The campaign framed belonging as *"the universal human yearning to belong — the desire to feel welcomed, and respected, and appreciated for who you are, no matter where you might be."*
277
+
278
+ That 2014 thesis is still the company's foundation, but the positioning has evolved substantially. In **May 2024**, the **Icons Release** introduced a new category — *"extraordinary experiences from the world's greatest icons"* — with partnerships across sports, music, and film, alongside group-trip features (shared wishlists, a redesigned Messages tab). In **2025**, the **Summer Release** expanded Airbnb into a three-pillar platform — **Homes, Experiences, and Services** — launching 10 service categories across 260 cities and a curated "Airbnb Originals" line. Brian Chesky framed the shift verbatim: *"With the launch of services and experiences, we're changing travel again. Now you can Airbnb more than an Airbnb."* The 2025 release shipped with a **visual-language refresh toward 3D, skeuomorphic, Pixar-inspired iconography** — *"vibrant, tactile, and full of depth"*, with *"smooth animations, subtle lighting, soft curves, and drop-shadows"* — while deliberately preserving the **Cereal** typeface, **Rausch Red** accent, and the underlying Belong-Anywhere thesis. The brand evolved into what Airbnb now frames as an "everything app" without abandoning any of the 2014 foundation.
279
+
280
+ What Airbnb refuses: the "hotel booking site" aesthetic (stock photography, star ratings as the only trust signal, "Book Now" pressure tactics), the gig-economy aesthetic (minimalist-cold, platform-as-intermediary), and any design choice that would reduce a home to a commodity. What it embraces: photography-first listing cards where the Host's own photos are the hero content, Rausch Red (`#ff385c`) — named after the company's early office address on Rausch Street, so the brand color is a personal reference rather than a committee decision — generous border-radius that reads as soft rather than precise, and a Bélo logo designed so anyone, anywhere, could draw it.
281
+
282
+ ## 12. Principles
283
+
284
+ 1. **Belong anywhere.** *(Airbnb's official tagline since July 2014, verbatim.)* Every surface should feel like an invitation, not a transaction. If a design move reads as transactional pressure ("Only 2 left! Book now!"), it violates the thesis.
285
+ 2. **Home, not accommodation.** *(Brian Chesky, 2014, verbatim: "A house is just a space, but a home is where you belong.")* Copy, illustration, and imagery refer to "homes", never "units", "properties", or "accommodations".
286
+ 3. **Hosts are capital H.** Hosts are partners, not suppliers. Product copy capitalizes the role (Host, Superhost) as a form of respect. Guest is lowercase when used as a common noun; guests are universal, Hosts are individual.
287
+ 4. **Photography is the hero.** Listing cards, search results, marketing pages — the Host's photography is the primary visual. The chrome's job is to get out of the way of that photography.
288
+ 5. **Warm minimalism.** White canvas, Rausch Red as singular accent, near-black (`#222222`) text with a whiff of warmth, generous radius throughout. The palette refuses the "cool gray institutional" default of travel-tech.
289
+ 6. **Trust is designed.** Every trust-signaling element — reviews, Host verification, cancellation policies, identity verification — is a first-class UI element, not buried in small print. Warmth without trust is hospitality theater.
290
+ 7. **Pay attention to the in-between moments.** Empty states, error states, between-booking follow-ups — these are where belonging is either reinforced or broken. A generic "No results found" state is an Airbnb failure.
291
+ 8. **The Bélo is universal on purpose.** The 2014 Bélo was designed so anyone, anywhere, could draw it. Brand marks are not decoration — they are symbols of the community they represent, and community symbols must be replicable by the community.
292
+ 9. **Hospitality is more than a look.** Design decisions are judged against whether a real Host would feel dignified showing their listing inside this chrome. If the answer is "not quite", the chrome is wrong.
293
+ 10. **The super-app is an extension of hospitality, not a pivot from it.** *(Contemporary, 2024–2025 era.)* The 2024 **Icons Release** and 2025 expansion to **Homes + Experiences + Services** inherit the 2014 "Belong Anywhere" thesis — the unit of belonging scales from a home stay to an experience or a service, but the emotional register stays hospitable. The 2025 shift to 3D / skeuomorphic / Pixar-inspired iconography kept Cereal, Rausch Red, and the warm-minimalist chrome intact precisely because the brand is evolving, not rebooting. A redesign that introduced a cold palette or a sans-serif brand type would violate the thesis, no matter how "modern" it looked.
294
+
295
+ ## 13. Personas
296
+
297
+ *Personas below are fictional archetypes informed by publicly observable Airbnb user segments (leisure travelers, Hosts, long-stay remote workers, multigenerational family travelers), not individual people.*
298
+
299
+ **Léa Dubois, 31, Paris.** Marketing manager at a fashion startup. Books 4–6 Airbnb stays a year, mostly short European weekends with her partner. Reads listing descriptions carefully; checks the Host's review history *before* the listing photos. Would rather pay 20% more for a Superhost with a long review history than save money on a new listing. Notices when Airbnb's empty-state copy is warm or cold and judges the product accordingly.
300
+
301
+ **Dimitri Stavros, 58, Thessaloniki.** Retired and runs a 2-bedroom Superhost listing in his family's village home. Uses the Host app daily. Values that the Host-facing copy treats him as a partner, not a gig-economy worker. Reads every update to Airbnb's cancellation policies carefully because they affect his household income. Would leave the platform if the Host tools ever felt more extractive than collaborative.
302
+
303
+ **Aisha Mohammed, 27, Cairo.** Software engineer working fully remote. Uses Airbnb for 30–90 day "slow travel" stays — Lisbon, Mexico City, Medellín. Filters aggressively for listings with workspace photos and fiber internet mentions. Has written a Medium post about her personal rotation of Superhosts in four cities. Sees Airbnb more as "a distributed home network" than a travel product.
304
+
305
+ **Kenji and Yuki Watanabe, 44 and 41, Yokohama.** Family of four. Book 2–3 Airbnb stays per year for multigenerational trips where hotel rooms would require 2–3 separate rooms. Value the "entire home" filter specifically because it lets grandparents and grandchildren share a kitchen. Read reviews filtered by the "Families" tag. Distrust listings that use professional staging photography — they prefer the slightly-imperfect real-Host photos as a trust signal.
306
+
307
+ ## 14. States
308
+
309
+ | State | Treatment |
310
+ |---|---|
311
+ | **Empty (search, no results)** | Single warm line in near-black (`#222222`): "We couldn't find any homes matching all your filters." One soft-CTA link in Rausch Red: "Clear filters". No illustration. Filter chips visible above so users can adjust in place. |
312
+ | **Empty (wishlist, first use)** | Warm-gray body text: "Save places you love by tapping the heart on any home." One ghost CTA: "Explore homes". No illustration, no sparkles, no tour. |
313
+ | **Empty (messages, new user)** | Near-black headline + warm-gray body: "Your conversations with Hosts will appear here." Nothing more — Airbnb trusts that this becomes obvious once you book. |
314
+ | **Loading (search results)** | Warm-tone skeleton cards preserving the listing-card shape (image area + 3 text lines + price). 1.2s shimmer in a lighter warm tone. Skeletons use the same 12px+ radius as real cards — no geometric surprise on paint-in. |
315
+ | **Loading (map pan)** | Result pins fade at `motion-fast` as the user drags; map tiles load underneath. No blocking overlay, no "Loading..." text on the map. |
316
+ | **Error (booking failed)** | Warm apology + specific cause + recovery path. *"Your booking didn't go through. Please try again, or contact the Host directly."* Rausch Red used only on the "Try again" button. Never a bright red banner. |
317
+ | **Error (form validation)** | Field-level. Ultra-thin border switches from warm gray to Rausch Red. 13px warm message below: what's invalid and what would be valid. |
318
+ | **Error (Host decline)** | Warm, explanatory surface. Not framed as failure — framed as "this Host isn't available; here are similar homes". The rejection is never hidden, but the alternative is immediate and present. |
319
+ | **Success (booking confirmed)** | Dedicated confirmation screen. Host's first name + photo + welcome note if they wrote one. Check-in details prominent. Rausch Red only on the "Message Host" button. Past tense: "You're booked." |
320
+ | **Success (review submitted)** | Brief warm-gray inline confirmation: "Thanks for your review." 4s auto-dismiss. No toast spam; reviews are a small ritual, treated quietly. |
321
+ | **Skeleton** | Warm-tone blocks at exact final card dimensions. Shimmer in a lighter warm tone, never cool blue. Photography placeholder is a subtle warm gradient, never a blank gray square — even skeletons respect the photography-first principle. |
322
+ | **Disabled** | Opacity on text and warm-border together. Rausch Red actions become `rgba(255,56,92,0.3)` — faded warm red, not switched to gray. |
323
+ | **Loading (Host publishing a listing)** | Multi-step progress with named steps ("Photos uploaded", "Description saved", "Calendar synced"). Warm, specific, never abstract "Loading..." text. |
324
+
325
+ ## 15. Motion & Easing
326
+
327
+ **Durations**:
328
+
329
+ | Token | Value | Use |
330
+ |---|---|---|
331
+ | `motion-instant` | 0ms | State commits, selection, keyboard confirm |
332
+ | `motion-fast` | 160ms | Hover, focus, heart-icon toggle, map pin interactions |
333
+ | `motion-standard` | 260ms | Sheet, modal, gallery swipe, card expand |
334
+ | `motion-slow` | 400ms | Full-screen photo gallery transitions, rare hero reveals |
335
+
336
+ **Easings**:
337
+
338
+ | Token | Curve | Use |
339
+ |---|---|---|
340
+ | `ease-enter` | `cubic-bezier(0.2, 0.6, 0.25, 1)` | Arriving — sheets, modals, filter drawers |
341
+ | `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals |
342
+ | `ease-standard` | `cubic-bezier(0.25, 0.1, 0.25, 1)` | Two-way transitions |
343
+ | `ease-warm` | `cubic-bezier(0.25, 0.8, 0.25, 1)` | Heart-icon toggle, Wishlist save — slightly more settled at the end, matching the emotional register of saving a home |
344
+
345
+ **Signature motions.**
346
+
347
+ 1. **Heart-icon save (Wishlist).** The heart transitions from outline to filled Rausch Red over `motion-fast` with `ease-warm`. A small scale pulse (`0.9 → 1.05 → 1.0`) accompanies the color fill. This is the one place Airbnb's UI allows a tiny "joy" motion — saving a home to come back to later is an emotional act, not a neutral bookmark.
348
+ 2. **Photo gallery swipe.** Full-screen photos swipe at `motion-standard` with `ease-standard`. No parallax on the photos themselves; the user should feel like they're looking at real photographs, not a marketing carousel.
349
+ 3. **Search filter drawer.** Filter drawer rises at `motion-standard` with `ease-enter`. Backdrop fades in synchronously. Dismissal at `motion-fast` with `ease-exit`.
350
+ 4. **Map pin selection.** When a result pin is tapped, the corresponding listing card slides into focus at the bottom of the screen at `motion-standard` with `ease-enter`. The pin itself scales `1.0 → 1.15` over `motion-fast` to confirm selection.
351
+ 5. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. The heart-icon pulse becomes an instant color switch. Gallery transitions become cuts. The product stays fully functional; hospitality voice is preserved through copy, not through motion.
352
+
353
+ <!--
354
+ OmD v0.1 Sources — Philosophy Layer (sections 10–15)
355
+
356
+ Direct verification via WebFetch / WebSearch (2026-04-19):
357
+
358
+ Historical (2014 era) — the foundation still in force:
359
+ - Brian Chesky, "Belong Anywhere" (Medium, July 2014) — confirms the tagline
360
+ launch and this verbatim framing used directly in §10 and §11:
361
+ "really, we're about home. You see, a house is just a space, but a
362
+ home is where you belong. And what makes this global community so
363
+ special is that for the very first time, you can belong anywhere."
364
+ https://medium.com/@bchesky/belong-anywhere-ccf42702d010
365
+ - "How Airbnb Found a Mission—and a Brand" (Fortune longform) — confirms
366
+ the July 2014 rebrand context, the Bélo logo naming (by then-CMO
367
+ Jonathan Mildenhall), and the campaign framing verbatim:
368
+ "the universal human yearning to belong — the desire to feel
369
+ welcomed, and respected, and appreciated for who you are, no
370
+ matter where you might be."
371
+ https://fortune.com/longform/airbnb-travel-mission-brand/
372
+
373
+ Contemporary (2024–2025 era) — the current positioning:
374
+ - Airbnb 2024 Summer Release (Icons launch) — WebSearch confirms verbatim:
375
+ "extraordinary experiences from the world's greatest icons"
376
+ Also confirmed: the Icons category launch with partners across sports,
377
+ music, and film; group-trip features (shared wishlists, redesigned
378
+ Messages tab). Announced by Brian Chesky in a 34-minute video release.
379
+ https://news.airbnb.com/airbnb-2024-summer-release/
380
+ - Airbnb 2025 Summer Release — WebSearch confirms Brian Chesky verbatim:
381
+ "With the launch of services and experiences, we're changing travel
382
+ again. Now you can Airbnb more than an Airbnb."
383
+ Three-pillar expansion confirmed (Homes + Experiences + Services), 10
384
+ launch categories (including Chefs) across 260 cities, Airbnb Originals
385
+ line.
386
+ https://news.airbnb.com/airbnb-2025-summer-release/
387
+ https://www.airbnb.com/release
388
+ - Medium / Design Bootcamp, "Airbnb Summer 2025 update" — confirms the
389
+ visual-language refresh verbatim:
390
+ "3D, skeuomorphic, Pixar-inspired icons — vibrant, tactile, and full
391
+ of depth"
392
+ "smooth animations, subtle lighting, soft curves, and drop-shadows"
393
+ "playful, utility-driven icon set with consistent visual language —
394
+ curved, bold, and full of personality"
395
+ Also confirms that Cereal typeface and existing logo were preserved
396
+ through the 2025 redesign — evolution, not reboot.
397
+
398
+ Note: Direct WebFetch of https://news.airbnb.com/ and https://www.airbnb.com/
399
+ returned HTTP 403 (likely bot protection), so 2024–2025 release quotes
400
+ above were captured via WebSearch against the same underlying source pages
401
+ and cross-confirmed against the Medium analysis piece.
402
+
403
+ Base DESIGN.md (sections 1–9) is the source for all token-level claims
404
+ (Rausch Red #ff385c, Airbnb Cereal VF typeface, three-layer shadow stacks,
405
+ generous radius scale 8px–32px, Near-Black #222222, Luxe Purple #460479
406
+ and Plus Magenta #92174d for premium tiers).
407
+
408
+ Not independently verified via WebFetch — widely documented public facts used:
409
+ - Airbnb was founded in 2008 in San Francisco by Brian Chesky, Joe Gebbia,
410
+ and Nathan Blecharczyk; the origin story involving air mattresses during
411
+ a San Francisco design conference is widely documented.
412
+ - Rausch Red (#ff385c) is reported to be named after Rausch Street, the
413
+ location of an early Airbnb office.
414
+ - Airbnb's Host / Superhost program terminology is widely used in
415
+ the company's own product and Host-facing surfaces.
416
+
417
+ Personas (§13) are fictional archetypes informed by publicly observable
418
+ Airbnb user segments (leisure travelers, Hosts / Superhosts, long-stay
419
+ remote workers, multigenerational family travelers). Names are illustrative;
420
+ they do not refer to real people.
421
+
422
+ Interpretive claims (e.g., "hospitality is more than a look", "the Bélo is
423
+ universal on purpose", "warm minimalism refuses the cool-gray institutional
424
+ default") are editorial readings connecting Airbnb's stated 2014 brand
425
+ thesis to the design system, not directly sourced Airbnb statements.
426
+ -->
427
+
@@ -0,0 +1,23 @@
1
+ # Airbnb Inspired Design System
2
+
3
+ [DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/airbnb/DESIGN.md) extracted from the public [Airbnb](https://airbnb.com/) website. This is not the official design system. Colors, fonts, and spacing may not be 100% accurate. But it's a good starting point for building something similar.
4
+
5
+ ## Files
6
+
7
+ | File | Description |
8
+ |------|-------------|
9
+ | `DESIGN.md` | Complete design system documentation (9 sections) |
10
+ | `preview.html` | Interactive design token catalog (light) |
11
+ | `preview-dark.html` | Interactive design token catalog (dark) |
12
+
13
+ Use [DESIGN.md](https://github.com/VoltAgent/awesome-design-md/blob/main/design-md/airbnb/DESIGN.md) to use as a reference for AI agents (Claude, Cursor, Stitch) to generate UI that looks like the Airbnb design language.
14
+
15
+ ## Preview
16
+
17
+ A sample landing page built with DESIGN.md. It shows the actual colors, typography, buttons, cards, spacing, and elevation, all in one page.
18
+
19
+ ### Dark Mode
20
+ ![Airbnb Design System — Dark Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/airbnb/preview-dark-screenshot.png)
21
+
22
+ ### Light Mode
23
+ ![Airbnb Design System — Light Mode](https://pub-2e4ecbcbc9b24e7b93f1a6ab5b2bc71f.r2.dev/designs/airbnb/preview-screenshot.png)