solmate-skills 1.0.1 → 1.0.2

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 (374) hide show
  1. package/AGENTS.md +6 -2
  2. package/README.md +142 -20
  3. package/awesome-design-md/.github/FUNDING.yml +4 -0
  4. package/awesome-design-md/.github/ISSUE_TEMPLATE/design-md-request.yml +46 -0
  5. package/awesome-design-md/CONTRIBUTING.md +28 -0
  6. package/awesome-design-md/LICENSE +21 -0
  7. package/awesome-design-md/README.md +172 -0
  8. package/awesome-design-md/design-md/airbnb/DESIGN.md +246 -0
  9. package/awesome-design-md/design-md/airbnb/README.md +23 -0
  10. package/awesome-design-md/design-md/airbnb/preview-dark.html +234 -0
  11. package/awesome-design-md/design-md/airbnb/preview.html +233 -0
  12. package/awesome-design-md/design-md/airtable/DESIGN.md +89 -0
  13. package/awesome-design-md/design-md/airtable/README.md +23 -0
  14. package/awesome-design-md/design-md/airtable/preview-dark.html +165 -0
  15. package/awesome-design-md/design-md/airtable/preview.html +164 -0
  16. package/awesome-design-md/design-md/apple/DESIGN.md +313 -0
  17. package/awesome-design-md/design-md/apple/README.md +24 -0
  18. package/awesome-design-md/design-md/apple/preview-dark.html +422 -0
  19. package/awesome-design-md/design-md/apple/preview.html +416 -0
  20. package/awesome-design-md/design-md/bmw/DESIGN.md +180 -0
  21. package/awesome-design-md/design-md/bmw/README.md +23 -0
  22. package/awesome-design-md/design-md/bmw/preview-dark.html +211 -0
  23. package/awesome-design-md/design-md/bmw/preview.html +210 -0
  24. package/awesome-design-md/design-md/cal/DESIGN.md +259 -0
  25. package/awesome-design-md/design-md/cal/README.md +23 -0
  26. package/awesome-design-md/design-md/cal/preview-dark.html +449 -0
  27. package/awesome-design-md/design-md/cal/preview.html +575 -0
  28. package/awesome-design-md/design-md/claude/DESIGN.md +312 -0
  29. package/awesome-design-md/design-md/claude/README.md +24 -0
  30. package/awesome-design-md/design-md/claude/preview-dark.html +803 -0
  31. package/awesome-design-md/design-md/claude/preview.html +826 -0
  32. package/awesome-design-md/design-md/clay/DESIGN.md +304 -0
  33. package/awesome-design-md/design-md/clay/README.md +23 -0
  34. package/awesome-design-md/design-md/clay/preview-dark.html +318 -0
  35. package/awesome-design-md/design-md/clay/preview.html +317 -0
  36. package/awesome-design-md/design-md/clickhouse/DESIGN.md +281 -0
  37. package/awesome-design-md/design-md/clickhouse/README.md +24 -0
  38. package/awesome-design-md/design-md/clickhouse/preview-dark.html +834 -0
  39. package/awesome-design-md/design-md/clickhouse/preview.html +786 -0
  40. package/awesome-design-md/design-md/cohere/DESIGN.md +266 -0
  41. package/awesome-design-md/design-md/cohere/README.md +24 -0
  42. package/awesome-design-md/design-md/cohere/preview-dark.html +810 -0
  43. package/awesome-design-md/design-md/cohere/preview.html +814 -0
  44. package/awesome-design-md/design-md/coinbase/DESIGN.md +129 -0
  45. package/awesome-design-md/design-md/coinbase/README.md +23 -0
  46. package/awesome-design-md/design-md/coinbase/preview-dark.html +164 -0
  47. package/awesome-design-md/design-md/coinbase/preview.html +163 -0
  48. package/awesome-design-md/design-md/composio/DESIGN.md +307 -0
  49. package/awesome-design-md/design-md/composio/README.md +24 -0
  50. package/awesome-design-md/design-md/composio/preview-dark.html +958 -0
  51. package/awesome-design-md/design-md/composio/preview.html +933 -0
  52. package/awesome-design-md/design-md/cursor/DESIGN.md +309 -0
  53. package/awesome-design-md/design-md/cursor/README.md +24 -0
  54. package/awesome-design-md/design-md/cursor/preview-dark.html +395 -0
  55. package/awesome-design-md/design-md/cursor/preview.html +385 -0
  56. package/awesome-design-md/design-md/elevenlabs/DESIGN.md +265 -0
  57. package/awesome-design-md/design-md/elevenlabs/README.md +23 -0
  58. package/awesome-design-md/design-md/elevenlabs/preview-dark.html +254 -0
  59. package/awesome-design-md/design-md/elevenlabs/preview.html +253 -0
  60. package/awesome-design-md/design-md/expo/DESIGN.md +281 -0
  61. package/awesome-design-md/design-md/expo/README.md +24 -0
  62. package/awesome-design-md/design-md/expo/preview-dark.html +536 -0
  63. package/awesome-design-md/design-md/expo/preview.html +536 -0
  64. package/awesome-design-md/design-md/figma/DESIGN.md +220 -0
  65. package/awesome-design-md/design-md/figma/README.md +24 -0
  66. package/awesome-design-md/design-md/figma/preview-dark.html +831 -0
  67. package/awesome-design-md/design-md/figma/preview.html +841 -0
  68. package/awesome-design-md/design-md/framer/DESIGN.md +246 -0
  69. package/awesome-design-md/design-md/framer/README.md +23 -0
  70. package/awesome-design-md/design-md/framer/preview-dark.html +904 -0
  71. package/awesome-design-md/design-md/framer/preview.html +885 -0
  72. package/awesome-design-md/design-md/hashicorp/DESIGN.md +278 -0
  73. package/awesome-design-md/design-md/hashicorp/README.md +24 -0
  74. package/awesome-design-md/design-md/hashicorp/preview-dark.html +1206 -0
  75. package/awesome-design-md/design-md/hashicorp/preview.html +1195 -0
  76. package/awesome-design-md/design-md/ibm/DESIGN.md +332 -0
  77. package/awesome-design-md/design-md/ibm/README.md +24 -0
  78. package/awesome-design-md/design-md/ibm/preview-dark.html +445 -0
  79. package/awesome-design-md/design-md/ibm/preview.html +430 -0
  80. package/awesome-design-md/design-md/intercom/DESIGN.md +146 -0
  81. package/awesome-design-md/design-md/intercom/README.md +23 -0
  82. package/awesome-design-md/design-md/intercom/preview-dark.html +185 -0
  83. package/awesome-design-md/design-md/intercom/preview.html +184 -0
  84. package/awesome-design-md/design-md/kraken/DESIGN.md +125 -0
  85. package/awesome-design-md/design-md/kraken/README.md +23 -0
  86. package/awesome-design-md/design-md/kraken/preview-dark.html +169 -0
  87. package/awesome-design-md/design-md/kraken/preview.html +168 -0
  88. package/awesome-design-md/design-md/linear.app/DESIGN.md +367 -0
  89. package/awesome-design-md/design-md/linear.app/README.md +24 -0
  90. package/awesome-design-md/design-md/linear.app/preview-dark.html +385 -0
  91. package/awesome-design-md/design-md/linear.app/preview.html +375 -0
  92. package/awesome-design-md/design-md/lovable/DESIGN.md +298 -0
  93. package/awesome-design-md/design-md/lovable/README.md +24 -0
  94. package/awesome-design-md/design-md/lovable/preview-dark.html +351 -0
  95. package/awesome-design-md/design-md/lovable/preview.html +350 -0
  96. package/awesome-design-md/design-md/minimax/DESIGN.md +257 -0
  97. package/awesome-design-md/design-md/minimax/README.md +24 -0
  98. package/awesome-design-md/design-md/minimax/preview-dark.html +1267 -0
  99. package/awesome-design-md/design-md/minimax/preview.html +1253 -0
  100. package/awesome-design-md/design-md/mintlify/DESIGN.md +326 -0
  101. package/awesome-design-md/design-md/mintlify/README.md +24 -0
  102. package/awesome-design-md/design-md/mintlify/preview-dark.html +411 -0
  103. package/awesome-design-md/design-md/mintlify/preview.html +400 -0
  104. package/awesome-design-md/design-md/miro/DESIGN.md +108 -0
  105. package/awesome-design-md/design-md/miro/README.md +23 -0
  106. package/awesome-design-md/design-md/miro/preview-dark.html +174 -0
  107. package/awesome-design-md/design-md/miro/preview.html +173 -0
  108. package/awesome-design-md/design-md/mistral.ai/DESIGN.md +261 -0
  109. package/awesome-design-md/design-md/mistral.ai/README.md +24 -0
  110. package/awesome-design-md/design-md/mistral.ai/preview-dark.html +813 -0
  111. package/awesome-design-md/design-md/mistral.ai/preview.html +812 -0
  112. package/awesome-design-md/design-md/mongodb/DESIGN.md +266 -0
  113. package/awesome-design-md/design-md/mongodb/README.md +23 -0
  114. package/awesome-design-md/design-md/mongodb/preview-dark.html +262 -0
  115. package/awesome-design-md/design-md/mongodb/preview.html +261 -0
  116. package/awesome-design-md/design-md/notion/DESIGN.md +309 -0
  117. package/awesome-design-md/design-md/notion/README.md +24 -0
  118. package/awesome-design-md/design-md/notion/preview-dark.html +374 -0
  119. package/awesome-design-md/design-md/notion/preview.html +366 -0
  120. package/awesome-design-md/design-md/nvidia/DESIGN.md +293 -0
  121. package/awesome-design-md/design-md/nvidia/README.md +24 -0
  122. package/awesome-design-md/design-md/nvidia/preview-dark.html +376 -0
  123. package/awesome-design-md/design-md/nvidia/preview.html +368 -0
  124. package/awesome-design-md/design-md/ollama/DESIGN.md +267 -0
  125. package/awesome-design-md/design-md/ollama/README.md +24 -0
  126. package/awesome-design-md/design-md/ollama/preview-dark.html +678 -0
  127. package/awesome-design-md/design-md/ollama/preview.html +678 -0
  128. package/awesome-design-md/design-md/opencode.ai/DESIGN.md +281 -0
  129. package/awesome-design-md/design-md/opencode.ai/README.md +24 -0
  130. package/awesome-design-md/design-md/opencode.ai/preview-dark.html +368 -0
  131. package/awesome-design-md/design-md/opencode.ai/preview.html +359 -0
  132. package/awesome-design-md/design-md/pinterest/DESIGN.md +230 -0
  133. package/awesome-design-md/design-md/pinterest/README.md +23 -0
  134. package/awesome-design-md/design-md/pinterest/preview-dark.html +233 -0
  135. package/awesome-design-md/design-md/pinterest/preview.html +232 -0
  136. package/awesome-design-md/design-md/posthog/DESIGN.md +256 -0
  137. package/awesome-design-md/design-md/posthog/README.md +23 -0
  138. package/awesome-design-md/design-md/posthog/preview-dark.html +701 -0
  139. package/awesome-design-md/design-md/posthog/preview.html +751 -0
  140. package/awesome-design-md/design-md/raycast/DESIGN.md +268 -0
  141. package/awesome-design-md/design-md/raycast/README.md +23 -0
  142. package/awesome-design-md/design-md/raycast/preview-dark.html +608 -0
  143. package/awesome-design-md/design-md/raycast/preview.html +690 -0
  144. package/awesome-design-md/design-md/replicate/DESIGN.md +261 -0
  145. package/awesome-design-md/design-md/replicate/README.md +24 -0
  146. package/awesome-design-md/design-md/replicate/preview-dark.html +828 -0
  147. package/awesome-design-md/design-md/replicate/preview.html +831 -0
  148. package/awesome-design-md/design-md/resend/DESIGN.md +303 -0
  149. package/awesome-design-md/design-md/resend/README.md +23 -0
  150. package/awesome-design-md/design-md/resend/preview-dark.html +357 -0
  151. package/awesome-design-md/design-md/resend/preview.html +356 -0
  152. package/awesome-design-md/design-md/revolut/DESIGN.md +185 -0
  153. package/awesome-design-md/design-md/revolut/README.md +23 -0
  154. package/awesome-design-md/design-md/revolut/preview-dark.html +234 -0
  155. package/awesome-design-md/design-md/revolut/preview.html +233 -0
  156. package/awesome-design-md/design-md/runwayml/DESIGN.md +244 -0
  157. package/awesome-design-md/design-md/runwayml/README.md +24 -0
  158. package/awesome-design-md/design-md/runwayml/preview-dark.html +664 -0
  159. package/awesome-design-md/design-md/runwayml/preview.html +665 -0
  160. package/awesome-design-md/design-md/sanity/DESIGN.md +357 -0
  161. package/awesome-design-md/design-md/sanity/README.md +24 -0
  162. package/awesome-design-md/design-md/sanity/preview-dark.html +995 -0
  163. package/awesome-design-md/design-md/sanity/preview.html +1140 -0
  164. package/awesome-design-md/design-md/sentry/DESIGN.md +262 -0
  165. package/awesome-design-md/design-md/sentry/README.md +24 -0
  166. package/awesome-design-md/design-md/sentry/preview-dark.html +628 -0
  167. package/awesome-design-md/design-md/sentry/preview.html +953 -0
  168. package/awesome-design-md/design-md/spacex/DESIGN.md +194 -0
  169. package/awesome-design-md/design-md/spacex/README.md +23 -0
  170. package/awesome-design-md/design-md/spacex/preview-dark.html +223 -0
  171. package/awesome-design-md/design-md/spacex/preview.html +222 -0
  172. package/awesome-design-md/design-md/spotify/DESIGN.md +246 -0
  173. package/awesome-design-md/design-md/spotify/README.md +23 -0
  174. package/awesome-design-md/design-md/spotify/preview-dark.html +231 -0
  175. package/awesome-design-md/design-md/spotify/preview.html +230 -0
  176. package/awesome-design-md/design-md/stripe/DESIGN.md +322 -0
  177. package/awesome-design-md/design-md/stripe/README.md +24 -0
  178. package/awesome-design-md/design-md/stripe/preview-dark.html +430 -0
  179. package/awesome-design-md/design-md/stripe/preview.html +421 -0
  180. package/awesome-design-md/design-md/supabase/DESIGN.md +255 -0
  181. package/awesome-design-md/design-md/supabase/README.md +24 -0
  182. package/awesome-design-md/design-md/supabase/preview-dark.html +977 -0
  183. package/awesome-design-md/design-md/supabase/preview.html +955 -0
  184. package/awesome-design-md/design-md/superhuman/DESIGN.md +252 -0
  185. package/awesome-design-md/design-md/superhuman/README.md +23 -0
  186. package/awesome-design-md/design-md/superhuman/preview-dark.html +975 -0
  187. package/awesome-design-md/design-md/superhuman/preview.html +953 -0
  188. package/awesome-design-md/design-md/together.ai/DESIGN.md +263 -0
  189. package/awesome-design-md/design-md/together.ai/README.md +24 -0
  190. package/awesome-design-md/design-md/together.ai/preview-dark.html +892 -0
  191. package/awesome-design-md/design-md/together.ai/preview.html +897 -0
  192. package/awesome-design-md/design-md/uber/DESIGN.md +295 -0
  193. package/awesome-design-md/design-md/uber/README.md +24 -0
  194. package/awesome-design-md/design-md/uber/preview-dark.html +1164 -0
  195. package/awesome-design-md/design-md/uber/preview.html +1163 -0
  196. package/awesome-design-md/design-md/vercel/DESIGN.md +310 -0
  197. package/awesome-design-md/design-md/vercel/README.md +24 -0
  198. package/awesome-design-md/design-md/vercel/preview-dark.html +370 -0
  199. package/awesome-design-md/design-md/vercel/preview.html +369 -0
  200. package/awesome-design-md/design-md/voltagent/DESIGN.md +323 -0
  201. package/awesome-design-md/design-md/voltagent/README.md +24 -0
  202. package/awesome-design-md/design-md/voltagent/preview-dark.html +487 -0
  203. package/awesome-design-md/design-md/voltagent/preview.html +766 -0
  204. package/awesome-design-md/design-md/warp/DESIGN.md +253 -0
  205. package/awesome-design-md/design-md/warp/README.md +23 -0
  206. package/awesome-design-md/design-md/warp/preview-dark.html +502 -0
  207. package/awesome-design-md/design-md/warp/preview.html +535 -0
  208. package/awesome-design-md/design-md/webflow/DESIGN.md +92 -0
  209. package/awesome-design-md/design-md/webflow/README.md +23 -0
  210. package/awesome-design-md/design-md/webflow/preview-dark.html +147 -0
  211. package/awesome-design-md/design-md/webflow/preview.html +146 -0
  212. package/awesome-design-md/design-md/wise/DESIGN.md +173 -0
  213. package/awesome-design-md/design-md/wise/README.md +23 -0
  214. package/awesome-design-md/design-md/wise/preview-dark.html +230 -0
  215. package/awesome-design-md/design-md/wise/preview.html +229 -0
  216. package/awesome-design-md/design-md/x.ai/DESIGN.md +257 -0
  217. package/awesome-design-md/design-md/x.ai/README.md +24 -0
  218. package/awesome-design-md/design-md/x.ai/preview-dark.html +358 -0
  219. package/awesome-design-md/design-md/x.ai/preview.html +409 -0
  220. package/awesome-design-md/design-md/zapier/DESIGN.md +328 -0
  221. package/awesome-design-md/design-md/zapier/README.md +24 -0
  222. package/awesome-design-md/design-md/zapier/preview-dark.html +382 -0
  223. package/awesome-design-md/design-md/zapier/preview.html +374 -0
  224. package/business-plan/SKILL.md +227 -0
  225. package/dev-docs/SKILL.md +178 -0
  226. package/k-skill/.changeset/config.json +11 -0
  227. package/k-skill/.github/release-please/python-config.json +3 -0
  228. package/k-skill/.github/release-please/python-manifest.json +1 -0
  229. package/k-skill/.github/workflows/ci.yml +21 -0
  230. package/k-skill/.github/workflows/release-npm.yml +51 -0
  231. package/k-skill/.github/workflows/release-python.yml +41 -0
  232. package/k-skill/AGENTS.md +36 -0
  233. package/k-skill/CLAUDE.md +5 -0
  234. package/k-skill/LICENSE +21 -0
  235. package/k-skill/README.md +83 -0
  236. package/k-skill/blue-ribbon-nearby/SKILL.md +132 -0
  237. package/k-skill/coupang-product-search/SKILL.md +136 -0
  238. package/k-skill/daiso-product-search/SKILL.md +165 -0
  239. package/k-skill/delivery-tracking/SKILL.md +368 -0
  240. package/k-skill/docs/assets/k-skill-thumbnail.png +0 -0
  241. package/k-skill/docs/features/blue-ribbon-nearby.md +128 -0
  242. package/k-skill/docs/features/coupang-product-search.md +103 -0
  243. package/k-skill/docs/features/daiso-product-search.md +83 -0
  244. package/k-skill/docs/features/delivery-tracking.md +301 -0
  245. package/k-skill/docs/features/fine-dust-location.md +128 -0
  246. package/k-skill/docs/features/hwp.md +105 -0
  247. package/k-skill/docs/features/k-skill-proxy.md +82 -0
  248. package/k-skill/docs/features/kakao-bar-nearby.md +107 -0
  249. package/k-skill/docs/features/kakaotalk-mac.md +60 -0
  250. package/k-skill/docs/features/kbo-results.md +49 -0
  251. package/k-skill/docs/features/kleague-results.md +62 -0
  252. package/k-skill/docs/features/korean-law-search.md +127 -0
  253. package/k-skill/docs/features/ktx-booking.md +99 -0
  254. package/k-skill/docs/features/lotto-results.md +41 -0
  255. package/k-skill/docs/features/seoul-subway-arrival.md +61 -0
  256. package/k-skill/docs/features/srt-booking.md +67 -0
  257. package/k-skill/docs/features/toss-securities.md +83 -0
  258. package/k-skill/docs/features/used-car-price-search.md +86 -0
  259. package/k-skill/docs/features/zipcode-search.md +100 -0
  260. package/k-skill/docs/install.md +167 -0
  261. package/k-skill/docs/releasing.md +51 -0
  262. package/k-skill/docs/roadmap.md +135 -0
  263. package/k-skill/docs/security-and-secrets.md +69 -0
  264. package/k-skill/docs/setup.md +75 -0
  265. package/k-skill/docs/sources.md +47 -0
  266. package/k-skill/ecosystem.config.cjs +16 -0
  267. package/k-skill/examples/secrets.env.example +7 -0
  268. package/k-skill/fine-dust-location/SKILL.md +99 -0
  269. package/k-skill/hwp/SKILL.md +182 -0
  270. package/k-skill/k-skill-setup/SKILL.md +180 -0
  271. package/k-skill/kakao-bar-nearby/SKILL.md +86 -0
  272. package/k-skill/kakaotalk-mac/SKILL.md +167 -0
  273. package/k-skill/kbo-results/SKILL.md +92 -0
  274. package/k-skill/kleague-results/SKILL.md +102 -0
  275. package/k-skill/korean-law-search/SKILL.md +174 -0
  276. package/k-skill/ktx-booking/SKILL.md +138 -0
  277. package/k-skill/lotto-results/SKILL.md +90 -0
  278. package/k-skill/package.json +25 -0
  279. package/k-skill/packages/blue-ribbon-nearby/CHANGELOG.md +7 -0
  280. package/k-skill/packages/blue-ribbon-nearby/README.md +80 -0
  281. package/k-skill/packages/blue-ribbon-nearby/package.json +32 -0
  282. package/k-skill/packages/blue-ribbon-nearby/src/index.js +255 -0
  283. package/k-skill/packages/blue-ribbon-nearby/src/parse.js +309 -0
  284. package/k-skill/packages/blue-ribbon-nearby/test/fixtures/restaurants-map.json +48 -0
  285. package/k-skill/packages/blue-ribbon-nearby/test/fixtures/search-zone.html +17 -0
  286. package/k-skill/packages/blue-ribbon-nearby/test/index.test.js +159 -0
  287. package/k-skill/packages/daiso-product-search/CHANGELOG.md +7 -0
  288. package/k-skill/packages/daiso-product-search/README.md +80 -0
  289. package/k-skill/packages/daiso-product-search/package.json +32 -0
  290. package/k-skill/packages/daiso-product-search/src/index.js +183 -0
  291. package/k-skill/packages/daiso-product-search/src/parse.js +385 -0
  292. package/k-skill/packages/daiso-product-search/test/fixtures/online-stock.json +11 -0
  293. package/k-skill/packages/daiso-product-search/test/fixtures/search-goods.json +72 -0
  294. package/k-skill/packages/daiso-product-search/test/fixtures/store-detail.json +19 -0
  295. package/k-skill/packages/daiso-product-search/test/fixtures/store-pickup-stock.json +13 -0
  296. package/k-skill/packages/daiso-product-search/test/fixtures/store-search.json +38 -0
  297. package/k-skill/packages/daiso-product-search/test/index.test.js +454 -0
  298. package/k-skill/packages/k-lotto/CHANGELOG.md +7 -0
  299. package/k-skill/packages/k-lotto/README.md +44 -0
  300. package/k-skill/packages/k-lotto/package.json +31 -0
  301. package/k-skill/packages/k-lotto/src/index.js +107 -0
  302. package/k-skill/packages/k-lotto/src/parse.js +209 -0
  303. package/k-skill/packages/k-lotto/test/fixtures/latest-result.html +6 -0
  304. package/k-skill/packages/k-lotto/test/fixtures/round-1216.json +43 -0
  305. package/k-skill/packages/k-lotto/test/index.test.js +95 -0
  306. package/k-skill/packages/k-skill-proxy/README.md +40 -0
  307. package/k-skill/packages/k-skill-proxy/package.json +18 -0
  308. package/k-skill/packages/k-skill-proxy/src/airkorea.js +427 -0
  309. package/k-skill/packages/k-skill-proxy/src/server.js +448 -0
  310. package/k-skill/packages/k-skill-proxy/test/airkorea.test.js +195 -0
  311. package/k-skill/packages/k-skill-proxy/test/server.test.js +324 -0
  312. package/k-skill/packages/kakao-bar-nearby/CHANGELOG.md +7 -0
  313. package/k-skill/packages/kakao-bar-nearby/README.md +73 -0
  314. package/k-skill/packages/kakao-bar-nearby/package.json +33 -0
  315. package/k-skill/packages/kakao-bar-nearby/src/index.js +231 -0
  316. package/k-skill/packages/kakao-bar-nearby/src/parse.js +308 -0
  317. package/k-skill/packages/kakao-bar-nearby/test/fixtures/anchor-panel.json +21 -0
  318. package/k-skill/packages/kakao-bar-nearby/test/fixtures/anchor-search.html +22 -0
  319. package/k-skill/packages/kakao-bar-nearby/test/fixtures/bar-search.html +47 -0
  320. package/k-skill/packages/kakao-bar-nearby/test/fixtures/closed-bar-panel.json +72 -0
  321. package/k-skill/packages/kakao-bar-nearby/test/fixtures/non-bar-panel.json +28 -0
  322. package/k-skill/packages/kakao-bar-nearby/test/fixtures/open-bar-panel.json +80 -0
  323. package/k-skill/packages/kakao-bar-nearby/test/index.test.js +457 -0
  324. package/k-skill/packages/kleague-results/CHANGELOG.md +7 -0
  325. package/k-skill/packages/kleague-results/README.md +65 -0
  326. package/k-skill/packages/kleague-results/package.json +31 -0
  327. package/k-skill/packages/kleague-results/src/index.js +139 -0
  328. package/k-skill/packages/kleague-results/src/parse.js +387 -0
  329. package/k-skill/packages/kleague-results/test/fixtures/schedule-kleague1-2026-03.json +2195 -0
  330. package/k-skill/packages/kleague-results/test/fixtures/standings-kleague1-2026.json +1102 -0
  331. package/k-skill/packages/kleague-results/test/index.test.js +154 -0
  332. package/k-skill/packages/toss-securities/CHANGELOG.md +7 -0
  333. package/k-skill/packages/toss-securities/README.md +73 -0
  334. package/k-skill/packages/toss-securities/package.json +32 -0
  335. package/k-skill/packages/toss-securities/src/index.js +98 -0
  336. package/k-skill/packages/toss-securities/src/parse.js +123 -0
  337. package/k-skill/packages/toss-securities/test/index.test.js +103 -0
  338. package/k-skill/packages/used-car-price-search/CHANGELOG.md +7 -0
  339. package/k-skill/packages/used-car-price-search/README.md +50 -0
  340. package/k-skill/packages/used-car-price-search/package.json +32 -0
  341. package/k-skill/packages/used-car-price-search/src/index.js +51 -0
  342. package/k-skill/packages/used-car-price-search/src/providers/sk-tagobuy.js +123 -0
  343. package/k-skill/packages/used-car-price-search/src/search.js +87 -0
  344. package/k-skill/packages/used-car-price-search/src/util.js +41 -0
  345. package/k-skill/packages/used-car-price-search/test/fixtures/tb-empty.html +2 -0
  346. package/k-skill/packages/used-car-price-search/test/fixtures/tb-page.html +7 -0
  347. package/k-skill/packages/used-car-price-search/test/index.test.js +175 -0
  348. package/k-skill/python-packages/README.md +17 -0
  349. package/k-skill/scripts/check-setup.sh +29 -0
  350. package/k-skill/scripts/fine_dust.py +542 -0
  351. package/k-skill/scripts/fixtures/delivery-tracking-public-provenance.json +10 -0
  352. package/k-skill/scripts/fixtures/delivery-tracking-public-samples.json +51 -0
  353. package/k-skill/scripts/fixtures/fine-dust-measurements.json +35 -0
  354. package/k-skill/scripts/fixtures/fine-dust-stations.json +26 -0
  355. package/k-skill/scripts/ktx_booking.py +760 -0
  356. package/k-skill/scripts/run-k-skill-proxy.sh +15 -0
  357. package/k-skill/scripts/skill-docs.test.js +1104 -0
  358. package/k-skill/scripts/test_fine_dust.py +284 -0
  359. package/k-skill/scripts/test_ktx_booking.py +204 -0
  360. package/k-skill/scripts/validate-skills.sh +56 -0
  361. package/k-skill/seoul-subway-arrival/SKILL.md +95 -0
  362. package/k-skill/srt-booking/SKILL.md +150 -0
  363. package/k-skill/toss-securities/SKILL.md +106 -0
  364. package/k-skill/tsconfig.json +24 -0
  365. package/k-skill/used-car-price-search/SKILL.md +119 -0
  366. package/k-skill/zipcode-search/SKILL.md +144 -0
  367. package/manage-docs/SKILL.md +60 -327
  368. package/package.json +1 -1
  369. package/pitch-deck/SKILL.md +272 -0
  370. package/plan-docs/SKILL.md +156 -0
  371. package/product-workflow/SKILL.md +278 -0
  372. package/role-team-lead/SKILL.md +65 -0
  373. package/role-team-member/SKILL.md +74 -0
  374. package/verify-docs/SKILL.md +91 -16
