@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.
- package/dist/agent/index.js +76 -301
- package/dist/cli.js +11 -0
- package/dist/designer/data/systems/agentic/DESIGN.md +71 -0
- package/dist/designer/data/systems/agentic/components.html +154 -0
- package/dist/designer/data/systems/agentic/tokens.css +63 -0
- package/dist/designer/data/systems/airbnb/DESIGN.md +393 -0
- package/dist/designer/data/systems/airbnb/components.html +1373 -0
- package/dist/designer/data/systems/airbnb/tokens.css +261 -0
- package/dist/designer/data/systems/airtable/DESIGN.md +92 -0
- package/dist/designer/data/systems/airtable/components.html +489 -0
- package/dist/designer/data/systems/airtable/tokens.css +261 -0
- package/dist/designer/data/systems/ant/DESIGN.md +71 -0
- package/dist/designer/data/systems/ant/components.html +154 -0
- package/dist/designer/data/systems/ant/tokens.css +63 -0
- package/dist/designer/data/systems/apple/DESIGN.md +250 -0
- package/dist/designer/data/systems/apple/components.html +749 -0
- package/dist/designer/data/systems/apple/tokens.css +286 -0
- package/dist/designer/data/systems/application/DESIGN.md +71 -0
- package/dist/designer/data/systems/application/components.html +154 -0
- package/dist/designer/data/systems/application/tokens.css +63 -0
- package/dist/designer/data/systems/arc/DESIGN.md +152 -0
- package/dist/designer/data/systems/arc/components.html +432 -0
- package/dist/designer/data/systems/arc/tokens.css +137 -0
- package/dist/designer/data/systems/artistic/DESIGN.md +71 -0
- package/dist/designer/data/systems/artistic/components.html +136 -0
- package/dist/designer/data/systems/artistic/tokens.css +63 -0
- package/dist/designer/data/systems/atelier-zero/DESIGN.md +316 -0
- package/dist/designer/data/systems/atelier-zero/components.html +136 -0
- package/dist/designer/data/systems/atelier-zero/tokens.css +63 -0
- package/dist/designer/data/systems/bento/DESIGN.md +71 -0
- package/dist/designer/data/systems/bento/components.html +136 -0
- package/dist/designer/data/systems/bento/tokens.css +63 -0
- package/dist/designer/data/systems/binance/DESIGN.md +348 -0
- package/dist/designer/data/systems/binance/components.html +550 -0
- package/dist/designer/data/systems/binance/tokens.css +255 -0
- package/dist/designer/data/systems/bmw/DESIGN.md +183 -0
- package/dist/designer/data/systems/bmw/components.html +551 -0
- package/dist/designer/data/systems/bmw/tokens.css +179 -0
- package/dist/designer/data/systems/bmw-m/DESIGN.md +246 -0
- package/dist/designer/data/systems/bmw-m/components.html +342 -0
- package/dist/designer/data/systems/bmw-m/tokens.css +64 -0
- package/dist/designer/data/systems/bold/DESIGN.md +71 -0
- package/dist/designer/data/systems/bold/components.html +136 -0
- package/dist/designer/data/systems/bold/tokens.css +63 -0
- package/dist/designer/data/systems/brutalism/DESIGN.md +71 -0
- package/dist/designer/data/systems/brutalism/components.html +154 -0
- package/dist/designer/data/systems/brutalism/tokens.css +63 -0
- package/dist/designer/data/systems/bugatti/DESIGN.md +271 -0
- package/dist/designer/data/systems/bugatti/components.html +342 -0
- package/dist/designer/data/systems/bugatti/tokens.css +64 -0
- package/dist/designer/data/systems/cafe/DESIGN.md +71 -0
- package/dist/designer/data/systems/cafe/components.html +136 -0
- package/dist/designer/data/systems/cafe/tokens.css +63 -0
- package/dist/designer/data/systems/cal/DESIGN.md +262 -0
- package/dist/designer/data/systems/cal/components.html +376 -0
- package/dist/designer/data/systems/cal/tokens.css +265 -0
- package/dist/designer/data/systems/canva/DESIGN.md +157 -0
- package/dist/designer/data/systems/canva/components.html +461 -0
- package/dist/designer/data/systems/canva/tokens.css +147 -0
- package/dist/designer/data/systems/cisco/DESIGN.md +201 -0
- package/dist/designer/data/systems/cisco/components.html +342 -0
- package/dist/designer/data/systems/cisco/tokens.css +64 -0
- package/dist/designer/data/systems/claude/DESIGN.md +315 -0
- package/dist/designer/data/systems/claude/components.html +483 -0
- package/dist/designer/data/systems/claude/tokens.css +130 -0
- package/dist/designer/data/systems/clay/DESIGN.md +307 -0
- package/dist/designer/data/systems/clay/components.html +136 -0
- package/dist/designer/data/systems/clay/tokens.css +63 -0
- package/dist/designer/data/systems/claymorphism/DESIGN.md +71 -0
- package/dist/designer/data/systems/claymorphism/components.html +136 -0
- package/dist/designer/data/systems/claymorphism/tokens.css +63 -0
- package/dist/designer/data/systems/clean/DESIGN.md +71 -0
- package/dist/designer/data/systems/clean/components.html +136 -0
- package/dist/designer/data/systems/clean/tokens.css +63 -0
- package/dist/designer/data/systems/clickhouse/DESIGN.md +284 -0
- package/dist/designer/data/systems/clickhouse/components.html +506 -0
- package/dist/designer/data/systems/clickhouse/tokens.css +135 -0
- package/dist/designer/data/systems/cohere/DESIGN.md +269 -0
- package/dist/designer/data/systems/cohere/components.html +353 -0
- package/dist/designer/data/systems/cohere/tokens.css +126 -0
- package/dist/designer/data/systems/coinbase/DESIGN.md +132 -0
- package/dist/designer/data/systems/coinbase/components.html +501 -0
- package/dist/designer/data/systems/coinbase/tokens.css +257 -0
- package/dist/designer/data/systems/colorful/DESIGN.md +71 -0
- package/dist/designer/data/systems/colorful/components.html +136 -0
- package/dist/designer/data/systems/colorful/tokens.css +63 -0
- package/dist/designer/data/systems/composio/DESIGN.md +310 -0
- package/dist/designer/data/systems/composio/components.html +342 -0
- package/dist/designer/data/systems/composio/tokens.css +64 -0
- package/dist/designer/data/systems/contemporary/DESIGN.md +71 -0
- package/dist/designer/data/systems/contemporary/components.html +136 -0
- package/dist/designer/data/systems/contemporary/tokens.css +63 -0
- package/dist/designer/data/systems/corporate/DESIGN.md +71 -0
- package/dist/designer/data/systems/corporate/components.html +136 -0
- package/dist/designer/data/systems/corporate/tokens.css +63 -0
- package/dist/designer/data/systems/cosmic/DESIGN.md +71 -0
- package/dist/designer/data/systems/cosmic/components.html +136 -0
- package/dist/designer/data/systems/cosmic/tokens.css +63 -0
- package/dist/designer/data/systems/creative/DESIGN.md +71 -0
- package/dist/designer/data/systems/creative/components.html +136 -0
- package/dist/designer/data/systems/creative/tokens.css +63 -0
- package/dist/designer/data/systems/cursor/DESIGN.md +312 -0
- package/dist/designer/data/systems/cursor/components.html +654 -0
- package/dist/designer/data/systems/cursor/tokens.css +218 -0
- package/dist/designer/data/systems/dashboard/DESIGN.md +71 -0
- package/dist/designer/data/systems/dashboard/components.html +154 -0
- package/dist/designer/data/systems/dashboard/tokens.css +63 -0
- package/dist/designer/data/systems/default/DESIGN.md +62 -0
- package/dist/designer/data/systems/default/components.html +523 -0
- package/dist/designer/data/systems/default/tokens.css +200 -0
- package/dist/designer/data/systems/discord/DESIGN.md +162 -0
- package/dist/designer/data/systems/discord/components.html +359 -0
- package/dist/designer/data/systems/discord/tokens.css +125 -0
- package/dist/designer/data/systems/dithered/DESIGN.md +71 -0
- package/dist/designer/data/systems/dithered/components.html +136 -0
- package/dist/designer/data/systems/dithered/tokens.css +63 -0
- package/dist/designer/data/systems/doodle/DESIGN.md +71 -0
- package/dist/designer/data/systems/doodle/components.html +136 -0
- package/dist/designer/data/systems/doodle/tokens.css +63 -0
- package/dist/designer/data/systems/dramatic/DESIGN.md +71 -0
- package/dist/designer/data/systems/dramatic/components.html +136 -0
- package/dist/designer/data/systems/dramatic/tokens.css +63 -0
- package/dist/designer/data/systems/duolingo/DESIGN.md +154 -0
- package/dist/designer/data/systems/duolingo/components.html +532 -0
- package/dist/designer/data/systems/duolingo/tokens.css +130 -0
- package/dist/designer/data/systems/editorial/DESIGN.md +71 -0
- package/dist/designer/data/systems/editorial/components.html +154 -0
- package/dist/designer/data/systems/editorial/tokens.css +63 -0
- package/dist/designer/data/systems/elegant/DESIGN.md +71 -0
- package/dist/designer/data/systems/elegant/components.html +136 -0
- package/dist/designer/data/systems/elegant/tokens.css +63 -0
- package/dist/designer/data/systems/elevenlabs/DESIGN.md +268 -0
- package/dist/designer/data/systems/elevenlabs/components.html +342 -0
- package/dist/designer/data/systems/elevenlabs/tokens.css +127 -0
- package/dist/designer/data/systems/energetic/DESIGN.md +72 -0
- package/dist/designer/data/systems/energetic/components.html +136 -0
- package/dist/designer/data/systems/energetic/tokens.css +63 -0
- package/dist/designer/data/systems/enterprise/DESIGN.md +71 -0
- package/dist/designer/data/systems/enterprise/components.html +154 -0
- package/dist/designer/data/systems/enterprise/tokens.css +63 -0
- package/dist/designer/data/systems/expo/DESIGN.md +284 -0
- package/dist/designer/data/systems/expo/components.html +342 -0
- package/dist/designer/data/systems/expo/tokens.css +64 -0
- package/dist/designer/data/systems/expressive/DESIGN.md +71 -0
- package/dist/designer/data/systems/expressive/components.html +136 -0
- package/dist/designer/data/systems/expressive/tokens.css +63 -0
- package/dist/designer/data/systems/fantasy/DESIGN.md +71 -0
- package/dist/designer/data/systems/fantasy/components.html +136 -0
- package/dist/designer/data/systems/fantasy/tokens.css +63 -0
- package/dist/designer/data/systems/ferrari/DESIGN.md +317 -0
- package/dist/designer/data/systems/ferrari/components.html +342 -0
- package/dist/designer/data/systems/ferrari/tokens.css +64 -0
- package/dist/designer/data/systems/figma/DESIGN.md +223 -0
- package/dist/designer/data/systems/figma/components.html +344 -0
- package/dist/designer/data/systems/figma/tokens.css +126 -0
- package/dist/designer/data/systems/flat/DESIGN.md +71 -0
- package/dist/designer/data/systems/flat/components.html +136 -0
- package/dist/designer/data/systems/flat/tokens.css +63 -0
- package/dist/designer/data/systems/framer/DESIGN.md +249 -0
- package/dist/designer/data/systems/framer/components.html +438 -0
- package/dist/designer/data/systems/framer/tokens.css +238 -0
- package/dist/designer/data/systems/friendly/DESIGN.md +71 -0
- package/dist/designer/data/systems/friendly/components.html +136 -0
- package/dist/designer/data/systems/friendly/tokens.css +63 -0
- package/dist/designer/data/systems/futuristic/DESIGN.md +71 -0
- package/dist/designer/data/systems/futuristic/components.html +136 -0
- package/dist/designer/data/systems/futuristic/tokens.css +63 -0
- package/dist/designer/data/systems/github/DESIGN.md +155 -0
- package/dist/designer/data/systems/github/components.html +383 -0
- package/dist/designer/data/systems/github/tokens.css +125 -0
- package/dist/designer/data/systems/glassmorphism/DESIGN.md +71 -0
- package/dist/designer/data/systems/glassmorphism/components.html +154 -0
- package/dist/designer/data/systems/glassmorphism/tokens.css +63 -0
- package/dist/designer/data/systems/gradient/DESIGN.md +71 -0
- package/dist/designer/data/systems/gradient/components.html +154 -0
- package/dist/designer/data/systems/gradient/tokens.css +63 -0
- package/dist/designer/data/systems/hashicorp/DESIGN.md +281 -0
- package/dist/designer/data/systems/hashicorp/components.html +502 -0
- package/dist/designer/data/systems/hashicorp/tokens.css +272 -0
- package/dist/designer/data/systems/hud/DESIGN.md +173 -0
- package/dist/designer/data/systems/hud/components.html +136 -0
- package/dist/designer/data/systems/hud/tokens.css +63 -0
- package/dist/designer/data/systems/huggingface/DESIGN.md +149 -0
- package/dist/designer/data/systems/huggingface/components.html +346 -0
- package/dist/designer/data/systems/huggingface/tokens.css +125 -0
- package/dist/designer/data/systems/ibm/DESIGN.md +335 -0
- package/dist/designer/data/systems/ibm/components.html +342 -0
- package/dist/designer/data/systems/ibm/tokens.css +64 -0
- package/dist/designer/data/systems/intercom/DESIGN.md +149 -0
- package/dist/designer/data/systems/intercom/components.html +557 -0
- package/dist/designer/data/systems/intercom/tokens.css +150 -0
- package/dist/designer/data/systems/kami/DESIGN.md +410 -0
- package/dist/designer/data/systems/kami/components.html +601 -0
- package/dist/designer/data/systems/kami/tokens.css +272 -0
- package/dist/designer/data/systems/kraken/DESIGN.md +128 -0
- package/dist/designer/data/systems/kraken/components.html +342 -0
- package/dist/designer/data/systems/kraken/tokens.css +64 -0
- package/dist/designer/data/systems/lamborghini/DESIGN.md +291 -0
- package/dist/designer/data/systems/lamborghini/components.html +342 -0
- package/dist/designer/data/systems/lamborghini/tokens.css +64 -0
- package/dist/designer/data/systems/levels/DESIGN.md +71 -0
- package/dist/designer/data/systems/levels/components.html +154 -0
- package/dist/designer/data/systems/levels/tokens.css +63 -0
- package/dist/designer/data/systems/linear-app/DESIGN.md +370 -0
- package/dist/designer/data/systems/linear-app/components.html +370 -0
- package/dist/designer/data/systems/linear-app/tokens.css +130 -0
- package/dist/designer/data/systems/lingo/DESIGN.md +71 -0
- package/dist/designer/data/systems/lingo/components.html +154 -0
- package/dist/designer/data/systems/lingo/tokens.css +63 -0
- package/dist/designer/data/systems/loom/DESIGN.md +201 -0
- package/dist/designer/data/systems/loom/components.html +446 -0
- package/dist/designer/data/systems/loom/tokens.css +138 -0
- package/dist/designer/data/systems/lovable/DESIGN.md +301 -0
- package/dist/designer/data/systems/lovable/components.html +441 -0
- package/dist/designer/data/systems/lovable/tokens.css +258 -0
- package/dist/designer/data/systems/luxury/DESIGN.md +71 -0
- package/dist/designer/data/systems/luxury/components.html +154 -0
- package/dist/designer/data/systems/luxury/tokens.css +63 -0
- package/dist/designer/data/systems/mastercard/DESIGN.md +368 -0
- package/dist/designer/data/systems/mastercard/components.html +342 -0
- package/dist/designer/data/systems/mastercard/tokens.css +64 -0
- package/dist/designer/data/systems/material/DESIGN.md +71 -0
- package/dist/designer/data/systems/material/components.html +154 -0
- package/dist/designer/data/systems/material/tokens.css +63 -0
- package/dist/designer/data/systems/meta/DESIGN.md +369 -0
- package/dist/designer/data/systems/meta/components.html +398 -0
- package/dist/designer/data/systems/meta/tokens.css +263 -0
- package/dist/designer/data/systems/minimal/DESIGN.md +71 -0
- package/dist/designer/data/systems/minimal/components.html +154 -0
- package/dist/designer/data/systems/minimal/tokens.css +63 -0
- package/dist/designer/data/systems/minimax/DESIGN.md +260 -0
- package/dist/designer/data/systems/minimax/components.html +590 -0
- package/dist/designer/data/systems/minimax/tokens.css +148 -0
- package/dist/designer/data/systems/mintlify/DESIGN.md +329 -0
- package/dist/designer/data/systems/mintlify/components.html +737 -0
- package/dist/designer/data/systems/mintlify/tokens.css +256 -0
- package/dist/designer/data/systems/miro/DESIGN.md +111 -0
- package/dist/designer/data/systems/miro/components.html +342 -0
- package/dist/designer/data/systems/miro/tokens.css +64 -0
- package/dist/designer/data/systems/mission-control/DESIGN.md +474 -0
- package/dist/designer/data/systems/mission-control/components.html +136 -0
- package/dist/designer/data/systems/mission-control/tokens.css +63 -0
- package/dist/designer/data/systems/mistral-ai/DESIGN.md +264 -0
- package/dist/designer/data/systems/mistral-ai/components.html +338 -0
- package/dist/designer/data/systems/mistral-ai/tokens.css +125 -0
- package/dist/designer/data/systems/modern/DESIGN.md +71 -0
- package/dist/designer/data/systems/modern/components.html +154 -0
- package/dist/designer/data/systems/modern/tokens.css +63 -0
- package/dist/designer/data/systems/mongodb/DESIGN.md +269 -0
- package/dist/designer/data/systems/mongodb/components.html +462 -0
- package/dist/designer/data/systems/mongodb/tokens.css +176 -0
- package/dist/designer/data/systems/mono/DESIGN.md +71 -0
- package/dist/designer/data/systems/mono/components.html +136 -0
- package/dist/designer/data/systems/mono/tokens.css +63 -0
- package/dist/designer/data/systems/neobrutalism/DESIGN.md +71 -0
- package/dist/designer/data/systems/neobrutalism/components.html +136 -0
- package/dist/designer/data/systems/neobrutalism/tokens.css +63 -0
- package/dist/designer/data/systems/neon/DESIGN.md +71 -0
- package/dist/designer/data/systems/neon/components.html +136 -0
- package/dist/designer/data/systems/neon/tokens.css +63 -0
- package/dist/designer/data/systems/neumorphism/DESIGN.md +71 -0
- package/dist/designer/data/systems/neumorphism/components.html +136 -0
- package/dist/designer/data/systems/neumorphism/tokens.css +63 -0
- package/dist/designer/data/systems/nike/DESIGN.md +366 -0
- package/dist/designer/data/systems/nike/components.html +512 -0
- package/dist/designer/data/systems/nike/tokens.css +304 -0
- package/dist/designer/data/systems/notion/DESIGN.md +312 -0
- package/dist/designer/data/systems/notion/components.html +413 -0
- package/dist/designer/data/systems/notion/tokens.css +130 -0
- package/dist/designer/data/systems/nvidia/DESIGN.md +296 -0
- package/dist/designer/data/systems/nvidia/components.html +414 -0
- package/dist/designer/data/systems/nvidia/tokens.css +133 -0
- package/dist/designer/data/systems/ollama/DESIGN.md +270 -0
- package/dist/designer/data/systems/ollama/components.html +700 -0
- package/dist/designer/data/systems/ollama/tokens.css +242 -0
- package/dist/designer/data/systems/openai/DESIGN.md +140 -0
- package/dist/designer/data/systems/openai/components.html +382 -0
- package/dist/designer/data/systems/openai/tokens.css +133 -0
- package/dist/designer/data/systems/opencode-ai/DESIGN.md +284 -0
- package/dist/designer/data/systems/opencode-ai/components.html +389 -0
- package/dist/designer/data/systems/opencode-ai/tokens.css +126 -0
- package/dist/designer/data/systems/pacman/DESIGN.md +71 -0
- package/dist/designer/data/systems/pacman/components.html +342 -0
- package/dist/designer/data/systems/pacman/tokens.css +64 -0
- package/dist/designer/data/systems/paper/DESIGN.md +71 -0
- package/dist/designer/data/systems/paper/components.html +136 -0
- package/dist/designer/data/systems/paper/tokens.css +63 -0
- package/dist/designer/data/systems/perplexity/DESIGN.md +286 -0
- package/dist/designer/data/systems/perplexity/components.html +455 -0
- package/dist/designer/data/systems/perplexity/tokens.css +151 -0
- package/dist/designer/data/systems/perspective/DESIGN.md +71 -0
- package/dist/designer/data/systems/perspective/components.html +136 -0
- package/dist/designer/data/systems/perspective/tokens.css +63 -0
- package/dist/designer/data/systems/pinterest/DESIGN.md +233 -0
- package/dist/designer/data/systems/pinterest/components.html +865 -0
- package/dist/designer/data/systems/pinterest/tokens.css +262 -0
- package/dist/designer/data/systems/playstation/DESIGN.md +367 -0
- package/dist/designer/data/systems/playstation/components.html +414 -0
- package/dist/designer/data/systems/playstation/tokens.css +150 -0
- package/dist/designer/data/systems/posthog/DESIGN.md +259 -0
- package/dist/designer/data/systems/posthog/components.html +827 -0
- package/dist/designer/data/systems/posthog/tokens.css +272 -0
- package/dist/designer/data/systems/premium/DESIGN.md +71 -0
- package/dist/designer/data/systems/premium/components.html +154 -0
- package/dist/designer/data/systems/premium/tokens.css +63 -0
- package/dist/designer/data/systems/professional/DESIGN.md +71 -0
- package/dist/designer/data/systems/professional/components.html +136 -0
- package/dist/designer/data/systems/professional/tokens.css +63 -0
- package/dist/designer/data/systems/publication/DESIGN.md +71 -0
- package/dist/designer/data/systems/publication/components.html +154 -0
- package/dist/designer/data/systems/publication/tokens.css +63 -0
- package/dist/designer/data/systems/raycast/DESIGN.md +271 -0
- package/dist/designer/data/systems/raycast/components.html +507 -0
- package/dist/designer/data/systems/raycast/tokens.css +143 -0
- package/dist/designer/data/systems/refined/DESIGN.md +71 -0
- package/dist/designer/data/systems/refined/components.html +136 -0
- package/dist/designer/data/systems/refined/tokens.css +63 -0
- package/dist/designer/data/systems/renault/DESIGN.md +314 -0
- package/dist/designer/data/systems/renault/components.html +154 -0
- package/dist/designer/data/systems/renault/tokens.css +63 -0
- package/dist/designer/data/systems/replicate/DESIGN.md +264 -0
- package/dist/designer/data/systems/replicate/components.html +340 -0
- package/dist/designer/data/systems/replicate/tokens.css +125 -0
- package/dist/designer/data/systems/resend/DESIGN.md +306 -0
- package/dist/designer/data/systems/resend/components.html +839 -0
- package/dist/designer/data/systems/resend/tokens.css +353 -0
- package/dist/designer/data/systems/retro/DESIGN.md +71 -0
- package/dist/designer/data/systems/retro/components.html +136 -0
- package/dist/designer/data/systems/retro/tokens.css +63 -0
- package/dist/designer/data/systems/revolut/DESIGN.md +188 -0
- package/dist/designer/data/systems/revolut/components.html +342 -0
- package/dist/designer/data/systems/revolut/tokens.css +64 -0
- package/dist/designer/data/systems/runwayml/DESIGN.md +247 -0
- package/dist/designer/data/systems/runwayml/components.html +638 -0
- package/dist/designer/data/systems/runwayml/tokens.css +204 -0
- package/dist/designer/data/systems/sanity/DESIGN.md +360 -0
- package/dist/designer/data/systems/sanity/components.html +342 -0
- package/dist/designer/data/systems/sanity/tokens.css +64 -0
- package/dist/designer/data/systems/sentry/DESIGN.md +265 -0
- package/dist/designer/data/systems/sentry/components.html +387 -0
- package/dist/designer/data/systems/sentry/tokens.css +219 -0
- package/dist/designer/data/systems/shadcn/DESIGN.md +71 -0
- package/dist/designer/data/systems/shadcn/components.html +732 -0
- package/dist/designer/data/systems/shadcn/tokens.css +255 -0
- package/dist/designer/data/systems/shopify/DESIGN.md +353 -0
- package/dist/designer/data/systems/shopify/components.html +342 -0
- package/dist/designer/data/systems/shopify/tokens.css +141 -0
- package/dist/designer/data/systems/simple/DESIGN.md +71 -0
- package/dist/designer/data/systems/simple/components.html +136 -0
- package/dist/designer/data/systems/simple/tokens.css +63 -0
- package/dist/designer/data/systems/skeumorphism/DESIGN.md +71 -0
- package/dist/designer/data/systems/skeumorphism/components.html +136 -0
- package/dist/designer/data/systems/skeumorphism/tokens.css +63 -0
- package/dist/designer/data/systems/slack/DESIGN.md +363 -0
- package/dist/designer/data/systems/slack/components.html +387 -0
- package/dist/designer/data/systems/slack/tokens.css +127 -0
- package/dist/designer/data/systems/sleek/DESIGN.md +71 -0
- package/dist/designer/data/systems/sleek/components.html +136 -0
- package/dist/designer/data/systems/sleek/tokens.css +63 -0
- package/dist/designer/data/systems/spacex/DESIGN.md +197 -0
- package/dist/designer/data/systems/spacex/components.html +496 -0
- package/dist/designer/data/systems/spacex/tokens.css +154 -0
- package/dist/designer/data/systems/spacious/DESIGN.md +71 -0
- package/dist/designer/data/systems/spacious/components.html +136 -0
- package/dist/designer/data/systems/spacious/tokens.css +63 -0
- package/dist/designer/data/systems/spotify/DESIGN.md +249 -0
- package/dist/designer/data/systems/spotify/components.html +365 -0
- package/dist/designer/data/systems/spotify/tokens.css +127 -0
- package/dist/designer/data/systems/starbucks/DESIGN.md +583 -0
- package/dist/designer/data/systems/starbucks/components.html +493 -0
- package/dist/designer/data/systems/starbucks/tokens.css +182 -0
- package/dist/designer/data/systems/storytelling/DESIGN.md +71 -0
- package/dist/designer/data/systems/storytelling/components.html +136 -0
- package/dist/designer/data/systems/storytelling/tokens.css +63 -0
- package/dist/designer/data/systems/stripe/DESIGN.md +325 -0
- package/dist/designer/data/systems/stripe/components.html +1018 -0
- package/dist/designer/data/systems/stripe/tokens.css +295 -0
- package/dist/designer/data/systems/supabase/DESIGN.md +258 -0
- package/dist/designer/data/systems/supabase/components.html +741 -0
- package/dist/designer/data/systems/supabase/tokens.css +294 -0
- package/dist/designer/data/systems/superhuman/DESIGN.md +255 -0
- package/dist/designer/data/systems/superhuman/components.html +537 -0
- package/dist/designer/data/systems/superhuman/tokens.css +160 -0
- package/dist/designer/data/systems/tesla/DESIGN.md +289 -0
- package/dist/designer/data/systems/tesla/components.html +724 -0
- package/dist/designer/data/systems/tesla/tokens.css +285 -0
- package/dist/designer/data/systems/tetris/DESIGN.md +71 -0
- package/dist/designer/data/systems/tetris/components.html +342 -0
- package/dist/designer/data/systems/tetris/tokens.css +64 -0
- package/dist/designer/data/systems/theverge/DESIGN.md +342 -0
- package/dist/designer/data/systems/theverge/components.html +342 -0
- package/dist/designer/data/systems/theverge/tokens.css +64 -0
- package/dist/designer/data/systems/together-ai/DESIGN.md +266 -0
- package/dist/designer/data/systems/together-ai/components.html +422 -0
- package/dist/designer/data/systems/together-ai/tokens.css +127 -0
- package/dist/designer/data/systems/totality-festival/DESIGN.md +206 -0
- package/dist/designer/data/systems/totality-festival/components.html +136 -0
- package/dist/designer/data/systems/totality-festival/tokens.css +63 -0
- package/dist/designer/data/systems/trading-terminal/DESIGN.md +178 -0
- package/dist/designer/data/systems/trading-terminal/components.html +154 -0
- package/dist/designer/data/systems/trading-terminal/tokens.css +63 -0
- package/dist/designer/data/systems/uber/DESIGN.md +298 -0
- package/dist/designer/data/systems/uber/components.html +347 -0
- package/dist/designer/data/systems/uber/tokens.css +131 -0
- package/dist/designer/data/systems/urdu/DESIGN.md +1002 -0
- package/dist/designer/data/systems/urdu/components.html +136 -0
- package/dist/designer/data/systems/urdu/tokens.css +63 -0
- package/dist/designer/data/systems/vercel/DESIGN.md +313 -0
- package/dist/designer/data/systems/vercel/components.html +839 -0
- package/dist/designer/data/systems/vercel/tokens.css +270 -0
- package/dist/designer/data/systems/vibrant/DESIGN.md +71 -0
- package/dist/designer/data/systems/vibrant/components.html +136 -0
- package/dist/designer/data/systems/vibrant/tokens.css +63 -0
- package/dist/designer/data/systems/vintage/DESIGN.md +71 -0
- package/dist/designer/data/systems/vintage/components.html +136 -0
- package/dist/designer/data/systems/vintage/tokens.css +63 -0
- package/dist/designer/data/systems/vodafone/DESIGN.md +426 -0
- package/dist/designer/data/systems/vodafone/components.html +342 -0
- package/dist/designer/data/systems/vodafone/tokens.css +64 -0
- package/dist/designer/data/systems/voltagent/DESIGN.md +326 -0
- package/dist/designer/data/systems/voltagent/components.html +154 -0
- package/dist/designer/data/systems/voltagent/tokens.css +63 -0
- package/dist/designer/data/systems/warm-editorial/DESIGN.md +65 -0
- package/dist/designer/data/systems/warm-editorial/components.html +136 -0
- package/dist/designer/data/systems/warm-editorial/tokens.css +63 -0
- package/dist/designer/data/systems/warp/DESIGN.md +256 -0
- package/dist/designer/data/systems/warp/components.html +411 -0
- package/dist/designer/data/systems/warp/tokens.css +156 -0
- package/dist/designer/data/systems/webex/DESIGN.md +207 -0
- package/dist/designer/data/systems/webex/components.html +342 -0
- package/dist/designer/data/systems/webex/tokens.css +64 -0
- package/dist/designer/data/systems/webflow/DESIGN.md +95 -0
- package/dist/designer/data/systems/webflow/components.html +413 -0
- package/dist/designer/data/systems/webflow/tokens.css +191 -0
- package/dist/designer/data/systems/wechat/DESIGN.md +302 -0
- package/dist/designer/data/systems/wechat/components.html +507 -0
- package/dist/designer/data/systems/wechat/tokens.css +176 -0
- package/dist/designer/data/systems/wired/DESIGN.md +281 -0
- package/dist/designer/data/systems/wired/components.html +342 -0
- package/dist/designer/data/systems/wired/tokens.css +64 -0
- package/dist/designer/data/systems/wise/DESIGN.md +176 -0
- package/dist/designer/data/systems/wise/components.html +365 -0
- package/dist/designer/data/systems/wise/tokens.css +141 -0
- package/dist/designer/data/systems/x-ai/DESIGN.md +260 -0
- package/dist/designer/data/systems/x-ai/components.html +460 -0
- package/dist/designer/data/systems/x-ai/tokens.css +268 -0
- package/dist/designer/data/systems/xiaohongshu/DESIGN.md +402 -0
- package/dist/designer/data/systems/xiaohongshu/components.html +865 -0
- package/dist/designer/data/systems/xiaohongshu/tokens.css +193 -0
- package/dist/designer/data/systems/zapier/DESIGN.md +331 -0
- package/dist/designer/data/systems/zapier/components.html +342 -0
- package/dist/designer/data/systems/zapier/tokens.css +64 -0
- package/dist/designer/guidelines.js +176 -0
- package/dist/designer/index.js +236 -0
- package/dist/designer/skills.js +1675 -0
- package/dist/designer/systems.js +216 -0
- package/dist/server/pi-bridge.js +155 -5
- package/dist/server/session-stream.js +45 -1
- 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‑planetary.</h1>
|
|
387
|
+
<p class="lead">
|
|
388
|
+
From low‑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‑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‑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‑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‑entry telemetry.</h2>
|
|
471
|
+
<p class="body-muted" style="text-transform: uppercase; letter-spacing: 0.02em; max-width: 48ch;">
|
|
472
|
+
We’ll send pre‑flight readiness reviews and
|
|
473
|
+
post‑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
|
+
}
|