oh-my-design-cli 1.0.2 → 1.2.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/README.ja.md +7 -7
- package/README.ko.md +7 -7
- package/README.md +15 -18
- package/README.zh-TW.md +7 -7
- package/agents/omd-ux-writer.md +1 -1
- package/data/architecture-proposals/2026-05-13-thin-install-fresh-fetch.md +189 -0
- package/data/reference-audits/2026-05-13-kr10.md +132 -0
- package/data/reference-fingerprints.json +626 -3
- package/data/reference-tags.md +15 -1
- package/package.json +2 -2
- package/skills/omd-apply/SKILL.md +1 -1
- package/skills/omd-harness/SKILL.md +3 -3
- package/skills/omd-init/SKILL.md +2 -2
- package/web/AGENTS.md +5 -0
- package/web/references/29cm/DESIGN.md +445 -0
- package/web/references/ably/DESIGN.md +582 -0
- package/{references → web/references}/airbnb/DESIGN.md +158 -19
- package/web/references/airtable/DESIGN.md +241 -0
- package/{references → web/references}/apple/DESIGN.md +131 -76
- package/web/references/baemin/DESIGN.md +470 -0
- package/web/references/banksalad/DESIGN.md +606 -0
- package/{references → web/references}/bmw/DESIGN.md +138 -9
- package/{references → web/references}/cal/DESIGN.md +173 -17
- package/{references → web/references}/claude/DESIGN.md +11 -1
- package/{references → web/references}/clay/DESIGN.md +75 -0
- package/{references → web/references}/clickhouse/DESIGN.md +74 -0
- package/{references → web/references}/cohere/DESIGN.md +75 -0
- package/web/references/coinbase/DESIGN.md +205 -0
- package/{references → web/references}/composio/DESIGN.md +74 -0
- package/web/references/coupang/DESIGN.md +487 -0
- package/{references → web/references}/cursor/DESIGN.md +74 -0
- package/web/references/dcard/DESIGN.md +567 -0
- package/{references → web/references}/elevenlabs/DESIGN.md +91 -0
- package/{references → web/references}/expo/DESIGN.md +72 -0
- package/{references → web/references}/ferrari/DESIGN.md +72 -0
- package/{references → web/references}/figma/DESIGN.md +124 -48
- package/{references → web/references}/framer/DESIGN.md +143 -16
- package/web/references/freee/DESIGN.md +558 -0
- package/web/references/gangnamunni/DESIGN.md +605 -0
- package/{references → web/references}/hashicorp/DESIGN.md +72 -0
- package/{references → web/references}/ibm/DESIGN.md +68 -0
- package/{references → web/references}/intercom/DESIGN.md +73 -0
- package/web/references/kakao/DESIGN.md +490 -0
- package/web/references/kakaobank/DESIGN.md +533 -0
- package/web/references/kakaopay/DESIGN.md +529 -0
- package/web/references/karrot/DESIGN.md +431 -0
- package/web/references/kraken/DESIGN.md +219 -0
- package/web/references/krds/DESIGN.md +982 -0
- package/web/references/kurly/DESIGN.md +574 -0
- package/{references → web/references}/lamborghini/DESIGN.md +74 -0
- package/{references → web/references}/line/DESIGN.md +84 -43
- package/{references → web/references}/linear.app/DESIGN.md +8 -1
- package/{references → web/references}/lovable/DESIGN.md +73 -0
- package/web/references/mercari/DESIGN.md +464 -0
- package/{references → web/references}/minimax/DESIGN.md +72 -0
- package/{references → web/references}/mintlify/DESIGN.md +72 -0
- package/web/references/miro/DESIGN.md +252 -0
- package/{references → web/references}/mistral.ai/DESIGN.md +72 -0
- package/{references → web/references}/mongodb/DESIGN.md +72 -0
- package/web/references/musinsa/DESIGN.md +536 -0
- package/web/references/naver/DESIGN.md +518 -0
- package/{references → web/references}/notion/DESIGN.md +9 -1
- package/web/references/nvidia/DESIGN.md +491 -0
- package/web/references/ohouse/DESIGN.md +570 -0
- package/{references → web/references}/ollama/DESIGN.md +72 -0
- package/{references → web/references}/opencode.ai/DESIGN.md +73 -0
- package/web/references/pinkoi/DESIGN.md +575 -0
- package/{references → web/references}/pinterest/DESIGN.md +73 -0
- package/{references → web/references}/posthog/DESIGN.md +172 -18
- package/web/references/qanda/DESIGN.md +459 -0
- package/{references → web/references}/raycast/DESIGN.md +169 -34
- package/web/references/remember/DESIGN.md +445 -0
- package/{references → web/references}/renault/DESIGN.md +72 -0
- package/{references → web/references}/replicate/DESIGN.md +73 -0
- package/{references → web/references}/resend/DESIGN.md +73 -0
- package/{references → web/references}/revolut/DESIGN.md +74 -0
- package/web/references/ridi/DESIGN.md +517 -0
- package/{references → web/references}/runwayml/DESIGN.md +152 -24
- package/{references → web/references}/sanity/DESIGN.md +72 -0
- package/{references → web/references}/sentry/DESIGN.md +73 -0
- package/web/references/socar/DESIGN.md +370 -0
- package/web/references/spacex/DESIGN.md +379 -0
- package/web/references/spotify/DESIGN.md +426 -0
- package/{references → web/references}/stripe/DESIGN.md +44 -1
- package/{references → web/references}/supabase/DESIGN.md +73 -0
- package/{references → web/references}/superhuman/DESIGN.md +159 -17
- package/{references → web/references}/tesla/DESIGN.md +170 -0
- package/{references → web/references}/together.ai/DESIGN.md +73 -0
- package/{references → web/references}/toss/DESIGN.md +304 -50
- package/{references → web/references}/uber/DESIGN.md +73 -0
- package/{references → web/references}/vercel/DESIGN.md +9 -1
- package/{references → web/references}/voltagent/DESIGN.md +73 -0
- package/web/references/wanted/DESIGN.md +515 -0
- package/{references → web/references}/warp/DESIGN.md +142 -15
- package/web/references/webflow/DESIGN.md +253 -0
- package/{references → web/references}/wise/DESIGN.md +84 -0
- package/{references → web/references}/x.ai/DESIGN.md +85 -0
- package/web/references/yanolja/DESIGN.md +448 -0
- package/web/references/yeogiotte/DESIGN.md +424 -0
- package/{references → web/references}/zapier/DESIGN.md +85 -0
- package/web/references/zigbang/DESIGN.md +457 -0
- package/web/references/zigzag/DESIGN.md +618 -0
- package/references/airtable/DESIGN.md +0 -107
- package/references/baemin/DESIGN.md +0 -260
- package/references/coinbase/DESIGN.md +0 -129
- package/references/dcard/DESIGN.md +0 -302
- package/references/freee/DESIGN.md +0 -308
- package/references/kakao/DESIGN.md +0 -261
- package/references/karrot/DESIGN.md +0 -252
- package/references/kraken/DESIGN.md +0 -146
- package/references/mercari/DESIGN.md +0 -294
- package/references/miro/DESIGN.md +0 -108
- package/references/nvidia/DESIGN.md +0 -308
- package/references/pinkoi/DESIGN.md +0 -309
- package/references/spacex/DESIGN.md +0 -205
- package/references/spotify/DESIGN.md +0 -246
- 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
|
+
|