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.
Files changed (145) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +40 -0
  3. package/bin/relay.js +362 -0
  4. package/design-md/airbnb/DESIGN.md +545 -0
  5. package/design-md/airbnb/README.md +5 -0
  6. package/design-md/airtable/DESIGN.md +554 -0
  7. package/design-md/airtable/README.md +5 -0
  8. package/design-md/apple/DESIGN.md +562 -0
  9. package/design-md/apple/README.md +5 -0
  10. package/design-md/binance/DESIGN.md +634 -0
  11. package/design-md/binance/README.md +5 -0
  12. package/design-md/bmw/DESIGN.md +544 -0
  13. package/design-md/bmw/README.md +5 -0
  14. package/design-md/bmw-m/DESIGN.md +503 -0
  15. package/design-md/bmw-m/README.md +5 -0
  16. package/design-md/bugatti/DESIGN.md +454 -0
  17. package/design-md/bugatti/README.md +5 -0
  18. package/design-md/cal/DESIGN.md +542 -0
  19. package/design-md/cal/README.md +5 -0
  20. package/design-md/claude/DESIGN.md +589 -0
  21. package/design-md/claude/README.md +5 -0
  22. package/design-md/clay/DESIGN.md +541 -0
  23. package/design-md/clay/README.md +5 -0
  24. package/design-md/clickhouse/DESIGN.md +544 -0
  25. package/design-md/clickhouse/README.md +5 -0
  26. package/design-md/cohere/DESIGN.md +451 -0
  27. package/design-md/cohere/README.md +5 -0
  28. package/design-md/coinbase/DESIGN.md +570 -0
  29. package/design-md/coinbase/README.md +5 -0
  30. package/design-md/composio/DESIGN.md +506 -0
  31. package/design-md/composio/README.md +5 -0
  32. package/design-md/cursor/DESIGN.md +537 -0
  33. package/design-md/cursor/README.md +5 -0
  34. package/design-md/elevenlabs/DESIGN.md +504 -0
  35. package/design-md/elevenlabs/README.md +5 -0
  36. package/design-md/expo/DESIGN.md +526 -0
  37. package/design-md/expo/README.md +5 -0
  38. package/design-md/ferrari/DESIGN.md +531 -0
  39. package/design-md/ferrari/README.md +5 -0
  40. package/design-md/figma/DESIGN.md +578 -0
  41. package/design-md/figma/README.md +5 -0
  42. package/design-md/framer/DESIGN.md +544 -0
  43. package/design-md/framer/README.md +5 -0
  44. package/design-md/hashicorp/DESIGN.md +575 -0
  45. package/design-md/hashicorp/README.md +5 -0
  46. package/design-md/ibm/DESIGN.md +550 -0
  47. package/design-md/ibm/README.md +5 -0
  48. package/design-md/intercom/DESIGN.md +546 -0
  49. package/design-md/intercom/README.md +5 -0
  50. package/design-md/kraken/DESIGN.md +125 -0
  51. package/design-md/kraken/README.md +5 -0
  52. package/design-md/lamborghini/DESIGN.md +288 -0
  53. package/design-md/lamborghini/README.md +5 -0
  54. package/design-md/linear.app/DESIGN.md +548 -0
  55. package/design-md/linear.app/README.md +5 -0
  56. package/design-md/lovable/DESIGN.md +298 -0
  57. package/design-md/lovable/README.md +5 -0
  58. package/design-md/mastercard/DESIGN.md +365 -0
  59. package/design-md/mastercard/README.md +5 -0
  60. package/design-md/meta/DESIGN.md +683 -0
  61. package/design-md/meta/README.md +5 -0
  62. package/design-md/minimax/DESIGN.md +746 -0
  63. package/design-md/minimax/README.md +5 -0
  64. package/design-md/mintlify/DESIGN.md +852 -0
  65. package/design-md/mintlify/README.md +5 -0
  66. package/design-md/miro/DESIGN.md +825 -0
  67. package/design-md/miro/README.md +5 -0
  68. package/design-md/mistral.ai/DESIGN.md +773 -0
  69. package/design-md/mistral.ai/README.md +5 -0
  70. package/design-md/mongodb/DESIGN.md +767 -0
  71. package/design-md/mongodb/README.md +5 -0
  72. package/design-md/nike/DESIGN.md +575 -0
  73. package/design-md/nike/README.md +5 -0
  74. package/design-md/notion/DESIGN.md +821 -0
  75. package/design-md/notion/README.md +5 -0
  76. package/design-md/nvidia/DESIGN.md +640 -0
  77. package/design-md/nvidia/README.md +5 -0
  78. package/design-md/ollama/DESIGN.md +539 -0
  79. package/design-md/ollama/README.md +5 -0
  80. package/design-md/opencode.ai/DESIGN.md +521 -0
  81. package/design-md/opencode.ai/README.md +5 -0
  82. package/design-md/pinterest/DESIGN.md +597 -0
  83. package/design-md/pinterest/README.md +5 -0
  84. package/design-md/playstation/DESIGN.md +661 -0
  85. package/design-md/playstation/README.md +5 -0
  86. package/design-md/posthog/DESIGN.md +690 -0
  87. package/design-md/posthog/README.md +5 -0
  88. package/design-md/raycast/DESIGN.md +669 -0
  89. package/design-md/raycast/README.md +5 -0
  90. package/design-md/renault/DESIGN.md +589 -0
  91. package/design-md/renault/README.md +5 -0
  92. package/design-md/replicate/DESIGN.md +616 -0
  93. package/design-md/replicate/README.md +5 -0
  94. package/design-md/resend/DESIGN.md +585 -0
  95. package/design-md/resend/README.md +5 -0
  96. package/design-md/revolut/DESIGN.md +636 -0
  97. package/design-md/revolut/README.md +5 -0
  98. package/design-md/runwayml/DESIGN.md +244 -0
  99. package/design-md/runwayml/README.md +5 -0
  100. package/design-md/sanity/DESIGN.md +357 -0
  101. package/design-md/sanity/README.md +5 -0
  102. package/design-md/sentry/DESIGN.md +551 -0
  103. package/design-md/sentry/README.md +5 -0
  104. package/design-md/shopify/DESIGN.md +516 -0
  105. package/design-md/shopify/README.md +5 -0
  106. package/design-md/slack/DESIGN.md +482 -0
  107. package/design-md/spacex/DESIGN.md +363 -0
  108. package/design-md/spacex/README.md +5 -0
  109. package/design-md/spotify/DESIGN.md +246 -0
  110. package/design-md/spotify/README.md +5 -0
  111. package/design-md/starbucks/DESIGN.md +580 -0
  112. package/design-md/starbucks/README.md +5 -0
  113. package/design-md/stripe/DESIGN.md +487 -0
  114. package/design-md/stripe/README.md +5 -0
  115. package/design-md/supabase/DESIGN.md +462 -0
  116. package/design-md/supabase/README.md +5 -0
  117. package/design-md/superhuman/DESIGN.md +448 -0
  118. package/design-md/superhuman/README.md +5 -0
  119. package/design-md/tesla/DESIGN.md +286 -0
  120. package/design-md/tesla/README.md +5 -0
  121. package/design-md/theverge/DESIGN.md +339 -0
  122. package/design-md/theverge/README.md +5 -0
  123. package/design-md/together.ai/DESIGN.md +633 -0
  124. package/design-md/together.ai/README.md +5 -0
  125. package/design-md/uber/DESIGN.md +636 -0
  126. package/design-md/uber/README.md +5 -0
  127. package/design-md/vercel/DESIGN.md +736 -0
  128. package/design-md/vercel/README.md +5 -0
  129. package/design-md/vodafone/DESIGN.md +538 -0
  130. package/design-md/vodafone/README.md +5 -0
  131. package/design-md/voltagent/DESIGN.md +521 -0
  132. package/design-md/voltagent/README.md +5 -0
  133. package/design-md/warp/DESIGN.md +526 -0
  134. package/design-md/warp/README.md +5 -0
  135. package/design-md/webflow/DESIGN.md +588 -0
  136. package/design-md/webflow/README.md +5 -0
  137. package/design-md/wired/DESIGN.md +497 -0
  138. package/design-md/wired/README.md +5 -0
  139. package/design-md/wise/DESIGN.md +544 -0
  140. package/design-md/wise/README.md +5 -0
  141. package/design-md/x.ai/DESIGN.md +465 -0
  142. package/design-md/x.ai/README.md +5 -0
  143. package/design-md/zapier/DESIGN.md +537 -0
  144. package/design-md/zapier/README.md +5 -0
  145. package/package.json +31 -0
