getrelay 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +40 -0
- package/bin/relay.js +362 -0
- package/design-md/airbnb/DESIGN.md +545 -0
- package/design-md/airbnb/README.md +5 -0
- package/design-md/airtable/DESIGN.md +554 -0
- package/design-md/airtable/README.md +5 -0
- package/design-md/apple/DESIGN.md +562 -0
- package/design-md/apple/README.md +5 -0
- package/design-md/binance/DESIGN.md +634 -0
- package/design-md/binance/README.md +5 -0
- package/design-md/bmw/DESIGN.md +544 -0
- package/design-md/bmw/README.md +5 -0
- package/design-md/bmw-m/DESIGN.md +503 -0
- package/design-md/bmw-m/README.md +5 -0
- package/design-md/bugatti/DESIGN.md +454 -0
- package/design-md/bugatti/README.md +5 -0
- package/design-md/cal/DESIGN.md +542 -0
- package/design-md/cal/README.md +5 -0
- package/design-md/claude/DESIGN.md +589 -0
- package/design-md/claude/README.md +5 -0
- package/design-md/clay/DESIGN.md +541 -0
- package/design-md/clay/README.md +5 -0
- package/design-md/clickhouse/DESIGN.md +544 -0
- package/design-md/clickhouse/README.md +5 -0
- package/design-md/cohere/DESIGN.md +451 -0
- package/design-md/cohere/README.md +5 -0
- package/design-md/coinbase/DESIGN.md +570 -0
- package/design-md/coinbase/README.md +5 -0
- package/design-md/composio/DESIGN.md +506 -0
- package/design-md/composio/README.md +5 -0
- package/design-md/cursor/DESIGN.md +537 -0
- package/design-md/cursor/README.md +5 -0
- package/design-md/elevenlabs/DESIGN.md +504 -0
- package/design-md/elevenlabs/README.md +5 -0
- package/design-md/expo/DESIGN.md +526 -0
- package/design-md/expo/README.md +5 -0
- package/design-md/ferrari/DESIGN.md +531 -0
- package/design-md/ferrari/README.md +5 -0
- package/design-md/figma/DESIGN.md +578 -0
- package/design-md/figma/README.md +5 -0
- package/design-md/framer/DESIGN.md +544 -0
- package/design-md/framer/README.md +5 -0
- package/design-md/hashicorp/DESIGN.md +575 -0
- package/design-md/hashicorp/README.md +5 -0
- package/design-md/ibm/DESIGN.md +550 -0
- package/design-md/ibm/README.md +5 -0
- package/design-md/intercom/DESIGN.md +546 -0
- package/design-md/intercom/README.md +5 -0
- package/design-md/kraken/DESIGN.md +125 -0
- package/design-md/kraken/README.md +5 -0
- package/design-md/lamborghini/DESIGN.md +288 -0
- package/design-md/lamborghini/README.md +5 -0
- package/design-md/linear.app/DESIGN.md +548 -0
- package/design-md/linear.app/README.md +5 -0
- package/design-md/lovable/DESIGN.md +298 -0
- package/design-md/lovable/README.md +5 -0
- package/design-md/mastercard/DESIGN.md +365 -0
- package/design-md/mastercard/README.md +5 -0
- package/design-md/meta/DESIGN.md +683 -0
- package/design-md/meta/README.md +5 -0
- package/design-md/minimax/DESIGN.md +746 -0
- package/design-md/minimax/README.md +5 -0
- package/design-md/mintlify/DESIGN.md +852 -0
- package/design-md/mintlify/README.md +5 -0
- package/design-md/miro/DESIGN.md +825 -0
- package/design-md/miro/README.md +5 -0
- package/design-md/mistral.ai/DESIGN.md +773 -0
- package/design-md/mistral.ai/README.md +5 -0
- package/design-md/mongodb/DESIGN.md +767 -0
- package/design-md/mongodb/README.md +5 -0
- package/design-md/nike/DESIGN.md +575 -0
- package/design-md/nike/README.md +5 -0
- package/design-md/notion/DESIGN.md +821 -0
- package/design-md/notion/README.md +5 -0
- package/design-md/nvidia/DESIGN.md +640 -0
- package/design-md/nvidia/README.md +5 -0
- package/design-md/ollama/DESIGN.md +539 -0
- package/design-md/ollama/README.md +5 -0
- package/design-md/opencode.ai/DESIGN.md +521 -0
- package/design-md/opencode.ai/README.md +5 -0
- package/design-md/pinterest/DESIGN.md +597 -0
- package/design-md/pinterest/README.md +5 -0
- package/design-md/playstation/DESIGN.md +661 -0
- package/design-md/playstation/README.md +5 -0
- package/design-md/posthog/DESIGN.md +690 -0
- package/design-md/posthog/README.md +5 -0
- package/design-md/raycast/DESIGN.md +669 -0
- package/design-md/raycast/README.md +5 -0
- package/design-md/renault/DESIGN.md +589 -0
- package/design-md/renault/README.md +5 -0
- package/design-md/replicate/DESIGN.md +616 -0
- package/design-md/replicate/README.md +5 -0
- package/design-md/resend/DESIGN.md +585 -0
- package/design-md/resend/README.md +5 -0
- package/design-md/revolut/DESIGN.md +636 -0
- package/design-md/revolut/README.md +5 -0
- package/design-md/runwayml/DESIGN.md +244 -0
- package/design-md/runwayml/README.md +5 -0
- package/design-md/sanity/DESIGN.md +357 -0
- package/design-md/sanity/README.md +5 -0
- package/design-md/sentry/DESIGN.md +551 -0
- package/design-md/sentry/README.md +5 -0
- package/design-md/shopify/DESIGN.md +516 -0
- package/design-md/shopify/README.md +5 -0
- package/design-md/slack/DESIGN.md +482 -0
- package/design-md/spacex/DESIGN.md +363 -0
- package/design-md/spacex/README.md +5 -0
- package/design-md/spotify/DESIGN.md +246 -0
- package/design-md/spotify/README.md +5 -0
- package/design-md/starbucks/DESIGN.md +580 -0
- package/design-md/starbucks/README.md +5 -0
- package/design-md/stripe/DESIGN.md +487 -0
- package/design-md/stripe/README.md +5 -0
- package/design-md/supabase/DESIGN.md +462 -0
- package/design-md/supabase/README.md +5 -0
- package/design-md/superhuman/DESIGN.md +448 -0
- package/design-md/superhuman/README.md +5 -0
- package/design-md/tesla/DESIGN.md +286 -0
- package/design-md/tesla/README.md +5 -0
- package/design-md/theverge/DESIGN.md +339 -0
- package/design-md/theverge/README.md +5 -0
- package/design-md/together.ai/DESIGN.md +633 -0
- package/design-md/together.ai/README.md +5 -0
- package/design-md/uber/DESIGN.md +636 -0
- package/design-md/uber/README.md +5 -0
- package/design-md/vercel/DESIGN.md +736 -0
- package/design-md/vercel/README.md +5 -0
- package/design-md/vodafone/DESIGN.md +538 -0
- package/design-md/vodafone/README.md +5 -0
- package/design-md/voltagent/DESIGN.md +521 -0
- package/design-md/voltagent/README.md +5 -0
- package/design-md/warp/DESIGN.md +526 -0
- package/design-md/warp/README.md +5 -0
- package/design-md/webflow/DESIGN.md +588 -0
- package/design-md/webflow/README.md +5 -0
- package/design-md/wired/DESIGN.md +497 -0
- package/design-md/wired/README.md +5 -0
- package/design-md/wise/DESIGN.md +544 -0
- package/design-md/wise/README.md +5 -0
- package/design-md/x.ai/DESIGN.md +465 -0
- package/design-md/x.ai/README.md +5 -0
- package/design-md/zapier/DESIGN.md +537 -0
- package/design-md/zapier/README.md +5 -0
- package/package.json +31 -0
|
@@ -0,0 +1,669 @@
|
|
|
1
|
+
---
|
|
2
|
+
version: alpha
|
|
3
|
+
name: Raycast
|
|
4
|
+
属于: A dark-canvas developer-tools system that treats the marketing page like an extended product screenshot — pure-near-black background, command-palette mockups as the hero, Inter typography with the ss03 stylistic set turned on, and a single white CTA pill that doesn't break the inky atmosphere. The chrome reads like Raycast's own command-palette UI scaled up to a marketing page: monochrome dark surfaces with a faint surface ladder (#07080a → #0d0d0d → #101111), tight 6–10px radius on cards, hairline 1px borders in #242728, and rare splashes of saturated accent (Hacker News yellow, Slack red, Mac green, info blue) reserved for product-tile category illustrations. The signature visual moment is a red gradient hero wordmark — three diagonal red stripes laid across the very top of the home page like a launch-banner — paired with full-bleed product UI screenshots that show Raycast's actual command palette, store, and AI chat surfaces.
|
|
5
|
+
description: |
|
|
6
|
+
Raycast's marketing system reads like an extended product screenshot. The chrome IS the in-product chrome at marketing scale: pure-near-black canvas, hairline 1px borders, command-palette-style cards, Inter typography with the ss03 stylistic set enabled site-wide, white CTA pill, and a small set of saturated category accent colors (yellow / red / green / blue) reserved for extension and feature illustrations. Section rhythm is generous (~96px) but the page never breaks tonal continuity — the whole site sits in one continuous dark mode.
|
|
7
|
+
|
|
8
|
+
colors:
|
|
9
|
+
primary: "#ffffff"
|
|
10
|
+
primary-pressed: "#e8e8e8"
|
|
11
|
+
on-primary: "#000000"
|
|
12
|
+
ink: "#f4f4f6"
|
|
13
|
+
body: "#cdcdcd"
|
|
14
|
+
charcoal: "#d3d3d4"
|
|
15
|
+
mute: "#9c9c9d"
|
|
16
|
+
ash: "#6a6b6c"
|
|
17
|
+
stone: "#434345"
|
|
18
|
+
on-dark: "#ffffff"
|
|
19
|
+
on-dark-mute: "rgba(255,255,255,0.72)"
|
|
20
|
+
canvas: "#07080a"
|
|
21
|
+
surface: "#0d0d0d"
|
|
22
|
+
surface-elevated: "#101111"
|
|
23
|
+
surface-card: "#121212"
|
|
24
|
+
button-fg: "#18191a"
|
|
25
|
+
hairline: "#242728"
|
|
26
|
+
hairline-soft: "rgba(255,255,255,0.08)"
|
|
27
|
+
hairline-strong: "rgba(255,255,255,0.16)"
|
|
28
|
+
accent-blue: "#57c1ff"
|
|
29
|
+
accent-blue-soft: "rgba(87,193,255,0.15)"
|
|
30
|
+
accent-red: "#ff6161"
|
|
31
|
+
accent-red-soft: "rgba(255,97,97,0.15)"
|
|
32
|
+
accent-green: "#59d499"
|
|
33
|
+
accent-green-soft: "rgba(89,212,153,0.15)"
|
|
34
|
+
accent-yellow: "#ffc533"
|
|
35
|
+
accent-yellow-soft: "rgba(255,197,51,0.15)"
|
|
36
|
+
hero-stripe-start: "#ff5757"
|
|
37
|
+
hero-stripe-end: "#a1131a"
|
|
38
|
+
key-bg-start: "#121212"
|
|
39
|
+
key-bg-end: "#0d0d0d"
|
|
40
|
+
|
|
41
|
+
typography:
|
|
42
|
+
display-xl:
|
|
43
|
+
fontFamily: Inter
|
|
44
|
+
fontSize: 64px
|
|
45
|
+
fontWeight: 600
|
|
46
|
+
lineHeight: 1.1
|
|
47
|
+
letterSpacing: 0
|
|
48
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
49
|
+
display-lg:
|
|
50
|
+
fontFamily: Inter
|
|
51
|
+
fontSize: 56px
|
|
52
|
+
fontWeight: 500
|
|
53
|
+
lineHeight: 1.17
|
|
54
|
+
letterSpacing: 0.2px
|
|
55
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
56
|
+
heading-xl:
|
|
57
|
+
fontFamily: Inter
|
|
58
|
+
fontSize: 24px
|
|
59
|
+
fontWeight: 500
|
|
60
|
+
lineHeight: 1.6
|
|
61
|
+
letterSpacing: 0.2px
|
|
62
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
63
|
+
heading-lg:
|
|
64
|
+
fontFamily: Inter
|
|
65
|
+
fontSize: 22px
|
|
66
|
+
fontWeight: 500
|
|
67
|
+
lineHeight: 1.15
|
|
68
|
+
letterSpacing: 0
|
|
69
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
70
|
+
heading-md:
|
|
71
|
+
fontFamily: Inter
|
|
72
|
+
fontSize: 20px
|
|
73
|
+
fontWeight: 500
|
|
74
|
+
lineHeight: 1.4
|
|
75
|
+
letterSpacing: 0.2px
|
|
76
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
77
|
+
heading-sm:
|
|
78
|
+
fontFamily: Inter
|
|
79
|
+
fontSize: 18px
|
|
80
|
+
fontWeight: 500
|
|
81
|
+
lineHeight: 1.4
|
|
82
|
+
letterSpacing: 0.2px
|
|
83
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
84
|
+
body-lg:
|
|
85
|
+
fontFamily: Inter
|
|
86
|
+
fontSize: 18px
|
|
87
|
+
fontWeight: 400
|
|
88
|
+
lineHeight: 1.6
|
|
89
|
+
letterSpacing: 0
|
|
90
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
91
|
+
body-md:
|
|
92
|
+
fontFamily: Inter
|
|
93
|
+
fontSize: 16px
|
|
94
|
+
fontWeight: 400
|
|
95
|
+
lineHeight: 1.6
|
|
96
|
+
letterSpacing: 0
|
|
97
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
98
|
+
body-strong:
|
|
99
|
+
fontFamily: Inter
|
|
100
|
+
fontSize: 16px
|
|
101
|
+
fontWeight: 500
|
|
102
|
+
lineHeight: 1.4
|
|
103
|
+
letterSpacing: 0.2px
|
|
104
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
105
|
+
body-sm:
|
|
106
|
+
fontFamily: Inter
|
|
107
|
+
fontSize: 14px
|
|
108
|
+
fontWeight: 400
|
|
109
|
+
lineHeight: 1.6
|
|
110
|
+
letterSpacing: 0
|
|
111
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
112
|
+
body-sm-strong:
|
|
113
|
+
fontFamily: Inter
|
|
114
|
+
fontSize: 14px
|
|
115
|
+
fontWeight: 500
|
|
116
|
+
lineHeight: 1.6
|
|
117
|
+
letterSpacing: 0.2px
|
|
118
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
119
|
+
caption-md:
|
|
120
|
+
fontFamily: Inter
|
|
121
|
+
fontSize: 13px
|
|
122
|
+
fontWeight: 400
|
|
123
|
+
lineHeight: 1.4
|
|
124
|
+
letterSpacing: 0.1px
|
|
125
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
126
|
+
caption-sm:
|
|
127
|
+
fontFamily: Inter
|
|
128
|
+
fontSize: 12px
|
|
129
|
+
fontWeight: 400
|
|
130
|
+
lineHeight: 1.5
|
|
131
|
+
letterSpacing: 0.4px
|
|
132
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
133
|
+
link-md:
|
|
134
|
+
fontFamily: Inter
|
|
135
|
+
fontSize: 16px
|
|
136
|
+
fontWeight: 500
|
|
137
|
+
lineHeight: 1.4
|
|
138
|
+
letterSpacing: 0.3px
|
|
139
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
140
|
+
button-md:
|
|
141
|
+
fontFamily: Inter
|
|
142
|
+
fontSize: 14px
|
|
143
|
+
fontWeight: 500
|
|
144
|
+
lineHeight: 1.6
|
|
145
|
+
letterSpacing: 0.2px
|
|
146
|
+
fontFeature: '"calt", "kern", "liga", "ss03"'
|
|
147
|
+
|
|
148
|
+
rounded:
|
|
149
|
+
none: 0px
|
|
150
|
+
xs: 4px
|
|
151
|
+
sm: 6px
|
|
152
|
+
md: 8px
|
|
153
|
+
lg: 10px
|
|
154
|
+
xl: 16px
|
|
155
|
+
full: 9999px
|
|
156
|
+
|
|
157
|
+
spacing:
|
|
158
|
+
xxs: 2px
|
|
159
|
+
xs: 4px
|
|
160
|
+
sm: 8px
|
|
161
|
+
md: 12px
|
|
162
|
+
lg: 16px
|
|
163
|
+
xl: 24px
|
|
164
|
+
xxl: 32px
|
|
165
|
+
section: 96px
|
|
166
|
+
|
|
167
|
+
components:
|
|
168
|
+
button-primary:
|
|
169
|
+
backgroundColor: "{colors.primary}"
|
|
170
|
+
textColor: "{colors.on-primary}"
|
|
171
|
+
typography: "{typography.button-md}"
|
|
172
|
+
rounded: "{rounded.md}"
|
|
173
|
+
padding: 8px 16px
|
|
174
|
+
height: 36px
|
|
175
|
+
button-primary-pressed:
|
|
176
|
+
backgroundColor: "{colors.primary-pressed}"
|
|
177
|
+
textColor: "{colors.on-primary}"
|
|
178
|
+
typography: "{typography.button-md}"
|
|
179
|
+
rounded: "{rounded.md}"
|
|
180
|
+
button-secondary:
|
|
181
|
+
backgroundColor: "transparent"
|
|
182
|
+
textColor: "{colors.on-dark}"
|
|
183
|
+
typography: "{typography.button-md}"
|
|
184
|
+
rounded: "{rounded.md}"
|
|
185
|
+
padding: 8px 16px
|
|
186
|
+
height: 36px
|
|
187
|
+
button-tertiary:
|
|
188
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
189
|
+
textColor: "{colors.on-dark}"
|
|
190
|
+
typography: "{typography.button-md}"
|
|
191
|
+
rounded: "{rounded.md}"
|
|
192
|
+
padding: 8px 16px
|
|
193
|
+
height: 36px
|
|
194
|
+
button-disabled:
|
|
195
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
196
|
+
textColor: "{colors.ash}"
|
|
197
|
+
rounded: "{rounded.md}"
|
|
198
|
+
install-button:
|
|
199
|
+
backgroundColor: "transparent"
|
|
200
|
+
textColor: "{colors.on-dark}"
|
|
201
|
+
typography: "{typography.button-md}"
|
|
202
|
+
rounded: "{rounded.md}"
|
|
203
|
+
padding: 6px 14px
|
|
204
|
+
text-input:
|
|
205
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
206
|
+
textColor: "{colors.on-dark}"
|
|
207
|
+
typography: "{typography.body-md}"
|
|
208
|
+
rounded: "{rounded.md}"
|
|
209
|
+
padding: 8px 12px
|
|
210
|
+
height: 36px
|
|
211
|
+
text-input-focused:
|
|
212
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
213
|
+
textColor: "{colors.on-dark}"
|
|
214
|
+
rounded: "{rounded.md}"
|
|
215
|
+
store-search-bar:
|
|
216
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
217
|
+
textColor: "{colors.on-dark}"
|
|
218
|
+
typography: "{typography.body-md}"
|
|
219
|
+
rounded: "{rounded.md}"
|
|
220
|
+
padding: 10px 16px
|
|
221
|
+
height: 44px
|
|
222
|
+
command-palette-row:
|
|
223
|
+
backgroundColor: "transparent"
|
|
224
|
+
textColor: "{colors.on-dark}"
|
|
225
|
+
typography: "{typography.body-md}"
|
|
226
|
+
rounded: "{rounded.sm}"
|
|
227
|
+
padding: 6px 10px
|
|
228
|
+
command-palette-row-active:
|
|
229
|
+
backgroundColor: "{colors.surface-card}"
|
|
230
|
+
textColor: "{colors.on-dark}"
|
|
231
|
+
typography: "{typography.body-md}"
|
|
232
|
+
rounded: "{rounded.sm}"
|
|
233
|
+
pill-tab:
|
|
234
|
+
backgroundColor: "transparent"
|
|
235
|
+
textColor: "{colors.body}"
|
|
236
|
+
typography: "{typography.body-sm}"
|
|
237
|
+
rounded: "{rounded.full}"
|
|
238
|
+
padding: 4px 10px
|
|
239
|
+
pill-tab-active:
|
|
240
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
241
|
+
textColor: "{colors.on-dark}"
|
|
242
|
+
typography: "{typography.body-sm}"
|
|
243
|
+
rounded: "{rounded.full}"
|
|
244
|
+
badge-pro:
|
|
245
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
246
|
+
textColor: "{colors.on-dark-mute}"
|
|
247
|
+
typography: "{typography.caption-sm}"
|
|
248
|
+
rounded: "{rounded.xs}"
|
|
249
|
+
padding: 2px 6px
|
|
250
|
+
badge-info-soft:
|
|
251
|
+
backgroundColor: "{colors.accent-blue-soft}"
|
|
252
|
+
textColor: "{colors.accent-blue}"
|
|
253
|
+
typography: "{typography.caption-sm}"
|
|
254
|
+
rounded: "{rounded.xs}"
|
|
255
|
+
padding: 2px 8px
|
|
256
|
+
keycap:
|
|
257
|
+
backgroundColor: "{colors.surface-card}"
|
|
258
|
+
textColor: "{colors.body}"
|
|
259
|
+
typography: "{typography.caption-md}"
|
|
260
|
+
rounded: "{rounded.xs}"
|
|
261
|
+
padding: 1px 6px
|
|
262
|
+
height: 20px
|
|
263
|
+
command-palette-card:
|
|
264
|
+
backgroundColor: "{colors.surface}"
|
|
265
|
+
textColor: "{colors.on-dark}"
|
|
266
|
+
typography: "{typography.body-md}"
|
|
267
|
+
rounded: "{rounded.lg}"
|
|
268
|
+
padding: 0px
|
|
269
|
+
feature-card-dark:
|
|
270
|
+
backgroundColor: "{colors.surface}"
|
|
271
|
+
textColor: "{colors.on-dark}"
|
|
272
|
+
typography: "{typography.body-md}"
|
|
273
|
+
rounded: "{rounded.lg}"
|
|
274
|
+
padding: 24px
|
|
275
|
+
feature-card-elevated:
|
|
276
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
277
|
+
textColor: "{colors.on-dark}"
|
|
278
|
+
typography: "{typography.body-md}"
|
|
279
|
+
rounded: "{rounded.lg}"
|
|
280
|
+
padding: 24px
|
|
281
|
+
store-extension-card:
|
|
282
|
+
backgroundColor: "{colors.surface}"
|
|
283
|
+
textColor: "{colors.on-dark}"
|
|
284
|
+
typography: "{typography.body-md}"
|
|
285
|
+
rounded: "{rounded.md}"
|
|
286
|
+
padding: 16px
|
|
287
|
+
pricing-tier-card:
|
|
288
|
+
backgroundColor: "{colors.surface}"
|
|
289
|
+
textColor: "{colors.on-dark}"
|
|
290
|
+
typography: "{typography.body-md}"
|
|
291
|
+
rounded: "{rounded.lg}"
|
|
292
|
+
padding: 24px
|
|
293
|
+
pricing-tier-card-featured:
|
|
294
|
+
backgroundColor: "{colors.surface-elevated}"
|
|
295
|
+
textColor: "{colors.on-dark}"
|
|
296
|
+
typography: "{typography.body-md}"
|
|
297
|
+
rounded: "{rounded.lg}"
|
|
298
|
+
padding: 24px
|
|
299
|
+
hero-stripe-band:
|
|
300
|
+
backgroundColor: "{colors.canvas}"
|
|
301
|
+
textColor: "{colors.on-dark}"
|
|
302
|
+
typography: "{typography.display-xl}"
|
|
303
|
+
rounded: "{rounded.none}"
|
|
304
|
+
padding: 96px 48px
|
|
305
|
+
app-icon-tile:
|
|
306
|
+
backgroundColor: "{colors.surface-card}"
|
|
307
|
+
rounded: "{rounded.md}"
|
|
308
|
+
size: 48px
|
|
309
|
+
app-icon-tile-large:
|
|
310
|
+
backgroundColor: "{colors.surface-card}"
|
|
311
|
+
rounded: "{rounded.md}"
|
|
312
|
+
size: 64px
|
|
313
|
+
primary-nav:
|
|
314
|
+
backgroundColor: "{colors.canvas}"
|
|
315
|
+
textColor: "{colors.on-dark}"
|
|
316
|
+
typography: "{typography.body-sm-strong}"
|
|
317
|
+
rounded: "{rounded.none}"
|
|
318
|
+
height: 56px
|
|
319
|
+
footer-section:
|
|
320
|
+
backgroundColor: "{colors.canvas}"
|
|
321
|
+
textColor: "{colors.body}"
|
|
322
|
+
typography: "{typography.body-sm}"
|
|
323
|
+
rounded: "{rounded.none}"
|
|
324
|
+
padding: 64px 48px
|
|
325
|
+
link-inline:
|
|
326
|
+
textColor: "{colors.on-dark}"
|
|
327
|
+
typography: "{typography.link-md}"
|
|
328
|
+
---
|
|
329
|
+
|
|
330
|
+
## Overview
|
|
331
|
+
|
|
332
|
+
Raycast's marketing site reads like an extended product screenshot. The chrome IS the in-product command palette at marketing scale: pure near-black canvas (`{colors.canvas}` — `#07080a`), hairline 1px borders (`{colors.hairline}` — `#242728`), command-palette-style cards with rounded corners between 6 and 16px, Inter typography with the **ss03 stylistic set enabled site-wide** (a single character — the alternate `g` — that gives Raycast's typography its signature subtle distinction), a single white CTA pill that anchors every primary action, and small splashes of saturated accent reserved for category illustrations.
|
|
333
|
+
|
|
334
|
+
The system has effectively one surface mode — dark — with a faint three-step surface ladder (`{colors.canvas}` → `{colors.surface}` → `{colors.surface-elevated}` → `{colors.surface-card}`) carrying cards, in-card panels, and key-cap glyph backgrounds. The signature decorative moment is a **red diagonal-stripe gradient band** across the very top of the home page hero, used as a launch-banner motif behind the headline (the only time saturated red appears on chrome). Beyond that single moment, color in the chrome is reserved for category accents inside extension and feature illustrations: Hacker News yellow, Slack red, Linear green, info blue.
|
|
335
|
+
|
|
336
|
+
The design philosophy is "the marketing page is the product." Section rhythm is generous (`{spacing.section}` 96px) but the page never breaks tonal continuity — the whole site sits in one continuous dark mode, full-bleed product UI screenshots show Raycast's actual command palette / store / AI chat surfaces, and the typography ligature settings (`ss03`) are inherited from the in-product app's text rendering.
|
|
337
|
+
|
|
338
|
+
**Key Characteristics:**
|
|
339
|
+
- Single dark surface mode with a 4-step surface ladder: `{colors.canvas}` (#07080a) → `{colors.surface}` (#0d0d0d) → `{colors.surface-elevated}` (#101111) → `{colors.surface-card}` (#121212)
|
|
340
|
+
- White CTA pill (`{colors.primary}` — #ffffff) is the universal primary action; everything else is monochrome dark
|
|
341
|
+
- Inter typography with `font-feature-settings: "calt", "kern", "liga", "ss03"` enabled site-wide — the ss03 alternate `g` is part of the brand voice
|
|
342
|
+
- Hairline 1px borders (`{colors.hairline}` — #242728) carry every card edge; there are no drop shadows in the system
|
|
343
|
+
- Multi-radius card vocabulary: `{rounded.sm}` (6px) for keycaps, `{rounded.md}` (8px) for buttons and small cards, `{rounded.lg}` (10px) for feature cards, `{rounded.xl}` (16px) for hero command-palette mockup containers
|
|
344
|
+
- Saturated category accents (`{colors.accent-yellow}` for Hacker News, `{colors.accent-red}` for Slack/Apple, `{colors.accent-green}` for productivity tools, `{colors.accent-blue}` for info) appear only inside extension tile imagery — never on chrome
|
|
345
|
+
- Signature red diagonal-stripe gradient band at the very top of the hero — three angled stripes in `{colors.hero-stripe-start}` → `{colors.hero-stripe-end}`, used once per page maximum
|
|
346
|
+
|
|
347
|
+
## Colors
|
|
348
|
+
|
|
349
|
+
> **Source pages:** `/` (home), `/store` (extension marketplace), `/core-features/ai` (feature page), `/pricing` (plan tiers), `/thomas/hacker-news` (single extension detail). The chrome palette is identical across all five pages — the dark surface ladder, hairline borders, white CTA, and ss03-enabled typography are the same on every page.
|
|
350
|
+
|
|
351
|
+
### Brand & Accent
|
|
352
|
+
- **White** (`{colors.primary}` — `#ffffff`): the universal primary CTA pill background. "Download" / "Install Extension" / "Get Pro" — every primary action carries it.
|
|
353
|
+
- **White Pressed** (`{colors.primary-pressed}` — `#e8e8e8`): pressed-state for the primary pill — a single notch dimmer.
|
|
354
|
+
- **On Primary** (`{colors.on-primary}` — `#000000`): pure black text on the white CTA — the only place black appears as text in the system.
|
|
355
|
+
|
|
356
|
+
### Surface
|
|
357
|
+
- **Canvas** (`{colors.canvas}` — `#07080a`): pure-near-black page background. The dominant surface across every page.
|
|
358
|
+
- **Surface** (`{colors.surface}` — `#0d0d0d`): card and elevated panel background — one notch lighter than canvas.
|
|
359
|
+
- **Surface Elevated** (`{colors.surface-elevated}` — `#101111`): button-tertiary fill, text-input fill, store-search-bar fill, pill-tab-active fill.
|
|
360
|
+
- **Surface Card** (`{colors.surface-card}` — `#121212`): app-icon-tile background, keycap fill, command-palette row hover.
|
|
361
|
+
- **Button FG (in-card)** (`{colors.button-fg}` — `#18191a`): rare deep-card variant used inside featured pricing tier card backgrounds.
|
|
362
|
+
- **Hairline** (`{colors.hairline}` — `#242728`): the universal 1px card border. Carries every card edge across every page.
|
|
363
|
+
- **Hairline Soft** (`{colors.hairline-soft}` — `rgba(255,255,255,0.08)`): even fainter border on translucent over-image overlays.
|
|
364
|
+
- **Hairline Strong** (`{colors.hairline-strong}` — `rgba(255,255,255,0.16)`): stronger 1px divider where a regular hairline reads as too soft.
|
|
365
|
+
|
|
366
|
+
### Text
|
|
367
|
+
- **Ink** (`{colors.ink}` — `#f4f4f6`): primary headlines on dark canvas. Slightly off-white for tonal coherence with the near-black background.
|
|
368
|
+
- **Body** (`{colors.body}` — `#cdcdcd`): default paragraph text and inline-link color.
|
|
369
|
+
- **Charcoal** (`{colors.charcoal}` — `#d3d3d4`): subtly brighter body where ink reads too soft.
|
|
370
|
+
- **Mute** (`{colors.mute}` — `#9c9c9d`): metadata, footer link text, secondary captions.
|
|
371
|
+
- **Ash** (`{colors.ash}` — `#6a6b6c`): disabled-state text, lowest-emphasis utility.
|
|
372
|
+
- **Stone** (`{colors.stone}` — `#434345`): least-emphasis caption text and disabled icon color.
|
|
373
|
+
- **On Dark** (`{colors.on-dark}` — `#ffffff`): interactive-state primary text (button label, focused tab).
|
|
374
|
+
- **On Dark Mute** (`{colors.on-dark-mute}` — `rgba(255,255,255,0.72)`): translucent secondary text on dark surfaces.
|
|
375
|
+
|
|
376
|
+
### Semantic
|
|
377
|
+
- **Accent Blue** (`{colors.accent-blue}` — `#57c1ff`) + **Soft** (`{colors.accent-blue-soft}` — `rgba(87,193,255,0.15)`): info and informational badge — used inside feature illustrations and the rare "New" pill.
|
|
378
|
+
- **Accent Red** (`{colors.accent-red}` — `#ff6161`) + **Soft** (`{colors.accent-red-soft}` — `rgba(255,97,97,0.15)`): destructive/error indicator + Slack/Apple category accent in extension illustrations.
|
|
379
|
+
- **Accent Green** (`{colors.accent-green}` — `#59d499`) + **Soft** (`{colors.accent-green-soft}` — `rgba(89,212,153,0.15)`): success state + productivity category accent in extension illustrations.
|
|
380
|
+
- **Accent Yellow** (`{colors.accent-yellow}` — `#ffc533`) + **Soft** (`{colors.accent-yellow-soft}` — `rgba(255,197,51,0.15)`): "warning" semantic + the Hacker News orange-yellow that appears as the most prominent accent illustration on the home page hero.
|
|
381
|
+
|
|
382
|
+
### Brand Gradient
|
|
383
|
+
- **Hero Stripe Gradient** — three diagonal red stripes layered across the very top of the home page hero, fading from `{colors.hero-stripe-start}` (`#ff5757`) to `{colors.hero-stripe-end}` (`#a1131a`). The system's only chromatic gradient on chrome — used once per page maximum and reserved for hero launch-banner moments.
|
|
384
|
+
- **Keycap Gradient** — the small key-glyph background uses a subtle linear-gradient from `{colors.key-bg-start}` (`#121212`) to `{colors.key-bg-end}` (`#0d0d0d`) that gives Raycast's keycap UI its slight 3D-key feel.
|
|
385
|
+
|
|
386
|
+
## Typography
|
|
387
|
+
|
|
388
|
+
### Font Family
|
|
389
|
+
**Inter** is the system's primary face, loaded with the `Inter Fallback` system fallback variant. Critically, Raycast enables `font-feature-settings: "calt", "kern", "liga", "ss03"` site-wide — the **ss03 stylistic set** swaps in Inter's alternate `g` glyph (single-story open `g`), which is the brand's signature typographic detail. Standard ligatures (`liga`), kerning (`kern`), and contextual alternates (`calt`) are also active. The display tier additionally enables `ss02` and `ss08` and disables standard `liga` to render the hero "Raycast Pro" wordmark with its distinctive geometric construction.
|
|
390
|
+
|
|
391
|
+
There is no monospace face used outside of inline `<code>` chips in documentation; the marketing pages use Inter for everything.
|
|
392
|
+
|
|
393
|
+
### Hierarchy
|
|
394
|
+
|
|
395
|
+
| Token | Size | Weight | Line Height | Letter Spacing | Use |
|
|
396
|
+
|---|---|---|---|---|---|
|
|
397
|
+
| `{typography.display-xl}` | 64px | 600 | 1.1 | 0 | Hero "Built for the perfect tools" / "The new way to..." headline (with `liga: 0`, `ss02`, `ss08`) |
|
|
398
|
+
| `{typography.display-lg}` | 56px | 500 | 1.17 | 0.2px | Section headline ("Explore", "Pricing", store hero "Store") |
|
|
399
|
+
| `{typography.heading-xl}` | 24px | 500 | 1.6 | 0.2px | Sub-section heading, pricing-tier name |
|
|
400
|
+
| `{typography.heading-lg}` | 22px | 500 | 1.15 | 0 | Mid-section feature heading |
|
|
401
|
+
| `{typography.heading-md}` | 20px | 500 | 1.4 | 0.2px | Card group title, in-card heading |
|
|
402
|
+
| `{typography.heading-sm}` | 18px | 500 | 1.4 | 0.2px | Small heading, extension card title |
|
|
403
|
+
| `{typography.body-lg}` | 18px | 400 | 1.6 | 0 | Pricing tier description, hero subtitle |
|
|
404
|
+
| `{typography.body-md}` | 16px | 400 | 1.6 | 0 | Default body, paragraph text |
|
|
405
|
+
| `{typography.body-strong}` | 16px | 500 | 1.4 | 0.2px | Inline emphasis, primary nav link |
|
|
406
|
+
| `{typography.body-sm}` | 14px | 400 | 1.6 | 0 | Card description, secondary copy |
|
|
407
|
+
| `{typography.body-sm-strong}` | 14px | 500 | 1.6 | 0.2px | In-card label, table-header text |
|
|
408
|
+
| `{typography.caption-md}` | 13px | 400 | 1.4 | 0.1px | Caption, metadata |
|
|
409
|
+
| `{typography.caption-sm}` | 12px | 400 | 1.5 | 0.4px | Smallest utility text, badge label |
|
|
410
|
+
| `{typography.link-md}` | 16px | 500 | 1.4 | 0.3px | Inline body anchor link |
|
|
411
|
+
| `{typography.button-md}` | 14px | 500 | 1.6 | 0.2px | Standard button label |
|
|
412
|
+
|
|
413
|
+
### Principles
|
|
414
|
+
The hierarchy works on a 1.6-line-height ladder for body and a 1.1–1.4 ladder for display/heading. Letter-spacing is consistently positive (0.1–0.4px) — slightly opening the type — which gives Raycast's chrome an airy quality at body sizes despite the dark canvas. The `ss03` stylistic set is the brand's most distinctive typographic detail; without it, the body face renders identically to plain Inter and loses Raycast's signature rendering.
|
|
415
|
+
|
|
416
|
+
### Note on Font Substitutes
|
|
417
|
+
Inter is open-source and Google-Fonts-hosted; load it directly. To preserve the brand's signature look, you must enable `font-feature-settings: "calt", "kern", "liga", "ss03"` on the body element. Without `ss03`, the typography is recognizably "Inter default" rather than "Raycast." On systems where Inter cannot be loaded, the documented fallback is `Inter Fallback` (a self-hosted variant) → `system-ui`. **JetBrains Mono** or **Geist Mono** are acceptable substitutes for inline code chips when needed, though Raycast's marketing chrome rarely uses code-styled text.
|
|
418
|
+
|
|
419
|
+
## Layout
|
|
420
|
+
|
|
421
|
+
### Spacing System
|
|
422
|
+
- **Base unit:** 8px (with 2/4/12px steps for tight inline gaps).
|
|
423
|
+
- **Tokens (front matter):** `{spacing.xxs}` (2px) · `{spacing.xs}` (4px) · `{spacing.sm}` (8px) · `{spacing.md}` (12px) · `{spacing.lg}` (16px) · `{spacing.xl}` (24px) · `{spacing.xxl}` (32px) · `{spacing.section}` (96px).
|
|
424
|
+
- **Universal section rhythm:** every page in the set uses `{spacing.section}` (96px) as the vertical gap between major content blocks. Card grids use `{spacing.lg}` (16px) gutters; in-card padding sits at `{spacing.xl}` (24px) for feature cards and `{spacing.lg}` (16px) for store extension cards.
|
|
425
|
+
|
|
426
|
+
### Grid & Container
|
|
427
|
+
- **Max width:** ~1240px content area at desktop with 24px gutters (~48px at ultrawide). Hero command-palette mockups run wider (~1080px) with the page background extending to full bleed.
|
|
428
|
+
- **Store extension grid:** 2-up at desktop with rows of 2 cards stacked, collapsing to 1-up at mobile. Each card is a horizontal layout with a large square app icon at the left and copy + Install button at the right.
|
|
429
|
+
- **Pricing tier grid:** 3-up at desktop (Free / Pro / Pro+Advanced AI), collapsing to 1-up stacked at mobile.
|
|
430
|
+
- **Featured extension card grid:** 3-up at desktop in the "Featured" row at the top of the store page.
|
|
431
|
+
- **Comparison table:** full-width on the pricing page below the tier cards — 5-column table (Free / Pro / Advanced AI / Custom for Teams / Enterprise) with feature rows.
|
|
432
|
+
- **Footer:** 6-column horizontal link grid at desktop, collapsing to 2-up at tablet and 1-up at mobile.
|
|
433
|
+
|
|
434
|
+
### Whitespace Philosophy
|
|
435
|
+
Whitespace is generous and the canvas is uninterrupted. Sections sit 96px apart with no decorative dividers between them — the dark canvas continues edge-to-edge from hero to footer. Inside a section, content is left-aligned in a tight column, with command-palette mockup imagery occupying the right 50–60% of the band on home-page feature rows. The signature decorative element — the red diagonal-stripe gradient band — only appears in the very first hero band; from the second section down, the page is monochrome dark.
|
|
436
|
+
|
|
437
|
+
## Elevation & Depth
|
|
438
|
+
|
|
439
|
+
| Level | Treatment | Use |
|
|
440
|
+
|---|---|---|
|
|
441
|
+
| 0 — Flat | No border, no shadow | Default for canvas-on-canvas blocks, hero text, footer body |
|
|
442
|
+
| 1 — Hairline border | 1px solid `{colors.hairline}` (#242728) | Every card on `{colors.surface}`, store extension card, pricing tier card |
|
|
443
|
+
| 2 — Hairline strong | 1px solid `{colors.hairline-strong}` | Stronger inline divider, table-row separator on the comparison table |
|
|
444
|
+
| 3 — Surface ladder elevation | `{colors.canvas}` → `{colors.surface}` → `{colors.surface-elevated}` → `{colors.surface-card}` | Multi-step background-color ladder used to create elevation without shadows |
|
|
445
|
+
|
|
446
|
+
The system has no drop-shadow elevation at all. Depth is built entirely from the surface-color ladder: each notch lighter on the dark scale reads as one step closer to the viewer.
|
|
447
|
+
|
|
448
|
+
### Decorative Depth
|
|
449
|
+
Depth comes from product imagery and a single stripe-gradient band:
|
|
450
|
+
- **Hero stripe gradient** — three diagonal red stripes (`{colors.hero-stripe-start}` → `{colors.hero-stripe-end}`) layered across the home-page hero band, evoking a launch-banner / motion-blur effect. The system's signature decorative moment.
|
|
451
|
+
- **Command-palette mockups** — full-fidelity Raycast in-product UI screenshots (the actual Spotlight-style overlay with rounded keycaps, command rows, and accent-color glyphs) sitting inside the home-page hero and feature rows. These ARE the brand decoration.
|
|
452
|
+
- **App icon tiles** — small 48–64px rounded-corner tiles displaying real app icons (Slack, Spotify, Figma, Notion, Linear, Hacker News) inside store and feature illustrations.
|
|
453
|
+
- **Keycap glyphs** — subtle gradient-filled rounded keycap glyphs used inline to indicate keyboard shortcuts (e.g., `⌘ K`), with a faint `{colors.key-bg-start}` → `{colors.key-bg-end}` linear gradient suggesting a physical key surface.
|
|
454
|
+
|
|
455
|
+
## Shapes
|
|
456
|
+
|
|
457
|
+
### Border Radius Scale
|
|
458
|
+
|
|
459
|
+
| Token | Value | Use |
|
|
460
|
+
|---|---|---|
|
|
461
|
+
| `{rounded.none}` | 0px | Hero band, primary nav, footer, full-bleed structural surfaces |
|
|
462
|
+
| `{rounded.xs}` | 4px | Keycap glyphs, badge-pro chips, small inline tags |
|
|
463
|
+
| `{rounded.sm}` | 6px | Command-palette row, inline buttons, micro chips |
|
|
464
|
+
| `{rounded.md}` | 8px | Standard buttons, text inputs, store search bar, app-icon tiles, store extension card |
|
|
465
|
+
| `{rounded.lg}` | 10px | Feature card, command-palette mockup card, pricing tier card |
|
|
466
|
+
| `{rounded.xl}` | 16px | Large hero command-palette mockup container, oversized feature panel |
|
|
467
|
+
| `{rounded.full}` | 9999px | Pill-tab chips, avatar circles |
|
|
468
|
+
|
|
469
|
+
The radius vocabulary clusters tightly between 4 and 16px, with most chrome at 6–10px. The system never goes flat (0px) on cards and never above 16px except for fully-rounded pills.
|
|
470
|
+
|
|
471
|
+
### Photography Geometry
|
|
472
|
+
There is no traditional photography. Visual elements are limited to:
|
|
473
|
+
- **Command-palette mockups** — full-fidelity Raycast UI screenshots at 16:9 or 4:3 aspect inside `{rounded.xl}` (16px) containers.
|
|
474
|
+
- **App icon tiles** — 48–64px square at `{rounded.md}` (8px), displaying real app icons.
|
|
475
|
+
- **Avatar circles** — 32–40px at `{rounded.full}` for in-extension author attribution.
|
|
476
|
+
- **Hero stripe gradient** — full-bleed wash with no aspect ratio.
|
|
477
|
+
|
|
478
|
+
## Components
|
|
479
|
+
|
|
480
|
+
> **No hover states documented** per system policy. Each spec covers Default and Active/Pressed only.
|
|
481
|
+
|
|
482
|
+
### Buttons
|
|
483
|
+
|
|
484
|
+
**`button-primary`** — the universal Raycast CTA
|
|
485
|
+
- Background `{colors.primary}` (white), text `{colors.on-primary}` (black), type `{typography.button-md}`, padding `8px 16px`, height ~36px, rounded `{rounded.md}`.
|
|
486
|
+
- Used for "Download" (sticky top-nav CTA), "Get Pro", "Install" — every primary action across every surface.
|
|
487
|
+
- Pressed state lives in `button-primary-pressed` — background dims to `{colors.primary-pressed}`.
|
|
488
|
+
|
|
489
|
+
**`button-secondary`** — transparent text button
|
|
490
|
+
- Background transparent, text `{colors.on-dark}`, type `{typography.button-md}`, padding `8px 16px`, height ~36px, rounded `{rounded.md}`.
|
|
491
|
+
- Lower-emphasis action: "Sign in" (top nav), "Learn more →", "View on GitHub".
|
|
492
|
+
|
|
493
|
+
**`button-tertiary`** — soft surface button
|
|
494
|
+
- Background `{colors.surface-elevated}`, text `{colors.on-dark}`, type `{typography.button-md}`, padding `8px 16px`, height ~36px, rounded `{rounded.md}`.
|
|
495
|
+
- Mid-emphasis: "Watch demo", "View extension", "Manage" buttons inside cards.
|
|
496
|
+
|
|
497
|
+
**`button-disabled`**
|
|
498
|
+
- Background `{colors.surface-elevated}`, text `{colors.ash}` — dim utility state.
|
|
499
|
+
|
|
500
|
+
**`install-button`** — the store-page install pill
|
|
501
|
+
- Background transparent with 1px solid `{colors.hairline-strong}` border, text `{colors.on-dark}`, type `{typography.button-md}`, padding `6px 14px`, rounded `{rounded.md}`.
|
|
502
|
+
- Sits at the right edge of every store extension card with the label "Install Extension".
|
|
503
|
+
|
|
504
|
+
### Filter & Tab Chips
|
|
505
|
+
|
|
506
|
+
**`pill-tab`** + **`pill-tab-active`** — small filter chip strip
|
|
507
|
+
- Default: transparent background, text `{colors.body}`, type `{typography.body-sm}`, padding `4px 10px`, rounded `{rounded.full}`.
|
|
508
|
+
- Active: background flips to `{colors.surface-elevated}`, text `{colors.on-dark}` — the chip "lifts" by one surface notch.
|
|
509
|
+
- Used in the store filter row ("All Extensions", "Recently Added", "Most Popular") and similar segmented controls.
|
|
510
|
+
|
|
511
|
+
**`badge-pro`** — small Pro/Plan label
|
|
512
|
+
- Background `{colors.surface-elevated}`, text `{colors.on-dark-mute}`, type `{typography.caption-sm}`, padding `2px 6px`, rounded `{rounded.xs}`.
|
|
513
|
+
- Inline "Pro" / "Pro+" / "Free" tier indicators on pricing tier cards.
|
|
514
|
+
|
|
515
|
+
**`badge-info-soft`** — translucent info chip
|
|
516
|
+
- Background `{colors.accent-blue-soft}`, text `{colors.accent-blue}`, type `{typography.caption-sm}`, padding `2px 8px`, rounded `{rounded.xs}`.
|
|
517
|
+
- Rare "New" / "Beta" inline tag.
|
|
518
|
+
|
|
519
|
+
### Inputs & Forms
|
|
520
|
+
|
|
521
|
+
**`text-input`** + **`text-input-focused`**
|
|
522
|
+
- Default: background `{colors.surface-elevated}`, text `{colors.on-dark}`, 1px solid `{colors.hairline}`, type `{typography.body-md}`, padding `8px 12px`, height ~36px, rounded `{rounded.md}`.
|
|
523
|
+
- Focused: same surface; 1px border becomes `{colors.hairline-strong}` — a subtle brightening rather than a colored ring.
|
|
524
|
+
|
|
525
|
+
**`store-search-bar`** — the store-page search field
|
|
526
|
+
- Background `{colors.surface-elevated}`, text `{colors.on-dark}`, type `{typography.body-md}`, padding `10px 16px`, height ~44px, rounded `{rounded.md}`.
|
|
527
|
+
- Sits at the top of the store page hero with a magnifier icon at the left and "Search the store..." placeholder. Slightly taller than the standard `text-input`.
|
|
528
|
+
|
|
529
|
+
### Cards & Containers
|
|
530
|
+
|
|
531
|
+
**`command-palette-card`** — the home-page hero command-palette mockup
|
|
532
|
+
- Container: background `{colors.surface}`, 1px solid `{colors.hairline}`, padding 0 (the mockup contents fill the card), rounded `{rounded.lg}` or `{rounded.xl}` depending on hero size.
|
|
533
|
+
- Layout: top header strip with macOS traffic-light dots + a search input row, body with a vertical stack of `{component.command-palette-row}` items, bottom-right keycap hint cluster.
|
|
534
|
+
|
|
535
|
+
**`command-palette-row`** + **`command-palette-row-active`** — single row inside the command palette
|
|
536
|
+
- Default: transparent background, text `{colors.on-dark}` in `{typography.body-md}`, padding `6px 10px`, rounded `{rounded.sm}`.
|
|
537
|
+
- Active: background `{colors.surface-card}` (one notch lighter than the surrounding palette card) — the selection state.
|
|
538
|
+
- Each row contains a small app-icon tile + label + optional keycap shortcut at the right edge.
|
|
539
|
+
|
|
540
|
+
**`feature-card-dark`** — standard product feature card
|
|
541
|
+
- Container: background `{colors.surface}`, 1px solid `{colors.hairline}`, padding `{spacing.xl}` (24px), rounded `{rounded.lg}`.
|
|
542
|
+
- Used in 2- or 3-up grids on home and feature pages — pairs a small product mockup or app-icon row with body copy and a "Learn more →" `{component.button-secondary}`.
|
|
543
|
+
|
|
544
|
+
**`feature-card-elevated`** — slightly-elevated variant
|
|
545
|
+
- Same chrome as `feature-card-dark` but background flips to `{colors.surface-elevated}` — used to break visual rhythm in alternating feature rows.
|
|
546
|
+
|
|
547
|
+
**`store-extension-card`** — store-page extension card
|
|
548
|
+
- Container: background `{colors.surface}`, 1px solid `{colors.hairline}`, padding `{spacing.lg}` (16px), rounded `{rounded.md}`.
|
|
549
|
+
- Layout: 48px `{component.app-icon-tile}` at left, vertical stack of name + by-author metadata + 1-line description in the center, `{component.install-button}` at the right edge.
|
|
550
|
+
|
|
551
|
+
**`pricing-tier-card`** — pricing plan card (default tier)
|
|
552
|
+
- Container: background `{colors.surface}`, 1px solid `{colors.hairline}`, padding `{spacing.xl}` (24px), rounded `{rounded.lg}`.
|
|
553
|
+
- Layout: tier name in `{typography.heading-xl}` (24px), price in larger numeric in `{typography.display-lg}`, body description in `{typography.body-lg}`, CTA `{component.button-primary}` (or `{component.button-secondary}` for free tier), feature checklist with `✓` glyphs.
|
|
554
|
+
|
|
555
|
+
**`pricing-tier-card-featured`** — middle "Pro" featured tier
|
|
556
|
+
- Same chrome but background flips to `{colors.surface-elevated}` (one notch lighter) — the only visual cue distinguishing the featured tier from the surrounding cards.
|
|
557
|
+
|
|
558
|
+
**`hero-stripe-band`** — home-page hero with red stripe gradient
|
|
559
|
+
- Background `{colors.canvas}` with three diagonal red stripes layered across the top half (`{colors.hero-stripe-start}` → `{colors.hero-stripe-end}`).
|
|
560
|
+
- Padding `{spacing.section}` 96px vertical / 48px horizontal, rounded `{rounded.none}`.
|
|
561
|
+
- Carries the hero headline in `{typography.display-xl}` and a single `{component.button-primary}` "Download" CTA.
|
|
562
|
+
|
|
563
|
+
### Decorative
|
|
564
|
+
|
|
565
|
+
**`app-icon-tile`** — small 48px square app icon
|
|
566
|
+
- Background `{colors.surface-card}`, padding 0 (icon fills the tile), rounded `{rounded.md}`, size 48×48.
|
|
567
|
+
- Used in command-palette rows and store extension cards.
|
|
568
|
+
|
|
569
|
+
**`app-icon-tile-large`** — 64px feature variant
|
|
570
|
+
- Same but at 64×64. Used in featured store cards and home-page hero illustration rows.
|
|
571
|
+
|
|
572
|
+
**`keycap`** — keyboard shortcut glyph
|
|
573
|
+
- Background `{colors.surface-card}` with a subtle linear gradient `{colors.key-bg-start}` → `{colors.key-bg-end}`, text `{colors.body}` in `{typography.caption-md}`, padding `1px 6px`, height ~20px, rounded `{rounded.xs}`.
|
|
574
|
+
- Renders inline command-palette shortcut hints like `⌘ K`, `⏎`, `Esc`. The signature "physical-key" feel on a flat dark canvas.
|
|
575
|
+
|
|
576
|
+
### Navigation
|
|
577
|
+
|
|
578
|
+
**`primary-nav`**
|
|
579
|
+
- Background `{colors.canvas}`, text `{colors.on-dark}`, height ~56px, type `{typography.body-sm-strong}`, rounded `{rounded.none}`, with a 1px `{colors.hairline}` bottom rule.
|
|
580
|
+
- Layout (desktop): Raycast wordmark at left, centered nav cluster ("Pro · AI · Store · Manual · Changelog · Blog · Pricing"), right cluster (Sign in link + the always-white `{component.button-primary}` "Download" CTA pill).
|
|
581
|
+
|
|
582
|
+
**Top Nav (Mobile)**
|
|
583
|
+
- Hamburger menu icon at left, Raycast wordmark at center, "Download" white CTA pill at right. Primary nav collapses into a full-screen drawer that slides from the left.
|
|
584
|
+
|
|
585
|
+
### Footer
|
|
586
|
+
|
|
587
|
+
**`footer-section`**
|
|
588
|
+
- Background `{colors.canvas}`, text `{colors.body}` in `{typography.body-sm}`, padding `64px 48px`, with a 1px `{colors.hairline}` top rule.
|
|
589
|
+
- Layout: 6-column horizontal link grid (Product · Core Features · Top Extensions · Company · Community · By Raycast) with column headers in `{typography.body-sm-strong}` `{colors.on-dark}` and link lists in `{typography.body-sm}` `{colors.body}`.
|
|
590
|
+
- Bottom row: small Raycast wordmark + a subscribe newsletter input field with `{component.button-primary}` "Subscribe" at the right.
|
|
591
|
+
- The very top of the footer band has a faint red stripe-gradient repeat — a smaller echo of the hero's diagonal stripe motif.
|
|
592
|
+
|
|
593
|
+
### Inline
|
|
594
|
+
|
|
595
|
+
**`link-inline`** — body-prose anchor link
|
|
596
|
+
- `{colors.on-dark}` text with no underline by default; underlines on focus. Inline body links are full-white rather than a tinted accent color, which keeps the dark canvas tonally pure.
|
|
597
|
+
|
|
598
|
+
## Do's and Don'ts
|
|
599
|
+
|
|
600
|
+
### Do
|
|
601
|
+
- Render the entire site in one continuous dark mode. There is no light variant in the system.
|
|
602
|
+
- Use `{colors.primary}` (white pill) for every primary CTA. There is no second primary color — white IS the brand action.
|
|
603
|
+
- Build elevation from the surface-color ladder (`{colors.canvas}` → `{colors.surface}` → `{colors.surface-elevated}` → `{colors.surface-card}`), never from drop shadows.
|
|
604
|
+
- Enable `font-feature-settings: "calt", "kern", "liga", "ss03"` on the body element. The ss03 alternate `g` is part of the brand identity.
|
|
605
|
+
- Anchor a `{component.command-palette-card}` mockup as the hero's load-bearing visual. Real Raycast UI is the brand.
|
|
606
|
+
- Use `{component.keycap}` glyphs inline to indicate keyboard shortcuts. Subtle key-bg gradient (`{colors.key-bg-start}` → `{colors.key-bg-end}`) is the brand's only "depth" decoration.
|
|
607
|
+
- Reserve `{colors.hero-stripe-start}` → `{colors.hero-stripe-end}` red gradient for the hero band exactly once per page. Never repeat the stripe gradient deeper in the page.
|
|
608
|
+
- Use saturated category accents (`{colors.accent-yellow}`, `{colors.accent-red}`, `{colors.accent-green}`, `{colors.accent-blue}`) only inside extension and feature illustrations — never on chrome buttons or text.
|
|
609
|
+
|
|
610
|
+
### Don't
|
|
611
|
+
- Don't introduce a light mode. The system is dark-only by design.
|
|
612
|
+
- Don't add drop shadows on cards. Elevation is built from the surface ladder, not from shadows.
|
|
613
|
+
- Don't replace `{colors.primary}` (white) with a tinted accent for the primary CTA. Pure white is the brand action color.
|
|
614
|
+
- Don't use the saturated accent colors (`{colors.accent-yellow}`, `{colors.accent-red}`, `{colors.accent-green}`, `{colors.accent-blue}`) on text, buttons, or chrome surfaces. They belong inside extension illustrations.
|
|
615
|
+
- Don't repeat the hero stripe gradient outside the top hero band. The one-band rule is the system's restraint.
|
|
616
|
+
- Don't use Inter without the `ss03` feature flag enabled. The chrome will lose its signature voice.
|
|
617
|
+
- Don't pad cards with 32px+ on all sides. The system runs tight at 16–24px in-card padding.
|
|
618
|
+
|
|
619
|
+
## Responsive Behavior
|
|
620
|
+
|
|
621
|
+
### Breakpoints
|
|
622
|
+
|
|
623
|
+
| Name | Width | Key Changes |
|
|
624
|
+
|---|---|---|
|
|
625
|
+
| ultrawide | 1920px+ | Content max-width holds at 1240px; outer gutters grow to ~80px |
|
|
626
|
+
| desktop-large | 1440px | Default — 3-up pricing grid, 2-up store extension grid |
|
|
627
|
+
| desktop | 1280px | Same with narrower outer gutters |
|
|
628
|
+
| desktop-small | 1024px | 3-up pricing collapses to 2+1; primary nav remains horizontal |
|
|
629
|
+
| tablet | 768px | Pricing → 1-up stacked; primary nav becomes hamburger drawer |
|
|
630
|
+
| mobile | 480px | Single-column everything; hero `{typography.display-xl}` scales 64px → ~36px |
|
|
631
|
+
| mobile-narrow | 320px | Section padding tightens to 48px |
|
|
632
|
+
|
|
633
|
+
### Touch Targets
|
|
634
|
+
All interactive elements meet WCAG AA at 36px+. `{component.button-primary}` and `{component.button-tertiary}` sit at 36px height with 16px padding. `{component.text-input}` sits at 36px. `{component.store-search-bar}` sits at 44px (above AAA). `{component.pill-tab}` is ~24–28px height with 10px padding extending to 36–40px tappable via inline padding (above AA but below AAA — intentional, the chips are compact). `{component.install-button}` sits at ~32px height with 14px padding.
|
|
635
|
+
|
|
636
|
+
### Collapsing Strategy
|
|
637
|
+
- **Primary nav:** desktop horizontal cluster → tablet hamburger drawer at 768px. The white "Download" CTA stays visible at every breakpoint.
|
|
638
|
+
- **Hero command-palette mockup:** desktop full-fidelity 2-column with copy at left + mockup at right → tablet stacks vertical with mockup below copy → mobile mockup scales down to ~80% width.
|
|
639
|
+
- **Store extension grid:** 2-up → 1-up at tablet.
|
|
640
|
+
- **Pricing tier grid:** 3-up → 2+1 at desktop-small → 1-up stacked at tablet.
|
|
641
|
+
- **Comparison table:** desktop full 5-column → tablet horizontal scroll → mobile vertical card stack with one tier per card.
|
|
642
|
+
- **Footer:** 6-up link columns → 3-up at tablet → 2-up at mobile-landscape → 1-up at mobile.
|
|
643
|
+
- **Section padding:** `{spacing.section}` (96px) desktop → 64px tablet → 48px mobile.
|
|
644
|
+
- **Hero headline:** `{typography.display-xl}` (64px) at desktop, scaling 56px / 44px / 36px down the breakpoint stack.
|
|
645
|
+
|
|
646
|
+
### Image Behavior
|
|
647
|
+
The only "imagery" in the system is in-product Raycast UI screenshots and small app-icon assets:
|
|
648
|
+
- **Command-palette mockups** scale fluidly with the container; the in-product UI itself is responsive and re-renders for each breakpoint.
|
|
649
|
+
- **App-icon tiles** stay at 48–64px fixed size at every breakpoint; they tile in flexible rows that wrap at narrower widths.
|
|
650
|
+
- **Hero stripe gradient** stays at the top of the hero band at every breakpoint with the stripe angle preserved.
|
|
651
|
+
|
|
652
|
+
## Iteration Guide
|
|
653
|
+
|
|
654
|
+
1. Focus on ONE component at a time. Pull its YAML entry and verify every property resolves.
|
|
655
|
+
2. Reference component names and tokens directly (`{colors.primary}`, `{component.button-primary-pressed}`, `{rounded.md}`) — do not paraphrase.
|
|
656
|
+
3. Run `npx @google/design.md lint DESIGN.md` after edits — `broken-ref`, `contrast-ratio`, and `orphaned-tokens` warnings flag issues automatically.
|
|
657
|
+
4. Add new variants as separate component entries (`-pressed`, `-disabled`, `-active`) — do not bury them inside prose.
|
|
658
|
+
5. Default body to `{typography.body-md}` (16px / 400 / 1.6); reach for `{typography.body-strong}` for emphasis; reserve `{typography.display-xl}` strictly for the hero band.
|
|
659
|
+
6. Keep `{colors.primary}` (white CTA pill) scarce per viewport — at most one solid white pill per fold.
|
|
660
|
+
7. When introducing a new component, ask whether it can be expressed with the existing surface-ladder + 8px-radius + ss03-Inter vocabulary before adding new tokens. The system's strength is that it almost never needs new ones.
|
|
661
|
+
|
|
662
|
+
## Known Gaps
|
|
663
|
+
|
|
664
|
+
- **Mobile screenshots not captured** — responsive behavior synthesizes Raycast's mobile pattern (hamburger drawer, single-column grid, hero downscale) from desktop evidence and the breakpoint stack.
|
|
665
|
+
- **Hover states not documented** by system policy. Raycast's in-product app has rich hover behavior on command-palette rows that this document doesn't capture.
|
|
666
|
+
- **In-product app chrome** (the actual Raycast launcher running on macOS) is referenced in marketing screenshots but not documented as a separate UI system here. The marketing site is documented; the in-product app surface is its own design system.
|
|
667
|
+
- **Dark mode is the only mode** — no light variant exists in the captured surfaces.
|
|
668
|
+
- **Form validation states** beyond the focused-input border treatment are not present in the captured surfaces.
|
|
669
|
+
- **Authenticated chrome** (account dashboard, billing settings, team management) not in the captured pages.
|