oh-my-design-cli 1.0.2 → 1.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 (99) hide show
  1. package/README.md +15 -18
  2. package/data/reference-fingerprints.json +337 -3
  3. package/data/reference-tags.md +15 -1
  4. package/package.json +2 -2
  5. package/skills/omd-init/SKILL.md +1 -1
  6. package/web/AGENTS.md +5 -0
  7. package/{references → web/references}/airbnb/DESIGN.md +158 -19
  8. package/web/references/airtable/DESIGN.md +241 -0
  9. package/{references → web/references}/apple/DESIGN.md +131 -76
  10. package/web/references/baemin/DESIGN.md +470 -0
  11. package/{references → web/references}/bmw/DESIGN.md +138 -9
  12. package/{references → web/references}/cal/DESIGN.md +173 -17
  13. package/{references → web/references}/claude/DESIGN.md +11 -1
  14. package/{references → web/references}/clay/DESIGN.md +75 -0
  15. package/{references → web/references}/clickhouse/DESIGN.md +74 -0
  16. package/{references → web/references}/cohere/DESIGN.md +75 -0
  17. package/web/references/coinbase/DESIGN.md +205 -0
  18. package/{references → web/references}/composio/DESIGN.md +74 -0
  19. package/web/references/coupang/DESIGN.md +487 -0
  20. package/{references → web/references}/cursor/DESIGN.md +74 -0
  21. package/web/references/dcard/DESIGN.md +567 -0
  22. package/{references → web/references}/elevenlabs/DESIGN.md +91 -0
  23. package/{references → web/references}/expo/DESIGN.md +72 -0
  24. package/{references → web/references}/ferrari/DESIGN.md +72 -0
  25. package/{references → web/references}/figma/DESIGN.md +124 -48
  26. package/{references → web/references}/framer/DESIGN.md +143 -16
  27. package/web/references/freee/DESIGN.md +558 -0
  28. package/{references → web/references}/hashicorp/DESIGN.md +72 -0
  29. package/{references → web/references}/ibm/DESIGN.md +68 -0
  30. package/{references → web/references}/intercom/DESIGN.md +73 -0
  31. package/web/references/kakao/DESIGN.md +490 -0
  32. package/web/references/kakaobank/DESIGN.md +533 -0
  33. package/web/references/karrot/DESIGN.md +431 -0
  34. package/web/references/kraken/DESIGN.md +219 -0
  35. package/web/references/krds/DESIGN.md +982 -0
  36. package/web/references/kurly/DESIGN.md +574 -0
  37. package/{references → web/references}/lamborghini/DESIGN.md +74 -0
  38. package/{references → web/references}/line/DESIGN.md +84 -43
  39. package/{references → web/references}/linear.app/DESIGN.md +8 -1
  40. package/{references → web/references}/lovable/DESIGN.md +73 -0
  41. package/web/references/mercari/DESIGN.md +464 -0
  42. package/{references → web/references}/minimax/DESIGN.md +72 -0
  43. package/{references → web/references}/mintlify/DESIGN.md +72 -0
  44. package/web/references/miro/DESIGN.md +252 -0
  45. package/{references → web/references}/mistral.ai/DESIGN.md +72 -0
  46. package/{references → web/references}/mongodb/DESIGN.md +72 -0
  47. package/web/references/musinsa/DESIGN.md +536 -0
  48. package/web/references/naver/DESIGN.md +518 -0
  49. package/{references → web/references}/notion/DESIGN.md +9 -1
  50. package/web/references/nvidia/DESIGN.md +491 -0
  51. package/web/references/ohouse/DESIGN.md +570 -0
  52. package/{references → web/references}/ollama/DESIGN.md +72 -0
  53. package/{references → web/references}/opencode.ai/DESIGN.md +73 -0
  54. package/web/references/pinkoi/DESIGN.md +575 -0
  55. package/{references → web/references}/pinterest/DESIGN.md +73 -0
  56. package/{references → web/references}/posthog/DESIGN.md +172 -18
  57. package/web/references/qanda/DESIGN.md +459 -0
  58. package/{references → web/references}/raycast/DESIGN.md +169 -34
  59. package/{references → web/references}/renault/DESIGN.md +72 -0
  60. package/{references → web/references}/replicate/DESIGN.md +73 -0
  61. package/{references → web/references}/resend/DESIGN.md +73 -0
  62. package/{references → web/references}/revolut/DESIGN.md +74 -0
  63. package/web/references/ridi/DESIGN.md +517 -0
  64. package/{references → web/references}/runwayml/DESIGN.md +152 -24
  65. package/{references → web/references}/sanity/DESIGN.md +72 -0
  66. package/{references → web/references}/sentry/DESIGN.md +73 -0
  67. package/web/references/spacex/DESIGN.md +379 -0
  68. package/web/references/spotify/DESIGN.md +426 -0
  69. package/{references → web/references}/stripe/DESIGN.md +44 -1
  70. package/{references → web/references}/supabase/DESIGN.md +73 -0
  71. package/{references → web/references}/superhuman/DESIGN.md +159 -17
  72. package/{references → web/references}/tesla/DESIGN.md +170 -0
  73. package/{references → web/references}/together.ai/DESIGN.md +73 -0
  74. package/{references → web/references}/toss/DESIGN.md +304 -50
  75. package/{references → web/references}/uber/DESIGN.md +73 -0
  76. package/{references → web/references}/vercel/DESIGN.md +9 -1
  77. package/{references → web/references}/voltagent/DESIGN.md +73 -0
  78. package/{references → web/references}/warp/DESIGN.md +142 -15
  79. package/web/references/webflow/DESIGN.md +253 -0
  80. package/{references → web/references}/wise/DESIGN.md +84 -0
  81. package/{references → web/references}/x.ai/DESIGN.md +85 -0
  82. package/web/references/yanolja/DESIGN.md +448 -0
  83. package/web/references/yeogiotte/DESIGN.md +424 -0
  84. package/{references → web/references}/zapier/DESIGN.md +85 -0
  85. package/references/airtable/DESIGN.md +0 -107
  86. package/references/baemin/DESIGN.md +0 -260
  87. package/references/coinbase/DESIGN.md +0 -129
  88. package/references/dcard/DESIGN.md +0 -302
  89. package/references/freee/DESIGN.md +0 -308
  90. package/references/kakao/DESIGN.md +0 -261
  91. package/references/karrot/DESIGN.md +0 -252
  92. package/references/kraken/DESIGN.md +0 -146
  93. package/references/mercari/DESIGN.md +0 -294
  94. package/references/miro/DESIGN.md +0 -108
  95. package/references/nvidia/DESIGN.md +0 -308
  96. package/references/pinkoi/DESIGN.md +0 -309
  97. package/references/spacex/DESIGN.md +0 -205
  98. package/references/spotify/DESIGN.md +0 -246
  99. package/references/webflow/DESIGN.md +0 -109
