@aexol/spectral 0.7.0 → 0.7.1

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 (459) hide show
  1. package/dist/agent/index.js +76 -301
  2. package/dist/cli.js +11 -0
  3. package/dist/designer/data/systems/agentic/DESIGN.md +71 -0
  4. package/dist/designer/data/systems/agentic/components.html +154 -0
  5. package/dist/designer/data/systems/agentic/tokens.css +63 -0
  6. package/dist/designer/data/systems/airbnb/DESIGN.md +393 -0
  7. package/dist/designer/data/systems/airbnb/components.html +1373 -0
  8. package/dist/designer/data/systems/airbnb/tokens.css +261 -0
  9. package/dist/designer/data/systems/airtable/DESIGN.md +92 -0
  10. package/dist/designer/data/systems/airtable/components.html +489 -0
  11. package/dist/designer/data/systems/airtable/tokens.css +261 -0
  12. package/dist/designer/data/systems/ant/DESIGN.md +71 -0
  13. package/dist/designer/data/systems/ant/components.html +154 -0
  14. package/dist/designer/data/systems/ant/tokens.css +63 -0
  15. package/dist/designer/data/systems/apple/DESIGN.md +250 -0
  16. package/dist/designer/data/systems/apple/components.html +749 -0
  17. package/dist/designer/data/systems/apple/tokens.css +286 -0
  18. package/dist/designer/data/systems/application/DESIGN.md +71 -0
  19. package/dist/designer/data/systems/application/components.html +154 -0
  20. package/dist/designer/data/systems/application/tokens.css +63 -0
  21. package/dist/designer/data/systems/arc/DESIGN.md +152 -0
  22. package/dist/designer/data/systems/arc/components.html +432 -0
  23. package/dist/designer/data/systems/arc/tokens.css +137 -0
  24. package/dist/designer/data/systems/artistic/DESIGN.md +71 -0
  25. package/dist/designer/data/systems/artistic/components.html +136 -0
  26. package/dist/designer/data/systems/artistic/tokens.css +63 -0
  27. package/dist/designer/data/systems/atelier-zero/DESIGN.md +316 -0
  28. package/dist/designer/data/systems/atelier-zero/components.html +136 -0
  29. package/dist/designer/data/systems/atelier-zero/tokens.css +63 -0
  30. package/dist/designer/data/systems/bento/DESIGN.md +71 -0
  31. package/dist/designer/data/systems/bento/components.html +136 -0
  32. package/dist/designer/data/systems/bento/tokens.css +63 -0
  33. package/dist/designer/data/systems/binance/DESIGN.md +348 -0
  34. package/dist/designer/data/systems/binance/components.html +550 -0
  35. package/dist/designer/data/systems/binance/tokens.css +255 -0
  36. package/dist/designer/data/systems/bmw/DESIGN.md +183 -0
  37. package/dist/designer/data/systems/bmw/components.html +551 -0
  38. package/dist/designer/data/systems/bmw/tokens.css +179 -0
  39. package/dist/designer/data/systems/bmw-m/DESIGN.md +246 -0
  40. package/dist/designer/data/systems/bmw-m/components.html +342 -0
  41. package/dist/designer/data/systems/bmw-m/tokens.css +64 -0
  42. package/dist/designer/data/systems/bold/DESIGN.md +71 -0
  43. package/dist/designer/data/systems/bold/components.html +136 -0
  44. package/dist/designer/data/systems/bold/tokens.css +63 -0
  45. package/dist/designer/data/systems/brutalism/DESIGN.md +71 -0
  46. package/dist/designer/data/systems/brutalism/components.html +154 -0
  47. package/dist/designer/data/systems/brutalism/tokens.css +63 -0
  48. package/dist/designer/data/systems/bugatti/DESIGN.md +271 -0
  49. package/dist/designer/data/systems/bugatti/components.html +342 -0
  50. package/dist/designer/data/systems/bugatti/tokens.css +64 -0
  51. package/dist/designer/data/systems/cafe/DESIGN.md +71 -0
  52. package/dist/designer/data/systems/cafe/components.html +136 -0
  53. package/dist/designer/data/systems/cafe/tokens.css +63 -0
  54. package/dist/designer/data/systems/cal/DESIGN.md +262 -0
  55. package/dist/designer/data/systems/cal/components.html +376 -0
  56. package/dist/designer/data/systems/cal/tokens.css +265 -0
  57. package/dist/designer/data/systems/canva/DESIGN.md +157 -0
  58. package/dist/designer/data/systems/canva/components.html +461 -0
  59. package/dist/designer/data/systems/canva/tokens.css +147 -0
  60. package/dist/designer/data/systems/cisco/DESIGN.md +201 -0
  61. package/dist/designer/data/systems/cisco/components.html +342 -0
  62. package/dist/designer/data/systems/cisco/tokens.css +64 -0
  63. package/dist/designer/data/systems/claude/DESIGN.md +315 -0
  64. package/dist/designer/data/systems/claude/components.html +483 -0
  65. package/dist/designer/data/systems/claude/tokens.css +130 -0
  66. package/dist/designer/data/systems/clay/DESIGN.md +307 -0
  67. package/dist/designer/data/systems/clay/components.html +136 -0
  68. package/dist/designer/data/systems/clay/tokens.css +63 -0
  69. package/dist/designer/data/systems/claymorphism/DESIGN.md +71 -0
  70. package/dist/designer/data/systems/claymorphism/components.html +136 -0
  71. package/dist/designer/data/systems/claymorphism/tokens.css +63 -0
  72. package/dist/designer/data/systems/clean/DESIGN.md +71 -0
  73. package/dist/designer/data/systems/clean/components.html +136 -0
  74. package/dist/designer/data/systems/clean/tokens.css +63 -0
  75. package/dist/designer/data/systems/clickhouse/DESIGN.md +284 -0
  76. package/dist/designer/data/systems/clickhouse/components.html +506 -0
  77. package/dist/designer/data/systems/clickhouse/tokens.css +135 -0
  78. package/dist/designer/data/systems/cohere/DESIGN.md +269 -0
  79. package/dist/designer/data/systems/cohere/components.html +353 -0
  80. package/dist/designer/data/systems/cohere/tokens.css +126 -0
  81. package/dist/designer/data/systems/coinbase/DESIGN.md +132 -0
  82. package/dist/designer/data/systems/coinbase/components.html +501 -0
  83. package/dist/designer/data/systems/coinbase/tokens.css +257 -0
  84. package/dist/designer/data/systems/colorful/DESIGN.md +71 -0
  85. package/dist/designer/data/systems/colorful/components.html +136 -0
  86. package/dist/designer/data/systems/colorful/tokens.css +63 -0
  87. package/dist/designer/data/systems/composio/DESIGN.md +310 -0
  88. package/dist/designer/data/systems/composio/components.html +342 -0
  89. package/dist/designer/data/systems/composio/tokens.css +64 -0
  90. package/dist/designer/data/systems/contemporary/DESIGN.md +71 -0
  91. package/dist/designer/data/systems/contemporary/components.html +136 -0
  92. package/dist/designer/data/systems/contemporary/tokens.css +63 -0
  93. package/dist/designer/data/systems/corporate/DESIGN.md +71 -0
  94. package/dist/designer/data/systems/corporate/components.html +136 -0
  95. package/dist/designer/data/systems/corporate/tokens.css +63 -0
  96. package/dist/designer/data/systems/cosmic/DESIGN.md +71 -0
  97. package/dist/designer/data/systems/cosmic/components.html +136 -0
  98. package/dist/designer/data/systems/cosmic/tokens.css +63 -0
  99. package/dist/designer/data/systems/creative/DESIGN.md +71 -0
  100. package/dist/designer/data/systems/creative/components.html +136 -0
  101. package/dist/designer/data/systems/creative/tokens.css +63 -0
  102. package/dist/designer/data/systems/cursor/DESIGN.md +312 -0
  103. package/dist/designer/data/systems/cursor/components.html +654 -0
  104. package/dist/designer/data/systems/cursor/tokens.css +218 -0
  105. package/dist/designer/data/systems/dashboard/DESIGN.md +71 -0
  106. package/dist/designer/data/systems/dashboard/components.html +154 -0
  107. package/dist/designer/data/systems/dashboard/tokens.css +63 -0
  108. package/dist/designer/data/systems/default/DESIGN.md +62 -0
  109. package/dist/designer/data/systems/default/components.html +523 -0
  110. package/dist/designer/data/systems/default/tokens.css +200 -0
  111. package/dist/designer/data/systems/discord/DESIGN.md +162 -0
  112. package/dist/designer/data/systems/discord/components.html +359 -0
  113. package/dist/designer/data/systems/discord/tokens.css +125 -0
  114. package/dist/designer/data/systems/dithered/DESIGN.md +71 -0
  115. package/dist/designer/data/systems/dithered/components.html +136 -0
  116. package/dist/designer/data/systems/dithered/tokens.css +63 -0
  117. package/dist/designer/data/systems/doodle/DESIGN.md +71 -0
  118. package/dist/designer/data/systems/doodle/components.html +136 -0
  119. package/dist/designer/data/systems/doodle/tokens.css +63 -0
  120. package/dist/designer/data/systems/dramatic/DESIGN.md +71 -0
  121. package/dist/designer/data/systems/dramatic/components.html +136 -0
  122. package/dist/designer/data/systems/dramatic/tokens.css +63 -0
  123. package/dist/designer/data/systems/duolingo/DESIGN.md +154 -0
  124. package/dist/designer/data/systems/duolingo/components.html +532 -0
  125. package/dist/designer/data/systems/duolingo/tokens.css +130 -0
  126. package/dist/designer/data/systems/editorial/DESIGN.md +71 -0
  127. package/dist/designer/data/systems/editorial/components.html +154 -0
  128. package/dist/designer/data/systems/editorial/tokens.css +63 -0
  129. package/dist/designer/data/systems/elegant/DESIGN.md +71 -0
  130. package/dist/designer/data/systems/elegant/components.html +136 -0
  131. package/dist/designer/data/systems/elegant/tokens.css +63 -0
  132. package/dist/designer/data/systems/elevenlabs/DESIGN.md +268 -0
  133. package/dist/designer/data/systems/elevenlabs/components.html +342 -0
  134. package/dist/designer/data/systems/elevenlabs/tokens.css +127 -0
  135. package/dist/designer/data/systems/energetic/DESIGN.md +72 -0
  136. package/dist/designer/data/systems/energetic/components.html +136 -0
  137. package/dist/designer/data/systems/energetic/tokens.css +63 -0
  138. package/dist/designer/data/systems/enterprise/DESIGN.md +71 -0
  139. package/dist/designer/data/systems/enterprise/components.html +154 -0
  140. package/dist/designer/data/systems/enterprise/tokens.css +63 -0
  141. package/dist/designer/data/systems/expo/DESIGN.md +284 -0
  142. package/dist/designer/data/systems/expo/components.html +342 -0
  143. package/dist/designer/data/systems/expo/tokens.css +64 -0
  144. package/dist/designer/data/systems/expressive/DESIGN.md +71 -0
  145. package/dist/designer/data/systems/expressive/components.html +136 -0
  146. package/dist/designer/data/systems/expressive/tokens.css +63 -0
  147. package/dist/designer/data/systems/fantasy/DESIGN.md +71 -0
  148. package/dist/designer/data/systems/fantasy/components.html +136 -0
  149. package/dist/designer/data/systems/fantasy/tokens.css +63 -0
  150. package/dist/designer/data/systems/ferrari/DESIGN.md +317 -0
  151. package/dist/designer/data/systems/ferrari/components.html +342 -0
  152. package/dist/designer/data/systems/ferrari/tokens.css +64 -0
  153. package/dist/designer/data/systems/figma/DESIGN.md +223 -0
  154. package/dist/designer/data/systems/figma/components.html +344 -0
  155. package/dist/designer/data/systems/figma/tokens.css +126 -0
  156. package/dist/designer/data/systems/flat/DESIGN.md +71 -0
  157. package/dist/designer/data/systems/flat/components.html +136 -0
  158. package/dist/designer/data/systems/flat/tokens.css +63 -0
  159. package/dist/designer/data/systems/framer/DESIGN.md +249 -0
  160. package/dist/designer/data/systems/framer/components.html +438 -0
  161. package/dist/designer/data/systems/framer/tokens.css +238 -0
  162. package/dist/designer/data/systems/friendly/DESIGN.md +71 -0
  163. package/dist/designer/data/systems/friendly/components.html +136 -0
  164. package/dist/designer/data/systems/friendly/tokens.css +63 -0
  165. package/dist/designer/data/systems/futuristic/DESIGN.md +71 -0
  166. package/dist/designer/data/systems/futuristic/components.html +136 -0
  167. package/dist/designer/data/systems/futuristic/tokens.css +63 -0
  168. package/dist/designer/data/systems/github/DESIGN.md +155 -0
  169. package/dist/designer/data/systems/github/components.html +383 -0
  170. package/dist/designer/data/systems/github/tokens.css +125 -0
  171. package/dist/designer/data/systems/glassmorphism/DESIGN.md +71 -0
  172. package/dist/designer/data/systems/glassmorphism/components.html +154 -0
  173. package/dist/designer/data/systems/glassmorphism/tokens.css +63 -0
  174. package/dist/designer/data/systems/gradient/DESIGN.md +71 -0
  175. package/dist/designer/data/systems/gradient/components.html +154 -0
  176. package/dist/designer/data/systems/gradient/tokens.css +63 -0
  177. package/dist/designer/data/systems/hashicorp/DESIGN.md +281 -0
  178. package/dist/designer/data/systems/hashicorp/components.html +502 -0
  179. package/dist/designer/data/systems/hashicorp/tokens.css +272 -0
  180. package/dist/designer/data/systems/hud/DESIGN.md +173 -0
  181. package/dist/designer/data/systems/hud/components.html +136 -0
  182. package/dist/designer/data/systems/hud/tokens.css +63 -0
  183. package/dist/designer/data/systems/huggingface/DESIGN.md +149 -0
  184. package/dist/designer/data/systems/huggingface/components.html +346 -0
  185. package/dist/designer/data/systems/huggingface/tokens.css +125 -0
  186. package/dist/designer/data/systems/ibm/DESIGN.md +335 -0
  187. package/dist/designer/data/systems/ibm/components.html +342 -0
  188. package/dist/designer/data/systems/ibm/tokens.css +64 -0
  189. package/dist/designer/data/systems/intercom/DESIGN.md +149 -0
  190. package/dist/designer/data/systems/intercom/components.html +557 -0
  191. package/dist/designer/data/systems/intercom/tokens.css +150 -0
  192. package/dist/designer/data/systems/kami/DESIGN.md +410 -0
  193. package/dist/designer/data/systems/kami/components.html +601 -0
  194. package/dist/designer/data/systems/kami/tokens.css +272 -0
  195. package/dist/designer/data/systems/kraken/DESIGN.md +128 -0
  196. package/dist/designer/data/systems/kraken/components.html +342 -0
  197. package/dist/designer/data/systems/kraken/tokens.css +64 -0
  198. package/dist/designer/data/systems/lamborghini/DESIGN.md +291 -0
  199. package/dist/designer/data/systems/lamborghini/components.html +342 -0
  200. package/dist/designer/data/systems/lamborghini/tokens.css +64 -0
  201. package/dist/designer/data/systems/levels/DESIGN.md +71 -0
  202. package/dist/designer/data/systems/levels/components.html +154 -0
  203. package/dist/designer/data/systems/levels/tokens.css +63 -0
  204. package/dist/designer/data/systems/linear-app/DESIGN.md +370 -0
  205. package/dist/designer/data/systems/linear-app/components.html +370 -0
  206. package/dist/designer/data/systems/linear-app/tokens.css +130 -0
  207. package/dist/designer/data/systems/lingo/DESIGN.md +71 -0
  208. package/dist/designer/data/systems/lingo/components.html +154 -0
  209. package/dist/designer/data/systems/lingo/tokens.css +63 -0
  210. package/dist/designer/data/systems/loom/DESIGN.md +201 -0
  211. package/dist/designer/data/systems/loom/components.html +446 -0
  212. package/dist/designer/data/systems/loom/tokens.css +138 -0
  213. package/dist/designer/data/systems/lovable/DESIGN.md +301 -0
  214. package/dist/designer/data/systems/lovable/components.html +441 -0
  215. package/dist/designer/data/systems/lovable/tokens.css +258 -0
  216. package/dist/designer/data/systems/luxury/DESIGN.md +71 -0
  217. package/dist/designer/data/systems/luxury/components.html +154 -0
  218. package/dist/designer/data/systems/luxury/tokens.css +63 -0
  219. package/dist/designer/data/systems/mastercard/DESIGN.md +368 -0
  220. package/dist/designer/data/systems/mastercard/components.html +342 -0
  221. package/dist/designer/data/systems/mastercard/tokens.css +64 -0
  222. package/dist/designer/data/systems/material/DESIGN.md +71 -0
  223. package/dist/designer/data/systems/material/components.html +154 -0
  224. package/dist/designer/data/systems/material/tokens.css +63 -0
  225. package/dist/designer/data/systems/meta/DESIGN.md +369 -0
  226. package/dist/designer/data/systems/meta/components.html +398 -0
  227. package/dist/designer/data/systems/meta/tokens.css +263 -0
  228. package/dist/designer/data/systems/minimal/DESIGN.md +71 -0
  229. package/dist/designer/data/systems/minimal/components.html +154 -0
  230. package/dist/designer/data/systems/minimal/tokens.css +63 -0
  231. package/dist/designer/data/systems/minimax/DESIGN.md +260 -0
  232. package/dist/designer/data/systems/minimax/components.html +590 -0
  233. package/dist/designer/data/systems/minimax/tokens.css +148 -0
  234. package/dist/designer/data/systems/mintlify/DESIGN.md +329 -0
  235. package/dist/designer/data/systems/mintlify/components.html +737 -0
  236. package/dist/designer/data/systems/mintlify/tokens.css +256 -0
  237. package/dist/designer/data/systems/miro/DESIGN.md +111 -0
  238. package/dist/designer/data/systems/miro/components.html +342 -0
  239. package/dist/designer/data/systems/miro/tokens.css +64 -0
  240. package/dist/designer/data/systems/mission-control/DESIGN.md +474 -0
  241. package/dist/designer/data/systems/mission-control/components.html +136 -0
  242. package/dist/designer/data/systems/mission-control/tokens.css +63 -0
  243. package/dist/designer/data/systems/mistral-ai/DESIGN.md +264 -0
  244. package/dist/designer/data/systems/mistral-ai/components.html +338 -0
  245. package/dist/designer/data/systems/mistral-ai/tokens.css +125 -0
  246. package/dist/designer/data/systems/modern/DESIGN.md +71 -0
  247. package/dist/designer/data/systems/modern/components.html +154 -0
  248. package/dist/designer/data/systems/modern/tokens.css +63 -0
  249. package/dist/designer/data/systems/mongodb/DESIGN.md +269 -0
  250. package/dist/designer/data/systems/mongodb/components.html +462 -0
  251. package/dist/designer/data/systems/mongodb/tokens.css +176 -0
  252. package/dist/designer/data/systems/mono/DESIGN.md +71 -0
  253. package/dist/designer/data/systems/mono/components.html +136 -0
  254. package/dist/designer/data/systems/mono/tokens.css +63 -0
  255. package/dist/designer/data/systems/neobrutalism/DESIGN.md +71 -0
  256. package/dist/designer/data/systems/neobrutalism/components.html +136 -0
  257. package/dist/designer/data/systems/neobrutalism/tokens.css +63 -0
  258. package/dist/designer/data/systems/neon/DESIGN.md +71 -0
  259. package/dist/designer/data/systems/neon/components.html +136 -0
  260. package/dist/designer/data/systems/neon/tokens.css +63 -0
  261. package/dist/designer/data/systems/neumorphism/DESIGN.md +71 -0
  262. package/dist/designer/data/systems/neumorphism/components.html +136 -0
  263. package/dist/designer/data/systems/neumorphism/tokens.css +63 -0
  264. package/dist/designer/data/systems/nike/DESIGN.md +366 -0
  265. package/dist/designer/data/systems/nike/components.html +512 -0
  266. package/dist/designer/data/systems/nike/tokens.css +304 -0
  267. package/dist/designer/data/systems/notion/DESIGN.md +312 -0
  268. package/dist/designer/data/systems/notion/components.html +413 -0
  269. package/dist/designer/data/systems/notion/tokens.css +130 -0
  270. package/dist/designer/data/systems/nvidia/DESIGN.md +296 -0
  271. package/dist/designer/data/systems/nvidia/components.html +414 -0
  272. package/dist/designer/data/systems/nvidia/tokens.css +133 -0
  273. package/dist/designer/data/systems/ollama/DESIGN.md +270 -0
  274. package/dist/designer/data/systems/ollama/components.html +700 -0
  275. package/dist/designer/data/systems/ollama/tokens.css +242 -0
  276. package/dist/designer/data/systems/openai/DESIGN.md +140 -0
  277. package/dist/designer/data/systems/openai/components.html +382 -0
  278. package/dist/designer/data/systems/openai/tokens.css +133 -0
  279. package/dist/designer/data/systems/opencode-ai/DESIGN.md +284 -0
  280. package/dist/designer/data/systems/opencode-ai/components.html +389 -0
  281. package/dist/designer/data/systems/opencode-ai/tokens.css +126 -0
  282. package/dist/designer/data/systems/pacman/DESIGN.md +71 -0
  283. package/dist/designer/data/systems/pacman/components.html +342 -0
  284. package/dist/designer/data/systems/pacman/tokens.css +64 -0
  285. package/dist/designer/data/systems/paper/DESIGN.md +71 -0
  286. package/dist/designer/data/systems/paper/components.html +136 -0
  287. package/dist/designer/data/systems/paper/tokens.css +63 -0
  288. package/dist/designer/data/systems/perplexity/DESIGN.md +286 -0
  289. package/dist/designer/data/systems/perplexity/components.html +455 -0
  290. package/dist/designer/data/systems/perplexity/tokens.css +151 -0
  291. package/dist/designer/data/systems/perspective/DESIGN.md +71 -0
  292. package/dist/designer/data/systems/perspective/components.html +136 -0
  293. package/dist/designer/data/systems/perspective/tokens.css +63 -0
  294. package/dist/designer/data/systems/pinterest/DESIGN.md +233 -0
  295. package/dist/designer/data/systems/pinterest/components.html +865 -0
  296. package/dist/designer/data/systems/pinterest/tokens.css +262 -0
  297. package/dist/designer/data/systems/playstation/DESIGN.md +367 -0
  298. package/dist/designer/data/systems/playstation/components.html +414 -0
  299. package/dist/designer/data/systems/playstation/tokens.css +150 -0
  300. package/dist/designer/data/systems/posthog/DESIGN.md +259 -0
  301. package/dist/designer/data/systems/posthog/components.html +827 -0
  302. package/dist/designer/data/systems/posthog/tokens.css +272 -0
  303. package/dist/designer/data/systems/premium/DESIGN.md +71 -0
  304. package/dist/designer/data/systems/premium/components.html +154 -0
  305. package/dist/designer/data/systems/premium/tokens.css +63 -0
  306. package/dist/designer/data/systems/professional/DESIGN.md +71 -0
  307. package/dist/designer/data/systems/professional/components.html +136 -0
  308. package/dist/designer/data/systems/professional/tokens.css +63 -0
  309. package/dist/designer/data/systems/publication/DESIGN.md +71 -0
  310. package/dist/designer/data/systems/publication/components.html +154 -0
  311. package/dist/designer/data/systems/publication/tokens.css +63 -0
  312. package/dist/designer/data/systems/raycast/DESIGN.md +271 -0
  313. package/dist/designer/data/systems/raycast/components.html +507 -0
  314. package/dist/designer/data/systems/raycast/tokens.css +143 -0
  315. package/dist/designer/data/systems/refined/DESIGN.md +71 -0
  316. package/dist/designer/data/systems/refined/components.html +136 -0
  317. package/dist/designer/data/systems/refined/tokens.css +63 -0
  318. package/dist/designer/data/systems/renault/DESIGN.md +314 -0
  319. package/dist/designer/data/systems/renault/components.html +154 -0
  320. package/dist/designer/data/systems/renault/tokens.css +63 -0
  321. package/dist/designer/data/systems/replicate/DESIGN.md +264 -0
  322. package/dist/designer/data/systems/replicate/components.html +340 -0
  323. package/dist/designer/data/systems/replicate/tokens.css +125 -0
  324. package/dist/designer/data/systems/resend/DESIGN.md +306 -0
  325. package/dist/designer/data/systems/resend/components.html +839 -0
  326. package/dist/designer/data/systems/resend/tokens.css +353 -0
  327. package/dist/designer/data/systems/retro/DESIGN.md +71 -0
  328. package/dist/designer/data/systems/retro/components.html +136 -0
  329. package/dist/designer/data/systems/retro/tokens.css +63 -0
  330. package/dist/designer/data/systems/revolut/DESIGN.md +188 -0
  331. package/dist/designer/data/systems/revolut/components.html +342 -0
  332. package/dist/designer/data/systems/revolut/tokens.css +64 -0
  333. package/dist/designer/data/systems/runwayml/DESIGN.md +247 -0
  334. package/dist/designer/data/systems/runwayml/components.html +638 -0
  335. package/dist/designer/data/systems/runwayml/tokens.css +204 -0
  336. package/dist/designer/data/systems/sanity/DESIGN.md +360 -0
  337. package/dist/designer/data/systems/sanity/components.html +342 -0
  338. package/dist/designer/data/systems/sanity/tokens.css +64 -0
  339. package/dist/designer/data/systems/sentry/DESIGN.md +265 -0
  340. package/dist/designer/data/systems/sentry/components.html +387 -0
  341. package/dist/designer/data/systems/sentry/tokens.css +219 -0
  342. package/dist/designer/data/systems/shadcn/DESIGN.md +71 -0
  343. package/dist/designer/data/systems/shadcn/components.html +732 -0
  344. package/dist/designer/data/systems/shadcn/tokens.css +255 -0
  345. package/dist/designer/data/systems/shopify/DESIGN.md +353 -0
  346. package/dist/designer/data/systems/shopify/components.html +342 -0
  347. package/dist/designer/data/systems/shopify/tokens.css +141 -0
  348. package/dist/designer/data/systems/simple/DESIGN.md +71 -0
  349. package/dist/designer/data/systems/simple/components.html +136 -0
  350. package/dist/designer/data/systems/simple/tokens.css +63 -0
  351. package/dist/designer/data/systems/skeumorphism/DESIGN.md +71 -0
  352. package/dist/designer/data/systems/skeumorphism/components.html +136 -0
  353. package/dist/designer/data/systems/skeumorphism/tokens.css +63 -0
  354. package/dist/designer/data/systems/slack/DESIGN.md +363 -0
  355. package/dist/designer/data/systems/slack/components.html +387 -0
  356. package/dist/designer/data/systems/slack/tokens.css +127 -0
  357. package/dist/designer/data/systems/sleek/DESIGN.md +71 -0
  358. package/dist/designer/data/systems/sleek/components.html +136 -0
  359. package/dist/designer/data/systems/sleek/tokens.css +63 -0
  360. package/dist/designer/data/systems/spacex/DESIGN.md +197 -0
  361. package/dist/designer/data/systems/spacex/components.html +496 -0
  362. package/dist/designer/data/systems/spacex/tokens.css +154 -0
  363. package/dist/designer/data/systems/spacious/DESIGN.md +71 -0
  364. package/dist/designer/data/systems/spacious/components.html +136 -0
  365. package/dist/designer/data/systems/spacious/tokens.css +63 -0
  366. package/dist/designer/data/systems/spotify/DESIGN.md +249 -0
  367. package/dist/designer/data/systems/spotify/components.html +365 -0
  368. package/dist/designer/data/systems/spotify/tokens.css +127 -0
  369. package/dist/designer/data/systems/starbucks/DESIGN.md +583 -0
  370. package/dist/designer/data/systems/starbucks/components.html +493 -0
  371. package/dist/designer/data/systems/starbucks/tokens.css +182 -0
  372. package/dist/designer/data/systems/storytelling/DESIGN.md +71 -0
  373. package/dist/designer/data/systems/storytelling/components.html +136 -0
  374. package/dist/designer/data/systems/storytelling/tokens.css +63 -0
  375. package/dist/designer/data/systems/stripe/DESIGN.md +325 -0
  376. package/dist/designer/data/systems/stripe/components.html +1018 -0
  377. package/dist/designer/data/systems/stripe/tokens.css +295 -0
  378. package/dist/designer/data/systems/supabase/DESIGN.md +258 -0
  379. package/dist/designer/data/systems/supabase/components.html +741 -0
  380. package/dist/designer/data/systems/supabase/tokens.css +294 -0
  381. package/dist/designer/data/systems/superhuman/DESIGN.md +255 -0
  382. package/dist/designer/data/systems/superhuman/components.html +537 -0
  383. package/dist/designer/data/systems/superhuman/tokens.css +160 -0
  384. package/dist/designer/data/systems/tesla/DESIGN.md +289 -0
  385. package/dist/designer/data/systems/tesla/components.html +724 -0
  386. package/dist/designer/data/systems/tesla/tokens.css +285 -0
  387. package/dist/designer/data/systems/tetris/DESIGN.md +71 -0
  388. package/dist/designer/data/systems/tetris/components.html +342 -0
  389. package/dist/designer/data/systems/tetris/tokens.css +64 -0
  390. package/dist/designer/data/systems/theverge/DESIGN.md +342 -0
  391. package/dist/designer/data/systems/theverge/components.html +342 -0
  392. package/dist/designer/data/systems/theverge/tokens.css +64 -0
  393. package/dist/designer/data/systems/together-ai/DESIGN.md +266 -0
  394. package/dist/designer/data/systems/together-ai/components.html +422 -0
  395. package/dist/designer/data/systems/together-ai/tokens.css +127 -0
  396. package/dist/designer/data/systems/totality-festival/DESIGN.md +206 -0
  397. package/dist/designer/data/systems/totality-festival/components.html +136 -0
  398. package/dist/designer/data/systems/totality-festival/tokens.css +63 -0
  399. package/dist/designer/data/systems/trading-terminal/DESIGN.md +178 -0
  400. package/dist/designer/data/systems/trading-terminal/components.html +154 -0
  401. package/dist/designer/data/systems/trading-terminal/tokens.css +63 -0
  402. package/dist/designer/data/systems/uber/DESIGN.md +298 -0
  403. package/dist/designer/data/systems/uber/components.html +347 -0
  404. package/dist/designer/data/systems/uber/tokens.css +131 -0
  405. package/dist/designer/data/systems/urdu/DESIGN.md +1002 -0
  406. package/dist/designer/data/systems/urdu/components.html +136 -0
  407. package/dist/designer/data/systems/urdu/tokens.css +63 -0
  408. package/dist/designer/data/systems/vercel/DESIGN.md +313 -0
  409. package/dist/designer/data/systems/vercel/components.html +839 -0
  410. package/dist/designer/data/systems/vercel/tokens.css +270 -0
  411. package/dist/designer/data/systems/vibrant/DESIGN.md +71 -0
  412. package/dist/designer/data/systems/vibrant/components.html +136 -0
  413. package/dist/designer/data/systems/vibrant/tokens.css +63 -0
  414. package/dist/designer/data/systems/vintage/DESIGN.md +71 -0
  415. package/dist/designer/data/systems/vintage/components.html +136 -0
  416. package/dist/designer/data/systems/vintage/tokens.css +63 -0
  417. package/dist/designer/data/systems/vodafone/DESIGN.md +426 -0
  418. package/dist/designer/data/systems/vodafone/components.html +342 -0
  419. package/dist/designer/data/systems/vodafone/tokens.css +64 -0
  420. package/dist/designer/data/systems/voltagent/DESIGN.md +326 -0
  421. package/dist/designer/data/systems/voltagent/components.html +154 -0
  422. package/dist/designer/data/systems/voltagent/tokens.css +63 -0
  423. package/dist/designer/data/systems/warm-editorial/DESIGN.md +65 -0
  424. package/dist/designer/data/systems/warm-editorial/components.html +136 -0
  425. package/dist/designer/data/systems/warm-editorial/tokens.css +63 -0
  426. package/dist/designer/data/systems/warp/DESIGN.md +256 -0
  427. package/dist/designer/data/systems/warp/components.html +411 -0
  428. package/dist/designer/data/systems/warp/tokens.css +156 -0
  429. package/dist/designer/data/systems/webex/DESIGN.md +207 -0
  430. package/dist/designer/data/systems/webex/components.html +342 -0
  431. package/dist/designer/data/systems/webex/tokens.css +64 -0
  432. package/dist/designer/data/systems/webflow/DESIGN.md +95 -0
  433. package/dist/designer/data/systems/webflow/components.html +413 -0
  434. package/dist/designer/data/systems/webflow/tokens.css +191 -0
  435. package/dist/designer/data/systems/wechat/DESIGN.md +302 -0
  436. package/dist/designer/data/systems/wechat/components.html +507 -0
  437. package/dist/designer/data/systems/wechat/tokens.css +176 -0
  438. package/dist/designer/data/systems/wired/DESIGN.md +281 -0
  439. package/dist/designer/data/systems/wired/components.html +342 -0
  440. package/dist/designer/data/systems/wired/tokens.css +64 -0
  441. package/dist/designer/data/systems/wise/DESIGN.md +176 -0
  442. package/dist/designer/data/systems/wise/components.html +365 -0
  443. package/dist/designer/data/systems/wise/tokens.css +141 -0
  444. package/dist/designer/data/systems/x-ai/DESIGN.md +260 -0
  445. package/dist/designer/data/systems/x-ai/components.html +460 -0
  446. package/dist/designer/data/systems/x-ai/tokens.css +268 -0
  447. package/dist/designer/data/systems/xiaohongshu/DESIGN.md +402 -0
  448. package/dist/designer/data/systems/xiaohongshu/components.html +865 -0
  449. package/dist/designer/data/systems/xiaohongshu/tokens.css +193 -0
  450. package/dist/designer/data/systems/zapier/DESIGN.md +331 -0
  451. package/dist/designer/data/systems/zapier/components.html +342 -0
  452. package/dist/designer/data/systems/zapier/tokens.css +64 -0
  453. package/dist/designer/guidelines.js +176 -0
  454. package/dist/designer/index.js +236 -0
  455. package/dist/designer/skills.js +1675 -0
  456. package/dist/designer/systems.js +216 -0
  457. package/dist/server/pi-bridge.js +155 -5
  458. package/dist/server/session-stream.js +45 -1
  459. package/package.json +1 -1