@@ -0,0 +1,246 @@
1
+ # Design System: Airbnb
2
+
3
+ ## 1. Visual Theme & Atmosphere
4
+
5
+ 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.
6
+
7
+ 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.
8
+
9
+ 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.
10
+
11
+ **Key Characteristics:**
12
+ - Pure white canvas with Rausch Red (`#ff385c`) as singular brand accent
13
+ - Airbnb Cereal VF — custom variable font with warm, rounded terminals
14
+ - Palette-based token system (`--palette-*`) for systematic color management
15
+ - Three-layer card shadows: border ring + soft blur + stronger blur
16
+ - Generous border-radius: 8px buttons, 14px badges, 20px cards, 32px large elements
17
+ - Circular navigation controls (50% radius)
18
+ - Photography-first listing cards — images are the hero content
19
+ - Near-black text (`#222222`) — warm, not cold
20
+ - Luxe Purple (`#460479`) and Plus Magenta (`#92174d`) for premium tiers
21
+
22
+ ## 2. Color Palette & Roles
23
+
24
+ ### Primary Brand
25
+ - **Rausch Red** (`#ff385c`): `--palette-bg-primary-core`, primary CTA, brand accent, active states
26
+ - **Deep Rausch** (`#e00b41`): `--palette-bg-tertiary-core`, pressed/dark variant of brand red
27
+ - **Error Red** (`#c13515`): `--palette-text-primary-error`, error text on light
28
+ - **Error Dark** (`#b32505`): `--palette-text-secondary-error-hover`, error hover
29
+
30
+ ### Premium Tiers
31
+ - **Luxe Purple** (`#460479`): `--palette-bg-primary-luxe`, Airbnb Luxe tier branding
32
+ - **Plus Magenta** (`#92174d`): `--palette-bg-primary-plus`, Airbnb Plus tier branding
33
+
34
+ ### Text Scale
35
+ - **Near Black** (`#222222`): `--palette-text-primary`, primary text — warm, not cold
36
+ - **Focused Gray** (`#3f3f3f`): `--palette-text-focused`, focused state text
37
+ - **Secondary Gray** (`#6a6a6a`): Secondary text, descriptions
38
+ - **Disabled** (`rgba(0,0,0,0.24)`): `--palette-text-material-disabled`, disabled state
39
+ - **Link Disabled** (`#929292`): `--palette-text-link-disabled`, disabled links
40
+
41
+ ### Interactive
42
+ - **Legal Blue** (`#428bff`): `--palette-text-legal`, legal links, informational
43
+ - **Border Gray** (`#c1c1c1`): Border color for cards and dividers
44
+ - **Light Surface** (`#f2f2f2`): Circular navigation buttons, secondary surfaces
45
+
46
+ ### Surface & Shadows
47
+ - **Pure White** (`#ffffff`): Page background, card surfaces
48
+ - **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
49
+ - **Hover Shadow** (`rgba(0,0,0,0.08) 0px 4px 12px`): Button hover elevation
50
+
51
+ ## 3. Typography Rules
52
+
53
+ ### Font Family
54
+ - **Primary**: `Airbnb Cereal VF`, fallbacks: `Circular, -apple-system, system-ui, Roboto, Helvetica Neue`
55
+ - **OpenType Features**: `"salt"` (stylistic alternates) on specific caption elements
56
+
57
+ ### Hierarchy
58
+
59
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
60
+ |------|------|------|--------|-------------|----------------|-------|
61
+ | Section Heading | Airbnb Cereal VF | 28px (1.75rem) | 700 | 1.43 | normal | Primary headings |
62
+ | Card Heading | Airbnb Cereal VF | 22px (1.38rem) | 600 | 1.18 (tight) | -0.44px | Category/card titles |
63
+ | Card Heading Medium | Airbnb Cereal VF | 22px (1.38rem) | 500 | 1.18 (tight) | -0.44px | Lighter variant |
64
+ | Sub-heading | Airbnb Cereal VF | 21px (1.31rem) | 700 | 1.43 | normal | Bold sub-headings |
65
+ | Feature Title | Airbnb Cereal VF | 20px (1.25rem) | 600 | 1.20 (tight) | -0.18px | Feature headings |
66
+ | UI Medium | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Nav, emphasized text |
67
+ | UI Semibold | Airbnb Cereal VF | 16px (1.00rem) | 600 | 1.25 (tight) | normal | Strong emphasis |
68
+ | Button | Airbnb Cereal VF | 16px (1.00rem) | 500 | 1.25 (tight) | normal | Button labels |
69
+ | Body / Link | Airbnb Cereal VF | 14px (0.88rem) | 400 | 1.43 | normal | Standard body |
70
+ | Body Medium | Airbnb Cereal VF | 14px (0.88rem) | 500 | 1.29 (tight) | normal | Medium body |
71
+ | Caption Salt | Airbnb Cereal VF | 14px (0.88rem) | 600 | 1.43 | normal | `"salt"` feature |
72
+ | Small | Airbnb Cereal VF | 13px (0.81rem) | 400 | 1.23 (tight) | normal | Descriptions |
73
+ | Tag | Airbnb Cereal VF | 12px (0.75rem) | 400–700 | 1.33 | normal | Tags, prices |
74
+ | Badge | Airbnb Cereal VF | 11px (0.69rem) | 600 | 1.18 (tight) | normal | `"salt"` feature |
75
+ | Micro Uppercase | Airbnb Cereal VF | 8px (0.50rem) | 700 | 1.25 (tight) | 0.32px | `text-transform: uppercase` |
76
+
77
+ ### Principles
78
+ - **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.
79
+ - **Negative tracking on headings**: -0.18px to -0.44px letter-spacing on display creates intimate, cozy headings rather than cold, compressed ones.
80
+ - **"salt" OpenType feature**: Stylistic alternates on specific UI elements (badges, captions) create subtle glyph variations that add visual interest.
81
+ - **Variable font precision**: Cereal VF enables continuous weight interpolation, though the design system uses discrete stops at 500, 600, and 700.
82
+
83
+ ## 4. Component Stylings
84
+
85
+ ### Buttons
86
+
87
+ **Primary Dark**
88
+ - Background: `#222222` (near-black, not pure black)
89
+ - Text: `#ffffff`
90
+ - Padding: 0px 24px
91
+ - Radius: 8px
92
+ - Hover: transitions to error/brand accent via `var(--accent-bg-error)`
93
+ - Focus: `0 0 0 2px var(--palette-grey1000)` ring + scale(0.92)
94
+
95
+ **Circular Nav**
96
+ - Background: `#f2f2f2`
97
+ - Text: `#222222`
98
+ - Radius: 50% (circle)
99
+ - Hover: shadow `rgba(0,0,0,0.08) 0px 4px 12px` + translateX(50%)
100
+ - Active: 4px white border ring + focus shadow
101
+ - Focus: scale(0.92) shrink animation
102
+
103
+ ### Cards & Containers
104
+ - Background: `#ffffff`
105
+ - Radius: 14px (badges), 20px (cards/buttons), 32px (large)
106
+ - 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)
107
+ - Listing cards: full-width photography on top, details below
108
+ - Carousel controls: circular 50% buttons
109
+
110
+ ### Inputs
111
+ - Search: `#222222` text
112
+ - Focus: `var(--palette-bg-primary-error)` background tint + `0 0 0 2px` ring
113
+ - Radius: depends on context (search bar uses pill-like rounding)
114
+
115
+ ### Navigation
116
+ - White sticky header with search bar centered
117
+ - Airbnb logo (Rausch Red) left-aligned
118
+ - Category filter pills: horizontal scroll below search
119
+ - Circular nav controls for carousel navigation
120
+ - "Become a Host" text link, avatar/menu right-aligned
121
+
122
+ ### Image Treatment
123
+ - Listing photography fills card top with generous height
124
+ - Image carousel with dot indicators
125
+ - Heart/wishlist icon overlay on images
126
+ - 8px–14px radius on contained images
127
+
128
+ ## 5. Layout Principles
129
+
130
+ ### Spacing System
131
+ - Base unit: 8px
132
+ - Scale: 2px, 3px, 4px, 6px, 8px, 10px, 11px, 12px, 15px, 16px, 22px, 24px, 32px
133
+
134
+ ### Grid & Container
135
+ - Full-width header with centered search
136
+ - Category pill bar: horizontal scrollable row
137
+ - Listing grid: responsive multi-column (3–5 columns on desktop)
138
+ - Full-width footer with link columns
139
+
140
+ ### Whitespace Philosophy
141
+ - **Travel-magazine spacing**: Generous vertical padding between sections creates a leisurely browsing pace — you're meant to scroll slowly, like browsing a magazine.
142
+ - **Photography density**: Listing cards are packed relatively tightly, but each image is large enough to feel immersive.
143
+ - **Search bar prominence**: The search bar gets maximum vertical space in the header — finding your destination is the primary action.
144
+
145
+ ### Border Radius Scale
146
+ - Subtle (4px): Small links
147
+ - Standard (8px): Buttons, tabs, search elements
148
+ - Badge (14px): Status badges, labels
149
+ - Card (20px): Feature cards, large buttons
150
+ - Large (32px): Large containers, hero elements
151
+ - Circle (50%): Nav controls, avatars, icons
152
+
153
+ ## 6. Depth & Elevation
154
+
155
+ | Level | Treatment | Use |
156
+ |-------|-----------|-----|
157
+ | Flat (Level 0) | No shadow | Page background, text blocks |
158
+ | 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 |
159
+ | Hover (Level 2) | `rgba(0,0,0,0.08) 0px 4px 12px` | Button hover, interactive lift |
160
+ | Active Focus (Level 3) | `rgb(255,255,255) 0px 0px 0px 4px` + focus ring | Active/focused elements |
161
+
162
+ **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.
163
+
164
+ ## 7. Do's and Don'ts
165
+
166
+ ### Do
167
+ - Use `#222222` (warm near-black) for text — never pure `#000000`
168
+ - Apply Rausch Red (`#ff385c`) only for primary CTAs and brand moments — it's the singular accent
169
+ - Use Airbnb Cereal VF at weight 500–700 — the warm weight range is intentional
170
+ - Apply the three-layer card shadow for all elevated surfaces
171
+ - Use generous border-radius: 8px for buttons, 20px for cards, 50% for controls
172
+ - Use photography as the primary visual content — listings are image-first
173
+ - Apply negative letter-spacing (-0.18px to -0.44px) on headings for intimacy
174
+ - Use circular (50%) buttons for carousel/navigation controls
175
+
176
+ ### Don't
177
+ - Don't use pure black (`#000000`) for text — always `#222222` (warm)
178
+ - Don't apply Rausch Red to backgrounds or large surfaces — it's an accent only
179
+ - Don't use thin font weights (300, 400) for headings — 500 minimum
180
+ - Don't use heavy shadows (>0.1 opacity as primary layer) — keep them warm and graduated
181
+ - Don't use sharp corners (0–4px) on cards — the generous rounding (20px+) is core
182
+ - Don't introduce additional brand colors beyond the Rausch/Luxe/Plus system
183
+ - Don't override the palette token system — use `--palette-*` variables consistently
184
+
185
+ ## 8. Responsive Behavior
186
+
187
+ ### Breakpoints
188
+ | Name | Width | Key Changes |
189
+ |------|-------|-------------|
190
+ | Mobile Small | <375px | Single column, compact search |
191
+ | Mobile | 375–550px | Standard mobile listing grid |
192
+ | Tablet Small | 550–744px | 2-column listings |
193
+ | Tablet | 744–950px | Search bar expansion |
194
+ | Desktop Small | 950–1128px | 3-column listings |
195
+ | Desktop | 1128–1440px | 4-column grid, full header |
196
+ | Large Desktop | 1440–1920px | 5-column grid |
197
+ | Ultra-wide | >1920px | Maximum grid width |
198
+
199
+ *Note: Airbnb has 61 detected breakpoints — one of the most granular responsive systems observed, reflecting their obsession with layout at every possible screen size.*
200
+
201
+ ### Touch Targets
202
+ - Circular nav buttons: adequate 50% radius sizing
203
+ - Listing cards: full-card tap target on mobile
204
+ - Search bar: prominently sized for thumb interaction
205
+ - Category pills: horizontally scrollable with generous padding
206
+
207
+ ### Collapsing Strategy
208
+ - Listing grid: 5 → 4 → 3 → 2 → 1 columns
209
+ - Search: expanded bar → compact bar → overlay
210
+ - Category pills: horizontal scroll at all sizes
211
+ - Navigation: full header → mobile simplified
212
+ - Map: side panel → overlay/toggle
213
+
214
+ ### Image Behavior
215
+ - Listing photos: carousel with swipe on mobile
216
+ - Responsive image sizing with aspect ratio maintained
217
+ - Heart overlay positioned consistently across sizes
218
+ - Photo quality adjusts based on viewport
219
+
220
+ ## 9. Agent Prompt Guide
221
+
222
+ ### Quick Color Reference
223
+ - Background: Pure White (`#ffffff`)
224
+ - Text: Near Black (`#222222`)
225
+ - Brand accent: Rausch Red (`#ff385c`)
226
+ - Secondary text: `#6a6a6a`
227
+ - Disabled: `rgba(0,0,0,0.24)`
228
+ - Card border: `rgba(0,0,0,0.02) 0px 0px 0px 1px`
229
+ - Card shadow: full three-layer stack
230
+ - Button surface: `#f2f2f2`
231
+
232
+ ### Example Component Prompts
233
+ - "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."
234
+ - "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)."
235
+ - "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)."
236
+ - "Create a CTA button: #222222 background, white text, 8px radius, 16px Cereal VF weight 500, 0px 24px padding. Hover: brand red accent."
237
+ - "Design a heart/wishlist button: transparent background, 50% radius, white heart icon with dark shadow outline."
238
+
239
+ ### Iteration Guide
240
+ 1. Start with white — the photography provides all the color
241
+ 2. Rausch Red (#ff385c) is the singular accent — use sparingly for CTAs only
242
+ 3. Near-black (#222222) for text — the warmth matters
243
+ 4. Three-layer shadows create natural, warm lift — always use all three layers
244
+ 5. Generous radius: 8px buttons, 20px cards, 50% controls
245
+ 6. Cereal VF at 500–700 weight — no thin weights for any heading
246
+ 7. Photography is hero — every listing card is image-first
@@ -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)
@@ -0,0 +1,234 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>Design System Preview: Airbnb (Dark)</title>
7
+ <link rel="preconnect" href="https://fonts.googleapis.com">
8
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
9
+ <link href="https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@400;500;600;700&display=swap" rel="stylesheet">
10
+ <style>
11
+ :root {
12
+ --white: #1a1a1a; --near-black: #f0f0f0; --rausch: #ff385c; --deep-rausch: #e00b41;
13
+ --secondary: #a0a0a0; --disabled: #666666; --border: #3a3a3a; --surface: #2a2a2a;
14
+ --luxe: #460479; --plus: #92174d; --legal-blue: #428bff; --error: #c13515;
15
+ --shadow-card: 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;
16
+ --shadow-hover: rgba(0,0,0,0.08) 0px 4px 12px;
17
+ --font: 'Nunito Sans', -apple-system, system-ui, Roboto, Helvetica Neue, sans-serif;
18
+ }
19
+ * { margin:0; padding:0; box-sizing:border-box; }
20
+ body { background:var(--white); color:var(--near-black); font-family:var(--font); font-size:14px; font-weight:400; line-height:1.43; -webkit-font-smoothing:antialiased; }
21
+
22
+ .nav { position:sticky; top:0; z-index:100; display:flex; align-items:center; justify-content:space-between; padding:14px 24px; background:var(--white); border-bottom:1px solid #2a2a2a; }
23
+ .nav-brand { font-size:14px; font-weight:600; color:var(--near-black); text-decoration:none; }
24
+ .nav-links { display:flex; gap:20px; list-style:none; }
25
+ .nav-links a { font-size:14px; font-weight:500; color:var(--secondary); text-decoration:none; transition:color 0.15s; }
26
+ .nav-links a:hover { color:var(--near-black); }
27
+ .nav-cta { display:inline-flex; align-items:center; justify-content:center; background:var(--rausch); color:var(--white); width:40px; height:40px; border-radius:50%; font-size:18px; font-weight:700; text-decoration:none; border:none; }
28
+
29
+ .hero { padding:64px 24px; text-align:center; }
30
+ .hero h1 { font-size:28px; font-weight:700; line-height:1.43; margin-bottom:12px; }
31
+ .hero h1 span { color:var(--rausch); }
32
+ .hero p { font-size:16px; font-weight:400; color:var(--secondary); max-width:480px; margin:0 auto 24px; }
33
+ .hero-buttons { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
34
+ .btn-dark { display:inline-block; background:var(--near-black); color:var(--white); padding:12px 24px; border-radius:8px; font-family:var(--font); font-size:16px; font-weight:500; text-decoration:none; border:none; cursor:pointer; }
35
+ .btn-outline { display:inline-block; background:transparent; color:var(--near-black); padding:12px 24px; border-radius:8px; border:1px solid var(--near-black); font-family:var(--font); font-size:16px; font-weight:500; text-decoration:none; cursor:pointer; }
36
+ .btn-circle { display:inline-flex; align-items:center; justify-content:center; background:var(--surface); color:var(--near-black); width:36px; height:36px; border-radius:50%; font-size:14px; text-decoration:none; border:none; cursor:pointer; transition:box-shadow 0.2s; }
37
+ .btn-circle:hover { box-shadow:var(--shadow-hover); }
38
+
39
+ .section { padding:48px 24px; max-width:1100px; margin:0 auto; }
40
+ .section-label { font-size:12px; font-weight:700; color:var(--secondary); text-transform:uppercase; letter-spacing:0.32px; margin-bottom:8px; }
41
+ .section-title { font-size:22px; font-weight:600; line-height:1.18; letter-spacing:-0.44px; margin-bottom:24px; }
42
+ .section-divider { border:none; border-top:1px solid #2a2a2a; margin:0; }
43
+
44
+ .color-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(145px,1fr)); gap:10px; margin-bottom:20px; }
45
+ .color-swatch { border-radius:14px; overflow:hidden; box-shadow:var(--shadow-card); }
46
+ .color-swatch-block { height:64px; width:100%; }
47
+ .color-swatch-info { padding:10px; }
48
+ .color-swatch-name { font-size:12px; font-weight:600; margin-bottom:2px; }
49
+ .color-swatch-hex { font-size:10px; color:var(--secondary); font-family:monospace; }
50
+ .color-swatch-role { font-size:9px; color:var(--disabled); margin-top:2px; }
51
+ .color-group-label { font-size:12px; font-weight:700; color:var(--secondary); margin:20px 0 8px; }
52
+
53
+ .type-sample { margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid #f5f5f5; }
54
+ .type-sample:last-child { border-bottom:none; }
55
+ .type-meta { font-size:10px; color:var(--disabled); margin-top:4px; font-family:monospace; }
56
+
57
+ .button-row { display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
58
+ .button-item { text-align:center; }
59
+ .button-label { font-size:10px; color:var(--disabled); margin-top:6px; }
60
+
61
+ .card-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:16px; }
62
+ .card { background:var(--white); border-radius:20px; overflow:hidden; box-shadow:var(--shadow-card); }
63
+ .card-img { height:160px; background:var(--surface); display:flex; align-items:center; justify-content:center; color:var(--disabled); font-size:12px; }
64
+ .card-body { padding:16px; }
65
+ .card h3 { font-size:16px; font-weight:600; margin-bottom:4px; }
66
+ .card p { font-size:14px; color:var(--secondary); }
67
+
68
+ .form-group { margin-bottom:16px; max-width:400px; }
69
+ .form-label { display:block; font-size:12px; font-weight:600; margin-bottom:4px; }
70
+ .form-input { width:100%; background:var(--white); color:var(--near-black); border:1px solid var(--border); padding:12px 16px; border-radius:8px; font-family:var(--font); font-size:16px; outline:none; }
71
+ .form-input:focus { border-color:var(--near-black); box-shadow:0 0 0 2px var(--near-black); }
72
+ .form-input--focus { border-color:var(--near-black); box-shadow:0 0 0 2px var(--near-black); }
73
+ .form-input--error { border-color:var(--error); box-shadow:0 0 0 2px var(--error); }
74
+ .form-textarea { width:100%; min-height:80px; background:var(--white); color:var(--near-black); border:1px solid var(--border); padding:12px 16px; border-radius:8px; font-family:var(--font); font-size:16px; resize:vertical; outline:none; }
75
+ .form-state-label { font-size:9px; color:var(--disabled); margin-top:4px; }
76
+
77
+ .spacing-row { display:flex; align-items:flex-end; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
78
+ .spacing-item { text-align:center; }
79
+ .spacing-block { background:var(--rausch); border-radius:4px; margin-bottom:4px; height:24px; opacity:0.7; }
80
+ .spacing-value { font-size:9px; color:var(--disabled); font-family:monospace; }
81
+
82
+ .radius-row { display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
83
+ .radius-item { text-align:center; }
84
+ .radius-box { width:56px; height:56px; background:var(--surface); margin-bottom:4px; }
85
+ .radius-label { font-size:9px; color:var(--disabled); font-family:monospace; }
86
+ .radius-context { font-size:8px; color:var(--disabled); }
87
+
88
+ .elevation-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr)); gap:12px; }
89
+ .elevation-card { background:var(--white); border-radius:20px; padding:16px; text-align:center; }
90
+ .elevation-label { font-size:13px; font-weight:600; margin-bottom:4px; }
91
+ .elevation-desc { font-size:9px; color:var(--disabled); font-family:monospace; }
92
+
93
+ .footer { padding:24px; text-align:center; border-top:1px solid #2a2a2a; font-size:12px; color:var(--secondary); }
94
+ .footer a { color:var(--rausch); text-decoration:underline; }
95
+
96
+ @media (max-width:744px) { .nav-links { display:none; } .section { padding:32px 16px; } .card-grid { grid-template-columns:1fr; } }
97
+ </style>
98
+ </head>
99
+ <body>
100
+
101
+ <nav class="nav">
102
+ <a class="nav-brand" href="#">awesome-design-md</a>
103
+ <ul class="nav-links">
104
+ <li><a href="#colors">Colors</a></li>
105
+ <li><a href="#typography">Typography</a></li>
106
+ <li><a href="#buttons">Buttons</a></li>
107
+ <li><a href="#cards">Cards</a></li>
108
+ <li><a href="#forms">Forms</a></li>
109
+ </ul>
110
+ <a class="nav-cta" href="#">&#x1F50D;</a>
111
+ </nav>
112
+ <div style="position:fixed;top:16px;right:16px;z-index:200;background:#ff385c;color:#ffffff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:20px;">Dark Mode</div>
113
+
114
+ <section class="hero">
115
+ <h1>Design System Inspired by <span>Airbnb</span></h1>
116
+ <p>A design token catalog generated from DESIGN.md. Every color, font, component, and spacing value — visualized.</p>
117
+ <div class="hero-buttons">
118
+ <a class="btn-dark" href="#">Explore Stays</a>
119
+ <a class="btn-outline" href="#">Become a Host</a>
120
+ </div>
121
+ </section>
122
+
123
+ <hr class="section-divider">
124
+
125
+ <section class="section" id="colors">
126
+ <div class="section-label">01 / Colors</div><h2 class="section-title">Color Palette</h2>
127
+ <div class="color-group-label">Brand</div>
128
+ <div class="color-grid">
129
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#ff385c"></div><div class="color-swatch-info"><div class="color-swatch-name">Rausch Red</div><div class="color-swatch-hex">#ff385c</div><div class="color-swatch-role">Primary CTA</div></div></div>
130
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#e00b41"></div><div class="color-swatch-info"><div class="color-swatch-name">Deep Rausch</div><div class="color-swatch-hex">#e00b41</div><div class="color-swatch-role">Pressed state</div></div></div>
131
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#460479"></div><div class="color-swatch-info"><div class="color-swatch-name">Luxe Purple</div><div class="color-swatch-hex">#460479</div><div class="color-swatch-role">Luxe tier</div></div></div>
132
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#92174d"></div><div class="color-swatch-info"><div class="color-swatch-name">Plus Magenta</div><div class="color-swatch-hex">#92174d</div><div class="color-swatch-role">Plus tier</div></div></div>
133
+ </div>
134
+ <div class="color-group-label">Text & Neutral</div>
135
+ <div class="color-grid">
136
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#222222"></div><div class="color-swatch-info"><div class="color-swatch-name">Near Black</div><div class="color-swatch-hex">#222222</div><div class="color-swatch-role">Primary text</div></div></div>
137
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#6a6a6a"></div><div class="color-swatch-info"><div class="color-swatch-name">Secondary</div><div class="color-swatch-hex">#6a6a6a</div><div class="color-swatch-role">Secondary text</div></div></div>
138
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#c1c1c1"></div><div class="color-swatch-info"><div class="color-swatch-name">Border</div><div class="color-swatch-hex">#c1c1c1</div><div class="color-swatch-role">Borders</div></div></div>
139
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#f2f2f2"></div><div class="color-swatch-info"><div class="color-swatch-name">Surface</div><div class="color-swatch-hex">#f2f2f2</div><div class="color-swatch-role">Circular buttons</div></div></div>
140
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#428bff"></div><div class="color-swatch-info"><div class="color-swatch-name">Legal Blue</div><div class="color-swatch-hex">#428bff</div><div class="color-swatch-role">Legal links</div></div></div>
141
+ <div class="color-swatch"><div class="color-swatch-block" style="background:#c13515"></div><div class="color-swatch-info"><div class="color-swatch-name">Error</div><div class="color-swatch-hex">#c13515</div><div class="color-swatch-role">Error text</div></div></div>
142
+ </div>
143
+ </section>
144
+
145
+ <hr class="section-divider">
146
+
147
+ <section class="section" id="typography">
148
+ <div class="section-label">02 / Typography</div><h2 class="section-title">Typography Scale</h2>
149
+ <div class="type-sample"><div style="font-size:28px; font-weight:700; line-height:1.43;">Section Heading</div><div class="type-meta">Section — 28px / 700 / 1.43 / Cereal VF</div></div>
150
+ <div class="type-sample"><div style="font-size:22px; font-weight:600; line-height:1.18; letter-spacing:-0.44px;">Card Heading</div><div class="type-meta">Card — 22px / 600 / 1.18 / -0.44px</div></div>
151
+ <div class="type-sample"><div style="font-size:20px; font-weight:600; line-height:1.20; letter-spacing:-0.18px;">Feature Title</div><div class="type-meta">Feature — 20px / 600 / 1.20 / -0.18px</div></div>
152
+ <div class="type-sample"><div style="font-size:16px; font-weight:500; line-height:1.25;">UI Medium — Inspiration for future getaways</div><div class="type-meta">UI — 16px / 500 / 1.25</div></div>
153
+ <div class="type-sample"><div style="font-size:14px; font-weight:400; line-height:1.43; color:var(--secondary);">Body — Istanbul, Turkey. Apartment in Kadikoy. 2 guests, 1 bed, 1 bath.</div><div class="type-meta">Body — 14px / 400 / 1.43</div></div>
154
+ <div class="type-sample"><div style="font-size:12px; font-weight:700; line-height:1.33;">Tag Bold — $145 night</div><div class="type-meta">Tag Bold — 12px / 700 / 1.33</div></div>
155
+ <div class="type-sample"><div style="font-size:8px; font-weight:700; line-height:1.25; text-transform:uppercase; letter-spacing:0.32px;">SUPERHOST</div><div class="type-meta">Micro — 8px / 700 / uppercase / +0.32px</div></div>
156
+ </section>
157
+
158
+ <hr class="section-divider">
159
+
160
+ <section class="section" id="buttons">
161
+ <div class="section-label">03 / Buttons</div><h2 class="section-title">Button Variants</h2>
162
+ <div class="button-row">
163
+ <div class="button-item"><a class="btn-dark" href="#">Explore</a><div class="button-label">Primary Dark</div></div>
164
+ <div class="button-item"><a class="btn-outline" href="#">Host</a><div class="button-label">Outlined</div></div>
165
+ <div class="button-item"><a class="btn-circle" href="#">&#8592;</a><div class="button-label">Circle Nav</div></div>
166
+ <div class="button-item"><a class="btn-circle" href="#">&#8594;</a><div class="button-label">Circle Nav</div></div>
167
+ <div class="button-item"><span style="display:inline-flex; align-items:center; justify-content:center; background:var(--rausch); color:var(--white); width:40px; height:40px; border-radius:50%; font-size:18px;">&#x1F50D;</span><div class="button-label">Search</div></div>
168
+ </div>
169
+ </section>
170
+
171
+ <hr class="section-divider">
172
+
173
+ <section class="section" id="cards">
174
+ <div class="section-label">04 / Cards</div><h2 class="section-title">Card Examples</h2>
175
+ <div class="card-grid">
176
+ <div class="card"><div class="card-img">Photo placeholder</div><div class="card-body"><h3>Istanbul, Turkey</h3><p>Entire apartment. 2 guests, 1 bed. $78 night.</p></div></div>
177
+ <div class="card"><div class="card-img" style="background:#eee;">Photo placeholder</div><div class="card-body"><h3>Barcelona, Spain</h3><p>Private room. 3 guests, 2 beds. $92 night.</p></div></div>
178
+ <div class="card"><div class="card-img" style="background:#e8e8e8;">Photo placeholder</div><div class="card-body"><h3>Galveston, TX</h3><p>Entire house. 6 guests, 3 beds. $145 night.</p></div></div>
179
+ </div>
180
+ </section>
181
+
182
+ <hr class="section-divider">
183
+
184
+ <section class="section" id="forms">
185
+ <div class="section-label">05 / Forms</div><h2 class="section-title">Form Elements</h2>
186
+ <div class="form-group"><label class="form-label">Where</label><input class="form-input" type="text" placeholder="Search destinations"><div class="form-state-label">Default</div></div>
187
+ <div class="form-group"><label class="form-label">Check in</label><input class="form-input form-input--focus" type="text" value="Apr 15, 2026"><div class="form-state-label">Focus (dark ring)</div></div>
188
+ <div class="form-group"><label class="form-label">Guests</label><input class="form-input form-input--error" type="text" value="0 guests"><div class="form-state-label">Error</div></div>
189
+ <div class="form-group"><label class="form-label">Message host</label><textarea class="form-textarea" placeholder="Tell your host about your trip..."></textarea></div>
190
+ </section>
191
+
192
+ <hr class="section-divider">
193
+
194
+ <section class="section">
195
+ <div class="section-label">06 / Spacing</div><h2 class="section-title">Spacing Scale</h2>
196
+ <div class="spacing-row">
197
+ <div class="spacing-item"><div class="spacing-block" style="width:4px"></div><div class="spacing-value">4</div></div>
198
+ <div class="spacing-item"><div class="spacing-block" style="width:8px"></div><div class="spacing-value">8</div></div>
199
+ <div class="spacing-item"><div class="spacing-block" style="width:12px"></div><div class="spacing-value">12</div></div>
200
+ <div class="spacing-item"><div class="spacing-block" style="width:16px"></div><div class="spacing-value">16</div></div>
201
+ <div class="spacing-item"><div class="spacing-block" style="width:24px"></div><div class="spacing-value">24</div></div>
202
+ <div class="spacing-item"><div class="spacing-block" style="width:32px"></div><div class="spacing-value">32</div></div>
203
+ </div>
204
+ </section>
205
+
206
+ <hr class="section-divider">
207
+
208
+ <section class="section">
209
+ <div class="section-label">07 / Radius</div><h2 class="section-title">Border Radius</h2>
210
+ <div class="radius-row">
211
+ <div class="radius-item"><div class="radius-box" style="border-radius:8px"></div><div class="radius-label">8px</div><div class="radius-context">Buttons</div></div>
212
+ <div class="radius-item"><div class="radius-box" style="border-radius:14px"></div><div class="radius-label">14px</div><div class="radius-context">Badges</div></div>
213
+ <div class="radius-item"><div class="radius-box" style="border-radius:20px"></div><div class="radius-label">20px</div><div class="radius-context">Cards</div></div>
214
+ <div class="radius-item"><div class="radius-box" style="border-radius:32px"></div><div class="radius-label">32px</div><div class="radius-context">Large</div></div>
215
+ <div class="radius-item"><div class="radius-box" style="border-radius:50%; width:56px; height:56px;"></div><div class="radius-label">50%</div><div class="radius-context">Controls</div></div>
216
+ </div>
217
+ </section>
218
+
219
+ <hr class="section-divider">
220
+
221
+ <section class="section">
222
+ <div class="section-label">08 / Elevation</div><h2 class="section-title">Depth</h2>
223
+ <div class="elevation-grid">
224
+ <div class="elevation-card" style="border:1px solid #ebebeb;"><div class="elevation-label">Flat</div><div class="elevation-desc">No shadow</div></div>
225
+ <div class="elevation-card" style="box-shadow:var(--shadow-card);"><div class="elevation-label">Card</div><div class="elevation-desc">Three-layer warm</div></div>
226
+ <div class="elevation-card" style="box-shadow:var(--shadow-hover);"><div class="elevation-label">Hover</div><div class="elevation-desc">Interactive lift</div></div>
227
+ <div class="elevation-card" style="box-shadow:0 0 0 2px var(--near-black);"><div class="elevation-label">Focus</div><div class="elevation-desc">Dark focus ring</div></div>
228
+ </div>
229
+ </section>
230
+
231
+ <footer class="footer">Generated from <a href="https://airbnb.com/">airbnb.com</a> DESIGN.md — awesome-design-md</footer>
232
+
233
+ </body>
234
+ </html>