@@ -0,0 +1,431 @@
1
+ ---
2
+ omd: 0.1
3
+ brand: Karrot
4
+ ---
5
+
6
+ # Design System Inspiration of Karrot (당근)
7
+
8
+ ## 1. Visual Theme & Atmosphere
9
+
10
+ Karrot's interface is the digital equivalent of a friendly neighborhood bulletin board -- warm, approachable, and built for trust between strangers. The page opens on a clean white canvas (`#ffffff`) with warm near-black headings (`#1a1c20`) and the unmistakable Karrot Orange (`#ff6600`) that serves as the singular brand accent. This isn't the corporate orange of enterprise dashboards; it's the vivid, saturated orange of a fresh carrot -- energetic, trustworthy, and unmistakably local.
11
+
12
+ The design system, called **Seed Design**, is one of the most mature open-source systems in Korean tech. It operates on a strict 4px grid with a three-tier token architecture (palette → semantic → component) that ensures every measurement is intentional. Typography relies entirely on the platform's native font stack rather than a custom typeface -- Pretendard on web, system fonts on native -- putting community content first. The overall aesthetic is warm neutral: soft grays, generous whitespace, and that singular orange accent. Where Stripe uses shadows as brand expression, Karrot uses shadows as pure function -- minimal, neutral, and warm.
13
+
14
+ **Key Characteristics:**
15
+ - Karrot Orange (`#ff6600`) as the singular brand accent -- warm, energetic, unmistakable
16
+ - System font stack (Pretendard / Apple SD Gothic Neo) -- content takes center stage, no custom typeface
17
+ - 4px base grid with precise spacing from 2px (x0.5) to 64px (x16)
18
+ - Three-tier token system: palette → semantic → component for systematic theming
19
+ - Full dark mode via semantic token remapping (not simple inversion)
20
+ - 11-step gray scale (gray-00 through gray-1000) for nuanced depth
21
+ - Three-level shadow system with separate light/dark mode intensities
22
+ - Mobile-first at 375px baseline with `clamp()`-based accessibility font scaling
23
+
24
+ ## 2. Color Palette & Roles
25
+
26
+ ### Primary
27
+ - **Karrot Orange** (`#ff6600`): `$color.palette.carrot-600`. Primary CTA, active states, brand solid backgrounds. The iconic orange that defines every Karrot touchpoint.
28
+ - **Deep Orange** (`#e14d00`): `$color.palette.carrot-700`. Pressed/hover state for brand elements, dark mode brand solid.
29
+ - **Near Black** (`#1a1c20`): `$color.palette.gray-1000`, `fg-neutral`. Primary heading and text color. Warm near-black that avoids harshness.
30
+ - **Pure White** (`#ffffff`): `$color.palette.gray-00`, `bg-layer-default`. Page background, card surfaces.
31
+
32
+ ### Brand Tints
33
+ - **Orange Tint** (`#fff2ec`): `$color.palette.carrot-100`. Brand weak background, subtle orange-tinted surfaces.
34
+ - **Orange Light** (`#ffb999`): `$color.palette.carrot-400`. Medium brand tint, progress indicators.
35
+ - **Orange Deep** (`#b93901`): `$color.palette.carrot-800`. Deep orange for emphasis in dark contexts.
36
+
37
+ ### Semantic
38
+ - **Critical Red** (`#fa342c`): `fg-critical`. Error foreground, destructive action labels.
39
+ - **Informative Blue** (`#217cf9`): `fg-informative`. Links, informational highlights.
40
+ - **Positive Green** (`#079171`): `fg-positive`. Success states, confirmation indicators.
41
+ - **Warning Yellow** (`#9b7821`): `fg-warning`. Caution labels, attention-needed states.
42
+ - **Focus Blue** (`#5e98fe`): `stroke-focus-ring`. Keyboard focus ring on interactive elements.
43
+
44
+ ### Neutral Scale
45
+ - **Gray 100** (`#f7f8f9`): `bg-layer-fill`. Subtle background fill.
46
+ - **Gray 200** (`#f3f4f5`): `bg-layer-basement`, `bg-disabled`. Secondary surfaces.
47
+ - **Gray 400** (`#dcdee3`): `stroke-neutral-weak`. Standard borders, dividers.
48
+ - **Gray 600** (`#b0b3ba`): `fg-placeholder`. Placeholder text, muted icons.
49
+ - **Gray 700** (`#868b94`): `fg-neutral-subtle`. Captions, tertiary text.
50
+ - **Gray 800** (`#555d6d`): `fg-neutral-muted`. Secondary body text.
51
+
52
+ ### Surface & Borders
53
+ - **Border Subtle** (`rgba(0,0,0,0.08)`): `stroke-neutral-subtle`. Soft card borders, barely-there separation.
54
+ - **Border Muted** (`rgba(0,0,0,0.12)`): `stroke-neutral-muted`. Moderate borders for definition.
55
+ - **Overlay** (`rgba(0,0,0,0.7)`): `bg-overlay`. Modal/sheet backdrop.
56
+ - **Overlay Muted** (`rgba(0,0,0,0.5)`): `bg-overlay-muted`. Bottom sheet scrims.
57
+
58
+ ## 3. Typography Rules
59
+
60
+ ### Font Family
61
+ - **Primary**: `"Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", Roboto, "Noto Sans KR", sans-serif`
62
+ - **Monospace**: `"SF Mono", SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace`
63
+ - **Design Principle**: No custom brand typeface. Karrot intentionally uses the user's system font so community content feels native and personal, not branded.
64
+
65
+ ### Hierarchy
66
+
67
+ | Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
68
+ |------|------|------|--------|-------------|----------------|-------|
69
+ | Display XL | System | 26px (t10) | 700 | 35px | 0em | Hero headlines, splash screens |
70
+ | Display Large | System | 24px (t9) | 700 | 32px | 0em | Section headers |
71
+ | Heading Large | System | 20px (t7) | 700 | 27px | 0em | Card headings, sub-sections |
72
+ | Heading | System | 18px (t6) | 700 | 24px | 0em | List section headers |
73
+ | Title | System | 16px (t5) | 500 | 22px | 0em | Navigation, standard titles |
74
+ | Body | System | 14px (t4) | 400 | 19px | 0em | Standard reading text, listings |
75
+ | Body Small | System | 13px (t3) | 400 | 18px | 0em | Secondary text, metadata |
76
+ | Caption | System | 12px (t2) | 400 | 16px | 0em | Timestamps, small labels |
77
+ | Caption Small | System | 11px (t1) | 400 | 15px | 0em | Fine print, badges |
78
+
79
+ ### Principles
80
+ - **Three weights only**: Regular (400), Medium (500), Bold (700). No light or extra-bold -- the system is intentionally constrained.
81
+ - **Platform-aware tracking**: iOS uses 0em throughout; Android uses tighter tracking (-0.02em to -0.04em) for system font metrics.
82
+ - **Compact type scale**: 11px to 26px in 10 steps with no display sizes above 26px -- mobile-first, content-density over typographic drama.
83
+ - **Accessibility scaling**: All sizes use `clamp()` with `--seed-font-size-multiplier`, supporting 80% to 150% of base size.
84
+
85
+ ## 4. Component Stylings
86
+
87
+ ### Buttons
88
+
89
+ **Brand Solid (Primary CTA)**
90
+ - Background: `#ff6600` (carrot-600)
91
+ - Text: `#ffffff`
92
+ - Radius: 12px (large), 8px (medium/small), 9999px (xsmall pill)
93
+ - Min-height: 52px (large), 40px (medium), 36px (small), 32px (xsmall)
94
+ - Font: 16px weight 700 (large), 14px weight 700 (medium/small)
95
+ - Pressed: `#e14d00` (carrot-700)
96
+ - Disabled: `#f3f4f5` background, `#d1d3d8` text
97
+ - Use: Primary actions ("판매하기", "채팅하기")
98
+
99
+ **Neutral Weak**
100
+ - Background: `#f3f4f5` (gray-200)
101
+ - Text: `#1a1c20` (gray-1000)
102
+ - Pressed: `#eeeff1` (gray-300)
103
+ - Use: Tertiary actions, filters
104
+
105
+ **Neutral Outline**
106
+ - Background: transparent
107
+ - Text: `#1a1c20` (gray-1000)
108
+ - Border: 1px solid `#dcdee3` (gray-400)
109
+ - Pressed: `#f7f8f9` background
110
+ - Use: Cancel, dismiss, low-emphasis
111
+
112
+ **Critical Solid**
113
+ - Background: `#fa342c` (red-700)
114
+ - Text: `#ffffff`
115
+ - Use: Destructive actions ("삭제", "신고")
116
+
117
+ ### Cards & Containers
118
+ - Background: `#ffffff` (bg-layer-default)
119
+ - Border: 1px solid `rgba(0,0,0,0.08)` (stroke-neutral-subtle) or no border with shadow
120
+ - Radius: 8px (standard), 12px (featured), 16px (large cards)
121
+ - Shadow: `0px 2px 10px rgba(0,0,0,0.1)` (s2) for standard cards
122
+
123
+ ### Chips & Tags
124
+ - Background: `#f3f4f5` (gray-200), Selected: `#1a1c20` (gray-1000) with white text
125
+ - Radius: 9999px (pill)
126
+ - Height: 32px, Padding: 0 12px, Font: 13px weight 500
127
+
128
+ ### Inputs & Forms
129
+ - Background: `#f7f8f9` (gray-100)
130
+ - Border: 1px solid `#dcdee3` (gray-400)
131
+ - Radius: 8px
132
+ - Focus: 2px solid `#5e98fe` (blue-600) focus ring
133
+ - Text: `#1a1c20`, Placeholder: `#b0b3ba` (gray-600)
134
+ - Error border: `#fa342c` (red-700)
135
+
136
+ ### Navigation
137
+ - Bottom tab bar: white background, subtle top border
138
+ - Active tab: Karrot Orange icon + label, Inactive: `#868b94` (gray-700)
139
+ - App bar: white, centered title (16px weight 700), optional back arrow
140
+
141
+ ## 5. Layout Principles
142
+
143
+ ### Spacing System
144
+ - Base unit: 4px
145
+ - Scale: 2px (x0.5), 4px (x1), 6px (x1.5), 8px (x2), 12px (x3), 16px (x4), 20px (x5), 24px (x6), 32px (x8), 40px (x10), 56px (x14), 64px (x16)
146
+ - Global gutter: 16px (x4) on each side
147
+ - Component default vertical: 12px (x3)
148
+
149
+ ### Grid & Container
150
+ - Mobile: full-width with 16px horizontal gutter
151
+ - Content max-width: 640px for web
152
+ - Listing cards: full-width with 16px horizontal padding
153
+ - Card grid: 2-column on tablet, single column on mobile
154
+
155
+ ### Whitespace Philosophy
156
+ - **Content-dense, chrome-light**: Users scan many listings quickly. Spacing breathes but keeps 3-4 items per viewport.
157
+ - **Consistent gutter**: The 16px global gutter is sacred -- every screen edge, every card inset returns to this rhythm.
158
+ - **Grouped by proximity**: Related items use 4-8px gaps; distinct sections use 16-24px gaps.
159
+
160
+ ### Border Radius Scale
161
+ - Micro (2px): Progress bars, inline indicators
162
+ - Standard (8px): Buttons, inputs, standard cards
163
+ - Comfortable (12px): Large buttons, featured cards
164
+ - Large (16px): Image frames, prominent cards
165
+ - Sheet (20px): Bottom sheet top corners
166
+ - Dialog (24px): Modal dialogs
167
+ - Pill (9999px): Chips, avatars, xsmall buttons
168
+
169
+ ## 6. Depth & Elevation
170
+
171
+ | Level | Treatment | Use |
172
+ |-------|-----------|-----|
173
+ | Flat (Level 0) | No shadow | Page background, inline elements |
174
+ | Subtle (s1) | `0px 1px 4px rgba(0,0,0,0.08)` | Slight lift, list item hover |
175
+ | Standard (s2) | `0px 2px 10px rgba(0,0,0,0.10)` | Cards, dropdowns, popovers |
176
+ | Prominent (s3) | `0px 4px 16px rgba(0,0,0,0.12)` | Floating action button, bottom sheets, modals |
177
+
178
+ **Shadow Philosophy**: Only three levels -- enough for clear layering without visual clutter. Shadows use pure black with varying opacity (no brand-tinted shadows), keeping the system neutral so the orange accent remains the sole source of warmth. In dark mode, opacities increase dramatically (s1: 0.50, s2: 0.68, s3: 0.80) to remain perceptible on dark surfaces.
179
+
180
+ ## 7. Do's and Don'ts
181
+
182
+ ### Do
183
+ - Use Karrot Orange (`#ff6600`) as the singular brand accent -- it should feel special, not overwhelming
184
+ - Stick to the 4px spacing grid -- every measurement should be a multiple of 4px
185
+ - Use semantic tokens (`fg-neutral`, `bg-layer-default`) over raw palette values in component code
186
+ - Keep border-radius between 8px-12px for standard elements, pills (9999px) only for chips/avatars
187
+ - Use the system font stack -- Pretendard on web, system fonts on native
188
+ - Apply dark mode via semantic token remapping, not opacity tricks
189
+ - Maintain the 16px global gutter on all screen edges
190
+
191
+ ### Don't
192
+ - Don't overuse orange -- it's for primary CTAs and brand moments only, not backgrounds or borders
193
+ - Don't use shadows heavier than s3 -- the system intentionally avoids dramatic elevation
194
+ - Don't introduce additional brand colors -- Karrot is a one-accent-color system
195
+ - Don't exceed 26px for text sizes -- this is a mobile-first system with a compact type scale
196
+ - Don't use pure black (`#000000`) for text -- use gray-1000 (`#1a1c20`) for warmth
197
+ - Don't mix palette tokens and semantic tokens in the same component
198
+ - Don't skip the `clamp()` wrapper on font sizes -- accessibility scaling is non-negotiable
199
+
200
+ ## 8. Responsive Behavior
201
+
202
+ ### Breakpoints
203
+ | Name | Width | Key Changes |
204
+ |------|-------|-------------|
205
+ | Mobile | <480px | Full-width cards, single column, 16px gutter |
206
+ | Tablet | 480-768px | 2-column listing grid, expanded cards |
207
+ | Desktop (Web) | >768px | Max-width 640px content, centered layout |
208
+
209
+ ### Touch Targets
210
+ - Buttons: 52px (large), 40px (medium), 36px (small), 32px (xsmall)
211
+ - Tab bar items: 48px height with centered icon + label
212
+ - List items: minimum 56px row height
213
+ - Chips: 32px height minimum
214
+
215
+ ### Collapsing Strategy
216
+ - Listing grid: 2-column → single column below 480px
217
+ - Bottom tab bar persists across all sizes
218
+ - Bottom CTA: sticky full-width button + safe area padding
219
+ - Image carousels: horizontal scroll with page indicators
220
+
221
+ ### Image Behavior
222
+ - Listing thumbnails: 1:1 aspect ratio, 8px radius
223
+ - Profile avatars: circular (9999px), 36-48px diameter
224
+ - Full-width hero images: edge-to-edge, no radius
225
+
226
+ ## 9. Agent Prompt Guide
227
+
228
+ ### Quick Color Reference
229
+ - Primary CTA: Karrot Orange (`#ff6600`)
230
+ - CTA Pressed: Deep Orange (`#e14d00`)
231
+ - Background: Pure White (`#ffffff`)
232
+ - Heading text: Near Black (`#1a1c20`)
233
+ - Body text: Dark Gray (`#555d6d`)
234
+ - Caption text: Medium Gray (`#868b94`)
235
+ - Placeholder: Light Gray (`#b0b3ba`)
236
+ - Border: Soft Gray (`#dcdee3`)
237
+ - Disabled bg: Light Fill (`#f3f4f5`)
238
+ - Error: Red (`#fa342c`)
239
+ - Success: Green (`#079171`)
240
+ - Info: Blue (`#217cf9`)
241
+ - Focus ring: Blue (`#5e98fe`)
242
+
243
+ ### Example Component Prompts
244
+ - "Create a listing card: white background, 1px solid rgba(0,0,0,0.08) border, 8px radius. Horizontal layout with 1:1 thumbnail (8px radius) left. Title 16px weight 400, #1a1c20. Price 16px weight 700, #1a1c20. Location + time 13px weight 400, #868b94."
245
+ - "Build a primary CTA button: #ff6600 background, white text, 16px weight 700, min-height 52px, 12px radius, full-width. Pressed: #e14d00. Disabled: #f3f4f5 bg, #d1d3d8 text."
246
+ - "Design a filter chip bar: horizontal scroll, 8px gap. Each chip: #f3f4f5 bg, #1a1c20 text, 13px weight 500, 32px height, 9999px radius, 12px h-padding. Selected: #1a1c20 bg, #ffffff text."
247
+ - "Create a bottom sheet: white bg, 20px top-left/right radius, shadow 0px 4px 16px rgba(0,0,0,0.12). Handle: 36px wide, 4px height, #dcdee3, centered. Content: 16px h-padding."
248
+ - "Design a navigation bar: white bg, sticky top, 1px bottom border rgba(0,0,0,0.08). Centered title 16px weight 700, #1a1c20. Left: back arrow icon #1a1c20. Right: optional action icon. Height 56px."
249
+
250
+ ### Iteration Guide
251
+ 1. Primary color is `#ff6600` only -- no secondary brand hue exists
252
+ 2. All spacing snaps to 4px grid: 4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64
253
+ 3. Border-radius defaults: 8px buttons/inputs, 12px cards, 9999px chips/avatars
254
+ 4. Gray-1000 (`#1a1c20`) for headings, gray-800 (`#555d6d`) for body, gray-700 (`#868b94`) for captions
255
+ 5. Shadows are minimal: s1 for hover, s2 for cards, s3 for floating elements only
256
+ 6. Mobile-first: design at 375px width, 16px gutter, then scale up
257
+ 7. System font stack -- never embed a custom font for Karrot
258
+
259
+ ---
260
+
261
+ ## 10. Voice & Tone
262
+
263
+ Karrot speaks like a trustworthy neighbor who just moved in next door: warm, plain-spoken, low-friction, and allergic to anything that sounds like corporate marketing. The voice assumes two strangers are about to hand each other a used crib across a parking lot — it protects that trust with earnestness, removes barriers with `부담 없이` (without burden) framing, and stays in everyday Korean sentence endings (`-어요`, `-예요`) rather than the formal `-ㅂ니다`. English surfaces (Karrot in US/Canada/UK/JP) mirror this in plain, contraction-friendly English — *"Buy and sell for free with locals"*, not *"Discover premium local marketplace experiences"*.
264
+
265
+ | Context | Tone |
266
+ |---|---|
267
+ | CTAs | Short verb-first Korean (`판매하기`, `채팅하기`, `거래 완료`) / plain imperative English (`Sell`, `Chat`, `Apply`) |
268
+ | Empty states | One warm line explaining *why it's empty* + one low-pressure suggestion. Never `데이터가 없습니다`. |
269
+ | Error messages | Specific, blameless, actionable. Prefer `다시 시도해 주세요` over `오류가 발생했습니다`. |
270
+ | Success toasts | Past-tense single sentence (`거래가 완료되었어요`). Quiet, not celebratory. |
271
+ | Community guidelines | Second-person, direct, grounded in neighborhood norms. Reads like a house rule, not a ToS. |
272
+ | Trust & safety | Calm, factual, never fearmongering. The goal is to keep people transacting, not to scare them off. |
273
+ | Local / hyperlocal copy | Always name the neighborhood (`강남구 역삼동`, `Manhattan`). Proximity is the brand — surface it. |
274
+ | Onboarding | One screen, one idea, one action. No bullet lists. No feature tours. |
275
+
276
+ **Forbidden phrases.** `불편을 드려 죄송합니다`, `죄송하지만`, `데이터가 없습니다`, `오류가 발생했습니다`, `혁신적인`, English boilerplate like `Oops, something went wrong` or `We apologize for the inconvenience`. Marketing-speak bans: `amazing deals`, `best-in-class`, `revolutionary`, `world-class`. Emoji are permitted sparingly in community chat and stickers, but never in error messages, never in trust/safety copy, and never in financial/payment confirmations.
277
+
278
+ **Voice samples.**
279
+
280
+ - `Buy and sell for free with locals` — homepage hero, English. <!-- verified: https://www.karrotmarket.com, 2026-04 -->
281
+ - `Welcome to your new neighborhood buy & sell` — homepage sub-hero. <!-- verified: https://www.karrotmarket.com, 2026-04 -->
282
+ - `It's easier in the apps` / `Download the Karrot app` — app-install nudge. <!-- verified: https://www.karrotmarket.com, 2026-04 -->
283
+ - `동네를 여는 문, 당근` — brand narrative tagline (corporate site). <!-- verified: https://about.daangn.com, 2026-04 -->
284
+ - `로컬의 모든 것을 연결해, 동네의 숨은 가치를 깨워요` — mission statement. <!-- cited: about.daangn.com mission page, 2026-04 -->
285
+ - `<neighborhood>에서 <product>을(를) 찾고 있어요` — illustrative search/wanted-listing pattern (variable placeholders). <!-- illustrative: not verified as live Karrot copy -->
286
+ - `이 거래, 직접 만나서 할까요?` — illustrative in-chat nudge for face-to-face meeting (hyperlocal behavior). <!-- illustrative: not verified as live Karrot copy -->
287
+
288
+ ## 11. Brand Narrative
289
+
290
+ Karrot (당근, *daangn*) launched in 2015 in Pangyo, South Korea, founded by Kim Yong-hyun and Kim Jae-hyun — both former Kakao engineers who had watched the open-marketplace model (Korean e-commerce giants, nationwide shipping, anonymous counterparties) fail the one job users actually cared about: trust. Their founding bet was that secondhand transactions are not a logistics problem; they are a **neighborhood problem**. The first version of the app hard-capped transactions to a **6 km radius** (later relaxed to 10 km in KR/JP, up to 50 km in North America), on the theory that if you can walk to the meeting, you can look the other person in the eye ([Crunchbase](https://www.crunchbase.com/organization/daangn-market), [KED Global](https://www.kedglobal.com/korean-startups/newsView/ked202407040005)).
291
+
292
+ The product is built around that proximity constraint. Every listing surfaces the neighborhood name. Every match is geo-scoped. Every CTA assumes the buyer and seller will eventually stand in the same parking lot. The design language follows suit: a warm orange (`#ff6600`) that reads as a fresh carrot — not the corporate orange of enterprise dashboards, not the alarm orange of warnings — and no custom typeface, because the brand doesn't want a distinctive voice *around* user content; it wants user content to feel like the voice of the neighborhood itself. **Series D $162M August 2021** at **$2.7B valuation** made **Danggeun Market Inc.** Korea's **13th unicorn** (>1 trillion KRW). Earlier September 2019 raise: 40 billion KRW from **Altos Ventures + Goodwater Capital** (Silicon Valley). By early 2025 the company reports 40M+ cumulative registered users and 20M+ monthly active users across 1,400+ regions worldwide, with 227B KRW in cumulative funding ([Crunchbase — Karrot Market](https://www.crunchbase.com/organization/daangn-market), [KED Global — Korea's top flea market $180M](https://www.kedglobal.com/newsView/ked202102010008), [about.daangn.com](https://about.daangn.com)). <!-- about.daangn.com retrieved 2026-04 -->
293
+
294
+ What Karrot refuses: the anonymity of nationwide marketplaces (eBay, Coupang), the impersonal aesthetics of enterprise commerce (data-heavy dashboards, filter-rich search UIs), and the gamified engagement loops of consumer social (streaks, badges, algorithmic feeds). The brand's mission, stated on its own corporate page, is *"로컬의 모든 것을 연결해 동네의 숨은 가치를 기술로 깨우는"* — connecting everything local, awakening hidden neighborhood value through technology ([medium.com/daangn](https://medium.com/daangn)). Orange is the accent because the brand is supposed to feel like one warm thing in an otherwise neutral room.
295
+
296
+ ## 12. Principles
297
+
298
+ 1. **Orange is scarce, on purpose.** `#ff6600` appears only on the primary CTA, active states, and a small set of brand moments. It never decorates, never fills a hero background, never tints a shadow. *UI implication:* at most one orange element per viewport in the primary flow; if a design has two orange CTAs competing on one screen, one must demote to neutral-weak.
299
+ 2. **System font, because content is the brand.** No custom typeface. Pretendard on web, Apple SD Gothic Neo / system sans on native. The community's listings *are* the product; the UI's job is to disappear behind them. *UI implication:* never embed a branded webfont on Karrot-styled surfaces. If a heading needs weight, use weight 700, not a display face.
300
+ 3. **Proximity is surfaced, always.** Every listing, chat, and search result shows a neighborhood name. Distance is not a filter you have to remember to toggle — it's a default. *UI implication:* every card, row, or summary that represents user content must show the neighborhood (`동` / `neighborhood`) as visible metadata, not hidden in a detail screen.
301
+ 4. **Trust comes from calm, not from badges.** No padlock icons in the main flow, no "Verified Seller" trophies, no red "FRAUD WARNING" banners on first paint. Trust is communicated through consistency, neutrality, and the user's ability to meet in person. *UI implication:* trust-and-safety copy lives in body-weight neutral text; reserve red and warning-iconography for actual errors, not ambient advisories.
302
+ 5. **Everything on the 4px grid.** The Seed Design system snaps all measurements to multiples of 4px. Off-grid values accrete into visual noise. *UI implication:* any padding, gap, or component height not in `{4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64}` must be justified in a comment or corrected.
303
+ 6. **One accent. One system. One rhythm.** No secondary brand hue exists. No "Karrot Blue" for utility, no "Karrot Green" for success-branded promo. Semantic colors (`fg-critical`, `fg-informative`, `fg-positive`) exist — but they are utility, not brand. *UI implication:* if a design introduces a second brand-scale color, it has drifted off-system; reject or re-scope to semantic.
304
+ 7. **Dark mode is a remap, not an inversion.** Semantic tokens point to different palette entries in dark mode; brand solid, critical, and informative are intentionally re-tuned rather than auto-computed. *UI implication:* never rely on `filter: invert()` or runtime HSL math. Every component reads from semantic tokens that already account for theme.
305
+ 8. **Content-dense, chrome-light.** Users scan many listings in one session — a listing card is closer to an SMS than to a Pinterest tile. *UI implication:* target 3–4 listings visible per mobile viewport; chrome (borders, shadows, decorative space) must not push that below 3.
306
+
307
+ ## 13. Personas
308
+
309
+ *Personas are fictional archetypes informed by publicly described Karrot user segments, not individual people.*
310
+
311
+ **지우 (Jiwoo), 31, Seoul.** New mother in 망원동. Uses Karrot 3–4 times a week — mostly to sell outgrown baby gear and pick up a stroller from someone two blocks away. Expects the app to open on the local listings feed in <1s and remember her neighborhood without re-asking. Will walk 10 minutes for a good deal; won't drive 20.
312
+
313
+ **민호 (Minho), 26, Busan.** Graduate student. Treats Karrot as a free Craigslist replacement for textbooks, a desk lamp, and the occasional IKEA handoff. Reads every listing's neighborhood tag before the title — if it's outside 동구, he scrolls past. Prefers chat over calls; never gives out his phone number.
314
+
315
+ **Sarah, 34, Toronto.** Just moved to Leslieville from Manhattan. Installed Karrot after a neighbor mentioned it because Facebook Marketplace *"felt like strangers on the internet, and this feels like people on my street."* Expects English-first UI, imperial units, and the ability to set the pickup spot to a coffee shop without drama.
316
+
317
+ **이선생님 (Mr. Lee), 58, Daegu.** Retired, primary Karrot user is his spouse who shares the account. Uses it for *동네생활* community posts ("who has a working lawnmower I can borrow") more than buying and selling. Trust in face-to-face transactions is his whole reason for tolerating an app at all.
318
+
319
+ ## 14. States
320
+
321
+ | State | Treatment |
322
+ |---|---|
323
+ | **Empty (no listings nearby)** | Warm one-line explanation (`아직 우리 동네에 올라온 물건이 없어요`) + one secondary CTA in neutral-weak (`내 동네 바꾸기` / change neighborhood). Never an illustration. Never `데이터가 없습니다`. |
324
+ | **Empty (filter cleared)** | Single line of `gray-700` caption (`조건에 맞는 물건이 없어요`). No button — user resets the filter themselves. |
325
+ | **Empty (new user, first paint)** | Single welcome sentence naming the user's detected neighborhood, plus a primary CTA `둘러보기` (browse) in Karrot Orange. No onboarding carousel. |
326
+ | **Loading (first paint)** | Skeleton blocks at `gray-200` matching the final listing-card layout — 1:1 thumbnail box, two text lines, one metadata line. Shimmer at 1.2s with 8% white highlight. |
327
+ | **Loading (infinite scroll)** | Bottom-of-list spinner in Karrot Orange, 24px diameter. No overlay. Existing cards stay visible. |
328
+ | **Loading (refresh / pull-to-refresh)** | Pull-down reveals a carrot-glyph progress indicator in Karrot Orange; never a generic iOS spinner on branded surfaces. |
329
+ | **Error (inline field)** | Input border becomes `#fa342c` (red-700) 2px, helper text below in red-700 13px. One actionable sentence (`동네를 다시 선택해 주세요`). |
330
+ | **Error (toast)** | `#1a1c20` (gray-1000) background, white 14px weight 400 text, 3s auto-dismiss. Bottom of screen with 16px inset above the tab bar. One sentence. No icon. |
331
+ | **Error (network / server-blocking)** | Full-screen centered message in `gray-1000` 16px weight 600, `gray-800` 14px weight 400 subline, retry button in Karrot Orange. No illustration. |
332
+ | **Success (inline flash)** | Brief 300ms flash of `#fff2ec` (carrot-100) behind the updated element, fading back to default. For routine confirmations (favorited, saved search). |
333
+ | **Success (transaction complete)** | Dedicated confirmation screen — not a toast. `#079171` (positive green) check icon top-center, one-line past-tense sentence (`거래가 완료되었어요`), and a single primary button `매너 평가 남기기` (leave manner rating). |
334
+ | **Skeleton** | `gray-200` blocks at exact final dimensions matching the listing-card layout (1:1 thumbnail, two text lines, one metadata line). Shimmer 1.2s with 8% white highlight. Never over the neighborhood-name metadata — that slot stays blank until resolved, so the UI never implies a location that hasn't been confirmed. |
335
+ | **Disabled** | Button background drops to `gray-200`, text to `gray-500`. No color inversion. Geometry stays identical so re-enable is frame-stable. |
336
+
337
+ ## 15. Motion & Easing
338
+
339
+ **Durations** (named, not raw milliseconds):
340
+
341
+ | Token | Value | Use |
342
+ |---|---|---|
343
+ | `motion-instant` | 0ms | Toggle flips, checkbox state changes |
344
+ | `motion-fast` | 150ms | Hover, focus, button press overlays, inline flash success |
345
+ | `motion-standard` | 250ms | The default — card taps, tab switches, bottom-sheet reveals |
346
+ | `motion-slow` | 350ms | Emphasized transitions — full-sheet presentations, success screens |
347
+ | `motion-page` | 300ms | Native-style push/pop between routes |
348
+
349
+ **Easings:**
350
+
351
+ | Token | Curve | Use |
352
+ |---|---|---|
353
+ | `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Sheets, toasts, screen pushes appearing |
354
+ | `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals, pops, toast auto-close |
355
+ | `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — expandable cards, tab content |
356
+
357
+ **Spring stance.** **Spring and overshoot easings are forbidden across Karrot surfaces.** The brand is a neighborhood marketplace between strangers; playful bounce undermines the calm trust the rest of the system works to establish. Money and goods change hands on this app — a button that wobbles on press reads as toy-like, and a success card that springs in reads as celebratory in a way Karrot deliberately isn't. The one licensed exception is the native-platform pull-to-refresh indicator, which inherits the OS's default spring because overriding it would feel *more* jarring than accepting it. Every other motion uses `ease-enter`, `ease-exit`, or `ease-standard`.
358
+
359
+ **Signature motions.**
360
+
361
+ 1. **Listing-card tap.** Card compresses to 98% scale on press (`motion-fast / ease-standard`), releases on tap-up before navigation begins. Feedback is immediate; the route transition follows on `motion-page / ease-enter`.
362
+ 2. **Bottom-sheet presentation.** Sheets rise from `y+40px` with `motion-standard / ease-enter` and a synchronized backdrop fade from `rgba(0,0,0,0)` to `rgba(0,0,0,0.5)` (`bg-overlay-muted`). Dismissal uses `motion-fast / ease-exit` — leaving is lighter than entering.
363
+ 3. **Neighborhood switch.** When the user changes their 동 (neighborhood), the listings feed cross-fades over `motion-slow` rather than sliding — sliding would imply geographic direction, which is misleading (Korean neighborhoods aren't ordered on an axis).
364
+ 4. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. No exceptions. Cross-fades replace slides. Pull-to-refresh indicator simplifies to a static spinner. The app stays fully usable; just less kinetic.
365
+
366
+ <!--
367
+ OmD v0.1 Sources — Philosophy Layer (sections 10–15)
368
+
369
+ Tier 1 — Direct verification (WebFetch, 2026-04):
370
+ - https://www.karrotmarket.com — live English microcopy: "Buy and sell for free with locals",
371
+ "Welcome to your new neighborhood buy & sell", "It's easier in the apps",
372
+ "Download the Karrot app", category labels, CTAs, footer taxonomy.
373
+ - https://about.daangn.com — corporate site confirms mission tagline
374
+ "동네를 여는 문, 당근", full mission statement "로컬의 모든 것을 연결해,
375
+ 동네의 숨은 가치를 깨워요", Jan-2025 metrics (40M+ registered users,
376
+ 20M+ MAU, 1,400+ regions, 227B KRW funding).
377
+ - https://medium.com/daangn — engineering publication confirms
378
+ "로컬의 모든 것을 연결해 동네의 숨은 가치를 기술로 깨우는" as the tech-focused
379
+ mission variant; 4.3K followers; categories (Engineering, AI/ML, Data, Search).
380
+
381
+ Tier 2 — Press / secondary (WebSearch, 2026-04):
382
+ - https://www.crunchbase.com/organization/daangn-market — confirms 2015 founding,
383
+ co-founders Kim Yong-hyun and Kim Jae-hyun, both ex-Kakao.
384
+ - https://www.kedglobal.com/korean-startups/newsView/ked202407040005 —
385
+ confirms initial 6 km transaction radius, later 10 km (KR/JP) and up to
386
+ 50 km (US/CA), Canada expansion (2024).
387
+
388
+ Base DESIGN.md (sections 1–9) is the source for token-level claims including
389
+ Karrot Orange #ff6600, Seed Design system, 4px grid, semantic token architecture,
390
+ shadow levels, and the system-font-only typography decision.
391
+
392
+ Re-verification status:
393
+ - The 40M+ registered / 20M+ MAU / 1,400+ regions / 227B KRW figures in §11 are
394
+ carried from about.daangn.com as of the retrieval date. Numbers may drift;
395
+ re-verify before quoting publicly. <!-- source: about.daangn.com, 2026-04,
396
+ not independently cross-checked against financial filings -->
397
+ - The 6 km / 10 km / 50 km radius progression is widely reported in press
398
+ (KED Global, Crunchbase, TechCrunch 2020/2021). Current product-level radius
399
+ may differ; verify before using as a design constraint.
400
+
401
+ Not independently verified — widely documented public facts:
402
+ - Karrot (Danggeun Market Inc.) founded 2015 in Pangyo by Kim Yong-hyun and
403
+ Kim Jae-hyun, both formerly at Kakao Corp.
404
+ - Korean "동네" (neighborhood / dong) is a real administrative unit; the
405
+ characterization of nationwide Korean e-commerce incumbents is general
406
+ industry knowledge, not a sourced Karrot statement.
407
+
408
+ Personas (§13) are fictional archetypes informed by publicly described Karrot
409
+ user segments (KR urban young adult, KR secondary-city student, NA expat,
410
+ KR retiree 동네생활 user). Any resemblance to specific individuals is unintended.
411
+
412
+ Interpretive claims (editorial, not documented Karrot statements):
413
+ - "Orange is the accent because the brand is supposed to feel like one warm
414
+ thing in an otherwise neutral room" (§11 closing) — editorial reading of the
415
+ design, not a sourced brand statement.
416
+ - The characterization of the Karrot orange as "fresh carrot, not corporate
417
+ orange, not alarm orange" (§11) — editorial framing based on observed usage.
418
+ - The spring-forbidden stance (§15) — derived from the overall brand posture
419
+ (trust between strangers, calm neutrality) as expressed in base §6 Shadow
420
+ Philosophy and §7 Do's/Don'ts; not a documented Seed Design rule.
421
+ -->
422
+
423
+ ---
424
+
425
+ **Verified:** 2026-05-08 (omd:migrate run 30 — Apple-tier)
426
+ **Tier 1 sources:** daangn.com/kr (consumer hyperlocal — Karrot Orange `#ff6600` 4px / 32px / 14px·600 Primary + neighborhood-pill `#f3f4f5` 9999px / 40px / 16px·400 + skip-nav split-radius `0 0 4px 4px` `#2a3038`); about.daangn.com (corporate — Deep Charcoal `#1a1c20` 999px / 50px / 16px·400 brand-led pill).
427
+ **Tier 2 sources:** styles.refero.design / getdesign.md — no record.
428
+ **Tier 2 (Philosophy/founders):** Crunchbase (Karrot + Kim Jae-hyun + Kim Yong-hyun profiles), KED Global ($180M unicorn 2021), Korea Herald (Canada 2M), ZoomInfo (HQ Gangnam), KoreaTechDesk.
429
+ **Style ref:** `toss` (KR neighbor tone, retained).
430
+ **Conflicts unresolved:** none. **Earlier mistake reverted:** prior footer captured only consumer chrome; corporate about.daangn.com is a separate Deep Charcoal `#1a1c20` 999px pill system that should be documented as a second canonical track.
431
+