@@ -0,0 +1,339 @@
1
+ # Design System Inspired by The Verge
2
+
3
+ ## 1. Visual Theme & Atmosphere
4
+
5
+ The Verge's 2024 redesign feels like somebody wired a Condé Nast magazine to a chiptune soundboard. The canvas is almost-black (`#131313`), the headlines are built from a brutally heavy display face (Manuka) that runs up to 107px, and the whole page is peppered with acid-mint `#3cffd0` and ultraviolet `#5200ff` that behave less like brand colors and more like hazard tape. Story tiles are not quiet gray cards — they're saturated, full-bleed color blocks (yellow, pink, orange, blue, purple) that feel like pasted-up rave flyers arranged into a timeline. The mood is "developer console meets club night meets tech tabloid": serious enough to cover a congressional hearing, loud enough to review a synthesizer.
6
+
7
+ What makes this system unmistakable is the **StoryStream** timeline: a vertical feed where every post is a rounded rectangle — often 20–40px radius — filled edge-to-edge with color, framed by a thin border, and marked by a mono-uppercase timestamp on its left rail. Stories don't float on a grid; they stack on a dashed vertical rule like commits in a git log. Above that, a massive **"The Verge" wordmark** dominates the masthead in Manuka at hero scale, letting the reader know before any headline loads that this is editorial territory, not a template.
8
+
9
+ There is no "light mode" on the homepage — the dark canvas is the product, and the only time the palette inverts is when a single story tile takes a mint or yellow fill. The depth is almost entirely flat: **hairline 1px borders** (`#ffffff`, `#3cffd0`, or `#5200ff`) do the work that shadows would do on a Material-flavored site. Every container is either `#131313` with a 1px outline, a fully saturated accent block, or a slate-gray `#2d2d2d` secondary surface.
10
+
11
+ **Key Characteristics:**
12
+ - Near-black editorial canvas (`#131313`) as the default surface — no light mode on the homepage
13
+ - Acid-mint `#3cffd0` + ultraviolet `#5200ff` as hazard-tape accents, never quiet background wash
14
+ - Massive Manuka display headlines up to 107px — the single loudest type move in mainstream tech media
15
+ - Rounded pill-card everything: 20/24/30/40px corner radii, never square
16
+ - Fully saturated color-block story tiles (mint, purple, yellow, pink, orange, electric blue) on a dark page
17
+ - Timeline "StoryStream" feed with mono uppercase timestamps rather than a traditional magazine grid
18
+ - Flat depth — 1px borders in white, mint, purple do the work that shadows would do elsewhere
19
+
20
+ ## 2. Color Palette & Roles
21
+
22
+ ### Primary (Brand Hazards)
23
+ - **Jelly Mint** (`#3cffd0`): The Verge's signature acid-mint accent. Used as CTA button fill, link underlines, active tab borders, and high-attention story-tile backgrounds. Treat it as the visual equivalent of neon safety paint — applied sparingly to the most important element on screen.
24
+ - **Verge Ultraviolet** (`#5200ff`): The complementary brand hazard. Used for secondary color-block tiles, promotional spans, and the occasional outlined button. Often applied at 0.9 alpha to soften its cathode intensity.
25
+
26
+ ### Secondary & Accent
27
+ - **Console Mint Border** (`#309875`): A darker variant of the jelly mint used on card outlines and button borders where pure mint would over-saturate.
28
+ - **Deep Link Blue** (`#3860be`): The link *hover* color — the one moment blue appears on the site. It replaces mint/white/black on hover across every link style.
29
+ - **Focus Cyan** (`#1eaedb`): Reserved for button focus rings. Never shown outside a keyboard-focus state.
30
+ - **Purple Rule** (`#3d00bf`): A darker ultraviolet variant used as the vertical border on StoryStream `<li>` items.
31
+
32
+ ### Surface & Background
33
+ - **Canvas Black** (`#131313`): The default dark surface for the entire homepage. Almost-but-not-quite pure black — has just enough warmth to feel like a printed newsprint negative rather than an OLED void.
34
+ - **Surface Slate** (`#2d2d2d`): Secondary card background, used when a story tile doesn't need to be a saturated color block.
35
+ - **Image Frame** (`#313131`): The 1px border that wraps inline imagery.
36
+ - **Hazard White** (`#ffffff`): Used as story-tile fill, button border, and primary text. When white appears as a large block, it's an editorial decision — a "spotlight" on that tile.
37
+ - **Absolute Black** (`#000000`): Reserved for text on the mint/yellow/white tiles — the only place it appears.
38
+
39
+ ### Neutrals & Text
40
+ - **Primary Text** (`#ffffff`): Headlines and display text on the canvas.
41
+ - **Secondary Text** (`#949494`): Bylines, timestamps, photo credits. The mid-gray that anchors the metadata layer.
42
+ - **Muted Text** (`#e9e9e9`): Button text on dark slate buttons. Slightly off-white to reduce screen glare.
43
+ - **Inverted Text** (`#131313`): Used only on accent tiles (mint, yellow, white) to keep contrast legible.
44
+
45
+ ### Semantic & Accent
46
+ - **Focus Ring** (`#1eaedb`): Keyboard focus only.
47
+ - **Overlay Black** (`rgba(0, 0, 0, 0.33)`): Subtle 1px ring used as the quiet shadow alternative on stacked cards.
48
+ - **Dim Gray** (`#8c8c8c`): Active/pressed button background — the "pressed down" state.
49
+
50
+ ### Gradient System
51
+ The Verge uses **zero decorative gradients**. The only gradient-like treatment is the transition from a saturated accent story tile (mint/purple/yellow) back to the `#131313` canvas between rows. Color is applied in solid blocks, not as washes. This is a deliberate choice — the site's hazard-tape visual identity would dissolve if anything faded.
52
+
53
+ ## 3. Typography Rules
54
+
55
+ ### Font Family
56
+ - **Manuka** (Klim Type Foundry) — fallback: Impact, Helvetica. The signature display face for The Verge wordmark and feature headlines. A heavy-weight (900) industrial sans-serif with a condensed, almost-athletic stance. Runs at 60–107px on the homepage, never smaller.
57
+ - **PolySans** (PanGram Pangram / Nikolas Wrobel) — fallback: Helvetica, Arial. The UI and secondary headline workhorse. Covers weights 300 / 500 / 700 across the system — everything from kicker captions to body decks.
58
+ - **PolySans Mono** — fallback: Courier New, Courier. The monospaced sibling, used exclusively for ALL-CAPS labels: kickers, timestamps, category tags, button labels. This mono-uppercase usage is the second-most-identifiable Verge detail after Manuka.
59
+ - **FK Roman Standard** (Florian Karsten) — fallback: Georgia. A serif used sparingly for specific body/caption treatments (article excerpts, certain review pulls). Adds a "print-magazine" counterpoint to the PolySans stack.
60
+ - **Roboto** — fallback: `-apple-system`, `system-ui`. Utility UI font for widgets and legacy modules.
61
+
62
+ ### Hierarchy
63
+
64
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
65
+ |---|---|---|---|---|---|---|
66
+ | Hero Wordmark / Display | Manuka | 107px / 6.69rem | 900 | 0.80 | 1.07px | The top-of-page "The Verge" logo and feature headlines |
67
+ | Secondary Display | Manuka | 90px / 5.63rem | 900 | 0.80 | — | Section-level feature headlines |
68
+ | Tertiary Display | Manuka | 60px / 3.75rem | 900 | 0.80 | — | Inline feature callouts |
69
+ | Large Headline | PolySans | 34px / 2.13rem | 700 | 1.00 | — | Section and module headlines |
70
+ | Heading Wide | PolySans | 32px / 2.00rem | 400 | 1.10 | 0.32px | Sub-heroes, promotional units |
71
+ | Heading Medium | PolySans | 24px / 1.50rem | 700 | 1.00 | — | Story tile headlines in the main feed |
72
+ | Heading Small | PolySans | 20px / 1.25rem | 700 | 1.00 | — | Compact tile headlines |
73
+ | Light Capitalized Label | PolySans | 19px / 1.19rem | 300 | 1.20 | 1.9px | Thin-weight capitalized eyebrows — a distinctive Verge move |
74
+ | All-Caps Label XL | PolySans | 18px / 1.13rem | 400 | 1.10 | 1.8px | UPPERCASE section kickers |
75
+ | Bold Body | PolySans | 16px / 1.00rem | 700 | 1.00 | — | Emphasis within decks |
76
+ | Body Relaxed | PolySans | 16px / 1.00rem | 500 | 1.60 | — | Long-form reading body |
77
+ | Inline Label | PolySans | 15px / 0.94rem | 400 | 1.20 | 0.15px | UI labels and secondary headlines |
78
+ | Body Compact | PolySans | 13px / 0.81rem | 400 | 1.60 | — | Secondary captions and decks |
79
+ | Eyebrow All-Caps | PolySans | 12px / 0.75rem | 400 | 1.30 | 1.8px | UPPERCASE kicker above tile headlines |
80
+ | Tag Label | PolySans | 12px / 0.75rem | 400 | 1.20 | 0.72px | UPPERCASE category tag |
81
+ | Caption Micro | PolySans | 11px / 0.69rem | 400 | 1.20 | 1.1px | UPPERCASE bylines |
82
+ | Meta Nano | PolySans | 10px / 0.63rem | 500 | 1.40 | 1.5px | UPPERCASE timestamp microtext |
83
+ | Mono Button Label | PolySans Mono | 12px / 0.75rem | 600 | 2.00 | 1.5px | UPPERCASE button text, very open leading |
84
+ | Mono Timestamp | PolySans Mono | 11px / 0.69rem | 500/600 | 1.20 | 1.1–1.8px | UPPERCASE StoryStream timestamps |
85
+ | Serif Body | FK Roman Standard | 16px / 1.00rem | 400 | 1.30 | -0.16px | Review decks, print-voice excerpts |
86
+ | Serif Caption | FK Roman Standard | 20px / 1.25rem | 400 | 1.20 | — | Magazine-style pull quotes |
87
+
88
+ ### Principles
89
+ - **Manuka is always the hero, never the UI.** If you see Manuka below 60px you're looking at a bug. It exists to *shout the brand*, not to label a button.
90
+ - **PolySans is the workhorse, PolySans Mono is its uniformed sibling.** Mono is used exclusively for UPPERCASE labels, timestamps, tags, and certain buttons. Lowercase mono doesn't exist in this system.
91
+ - **Thin-weight (300) capitalized headlines** are a signature Verge move. The 19–20px weight-300 with 1.9px tracking creates a "fashion magazine whisper" that contrasts with the 107px Manuka shout above it. This whisper-vs-shout contrast is the typographic fingerprint.
92
+ - **Letter-spacing has two registers**: positive (0.72–1.9px) for ALL-CAPS mono and sans labels, negative (`-0.16px`) for the rare serif appearances, barely-positive (0.32px, 1.07px) for massive display. Plain 0 letter-spacing is rare.
93
+ - **FK Roman Standard is the editorial exception**, not the rule. Reserve it for long-form print-voice moments — reviews, critic pulls, masthead essays. Never use it in UI.
94
+ - **Line heights are tight** (0.80–1.30) for every display and label, relaxed (1.60–2.00) only for reading body and mono button labels. The leading jump is intentional — it gives the page a "telegraph ticker" rhythm.
95
+
96
+ ### Note on Font Substitutes
97
+ The 0.80 line-height on Manuka display (107px, 90px, 60px) assumes the **proprietary Manuka face from Klim Type Foundry**, which has aggressively tight vertical metrics designed for athletic stance at large sizes. If you substitute with wide-metric open-source condensed displays like **Anton**, **Oswald**, **Bebas Neue**, or **Archivo Black**, loosen display line-heights by approximately **+0.10 to +0.15** to prevent ascender/descender collisions (e.g., 0.80 → 0.95). PolySans substitutes (Space Grotesk, DM Sans, Hanken Grotesk) work at the token values without adjustment — their metrics are close enough. PolySans Mono substitutes (Space Mono, JetBrains Mono) and FK Roman substitutes (Newsreader, Literata) also work without adjustment.
98
+
99
+ ## 4. Component Stylings
100
+
101
+ ### Buttons
102
+
103
+ **Primary — Jelly Mint Pill**
104
+ - Background: `#3cffd0` (Jelly Mint)
105
+ - Text: `#000000` (Absolute Black), PolySans 16px / 700 or PolySans Mono 12px / 600 UPPERCASE
106
+ - Border: none (pure fill)
107
+ - Border radius: `24px` — fully rounded pill
108
+ - Padding: `10px 24px`
109
+ - Outline: `none` at rest
110
+ - Hover: background shifts to `rgba(255, 255, 255, 0.2)` (translucent white), text stays black, adds a 1px `#c2c2c2` ring shadow
111
+ - Active: background `rgba(140, 140, 140, 0.87)`, opacity `0.5`, ring shadow `#8c8c8c`
112
+ - Focus: background `#1eaedb`, white text, 1px solid `#0500ff` border, translucent white focus ring
113
+ - Transition: ~180ms ease on background and shadow
114
+
115
+ **Secondary — Dark Slate Pill**
116
+ - Background: `#2d2d2d` (Surface Slate)
117
+ - Text: `#e9e9e9` (Muted Text), PolySans 16px / 400
118
+ - Border: none
119
+ - Border radius: `24px`
120
+ - Padding: `10px 24px`
121
+ - Outline: `rgb(233, 233, 233) none 0px`
122
+ - Hover: same translucent white invert as primary — `rgba(255, 255, 255, 0.2)` bg, black text, 1px `#c2c2c2` ring
123
+ - Focus: same cyan focus treatment as primary
124
+
125
+ **Tertiary — Outlined Mint**
126
+ - Background: transparent
127
+ - Text: `#3cffd0`, PolySans Mono 12px / 600 UPPERCASE, 1.5px tracking
128
+ - Border: `1px solid #3cffd0`
129
+ - Border radius: `40px` — larger pill for secondary outline style
130
+ - Padding: ~`10px 20px`
131
+ - Hover: inverts to mint fill, black text
132
+ - Transition: 150ms ease
133
+
134
+ **Outlined Ultraviolet (Promotional)**
135
+ - Background: transparent
136
+ - Text: `#5200ff` or `#ffffff`
137
+ - Border: `1px solid #5200ff`
138
+ - Border radius: `30px`
139
+ - Used for "Subscribe" or "Join the Stream" style promotional callouts
140
+
141
+ **Pill Tag (Non-interactive)**
142
+ - Background: saturated accent (`#3cffd0`, `#5200ff`, yellow, etc.)
143
+ - Text: black or white depending on background luminance
144
+ - Border radius: `20px` (tighter radius than buttons — this is the *text pill*)
145
+ - Font: PolySans Mono 11px / 600 UPPERCASE, 1.8px tracking
146
+ - Padding: ~`4px 10px`
147
+
148
+ ### Cards & Containers
149
+
150
+ **StoryStream Tile**
151
+ - Background: either `#131313` + 1px white border, OR a saturated accent fill (mint, purple, yellow, pink, orange, white)
152
+ - Border radius: `20px` (standard) or `24px` (feature)
153
+ - Border: `1px solid #ffffff` (on dark) or `0px 0px 1px solid #3cffd0` (on mint) or nothing (on saturated fill)
154
+ - Padding: ~24–32px interior
155
+ - Hover: no lift, no scale — the headline text color transitions from white to `#3860be` (deep link blue)
156
+ - Transition: 150ms ease on color only
157
+
158
+ **Feature Card (Top Story)**
159
+ - Background: `#131313` with 1px hairline border, OR full-bleed color accent
160
+ - Border radius: `24px`
161
+ - Padding: 32px+
162
+ - Image inside: clipped to match the outer radius (`3px` or `4px` inner radius when nested)
163
+ - Hover: text color shift only; the image remains static
164
+
165
+ **StoryStream Rail (Timeline)**
166
+ - A vertical dashed or solid rule (1px `#3d00bf` or `#ffffff`) runs along the left edge of each item, marking the timeline spine
167
+ - Timestamps sit on the left rail in PolySans Mono 11px / 500 / UPPERCASE / 1.1px tracking
168
+ - Each entry is a pill-cornered rectangle separated from its neighbors by 12–16px vertical gap
169
+
170
+ ### Inputs & Forms
171
+ - **Default**: `#131313` background, 1px solid `#ffffff` or `#949494` border, `2px` border radius (tight, newspaper-form feel), PolySans 15px text in `#ffffff`, placeholder in `#949494`.
172
+ - **Focus**: border transitions to `#3cffd0` (jelly mint) with optional `1px solid #5200ff` inner ring on deep focus. No glow.
173
+ - **Error**: border turns `#5200ff` (ultraviolet — used as error/alert accent here, not the usual red).
174
+ - **Transition**: ~150ms ease on border-color.
175
+
176
+ ### Navigation
177
+
178
+ - **Top nav**: thin `#131313` bar with the Verge wordmark (Manuka) left-aligned, a search icon and a few UPPERCASE mono category links (12–14px, PolySans Mono, 1.5–1.8px tracking), and a single mint-pill CTA (usually "Subscribe") pinned right.
179
+ - **Wordmark**: massive on first scroll — the homepage treats the "The Verge" logo as a hero element, not a 32px corner logo.
180
+ - **Hover**: every link transitions from `#ffffff` to `#3860be` (deep link blue). No underline — it's a color-only response.
181
+ - **Active section**: marked by a 1px mint underline (inset box-shadow `0px -1px 0px 0px inset #3cffd0`)
182
+ - **Mobile**: the wordmark shrinks, category nav collapses into a hamburger drawer. Inside the drawer, links are mono-uppercase and stack with 16–20px gaps.
183
+
184
+ ### Image Treatment
185
+
186
+ - **Aspect ratios**: 16:9 dominates for hero and feature images, 4:3 for mid-feed, 1:1 for thumbnails and author avatars.
187
+ - **Corners**: always rounded to match the parent card — `3px`, `4px`, or inherit `20px` / `24px` from the tile.
188
+ - **Frame**: 1px `#313131` or `#ffffff` hairline around photography, giving a "contained Polaroid" feel.
189
+ - **Full-bleed**: only within the color-block tiles, where the image runs to the padded edge of the accent fill.
190
+ - **Hover**: static — no zoom, no scale, no opacity shift. The headline below is the only interactive response.
191
+ - **Lazy loading**: `loading="lazy"` on everything below the first fold; eager on the masthead hero only.
192
+
193
+ ### StoryStream Timeline Item (Distinctive)
194
+
195
+ - Vertical rail line (1px `#3d00bf` or `#ffffff` on `#131313`)
196
+ - Mono timestamp on the left in PolySans Mono 11px / UPPERCASE
197
+ - Pill-cornered body card (20px radius) with kicker, headline, and optional deck
198
+ - Stacked vertically with 12–16px gap, the rail continuing between them
199
+ - Often interleaved with full-bleed accent tiles that "break" the timeline rhythm for emphasis
200
+
201
+ ## 5. Layout Principles
202
+
203
+ ### Spacing System
204
+ - **Base unit**: 8px.
205
+ - **Scale**: 1, 2, 4, 5, 6, 8, 9, 10, 12, 14, 15, 16, 20, 24, 25px.
206
+ - **Section padding**: 32–64px vertical between major feed sections. StoryStream items themselves are tighter — 12–16px gaps.
207
+ - **Card padding**: 20–32px interior. Feature cards expand to 40–48px.
208
+ - **Inline spacing**: kickers sit ~6–10px above headlines; headlines sit ~10–14px above decks; timestamps sit ~6–8px below decks.
209
+ - **Micro-scale**: The 2/4/5/6/9/10px values are used inside buttons, pills, and tight label clusters, not in the editorial grid.
210
+
211
+ ### Grid & Container
212
+ - **Max width**: ~1280–1300px (dembrandt detected breakpoints at 1200/1280/1300).
213
+ - **Column patterns**: a 12-column underlying grid that resolves into 3-column hero + 1-column StoryStream rail + feature panels. The homepage feels freeform because color-block tiles frequently span 2–3 columns on a whim.
214
+ - **Container padding**: 24px mobile / 48px desktop on the outer edges.
215
+ - **Gutters**: 16–24px between columns, tighter (8–12px) inside StoryStream items.
216
+
217
+ ### Whitespace Philosophy
218
+ The Verge treats whitespace like a club DJ treats silence — as a dramatic reset between loud moments. The canvas is so dark and the accents are so saturated that even 32px of empty `#131313` between two tiles acts as a palette cleanser. The page is not airy like Apple or Stripe; it's **paced**, with loud hazard-color blocks interrupting stretches of near-black. Whitespace carries the rhythm, not the elegance.
219
+
220
+ ### Border Radius Scale
221
+ - **2px** — inputs, small badges (feels like a typewriter tag)
222
+ - **3px** — inline images (just enough to soften against the canvas)
223
+ - **4px** — nested card images and small button variants
224
+ - **20px** — standard pill cards and color-block tiles
225
+ - **24px** — feature tile radius and primary button pill
226
+ - **30px** — large promotional buttons
227
+ - **40px** — outlined CTA pills (the loudest pill in the system)
228
+ - **50%** — avatar circles, icon buttons, and certain round badges
229
+
230
+ Eight discrete radius values — a **lot** for a single site. This is deliberate: the rhythm between 2px typewriter tags, 20px pill cards, and 40px outlined buttons creates a "nested scale" feel where every component announces its hierarchy through its corners.
231
+
232
+ ## 6. Depth & Elevation
233
+
234
+ | Level | Treatment | Use |
235
+ |---|---|---|
236
+ | 0 | No border, no shadow | Default `#131313` canvas text |
237
+ | 1 | `rgba(0,0,0,0) 0px 0px 0px 0px inset` (placeholder) | Reset state for interactive elements |
238
+ | 2 | `1px solid #ffffff` or `#313131` hairline | Image frames and quiet card outlines |
239
+ | 3 | `1px solid #3cffd0` hairline | Active button outlines, focused story tiles |
240
+ | 4 | `1px solid #5200ff` hairline | Promotional/alternate state outlines |
241
+ | 5 | `rgba(0, 0, 0, 0.33) 0px 0px 0px 1px` | The single "atmospheric" ring — applied to layered cards |
242
+ | 6 | `0px -1px 0px 0px inset` (mint/black/white) | Active tab underline — a signature Verge move |
243
+ | 7 | Saturated accent fill (`#3cffd0`, `#5200ff`, white, yellow, pink) | Story-tile elevation via color, not shadow |
244
+
245
+ The Verge's depth philosophy is **color-as-elevation**. When something needs to stand out, it doesn't get a shadow — it gets a mint fill or a 1px hazard-color border. There are 14 shadow entries in the extracted tokens, but all of them are either inset underlines (0px -1px inset) or near-transparent 1px rings — none of them are traditional elevation shadows. The `#131313` canvas stays perfectly flat throughout, and hierarchy is carried by color saturation.
246
+
247
+ ### Decorative Depth
248
+ - **1px inset underline** on active tabs/nav links (mint, black, or white depending on context)
249
+ - **Subtle `rgba(0, 0, 0, 0.33)` 1px ring** on stacked cards — the only effect that faintly resembles a shadow
250
+ - **No gradients, no glows, no atmospheric blurs** anywhere. The hazard-tape aesthetic would break if anything faded softly.
251
+
252
+ ## 7. Do's and Don'ts
253
+
254
+ ### Do
255
+ - **Do** use `#131313` as the canvas for every view. There is no light mode.
256
+ - **Do** use Jelly Mint (`#3cffd0`) and Verge Ultraviolet (`#5200ff`) as hazard accents — buttons, borders, active states, and saturated color-block tiles.
257
+ - **Do** use Manuka exclusively at 60px+ for hero headlines. Treat anything smaller as a bug.
258
+ - **Do** round everything: 20px for cards, 24px for feature cards, 30–40px for pill buttons.
259
+ - **Do** use PolySans Mono for UPPERCASE labels, timestamps, kickers, and button text. Lowercase mono doesn't exist here.
260
+ - **Do** apply 1.5–1.9px letter-spacing to every ALL-CAPS label — this is a Verge signature.
261
+ - **Do** use saturated color-block tiles (mint, purple, yellow, pink, orange, white) to elevate a story — never a drop shadow.
262
+ - **Do** use `#3860be` (deep link blue) as the hover color on every link, regardless of base color.
263
+ - **Do** apply the StoryStream timeline rail (1px dashed/solid `#3d00bf` or white) on feed views.
264
+ - **Do** use thin-weight (300) PolySans at 19–20px with 1.9px tracking for "fashion-whisper" capitalized eyebrows — the contrast with the 107px Manuka shout is the whole voice.
265
+
266
+ ### Don't
267
+ - **Don't** use a light background. The dark canvas is the product.
268
+ - **Don't** add `box-shadow` for elevation. Use 1px borders or saturated accent fills instead.
269
+ - **Don't** use square corners. Every interactive and content container is rounded.
270
+ - **Don't** use Manuka for UI, buttons, or body copy. It's strictly display.
271
+ - **Don't** use lowercase mono. PolySans Mono is always UPPERCASE.
272
+ - **Don't** let mint and ultraviolet appear as background washes — they're hazard accents, not canvas tints.
273
+ - **Don't** use gradients anywhere. The system is solid color blocks only.
274
+ - **Don't** introduce new accent colors outside the declared mint / purple / yellow / pink / orange tile palette.
275
+ - **Don't** pair Manuka with FK Roman Standard in the same headline cluster — Manuka is the only display shout, serif pulls are reserved for body moments.
276
+ - **Don't** use `#3cffd0` text on a `#131313` background at under 16px — the contrast vibrates at small sizes.
277
+
278
+ ## 8. Responsive Behavior
279
+
280
+ ### Breakpoints
281
+
282
+ | Name | Width | Key Changes |
283
+ |---|---|---|
284
+ | Small Mobile | <400px | Single column, Manuka hero scales down to ~48–54px, StoryStream rail collapses to inline timestamps |
285
+ | Mobile | 400–549px | Single column, color-block tiles stack full-width, nav is a hamburger drawer |
286
+ | Large Mobile | 550–767px | Still single column but padding opens up, tile radii stay at 20px |
287
+ | Tablet | 768–1023px | 2-column StoryStream with feature card spanning, wordmark shrinks ~50% |
288
+ | Small Desktop | 1024–1179px | Full 3–4 column editorial grid, mint pill CTA restored to nav |
289
+ | Desktop | 1180–1299px | Max padding, Manuka wordmark at full hero scale |
290
+ | Large Desktop | ≥1300px | Container caps at ~1280–1300px, whitespace expands at the margins, no further scaling |
291
+
292
+ The dembrandt sweep detected 26 intermediate breakpoints (1300 → 1280 → 1200 → 1181 → 1180 → 1179 → 1024 → 1023 → 901 → 900 → 897 → 896 → 890 → 769 → 768 → 620 → 605 → 600 → 550 → 549 → 530 → 426 → 425 → 400 → 320). The Verge tunes its grid at virtually every major device boundary — an unusually aggressive responsive strategy.
293
+
294
+ ### Touch Targets
295
+ - Primary pill buttons are ~44px minimum height (10px vertical padding + 16px text + 2px border) — meets WCAG AA.
296
+ - Mono uppercase nav links are smaller (~28–32px tall) — for derivative work, pad to 44px on mobile.
297
+ - Circle icon buttons are 40–44px circles, touch-friendly.
298
+
299
+ ### Collapsing Strategy
300
+ - **Nav**: wordmark scales from hero (Manuka 60–107px) to ~24–32px on mobile. Category links collapse to a hamburger drawer below 900px.
301
+ - **Grid**: 4-col → 3-col → 2-col → 1-col. Feature cards that span 2 columns on desktop reflow to full-width single-column on mobile.
302
+ - **Spacing**: section padding tightens from 64px → 32px → 20px. Tile interior padding tightens from 32px → 20px.
303
+ - **Type**: Manuka hero scales from 107px to ~48–54px on mobile. PolySans headlines scale from 34px → 24px. Mono labels stay pinned at 11–12px (they don't shrink further or they become unreadable).
304
+ - **Color tiles**: accent story blocks never lose saturation on mobile — they just reflow to full width.
305
+
306
+ ### Image Behavior
307
+ - Responsive raster via `srcset`, aspect ratios preserved.
308
+ - No art-direction swaps — same crop scales across all viewports.
309
+ - `loading="lazy"` on everything below the fold, `eager` on the masthead hero.
310
+ - Images inside color-block tiles inherit the tile's inner radius (4px or 20px nested).
311
+
312
+ ## 9. Agent Prompt Guide
313
+
314
+ ### Quick Color Reference
315
+ - **Primary CTA**: "Jelly Mint (`#3cffd0`)"
316
+ - **Background (Canvas)**: "Canvas Black (`#131313`)"
317
+ - **Accent (Secondary Hazard)**: "Verge Ultraviolet (`#5200ff`)"
318
+ - **Heading Text**: "Hazard White (`#ffffff`)"
319
+ - **Body Text**: "Hazard White (`#ffffff`)" (primary) or "Muted Text (`#e9e9e9`)"
320
+ - **Secondary Text / Metadata**: "Secondary Text (`#949494`)"
321
+ - **Card Border**: "Hazard White (`#ffffff`)" hairline on dark, "Console Mint Border (`#309875`)" on mint variants
322
+ - **Link Hover**: "Deep Link Blue (`#3860be`)"
323
+
324
+ ### Example Component Prompts
325
+ 1. *"Create a StoryStream timeline item on a `#131313` canvas: a 20px-radius rectangle with a 1px solid `#ffffff` border, a PolySans Mono 11px / 600 / UPPERCASE / 1.1px tracking timestamp on the left rail, a 12px PolySans UPPERCASE kicker in mint (`#3cffd0`), and a 24px / 700 PolySans headline in white below. No shadow, no lift — hover only shifts the headline color to `#3860be`."*
326
+ 2. *"Design a primary subscribe button with a Jelly Mint (`#3cffd0`) fill, black text in PolySans Mono 12px / 600 / UPPERCASE / 1.5px tracking, 24px border radius, 10px × 24px padding. Hover state shifts to `rgba(255, 255, 255, 0.2)` background with a 1px `#c2c2c2` ring shadow, 180ms ease."*
327
+ 3. *"Build a feature hero with a 107px Manuka 900 headline in white with 1.07px letter-spacing and 0.80 line-height, a thin-weight 300 PolySans 20px capitalized kicker above with 1.9px tracking, on a `#131313` canvas with 64px vertical padding."*
328
+ 4. *"Create a color-block accent tile filled with Verge Ultraviolet (`#5200ff`) at 0.9 alpha, 24px border radius, white text, a PolySans Mono 11px UPPERCASE category label with 1.5px tracking at the top, and a 32px PolySans 400 capitalized headline with 0.32px tracking below."*
329
+ 5. *"Design a dark slate secondary button with a `#2d2d2d` background, `#e9e9e9` PolySans 16px text, 24px radius pill shape, 10px × 24px padding. Hover matches the primary button — translucent white `rgba(255, 255, 255, 0.2)` bg with black text."*
330
+
331
+ ### Iteration Guide
332
+ When refining existing screens generated with this design system:
333
+ 1. **Audit the canvas.** If you see a light background anywhere on the homepage, flatten it to `#131313`. There is no light mode.
334
+ 2. **Audit corners.** Every rectangle should land on 2/3/4/20/24/30/40px or 50%. Square corners break the voice.
335
+ 3. **Audit shadows.** Strip every `box-shadow` that isn't a 1px inset underline or a 1px hazard-color border. The Verge uses color for elevation, not shadow.
336
+ 4. **Audit type roles.** Manuka only ≥60px. PolySans Mono only UPPERCASE. PolySans 300 at 19–20px should have 1.9px tracking. FK Roman only for body/magazine moments, never UI.
337
+ 5. **Audit accent usage.** Mint and ultraviolet should appear as hazard accents — buttons, 1px borders, active underlines, saturated tile fills. If they're appearing as background washes or gradient fades, correct to solid blocks.
338
+ 6. **Audit labels.** Every kicker, timestamp, category tag, and button label should be ALL CAPS with 1.1–1.9px letter-spacing. Missing tracking = missing voice.
339
+ 7. **Audit link hover.** Every link, regardless of its base color, should hover to `#3860be` deep link blue with no underline. Any other hover color is drift.
@@ -0,0 +1,5 @@
1
+ # Theverge Inspired Design System
2
+
3
+ Design system details have been moved to: https://getdesign.md/theverge/design-md
4
+
5
+ You can also view previews, dark mode examples, and download options on getdesign.md.