@@ -0,0 +1,496 @@
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" />
6
+ <title>SpaceX — reference components</title>
7
+ <meta
8
+ name="description"
9
+ content="Reference fixture for design-systems/spacex. Pure black canvas,
10
+ spectral white type, full-viewport cinematic sections, D-DIN industrial
11
+ uppercase, ghost-button as the sole interactive element, zero shadows."
12
+ />
13
+
14
+ <style>
15
+ :root {
16
+ --bg: #000000;
17
+ --surface: #000000;
18
+ --surface-warm: var(--surface);
19
+
20
+ --fg: #f0f0fa;
21
+ --fg-2: var(--fg);
22
+ --muted: rgba(240, 240, 250, 0.7);
23
+ --meta: var(--muted);
24
+
25
+ --border: rgba(240, 240, 250, 0.35);
26
+ --border-soft: rgba(240, 240, 250, 0.1);
27
+
28
+ --accent: #f0f0fa;
29
+ --accent-on: #000000;
30
+ --accent-hover: #ffffff;
31
+ --accent-active: #d8d8e6;
32
+
33
+ --success: #16a34a;
34
+ --warn: #eab308;
35
+ --danger: #dc2626;
36
+
37
+ --font-display: "D-DIN-Bold", "D-DIN", "DIN Alternate", "Helvetica Neue", Arial, Verdana, sans-serif;
38
+ --font-body: "D-DIN", "DIN Alternate", "Helvetica Neue", Arial, Verdana, sans-serif;
39
+ --font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Monaco, Consolas, monospace;
40
+
41
+ --text-xs: 10px;
42
+ --text-sm: 12px;
43
+ --text-base: 16px;
44
+ --text-lg: 20px;
45
+ --text-xl: 24px;
46
+ --text-2xl: 32px;
47
+ --text-3xl: 40px;
48
+ --text-4xl: 48px;
49
+
50
+ --leading-body: 1.5;
51
+ --leading-tight: 1.0;
52
+ --tracking-display: 0.02em;
53
+
54
+ --space-1: 4px;
55
+ --space-2: 8px;
56
+ --space-3: 12px;
57
+ --space-4: 16px;
58
+ --space-5: 20px;
59
+ --space-6: 24px;
60
+ --space-8: 32px;
61
+ --space-12: 48px;
62
+
63
+ --section-y-desktop: 120px;
64
+ --section-y-tablet: 80px;
65
+ --section-y-phone: 56px;
66
+
67
+ --radius-sm: 4px;
68
+ --radius-md: 4px;
69
+ --radius-lg: 4px;
70
+ --radius-pill: 32px;
71
+
72
+ --elev-flat: none;
73
+ --elev-ring: 0 0 0 1px var(--border);
74
+ --elev-raised: none;
75
+
76
+ --focus-ring: 0 0 0 2px var(--accent);
77
+
78
+ --motion-fast: 150ms;
79
+ --motion-base: 200ms;
80
+ --ease-standard: cubic-bezier(0.2, 0, 0, 1);
81
+
82
+ --container-max: 1440px;
83
+ --container-gutter-desktop: 24px;
84
+ --container-gutter-tablet: 20px;
85
+ --container-gutter-phone: 18px;
86
+ }
87
+
88
+ /* ─── Reset ─────────────────────────────────────────────── */
89
+ *, *::before, *::after { box-sizing: border-box; }
90
+ html, body { margin: 0; padding: 0; }
91
+ body {
92
+ background: var(--bg);
93
+ color: var(--fg);
94
+ font-family: var(--font-body);
95
+ font-size: var(--text-base);
96
+ line-height: var(--leading-body);
97
+ -webkit-font-smoothing: antialiased;
98
+ }
99
+
100
+ /* ─── Layout ─────────────────────────────────────────────── */
101
+ .container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-gutter-desktop); }
102
+ section { padding-block: var(--section-y-desktop); }
103
+ /* Sharp 4px ghost dividers between cinematic scenes — never decorative */
104
+ section + section { border-top: 1px solid var(--border-soft); }
105
+ @media (max-width: 1023px) {
106
+ .container { padding-inline: var(--container-gutter-tablet); }
107
+ section { padding-block: var(--section-y-tablet); }
108
+ }
109
+ @media (max-width: 639px) {
110
+ .container { padding-inline: var(--container-gutter-phone); }
111
+ section { padding-block: var(--section-y-phone); }
112
+ }
113
+
114
+ /* ─── Typography — universal uppercase + positive tracking ─ */
115
+ h1, h2, h3 {
116
+ font-family: var(--font-display);
117
+ font-weight: 700;
118
+ line-height: var(--leading-tight);
119
+ text-transform: uppercase;
120
+ letter-spacing: var(--tracking-display);
121
+ margin: 0;
122
+ }
123
+ h1 { font-size: var(--text-4xl); }
124
+ h2 { font-size: var(--text-2xl); }
125
+ h3 { font-size: var(--text-base); letter-spacing: 0.04em; }
126
+ p { margin: 0; }
127
+ .lead {
128
+ font-size: var(--text-base);
129
+ color: var(--fg);
130
+ line-height: var(--leading-body);
131
+ text-transform: uppercase;
132
+ letter-spacing: 0.02em;
133
+ font-weight: 400;
134
+ }
135
+ .body-muted { color: var(--muted); }
136
+ /* Caption Bold / Nav Link Bold tier — DESIGN.md §3 (13px / 1.17px) */
137
+ .caption-bold {
138
+ font-family: var(--font-body);
139
+ font-size: 13px;
140
+ font-weight: 700;
141
+ line-height: 0.94;
142
+ letter-spacing: 1.17px;
143
+ text-transform: uppercase;
144
+ color: var(--fg);
145
+ }
146
+ /* Eyebrow — micro tier; DESIGN.md §3 Micro = 10px / 1px tracking */
147
+ .eyebrow {
148
+ font-size: var(--text-xs);
149
+ font-weight: 400;
150
+ line-height: 0.94;
151
+ letter-spacing: 1px;
152
+ text-transform: uppercase;
153
+ color: var(--muted);
154
+ }
155
+ .stack-3 > * + * { margin-block-start: var(--space-3); }
156
+ .stack-4 > * + * { margin-block-start: var(--space-4); }
157
+ .stack-6 > * + * { margin-block-start: var(--space-6); }
158
+ .stack-8 > * + * { margin-block-start: var(--space-8); }
159
+
160
+ /* ─── Buttons — Ghost is the only variant ────────────────
161
+ * DESIGN.md §4: rgba(240,240,250,0.1) bg, 1px spectral border,
162
+ * 32px radius, 18px padding. The sole interactive element. */
163
+ .btn {
164
+ display: inline-flex;
165
+ align-items: center;
166
+ gap: var(--space-2);
167
+ padding: 18px var(--space-6);
168
+ border-radius: var(--radius-pill);
169
+ font-family: var(--font-body);
170
+ font-size: var(--text-sm);
171
+ font-weight: 700;
172
+ line-height: 1;
173
+ letter-spacing: 1.17px;
174
+ text-transform: uppercase;
175
+ cursor: pointer;
176
+ text-decoration: none;
177
+ transition:
178
+ background-color var(--motion-fast) var(--ease-standard),
179
+ color var(--motion-fast) var(--ease-standard),
180
+ border-color var(--motion-fast) var(--ease-standard);
181
+ }
182
+ .btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
183
+ /* Ghost — the canonical SpaceX button */
184
+ .btn-ghost {
185
+ background: rgba(240, 240, 250, 0.1);
186
+ color: var(--fg);
187
+ border: 1px solid var(--border);
188
+ }
189
+ .btn-ghost:hover {
190
+ background: rgba(240, 240, 250, 0.18);
191
+ color: var(--accent-hover);
192
+ border-color: var(--accent-hover);
193
+ }
194
+ .btn-ghost:active { background: rgba(240, 240, 250, 0.24); }
195
+ /* Solid spectral — used sparingly for the highest-priority CTA */
196
+ .btn-solid {
197
+ background: var(--accent);
198
+ color: var(--accent-on);
199
+ border: 1px solid var(--accent);
200
+ }
201
+ .btn-solid:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
202
+ .btn-solid:active { background: var(--accent-active); border-color: var(--accent-active); }
203
+
204
+ /* ─── Inputs — spectral hairline only, no surface fill ──── */
205
+ .field { display: flex; flex-direction: column; gap: var(--space-2); }
206
+ .field label {
207
+ font-size: var(--text-xs);
208
+ font-weight: 700;
209
+ letter-spacing: 1px;
210
+ text-transform: uppercase;
211
+ color: var(--muted);
212
+ }
213
+ .field input {
214
+ padding: 14px var(--space-3);
215
+ border-radius: var(--radius-sm);
216
+ border: 1px solid var(--border);
217
+ background: transparent;
218
+ color: var(--fg);
219
+ font-family: var(--font-body);
220
+ font-size: var(--text-base);
221
+ text-transform: uppercase;
222
+ letter-spacing: 0.02em;
223
+ outline: none;
224
+ transition:
225
+ border-color var(--motion-fast) var(--ease-standard),
226
+ box-shadow var(--motion-fast) var(--ease-standard);
227
+ }
228
+ .field input:focus-visible {
229
+ border-color: var(--accent-hover);
230
+ box-shadow: var(--focus-ring);
231
+ }
232
+ .field input::placeholder {
233
+ color: var(--muted);
234
+ text-transform: uppercase;
235
+ letter-spacing: 0.02em;
236
+ }
237
+ .field-help {
238
+ font-size: var(--text-xs);
239
+ font-weight: 400;
240
+ letter-spacing: 1px;
241
+ text-transform: uppercase;
242
+ color: var(--muted);
243
+ }
244
+
245
+ /* ─── Hero — full-viewport cinematic scene ──────────────
246
+ * DESIGN.md §1: each section is a film frame. No external
247
+ * image lives in the fixture; we evoke the cosmic black
248
+ * sky / planetary curve with layered radial gradients +
249
+ * the canonical rgba(0,0,0,0.5) legibility overlay. */
250
+ .hero {
251
+ position: relative;
252
+ min-height: 100vh;
253
+ display: flex;
254
+ align-items: flex-end;
255
+ padding-block: var(--section-y-desktop);
256
+ background:
257
+ linear-gradient(180deg, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.5) 100%),
258
+ radial-gradient(2px 2px at 12% 22%, rgba(240, 240, 250, 0.85), transparent 60%),
259
+ radial-gradient(1px 1px at 28% 64%, rgba(240, 240, 250, 0.7), transparent 60%),
260
+ radial-gradient(2px 2px at 47% 18%, rgba(240, 240, 250, 0.6), transparent 60%),
261
+ radial-gradient(1px 1px at 63% 41%, rgba(240, 240, 250, 0.85), transparent 60%),
262
+ radial-gradient(1.5px 1.5px at 78% 12%, rgba(240, 240, 250, 0.5), transparent 60%),
263
+ radial-gradient(1px 1px at 88% 73%, rgba(240, 240, 250, 0.6), transparent 60%),
264
+ radial-gradient(1px 1px at 38% 88%, rgba(240, 240, 250, 0.4), transparent 60%),
265
+ radial-gradient(2px 2px at 6% 84%, rgba(240, 240, 250, 0.5), transparent 60%),
266
+ radial-gradient(ellipse 120% 70% at 50% 100%, rgba(36, 32, 64, 0.85) 0%, rgba(0, 0, 0, 0) 70%),
267
+ radial-gradient(ellipse 90% 60% at 80% 18%, rgba(80, 60, 110, 0.25) 0%, rgba(0, 0, 0, 0) 65%),
268
+ #000000;
269
+ }
270
+ .hero-inner { max-width: 720px; }
271
+ .hero h1 {
272
+ font-size: var(--text-4xl);
273
+ letter-spacing: var(--tracking-display);
274
+ }
275
+ .hero .lead { max-width: 56ch; }
276
+ .hero-actions { display: flex; gap: var(--space-4); margin-block-start: var(--space-8); flex-wrap: wrap; }
277
+
278
+ /* Mission status strip — uppercase, hairline-divided, no card */
279
+ .mission-strip {
280
+ display: grid;
281
+ grid-template-columns: repeat(4, 1fr);
282
+ gap: 0;
283
+ margin-block-start: var(--space-12);
284
+ border-top: 1px solid var(--border-soft);
285
+ border-bottom: 1px solid var(--border-soft);
286
+ }
287
+ .mission-strip > * {
288
+ padding: var(--space-5) var(--space-4);
289
+ }
290
+ .mission-strip > * + * { border-left: 1px solid var(--border-soft); }
291
+ @media (max-width: 1023px) {
292
+ .mission-strip { grid-template-columns: 1fr 1fr; }
293
+ .mission-strip > *:nth-child(2n+1) { border-left: none; }
294
+ }
295
+ @media (max-width: 639px) {
296
+ .mission-strip { grid-template-columns: 1fr; }
297
+ .mission-strip > * + * { border-left: none; border-top: 1px solid var(--border-soft); }
298
+ }
299
+ .mission-strip dt { color: var(--muted); margin: 0; }
300
+ .mission-strip dd {
301
+ margin: var(--space-2) 0 0;
302
+ font-family: var(--font-display);
303
+ font-size: var(--text-xl);
304
+ font-weight: 700;
305
+ line-height: var(--leading-tight);
306
+ text-transform: uppercase;
307
+ letter-spacing: 0.02em;
308
+ color: var(--fg);
309
+ }
310
+
311
+ /* ─── Features — text-on-void, no cards ─────────────────
312
+ * DESIGN.md §4: no panels, no containers, no cards. Three
313
+ * vertical text blocks sit directly on the void, separated
314
+ * only by hairline ghost dividers. */
315
+ .features-grid {
316
+ display: grid;
317
+ grid-template-columns: repeat(3, 1fr);
318
+ gap: 0;
319
+ border-top: 1px solid var(--border-soft);
320
+ }
321
+ .features-grid > article {
322
+ padding: var(--space-12) var(--space-6) var(--space-12) 0;
323
+ display: flex;
324
+ flex-direction: column;
325
+ gap: var(--space-4);
326
+ }
327
+ .features-grid > article + article {
328
+ border-left: 1px solid var(--border-soft);
329
+ padding-inline-start: var(--space-6);
330
+ }
331
+ @media (max-width: 1023px) {
332
+ .features-grid { grid-template-columns: 1fr; }
333
+ .features-grid > article + article {
334
+ border-left: none;
335
+ border-top: 1px solid var(--border-soft);
336
+ padding-inline-start: 0;
337
+ }
338
+ }
339
+ .feature-index {
340
+ font-family: var(--font-display);
341
+ font-size: var(--text-sm);
342
+ font-weight: 700;
343
+ letter-spacing: 1.17px;
344
+ text-transform: uppercase;
345
+ color: var(--muted);
346
+ }
347
+ .feature h3 {
348
+ font-size: var(--text-xl);
349
+ line-height: var(--leading-tight);
350
+ letter-spacing: var(--tracking-display);
351
+ }
352
+ .feature p { color: var(--muted); }
353
+ .feature a {
354
+ color: var(--fg);
355
+ font-size: var(--text-sm);
356
+ font-weight: 700;
357
+ letter-spacing: 1.17px;
358
+ text-transform: uppercase;
359
+ text-decoration: none;
360
+ border-bottom: 1px solid var(--border);
361
+ padding-block-end: 4px;
362
+ align-self: flex-start;
363
+ transition: color var(--motion-fast) var(--ease-standard),
364
+ border-color var(--motion-fast) var(--ease-standard);
365
+ }
366
+ .feature a:hover { color: var(--accent-hover); border-color: var(--accent-hover); }
367
+
368
+ /* ─── Form — mission briefing, spectral hairlines ──────── */
369
+ .form-row {
370
+ display: grid;
371
+ grid-template-columns: 1fr 1fr;
372
+ gap: var(--space-12);
373
+ align-items: start;
374
+ }
375
+ @media (max-width: 1023px) { .form-row { grid-template-columns: 1fr; gap: var(--space-8); } }
376
+ .form { display: flex; flex-direction: column; gap: var(--space-5); max-width: 480px; }
377
+ .form-actions { display: flex; gap: var(--space-3); margin-block-start: var(--space-3); flex-wrap: wrap; }
378
+ .icon { width: 14px; height: 14px; flex-shrink: 0; }
379
+ </style>
380
+ </head>
381
+ <body>
382
+ <main class="container">
383
+ <section class="hero" data-od-id="hero">
384
+ <div class="hero-inner stack-6">
385
+ <p class="caption-bold">SpaceX · Mission 2026</p>
386
+ <h1>Making life multi&#8209;planetary.</h1>
387
+ <p class="lead">
388
+ From low&#8209;Earth orbit to the surface of Mars — we build the
389
+ rockets, the spacecraft, and the operating cadence that turn
390
+ humanity into a multi&#8209;planet species.
391
+ </p>
392
+ <div class="hero-actions">
393
+ <a href="./tokens.css" class="btn btn-ghost">
394
+ Learn more
395
+ <svg class="icon" viewBox="0 0 24 24" fill="none"
396
+ stroke="currentColor" stroke-width="2"
397
+ stroke-linecap="round" stroke-linejoin="round"
398
+ aria-hidden="true"><path d="M5 12h14M13 6l6 6-6 6"/></svg>
399
+ </a>
400
+ <a href="./DESIGN.md" class="btn btn-ghost">View the spec</a>
401
+ </div>
402
+
403
+ <dl class="mission-strip" aria-label="Mission counters">
404
+ <div>
405
+ <dt class="eyebrow">Total Launches</dt>
406
+ <dd>438</dd>
407
+ </div>
408
+ <div>
409
+ <dt class="eyebrow">Total Landings</dt>
410
+ <dd>406</dd>
411
+ </div>
412
+ <div>
413
+ <dt class="eyebrow">Reflights</dt>
414
+ <dd>377</dd>
415
+ </div>
416
+ <div>
417
+ <dt class="eyebrow">Status</dt>
418
+ <dd>Nominal</dd>
419
+ </div>
420
+ </dl>
421
+ </div>
422
+ </section>
423
+
424
+ <section data-od-id="features">
425
+ <div class="stack-4">
426
+ <p class="eyebrow">What this fixture exercises</p>
427
+ <h2 style="max-width: 24ch">A type system for engineering on the edge of the atmosphere.</h2>
428
+ <p class="body-muted" style="max-width: 60ch; text-transform: uppercase; letter-spacing: 0.02em;">
429
+ Three principles, no cards, no shadows — text sits directly on the void.
430
+ </p>
431
+ </div>
432
+ <div class="features-grid" style="margin-block-start: var(--space-12)">
433
+ <article class="feature stack-4">
434
+ <p class="feature-index">01 / Atmosphere</p>
435
+ <h3>Pure black canvas, full&#8209;viewport imagery.</h3>
436
+ <p>
437
+ --bg (#000000) is the void. There is no card surface, no warm
438
+ tier — every section is text on photograph, every photograph
439
+ is one cinematic frame.
440
+ </p>
441
+ <a href="./tokens.css">Inspect surface tokens</a>
442
+ </article>
443
+ <article class="feature stack-4">
444
+ <p class="feature-index">02 / Voice</p>
445
+ <h3>Universal uppercase, positive tracking.</h3>
446
+ <p>
447
+ D&#8209;DIN at 0.02em (= 0.96px at 48px). Every label, every
448
+ counter, every CTA is stenciled like a serial number on a
449
+ spacecraft hull.
450
+ </p>
451
+ <a href="./DESIGN.md">Read the type rules</a>
452
+ </article>
453
+ <article class="feature stack-4">
454
+ <p class="feature-index">03 / Restraint</p>
455
+ <h3>Zero shadows, one ghost button.</h3>
456
+ <p>
457
+ --elev-raised resolves to <code style="font-family: var(--font-mono); font-size: var(--text-sm);">none</code>.
458
+ Depth comes from the photography. The lone ghost CTA at 32px
459
+ radius is the entire interactive surface area.
460
+ </p>
461
+ <a href="./tokens.css">Inspect elevation</a>
462
+ </article>
463
+ </div>
464
+ </section>
465
+
466
+ <section data-od-id="form">
467
+ <div class="form-row">
468
+ <div class="stack-6">
469
+ <p class="eyebrow">Mission Briefing</p>
470
+ <h2>Receive launch and re&#8209;entry telemetry.</h2>
471
+ <p class="body-muted" style="text-transform: uppercase; letter-spacing: 0.02em; max-width: 48ch;">
472
+ We&#8217;ll send pre&#8209;flight readiness reviews and
473
+ post&#8209;landing recovery summaries. Hairline borders only —
474
+ no surface fills, no shadows, no cool grays.
475
+ </p>
476
+ </div>
477
+ <form class="form" onsubmit="event.preventDefault();">
478
+ <div class="field">
479
+ <label for="callsign">Callsign</label>
480
+ <input id="callsign" type="text" placeholder="Mission control" autocomplete="username" required />
481
+ </div>
482
+ <div class="field">
483
+ <label for="email">Operator email</label>
484
+ <input id="email" type="email" placeholder="ops@spacex.com" autocomplete="email" required />
485
+ <p class="field-help">For mission summaries only.</p>
486
+ </div>
487
+ <div class="form-actions">
488
+ <button type="submit" class="btn btn-ghost">Confirm uplink</button>
489
+ <button type="button" class="btn btn-ghost">Stand down</button>
490
+ </div>
491
+ </form>
492
+ </div>
493
+ </section>
494
+ </main>
495
+ </body>
496
+ </html>
@@ -0,0 +1,154 @@
1
+ /* ─────────────────────────────────────────────────────────────────────────
2
+ * design-systems/spacex/tokens.css
3
+ *
4
+ * Structured token bindings for "Design System Inspired by SpaceX".
5
+ * Cinematic aerospace minimalism: pure black canvas, full-viewport
6
+ * photography, D-DIN industrial type, universal uppercase + positive
7
+ * tracking, zero shadows / cards / decoration. The interface disappears
8
+ * behind the imagery — only type, photography, and a single ghost button.
9
+ *
10
+ * Key brand decisions encoded here:
11
+ * - Pure Space Black (#000000) — the void of space; never a soft black
12
+ * - Spectral White (#f0f0fa) — slight blue-violet tint that mimics starlight
13
+ * - --surface aliases to --bg — SpaceX has NO cards, panels, or containers
14
+ * - Ghost border (rgba(240,240,250,0.35)) — only visible interactive edge
15
+ * - D-DIN industrial typeface — DIN heritage, stenciled aerospace voice
16
+ * - Display tracking 0.02em (= 0.96px at 48px) — DESIGN.md §3 verbatim
17
+ * - Tight leading 1.0 — compressed mission-briefing rhythm
18
+ * - --elev-raised: none — zero shadows; depth comes from photography
19
+ * - --radius-pill: 32px — the ghost button is the SOLE rounded element
20
+ * ─────────────────────────────────────────────────────────────────── */
21
+
22
+ :root {
23
+ /* ─── Surface ─────────────────────────────────────────────────────
24
+ * The void of space. There is no card tier, no warm tier — every
25
+ * SpaceX section is text-on-photograph, not text-on-surface. We
26
+ * still declare --surface so cross-brand components that paint a
27
+ * card still resolve, but it deliberately matches --bg. */
28
+ --bg: #000000; /* Space Black — pure void, the foundation canvas */
29
+ --surface: #000000; /* No card surfaces — content sits directly on the void */
30
+ --surface-warm: var(--surface); /* alias — no warm tier in an achromatic system */
31
+
32
+ /* ─── Foreground ──────────────────────────────────────────────────
33
+ * Spectral White, never pure white. The slight blue-violet tint
34
+ * mimics starlight on a spacecraft hull and prevents the clinical
35
+ * feel of #ffffff against pure black. */
36
+ --fg: #f0f0fa; /* Spectral White — primary text, mission-critical signal */
37
+ --fg-2: var(--fg); /* alias — single text weight throughout the system */
38
+ --muted: rgba(240, 240, 250, 0.7); /* Dimmed spectral — captions, secondary labels */
39
+ --meta: var(--muted); /* alias — tertiary FG identical to muted on dark canvas */
40
+
41
+ /* ─── Border ──────────────────────────────────────────────────────
42
+ * The Ghost Border (35% spectral) is the only edge that ever
43
+ * appears — on the lone ghost CTA button. Inner separators borrow
44
+ * the 10% spectral surface tint so they barely register. */
45
+ --border: rgba(240, 240, 250, 0.35); /* Ghost Border — DESIGN.md §2 verbatim */
46
+ --border-soft: rgba(240, 240, 250, 0.1); /* Inner separators / barely-visible dividers */
47
+
48
+ /* ─── Accent ──────────────────────────────────────────────────────
49
+ * SpaceX has no chromatic accent — Spectral White IS the accent.
50
+ * Hover lifts to pure white (Hover White / --white-100 in DESIGN.md);
51
+ * active gently dims. The full ghost-button affordance is
52
+ * implemented in components, not in the accent token. */
53
+ --accent: #f0f0fa; /* Spectral White stands in for any brand accent */
54
+ --accent-on: #000000; /* Black text when accent is the bg */
55
+ --accent-hover: #ffffff; /* Hover White — pure white per DESIGN.md §2 */
56
+ --accent-active: #d8d8e6; /* Dimmed spectral — pressed state */
57
+
58
+ /* ─── Semantic ────────────────────────────────────────────────────
59
+ * Schema defaults preserved. SpaceX's homepage is purely
60
+ * presentational and almost never surfaces semantic state, but the
61
+ * tokens must resolve when shared components reference them. */
62
+ --success: #16a34a;
63
+ --warn: #eab308;
64
+ --danger: #dc2626;
65
+
66
+ /* ─── Typography ──────────────────────────────────────────────────
67
+ * D-DIN — industrial geometric, German DIN heritage. Two weights
68
+ * only: 700 (Bold) for display + nav emphasis, 400 for body.
69
+ * Fallbacks per DESIGN.md §3: Arial, Verdana. */
70
+ --font-display: "D-DIN-Bold", "D-DIN", "DIN Alternate", "Helvetica Neue", Arial, Verdana, sans-serif;
71
+ --font-body: "D-DIN", "DIN Alternate", "Helvetica Neue", Arial, Verdana, sans-serif;
72
+ --font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Monaco, Consolas, monospace;
73
+
74
+ /* Type scale — DESIGN.md §3 anchors: 10px (Micro), 12px (Caption /
75
+ * Nav), 16px (Body), 48px (Display Hero). Intermediate tiers
76
+ * (20/24/32/40) are interpolated for the few moments a SpaceX-style
77
+ * layout needs them; the actual brand uses very few sizes. */
78
+ --text-xs: 10px; /* Micro — uppercase ghost labels */
79
+ --text-sm: 12px; /* Caption / Nav Link — uppercase */
80
+ --text-base: 16px; /* Body — standard reading text */
81
+ --text-lg: 20px;
82
+ --text-xl: 24px;
83
+ --text-2xl: 32px;
84
+ --text-3xl: 40px;
85
+ --text-4xl: 48px; /* Display Hero — D-DIN-Bold uppercase, "MISSION" weight */
86
+
87
+ --leading-body: 1.5; /* DESIGN.md says 1.5–1.7 for reading body */
88
+ --leading-tight: 1.0; /* Display / mission-briefing rhythm */
89
+ --tracking-display: 0.02em; /* = 0.96px at 48px — DESIGN.md §3 hero spec verbatim */
90
+
91
+ /* ─── Spacing ─────────────────────────────────────────────────────
92
+ * 8px base unit per DESIGN.md §5. Schema-default scale preserved —
93
+ * SpaceX's irregular published scale (3/5/12/15/18/20/24/30) is a
94
+ * brand-specific rhythm; cross-brand components paint at 4/8/12/16. */
95
+ --space-1: 4px;
96
+ --space-2: 8px;
97
+ --space-3: 12px;
98
+ --space-4: 16px;
99
+ --space-5: 20px;
100
+ --space-6: 24px;
101
+ --space-8: 32px;
102
+ --space-12: 48px;
103
+
104
+ /* ─── Section rhythm ──────────────────────────────────────────────
105
+ * DESIGN.md §5: each section is one full viewport. We can't bind
106
+ * "100vh" to padding (it would collapse on short content), so
107
+ * section-y is generous to evoke the cinematic single-viewport
108
+ * rhythm in fixture renderings. */
109
+ --section-y-desktop: 120px;
110
+ --section-y-tablet: 80px;
111
+ --section-y-phone: 56px;
112
+
113
+ /* ─── Radius ──────────────────────────────────────────────────────
114
+ * Sharp 4px on dividers / utility — DESIGN.md §5 "Sharp (4px)".
115
+ * --radius-pill rebound to 32px because SpaceX's ghost button IS
116
+ * the only rounded element in the system, and "pill" semantically
117
+ * maps to that lone interactive surface. */
118
+ --radius-sm: 4px;
119
+ --radius-md: 4px; /* No medium tier exists — same as sm */
120
+ --radius-lg: 4px; /* No large tier exists — same as sm */
121
+ --radius-pill: 32px; /* Ghost button radius — the only rounded element */
122
+
123
+ /* ─── Elevation (ZERO shadows) ────────────────────────────────────
124
+ * DESIGN.md §6: "SpaceX uses ZERO shadows." Every surface is
125
+ * already a photograph with natural lighting; CSS shadows would
126
+ * compete with the cinematic content. --elev-raised resolves to
127
+ * `none` so any shared component requesting a raised surface
128
+ * silently flattens instead of painting a synthetic drop shadow. */
129
+ --elev-flat: none;
130
+ --elev-ring: 0 0 0 1px var(--border); /* Hairline spectral ring — ghost-button edge */
131
+ --elev-raised: none; /* Zero shadows — photography carries depth */
132
+
133
+ /* ─── Focus ring ──────────────────────────────────────────────────
134
+ * Solid 2px spectral ring — high contrast on black canvas. No
135
+ * blurred glow (consistent with the zero-shadow philosophy). */
136
+ --focus-ring: 0 0 0 2px var(--accent);
137
+
138
+ /* ─── Motion ──────────────────────────────────────────────────────
139
+ * Standard schema durations. SpaceX's drama is in the photography
140
+ * and type, not in animated state changes. */
141
+ --motion-fast: 150ms;
142
+ --motion-base: 200ms;
143
+ --ease-standard: cubic-bezier(0.2, 0, 0, 1);
144
+
145
+ /* ─── Layout ──────────────────────────────────────────────────────
146
+ * 1440px container — wide-format layouts honour the cinematic
147
+ * full-bleed feel without letting hero copy stretch beyond
148
+ * readable on ultra-wide displays. Generous gutters keep the
149
+ * "edge-to-edge imagery" feel even at smaller breakpoints. */
150
+ --container-max: 1440px;
151
+ --container-gutter-desktop: 24px;
152
+ --container-gutter-tablet: 20px;
153
+ --container-gutter-phone: 18px;
154
+ }