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.
- package/README.md +15 -18
- package/data/reference-fingerprints.json +337 -3
- package/data/reference-tags.md +15 -1
- package/package.json +2 -2
- package/skills/omd-init/SKILL.md +1 -1
- package/web/AGENTS.md +5 -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/{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/{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/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/{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/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/{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/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,574 @@
|
|
|
1
|
+
---
|
|
2
|
+
omd: 0.1
|
|
3
|
+
brand: Kurly
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Design System Inspiration of Kurly (컬리 / 마켓컬리)
|
|
7
|
+
|
|
8
|
+
## 1. Visual Theme & Atmosphere
|
|
9
|
+
|
|
10
|
+
Kurly's interface is the digital equivalent of a curator's grocer -- a quiet white-and-cream gallery wall where the only saturated thing in the room is one deep, editorial purple. The page opens on a near-pure white canvas (`#ffffff`) with a soft cool-gray utility fill (`#f2f5f8`) and ink-black headings (`#222`), and the unmistakable **Kurly Purple `#5f0080`** carries every brand moment that matters: the wordmark, the primary CTA, the `샛별배송` (dawn delivery) badge, the cart icon's active state. This is not a corporate purple of fintech dashboards or telco logos; it is closer to the deep aubergine of a high-end pâtisserie awning -- premium, restrained, slightly aristocratic.
|
|
11
|
+
|
|
12
|
+
The system, internally referenced in compiled CSS as **KPDS (Kurly Product Design System)**, treats purple the way a fine-dining restaurant treats truffle: a small amount, deployed with intention. Typography is **Pretendard** -- Korea's de-facto product sans -- never a custom display face, because the photography of the food *is* the brand expression and the type's job is to step out of its way. The overall aesthetic is editorial-magazine-meets-grocery: dense product grids on cream/white, generous photographic real estate, restrained chrome, and the same purple repeated just often enough that the eye learns to associate it with "Kurly promised this."
|
|
13
|
+
|
|
14
|
+
**Key Characteristics:**
|
|
15
|
+
- Kurly Purple (`#5f0080`) as the singular brand mark -- premium, editorial, never a tint
|
|
16
|
+
- Pretendard product font with system-font fallback chain (no custom display typeface)
|
|
17
|
+
- Cool-gray neutral scale anchored at `#f2f5f8` (lightest) → `#222` (deepest), 12 steps total
|
|
18
|
+
- KPDS three-tier token system (palette → semantic → component) compiled into CSS variables
|
|
19
|
+
- Photography-forward product grids (1:1 thumbnail dominant, type secondary)
|
|
20
|
+
- Whitespace-generous "보다 나은 삶" (better life) tone -- never crowded, never carnival
|
|
21
|
+
- Dawn-delivery `샛별배송` badge as a recurring brand moment in purple
|
|
22
|
+
- Mobile-first commerce density: 2-column product grid below 768px, 4-column on desktop
|
|
23
|
+
|
|
24
|
+
## 2. Color Palette & Roles
|
|
25
|
+
|
|
26
|
+
### Primary
|
|
27
|
+
- **Kurly Purple** (`#5f0080`): KPDS `purple-900`. Primary CTA, brand wordmark, `샛별배송` (dawn delivery) badge, active states. The single defining color of the brand.
|
|
28
|
+
- **Purple 800** (`#672091`): Pressed/hover for purple CTAs, dark contexts.
|
|
29
|
+
- **Purple 700** (`#7e3ab0`): Mid-emphasis brand accent for editorial banners.
|
|
30
|
+
- **Purple 500** (`#9a60ca`): Tints used in hero gradients, lifestyle banners.
|
|
31
|
+
- **Purple 300** (`#c19edf`): Soft brand-tinted backgrounds, premium chips.
|
|
32
|
+
- **Purple 100** (`#e8dbf3`): Brand-weak background for ribbons, callouts.
|
|
33
|
+
- **Purple 50** (`#f5effa`): Whisper-tint for selected rows and subtle brand surfaces.
|
|
34
|
+
|
|
35
|
+
### Foreground (Ink)
|
|
36
|
+
- **Ink 900** (`#1c1c1c`): KPDS `gray-900`. Reserved for highest-contrast headings.
|
|
37
|
+
- **Ink 800** (`#222`): Default heading and price color. Slightly softer than pure black -- the warmth that keeps the white pages from going clinical.
|
|
38
|
+
- **Ink 600** (`#393d41`): Body text on white.
|
|
39
|
+
- **Ink 500** (`#464c52`): Sub-body, descriptions.
|
|
40
|
+
- **Ink 400** (`#565e67`): Caption, metadata.
|
|
41
|
+
- **Ink 300** (`#848f9a`): Disabled labels, placeholder.
|
|
42
|
+
|
|
43
|
+
### Surface & Border
|
|
44
|
+
- **Pure White** (`#ffffff`): Page background, card surface.
|
|
45
|
+
- **Cream Fill** (`#f2f5f8`): KPDS `gray-100`. Section background, search bar fill, neutral chip fill.
|
|
46
|
+
- **Hairline Soft** (`#eceff3`): KPDS `gray-200`. Subtle separators.
|
|
47
|
+
- **Hairline Default** (`#dfe4eb`): KPDS `gray-300`. Standard 1px borders.
|
|
48
|
+
- **Hairline Strong** (`#cbd1d7`): KPDS `gray-400`. Definitive borders, input outlines.
|
|
49
|
+
- **Mute Border** (`#bcc4cc`): KPDS `gray-500`. Pressed border on outline buttons.
|
|
50
|
+
|
|
51
|
+
### Semantic
|
|
52
|
+
- **Sale Red** (`#e22d2e`): KPDS `red-700`. Discount %, error foreground, `세일` badge.
|
|
53
|
+
- **Sale Red Deep** (`#d81b1c`): Pressed sale-red.
|
|
54
|
+
- **Sale Red Tint** (`#fbe4e4`): Discount ribbon background, error inline tint.
|
|
55
|
+
- **Coral** (`#fa622f`): KPDS `orange-700`. Limited-time offers, "오늘만" promotional color (used sparingly to avoid competing with purple).
|
|
56
|
+
- **Coral Tint** (`#feebe4`): Promotional background.
|
|
57
|
+
- **Success Green** (`#029568`): KPDS `green-600`. Success toasts, fresh/organic indicators.
|
|
58
|
+
- **Info Blue** (`#216ba5`): Hyperlinks, informational states.
|
|
59
|
+
|
|
60
|
+
### Promotional Purple (Bright)
|
|
61
|
+
- **Bright Purple** (`#bd76ff`): KPDS `purple-bright-300`. Promotional accent (mobile pill highlights, "Beauty Kurly" sub-brand) -- distinct from `#5f0080` by intent: deep purple = trust, bright purple = play.
|
|
62
|
+
- **Bright Purple Soft** (`#f6edff`): Promotional background tint.
|
|
63
|
+
|
|
64
|
+
## 3. Typography Rules
|
|
65
|
+
|
|
66
|
+
### Font Family
|
|
67
|
+
- **Primary**: `Pretendard, "Pretendard Variable", -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif`
|
|
68
|
+
- **Design Principle**: Pretendard is the entire type voice. There is no custom display face; the brand puts its visual personality into product photography and that one purple, not into letterforms.
|
|
69
|
+
|
|
70
|
+
### Hierarchy
|
|
71
|
+
|
|
72
|
+
| Role | Size | Weight | Use |
|
|
73
|
+
|------|------|--------|-----|
|
|
74
|
+
| Display 72 | 72px | 700 | Hero magazine headlines (web only) |
|
|
75
|
+
| Display 44 | 44px | 700 | Editorial section headers |
|
|
76
|
+
| Headline 36 | 36px | 700 | Page titles, category banners |
|
|
77
|
+
| Headline 28 | 28px | 700 | Subsection headers |
|
|
78
|
+
| Title 24 | 24px | 600 | Card-cluster titles, dialog titles |
|
|
79
|
+
| Title 20 | 20px | 600 | Strong product titles, list section headers |
|
|
80
|
+
| Title 18 | 18px | 600 | Standard product titles, modal titles |
|
|
81
|
+
| Body 16 | 16px | 400 | Default reading text, button labels (lg) |
|
|
82
|
+
| Body 14 | 14px | 400 | Secondary body, button labels (md) |
|
|
83
|
+
| Caption 13 | 13px | 400 | Metadata, brand line on product card |
|
|
84
|
+
| Caption 12 | 12px | 400 | Timestamps, fine print |
|
|
85
|
+
| Micro 10 | 10px | 600 | Badge text (`샛별배송`, `Kurly Only`) |
|
|
86
|
+
|
|
87
|
+
### Weights
|
|
88
|
+
- **400 Regular**: Body, captions, descriptions.
|
|
89
|
+
- **600 SemiBold**: Titles, button labels, pricing emphasis.
|
|
90
|
+
- **700 Bold**: Headlines, hero copy, the price-with-discount stack.
|
|
91
|
+
|
|
92
|
+
### Principles
|
|
93
|
+
- **Three weights only.** Pretendard offers more; Kurly uses 400/600/700 across the entire system to keep the editorial-grocery rhythm steady.
|
|
94
|
+
- **Price typography is its own register.** Discount percentage in `Sale Red #e22d2e` 18-20px / 700, original price in `Ink 300` 13px / 400 with strikethrough, final price in `Ink 800 #222` 18-20px / 700. The triple-stack repeats on every product card.
|
|
95
|
+
- **No italics in body.** Italics appear only inside long-form magazine content (recipe stories, supplier features), never in commerce chrome.
|
|
96
|
+
- **Korean-first metrics.** Sizes are tuned for Korean glyph density; line-height runs slightly tighter (1.4-1.5x) than equivalent Latin-only systems.
|
|
97
|
+
|
|
98
|
+
## 4. Component Stylings
|
|
99
|
+
|
|
100
|
+
### Buttons
|
|
101
|
+
|
|
102
|
+
**Primary (Kurly Purple)**
|
|
103
|
+
- Background: `#5f0080`
|
|
104
|
+
- Text: `#ffffff`
|
|
105
|
+
- Radius: 6px
|
|
106
|
+
- Padding: 16px 24px (lg), 12px 20px (md), 8px 16px (sm)
|
|
107
|
+
- Font: 16px / 600 / Pretendard
|
|
108
|
+
- Pressed: `#672091`
|
|
109
|
+
- Disabled: `#dfe4eb` background, `#848f9a` text
|
|
110
|
+
- Use: Primary commerce CTAs (`구매하기`, `장바구니 담기`, `주문하기`)
|
|
111
|
+
|
|
112
|
+
**Secondary (Outline Purple)**
|
|
113
|
+
- Background: `#ffffff`
|
|
114
|
+
- Text: `#5f0080`
|
|
115
|
+
- Border: 1px solid `#5f0080`
|
|
116
|
+
- Radius: 6px
|
|
117
|
+
- Padding: 12px 20px
|
|
118
|
+
- Font: 14px / 600 / Pretendard
|
|
119
|
+
- Pressed: `#f5effa` background
|
|
120
|
+
- Use: Secondary actions (`바로 구매`, `옵션 변경`)
|
|
121
|
+
|
|
122
|
+
**Neutral (Cream Fill)**
|
|
123
|
+
- Background: `#f2f5f8`
|
|
124
|
+
- Text: `#222`
|
|
125
|
+
- Border: 1px solid `#dfe4eb`
|
|
126
|
+
- Radius: 6px
|
|
127
|
+
- Padding: 12px 20px
|
|
128
|
+
- Font: 14px / 600 / Pretendard
|
|
129
|
+
- Pressed: `#eceff3` background
|
|
130
|
+
- Use: Tertiary actions (`취소`, `더보기`, filter open)
|
|
131
|
+
|
|
132
|
+
**Ghost / Text Link**
|
|
133
|
+
- Background: transparent
|
|
134
|
+
- Text: `#5f0080`
|
|
135
|
+
- Radius: 0
|
|
136
|
+
- Padding: 4px 8px
|
|
137
|
+
- Font: 14px / 600 / Pretendard with right-chevron glyph
|
|
138
|
+
- Use: Inline navigation (`전체보기 >`, `더 알아보기 >`)
|
|
139
|
+
|
|
140
|
+
**Critical (Sale / Destructive)**
|
|
141
|
+
- Background: `#e22d2e`
|
|
142
|
+
- Text: `#ffffff`
|
|
143
|
+
- Radius: 6px
|
|
144
|
+
- Padding: 12px 20px
|
|
145
|
+
- Font: 14px / 600 / Pretendard
|
|
146
|
+
- Pressed: `#d81b1c`
|
|
147
|
+
- Use: Last-chance sale CTAs, destructive confirms (`삭제`)
|
|
148
|
+
|
|
149
|
+
### Inputs
|
|
150
|
+
|
|
151
|
+
**Default**
|
|
152
|
+
- Background: `#ffffff`
|
|
153
|
+
- Border: 1px solid `#dfe4eb`
|
|
154
|
+
- Radius: 6px
|
|
155
|
+
- Padding: 12px 16px
|
|
156
|
+
- Font: 16px / 400 / Pretendard, text `#222`
|
|
157
|
+
- Placeholder: `#848f9a`
|
|
158
|
+
- Focus: 1px solid `#5f0080` (no glow ring -- editorial restraint)
|
|
159
|
+
- Disabled: `#f2f5f8` background, `#a7b2bc` text
|
|
160
|
+
- Use: Standard text fields (login, address, search-modal)
|
|
161
|
+
|
|
162
|
+
**Search Bar (Header)**
|
|
163
|
+
- Background: `#f2f5f8`
|
|
164
|
+
- Border: none
|
|
165
|
+
- Radius: 6px
|
|
166
|
+
- Padding: 10px 16px (left), 10px 44px (right -- search icon slot)
|
|
167
|
+
- Font: 14px / 400 / Pretendard
|
|
168
|
+
- Placeholder: `검색어를 입력해주세요` in `#848f9a`
|
|
169
|
+
- Active: focus underline `#5f0080` 1px on bottom edge
|
|
170
|
+
- Use: Persistent top-of-page search
|
|
171
|
+
|
|
172
|
+
**Quantity Stepper**
|
|
173
|
+
- Background: `#ffffff`
|
|
174
|
+
- Border: 1px solid `#dfe4eb`
|
|
175
|
+
- Radius: 4px
|
|
176
|
+
- Height: 36px, width 96px (3 segments: − / count / +)
|
|
177
|
+
- Font: 14px / 600 center segment
|
|
178
|
+
- Use: Cart and product page quantity selection
|
|
179
|
+
|
|
180
|
+
### Cards
|
|
181
|
+
|
|
182
|
+
**Product Card (Grid)**
|
|
183
|
+
- Background: `#ffffff`
|
|
184
|
+
- Border: none (separated by 16px gap on cream `#f2f5f8` page or 16px gap on white)
|
|
185
|
+
- Radius: 4px on image (top), 0 on text block
|
|
186
|
+
- Padding: 0 (image bleeds), 12px 4px (text block)
|
|
187
|
+
- Shadow: none in default state, `0px 0px 4px rgba(0,0,0,0.15)` on hover (KPDS shadow-2)
|
|
188
|
+
- Image: 1:1 aspect ratio, lazy-loaded WebP
|
|
189
|
+
- Title: 14px / 400 / `#222`, max 2 lines with ellipsis
|
|
190
|
+
- Brand line: 12px / 400 / `#848f9a`, max 1 line
|
|
191
|
+
- Price stack: discount % `#e22d2e` 16px / 700 + final price `#222` 16px / 700 + original price `#a7b2bc` 13px / 400 strikethrough
|
|
192
|
+
- Badges: `샛별배송` purple chip top-left of image area
|
|
193
|
+
- Use: Category list, search results, recommendation rails
|
|
194
|
+
|
|
195
|
+
**Editorial Banner Card**
|
|
196
|
+
- Background: `#ffffff` or photographic full-bleed
|
|
197
|
+
- Radius: 8px
|
|
198
|
+
- Padding: 24px when copy is overlaid on white panel; 0 when full-bleed photo with caption below
|
|
199
|
+
- Shadow: none (banners earn weight from photography, not chrome)
|
|
200
|
+
- Use: Magazine-style storytelling tiles (`Kurly's Pick`, `오늘의 레시피`)
|
|
201
|
+
|
|
202
|
+
**Modal / Dialog**
|
|
203
|
+
- Background: `#ffffff`
|
|
204
|
+
- Radius: 12px
|
|
205
|
+
- Padding: 24px
|
|
206
|
+
- Shadow: `0px 0px 30px rgba(0,0,0,0.25)` (KPDS shadow-elevated)
|
|
207
|
+
- Max-width: 480px
|
|
208
|
+
- Title: 20px / 700 / `#222`, body: 14px / 400 / `#393d41`
|
|
209
|
+
- Use: Confirmation dialogs, address-edit, coupon-apply
|
|
210
|
+
|
|
211
|
+
### Badges
|
|
212
|
+
|
|
213
|
+
**샛별배송 (Dawn Delivery)**
|
|
214
|
+
- Background: `#5f0080`
|
|
215
|
+
- Text: `#ffffff`
|
|
216
|
+
- Radius: 4px
|
|
217
|
+
- Padding: 4px 8px
|
|
218
|
+
- Font: 11px / 700 / Pretendard
|
|
219
|
+
- Use: Top-left overlay on product card image; signals dawn-delivery eligibility
|
|
220
|
+
|
|
221
|
+
**Kurly Only**
|
|
222
|
+
- Background: `#ffffff`
|
|
223
|
+
- Text: `#5f0080`
|
|
224
|
+
- Border: 1px solid `#5f0080`
|
|
225
|
+
- Radius: 4px
|
|
226
|
+
- Padding: 4px 8px
|
|
227
|
+
- Font: 11px / 700
|
|
228
|
+
- Use: Exclusive-to-Kurly product indicator
|
|
229
|
+
|
|
230
|
+
**Sale (Discount)**
|
|
231
|
+
- Background: `#e22d2e`
|
|
232
|
+
- Text: `#ffffff`
|
|
233
|
+
- Radius: 4px
|
|
234
|
+
- Padding: 4px 6px
|
|
235
|
+
- Font: 11px / 700
|
|
236
|
+
- Use: Time-bound discount overlays on hero rails
|
|
237
|
+
|
|
238
|
+
**Soldout**
|
|
239
|
+
- Background: rgba(0,0,0,0.5) full-image overlay
|
|
240
|
+
- Text: `#ffffff` 14px / 700 centered (`일시품절`)
|
|
241
|
+
- Radius: matches parent card image radius
|
|
242
|
+
- Use: Out-of-stock product card state
|
|
243
|
+
|
|
244
|
+
**Neutral Tag**
|
|
245
|
+
- Background: `#f2f5f8`
|
|
246
|
+
- Text: `#393d41`
|
|
247
|
+
- Radius: 4px
|
|
248
|
+
- Padding: 4px 8px
|
|
249
|
+
- Font: 12px / 400
|
|
250
|
+
- Use: Category chips, filter chips (inactive)
|
|
251
|
+
|
|
252
|
+
**Filter Chip — Selected**
|
|
253
|
+
- Background: `#5f0080`
|
|
254
|
+
- Text: `#ffffff`
|
|
255
|
+
- Radius: 4px
|
|
256
|
+
- Padding: 4px 8px
|
|
257
|
+
- Font: 12px / 600
|
|
258
|
+
- Use: Active filter selection in category browse
|
|
259
|
+
|
|
260
|
+
### Navigation
|
|
261
|
+
- **Top GNB**: White background, 80px height on desktop, 56px on mobile. Wordmark in Kurly Purple `#5f0080`, nav links in `#222` 14px / 600. Underline-on-active in `#5f0080` 2px.
|
|
262
|
+
- **Side category drawer**: Cream `#f2f5f8` background, hover state `#eceff3`, active row `#f5effa` with `#5f0080` left bar 3px.
|
|
263
|
+
- **Bottom tab (mobile app surface)**: White background with hairline top border `#eceff3`. Active tab icon + label `#5f0080`, inactive `#848f9a`.
|
|
264
|
+
|
|
265
|
+
## 5. Layout Principles
|
|
266
|
+
|
|
267
|
+
### Spacing System
|
|
268
|
+
- Base unit: 4px
|
|
269
|
+
- Scale: 2px, 4px, 6px, 8px, 10px, 12px, 16px, 24px, 32px, 40px, 48px, 64px, 80px, 96px, 160px (KPDS spacing tokens)
|
|
270
|
+
- Page horizontal gutter: 16px (mobile), 24px (tablet), 40px (desktop)
|
|
271
|
+
- Section vertical rhythm: 64px between major content sections, 32px between sub-sections
|
|
272
|
+
|
|
273
|
+
### Grid & Container
|
|
274
|
+
- Mobile: 2-column product grid, 8px gap
|
|
275
|
+
- Tablet: 3-column product grid, 12px gap
|
|
276
|
+
- Desktop: 4-column product grid, 16px gap, 1050px content max-width centered with editorial whitespace flanking
|
|
277
|
+
- Header GNB: full-bleed white, 1050px content cluster centered
|
|
278
|
+
|
|
279
|
+
### Whitespace Philosophy
|
|
280
|
+
- **Photography-forward, chrome-light.** Product images are the heroes; cards have no borders, hairlines stay quiet, shadows appear only on hover.
|
|
281
|
+
- **Cream rests, white acts.** Page bands alternate `#f2f5f8` (rest sections, footers) and `#ffffff` (active product grids) so the eye gets pause between commerce density.
|
|
282
|
+
- **Generous gutters in marketing, tight grids in commerce.** A `Kurly's Pick` editorial banner breathes at 64-96px vertical; a category grid tightens to 16-24px.
|
|
283
|
+
|
|
284
|
+
### Border Radius Scale
|
|
285
|
+
- Small (4px): Product card image, badges, chips, filter pills, search bar
|
|
286
|
+
- Medium (6px): Buttons, inputs, quantity stepper
|
|
287
|
+
- Large (8px): Editorial banners, content tiles
|
|
288
|
+
- XL (12px): Modals, sheets, large feature cards
|
|
289
|
+
|
|
290
|
+
## 6. Depth & Elevation
|
|
291
|
+
|
|
292
|
+
| Level | Treatment | Use |
|
|
293
|
+
|-------|-----------|-----|
|
|
294
|
+
| Flat (Level 0) | No shadow | Default product cards, page sections |
|
|
295
|
+
| Subtle | `0px 2px 2px 0px rgba(0,0,0,0.03)` | Sticky headers, gentle separation |
|
|
296
|
+
| Card-Hover | `0px 0px 4px 0px rgba(0,0,0,0.15)` | Product card on hover |
|
|
297
|
+
| Floating | `2px 2px 10px 0px rgba(0,0,0,0.10)` | Dropdown, popover, tooltip |
|
|
298
|
+
| Elevated | `0px 0px 30px 0px rgba(0,0,0,0.25)` | Modal dialogs, full-screen sheet entries |
|
|
299
|
+
| Overlay-Heavy | `0px 4px 10px 0px rgba(0,0,0,0.40)` | Image lightbox, full-takeover overlays |
|
|
300
|
+
|
|
301
|
+
**Shadow Philosophy.** Kurly shadows are pure black with low opacity — never purple-tinted. The brand wants the purple to feel like one warm, deliberate object on the page; tinting shadows would dilute that singular role. Default cards stay flat; elevation appears only at meaningful interaction (hover, modal entry). The system has 6 named shadows but 4 of them are reserved for floating/modal contexts — most surfaces are flat.
|
|
302
|
+
|
|
303
|
+
## 7. Do's and Don'ts
|
|
304
|
+
|
|
305
|
+
### Do
|
|
306
|
+
- Use Kurly Purple (`#5f0080`) as the singular brand mark — wordmark, primary CTA, dawn-delivery badge
|
|
307
|
+
- Pair purple with cream `#f2f5f8` and white `#ffffff` only — let photography supply the warmth
|
|
308
|
+
- Lead with photography on every product card — image takes the top 60% of the tile
|
|
309
|
+
- Stack the price triple consistently: discount % (red), final price (ink), original price (strikethrough gray)
|
|
310
|
+
- Use Pretendard at weights 400 / 600 / 700 only
|
|
311
|
+
- Rest the page on cream sections between commerce-dense white grids
|
|
312
|
+
- Reserve the bright purple `#bd76ff` for promotional sub-brand moments only (Beauty Kurly)
|
|
313
|
+
|
|
314
|
+
### Don't
|
|
315
|
+
- Don't tint shadows purple — Kurly shadows are neutral so the purple stays singular
|
|
316
|
+
- Don't use Kurly Purple for backgrounds at scale — it is for marks and CTAs, not hero fills
|
|
317
|
+
- Don't introduce a second deep brand color (no "Kurly Green," no "Kurly Navy")
|
|
318
|
+
- Don't crowd product cards with badges — at most 2 badges visible per card (`샛별배송` + one)
|
|
319
|
+
- Don't use italics in commerce chrome — italics belong only to long-form editorial copy
|
|
320
|
+
- Don't borrow Coupang/SSG visual cues (heavy red, dense ribbons) — Kurly is editorial, not arcade
|
|
321
|
+
- Don't use pure black `#000` for text — `#222` (ink-800) keeps the page from going clinical
|
|
322
|
+
|
|
323
|
+
## 8. Responsive Behavior
|
|
324
|
+
|
|
325
|
+
### Breakpoints
|
|
326
|
+
| Name | Width | Key Changes |
|
|
327
|
+
|------|-------|-------------|
|
|
328
|
+
| Mobile | <768px | 2-col product grid, 56px GNB, bottom tab bar |
|
|
329
|
+
| Tablet | 768-1024px | 3-col product grid, GNB compresses category dropdowns |
|
|
330
|
+
| Desktop | >1024px | 4-col grid, full GNB, 1050px content centered, editorial flanks |
|
|
331
|
+
|
|
332
|
+
### Touch Targets
|
|
333
|
+
- Buttons: 48px (lg), 44px (md), 36px (sm) — all comfortably above 44px AAA
|
|
334
|
+
- Tab bar items: 56px height with stacked icon + label
|
|
335
|
+
- Product card tap target: full card area (image + text block)
|
|
336
|
+
- Quantity stepper: 36px height, 32px wide segments
|
|
337
|
+
|
|
338
|
+
### Collapsing Strategy
|
|
339
|
+
- Product grid: 4 → 3 → 2 columns as viewport narrows
|
|
340
|
+
- GNB top: full menu on desktop → hamburger drawer on mobile
|
|
341
|
+
- Bottom CTA on PDP: sticky full-width on mobile, inline column on desktop
|
|
342
|
+
- Editorial banners: side-by-side on desktop → stacked single column on mobile
|
|
343
|
+
|
|
344
|
+
### Image Behavior
|
|
345
|
+
- Product thumbnail: 1:1 ratio, 4px top corner radius, WebP / JPEG fallback, lazy-loaded
|
|
346
|
+
- Hero banner: 16:9 on desktop, 4:3 on mobile
|
|
347
|
+
- Full-bleed editorial: edge-to-edge, no radius
|
|
348
|
+
|
|
349
|
+
## 9. Agent Prompt Guide
|
|
350
|
+
|
|
351
|
+
### Quick Color Reference
|
|
352
|
+
- Primary CTA: Kurly Purple (`#5f0080`)
|
|
353
|
+
- CTA Pressed: Deep Purple (`#672091`)
|
|
354
|
+
- Background: White (`#ffffff`) / Cream (`#f2f5f8`)
|
|
355
|
+
- Heading: Ink (`#222`)
|
|
356
|
+
- Body: Dark Gray (`#393d41`)
|
|
357
|
+
- Caption: Mid Gray (`#565e67`)
|
|
358
|
+
- Placeholder/Disabled: Light Gray (`#848f9a`)
|
|
359
|
+
- Border: Hairline (`#dfe4eb`)
|
|
360
|
+
- Sale Red: (`#e22d2e`)
|
|
361
|
+
- Success: (`#029568`)
|
|
362
|
+
- Bright Purple (promo): (`#bd76ff`)
|
|
363
|
+
|
|
364
|
+
### Example Component Prompts
|
|
365
|
+
- "Create a Kurly product card: white bg, no border, 1:1 image with 4px top radius. `샛별배송` purple badge top-left of image. Below image: brand line 12px #848f9a, title 14px #222 max 2 lines, price triple-stack (discount % #e22d2e 16px/700, final price #222 16px/700, original price #a7b2bc 13px/400 strikethrough). Card-hover shadow 0px 0px 4px rgba(0,0,0,0.15)."
|
|
366
|
+
- "Build a primary CTA: #5f0080 bg, white text, 16px weight 600 Pretendard, 6px radius, 16px 24px padding, full-width on mobile. Pressed: #672091. Disabled: #dfe4eb bg, #848f9a text."
|
|
367
|
+
- "Design a search bar: #f2f5f8 bg, no border, 6px radius, 14px Pretendard placeholder #848f9a. Search icon right-padding 44px slot. Focus underline #5f0080 1px on bottom edge."
|
|
368
|
+
- "Create a 샛별배송 badge: #5f0080 bg, white text 11px weight 700, 4px radius, 4px 8px padding. Place top-left over product image with 8px inset."
|
|
369
|
+
- "Build an editorial banner card: full-bleed photographic top, white panel below with 24px padding, 8px radius corners, no shadow. Title 24px/700 #222, supporting line 14px/400 #393d41, ghost CTA `더 알아보기 >` in #5f0080."
|
|
370
|
+
|
|
371
|
+
### Iteration Guide
|
|
372
|
+
1. Primary purple is `#5f0080` — only this hex for brand mark and primary CTA
|
|
373
|
+
2. Pair with white `#ffffff` and cream `#f2f5f8`; never tint hero backgrounds purple
|
|
374
|
+
3. Pretendard at 400 / 600 / 700 only — no italics in commerce chrome
|
|
375
|
+
4. Border-radius defaults: 4px (cards/badges), 6px (buttons/inputs), 8-12px (banners/modals)
|
|
376
|
+
5. Shadows are neutral black, low opacity, used only at hover and elevation
|
|
377
|
+
6. Price triple-stack is sacred: red % + ink final + gray original (strikethrough)
|
|
378
|
+
7. `샛별배송` purple badge is the brand's most repeated micro-component — recognize it as a brand moment
|
|
379
|
+
|
|
380
|
+
---
|
|
381
|
+
|
|
382
|
+
## 10. Voice & Tone
|
|
383
|
+
|
|
384
|
+
Kurly speaks like the friend who quietly knows the best butcher, the best baker, and the orchard that ships the strawberries before sunrise — confident without performing, warm without being chatty, and allergic to the gameshow shouting of mass e-commerce. The voice assumes a busy dual-income household at 10:47pm staring at an empty fridge: it does not exclaim, it does not gamify, it simply names the thing and confirms it will arrive while you sleep. Korean copy uses `-요` and `-습니다` registers fluidly — `장바구니에 담겼어요` for warmth, `주문이 완료되었습니다` for transactions — but never the playful `-야`/`-지` of younger consumer apps. English microcopy on the brand surfaces stays at the same register: *"Better Life for All"*, not *"Get groceries fast!!!"*
|
|
385
|
+
|
|
386
|
+
| Context | Tone |
|
|
387
|
+
|---|---|
|
|
388
|
+
| CTAs | Verb-first Korean (`구매하기`, `장바구니 담기`, `샛별배송으로 받기`) — never exclamatory, never `Click here!` |
|
|
389
|
+
| Empty states | One quiet sentence naming why it's empty + one low-key action. Never `데이터가 없습니다`. |
|
|
390
|
+
| Error messages | Specific and blameless. `다시 시도해 주세요` over `오류가 발생했습니다`. |
|
|
391
|
+
| Success toasts | Past-tense single sentence (`장바구니에 담겼어요`). No exclamation marks. |
|
|
392
|
+
| Product descriptions | Editorial — supplier name, region, harvest method first. Marketing claims (`최고의`, `프리미엄`) only when sourced. |
|
|
393
|
+
| Promotional banners | Restrained even in sales. `오늘만 이 가격` rather than `MEGA SALE!!!`. |
|
|
394
|
+
| Trust & delivery copy | Calm and operational. `내일 아침 7시 전 도착` is more powerful than `초고속 배송`. |
|
|
395
|
+
| Onboarding | One screen, one promise (dawn delivery), one CTA. No carousel of features. |
|
|
396
|
+
|
|
397
|
+
**Forbidden phrases.** `대박`, `미친 가격`, `초특가`, `쇼킹`, English boilerplate like `Mind-blowing deals`, `Lightning fast`, `Don't miss out`. Excessive emoji are banned in price chrome and trust copy; allowed sparingly in editorial recipe content. The voice never uses three exclamation marks; rarely uses one. `혁신적인` is banned — Kurly does not call itself innovative; it just delivers before sunrise.
|
|
398
|
+
|
|
399
|
+
**Voice samples.**
|
|
400
|
+
|
|
401
|
+
- `Better Life for All` — corporate brand promise. <!-- verified: kurly.com og:site_name + meta, 2026-05 -->
|
|
402
|
+
- `건강한 식재료부터 믿을 수 있는 뷰티, 라이프스타일 상품까지. 나와 내 가족이 사고 싶은 상품을 판매합니다.` — homepage meta description. <!-- verified: kurly.com meta description, 2026-05 -->
|
|
403
|
+
- `내일 아침 문 앞에서 만나요!` — dawn-delivery brand line, homepage meta. <!-- verified: kurly.com meta description, 2026-05 -->
|
|
404
|
+
- `샛별배송` — brand-defining badge for dawn delivery (delivered by 7am for orders by 11pm). <!-- verified: kurly.com brand surfaces, 2026-05 -->
|
|
405
|
+
- `장바구니에 담겼어요` — illustrative success-toast pattern in Kurly register. <!-- illustrative: not verified as live Kurly copy -->
|
|
406
|
+
- `오늘만 이 가격` — illustrative restrained promotion line in Kurly register. <!-- illustrative: not verified as live Kurly copy -->
|
|
407
|
+
- `내일의 장보기, 오늘 끝.` — illustrative tagline pattern in Kurly register (dawn-delivery promise). <!-- illustrative: not verified as live Kurly copy -->
|
|
408
|
+
|
|
409
|
+
## 11. Brand Narrative
|
|
410
|
+
|
|
411
|
+
Kurly (컬리, parent of 마켓컬리/Market Kurly) was founded on December 21, 2014 by **Sophie Kim (김슬아 / Kim Seul-ah)**, a Wellesley College political science graduate (2006, cum laude) who had spent her twenties at Goldman Sachs Hong Kong (2007, fixed income), McKinsey & Company (2010), Temasek Holdings (2012), and Bain & Company Korea (2013) — and who, at every stop, had been quietly frustrated that the produce in Korean grocery aisles never matched what her own family ate. The original company name was **The Farmers**; the consumer-facing service launched in 2015 with **30 SKUs**. The company rebranded to Kurly Inc. in 2018 ([Wikipedia: Sophie Kim](https://en.wikipedia.org/wiki/Sophie_Kim), [KED Global — Sophie Kim road less traveled](https://www.kedglobal.com/chief-executives/newsView/ked202201190017)).
|
|
412
|
+
|
|
413
|
+
The product is built around a single idea: **샛별배송 (saetbyeol-baesong, "morning star delivery")** — order by 11pm, your fresh groceries arrive by 7am the next morning, full cold chain maintained from farm to apartment door. This was unprecedented in Korea when Kurly launched it; the entire e-grocery industry has since copied the model. Around that operational spine sits a deliberately editorial commerce surface: 1:1 product photography, magazine-style supplier features, restrained chrome, and one deep purple (`#5f0080`) repeated just often enough to brand the promise. The visual decision tracks the founder's positioning bet — Korean grocery shoppers (especially dual-income working couples in Seoul/Pangyo/Gangnam) would pay a premium *if* the product, the photography, and the trust narrative all signaled "curated." So everything signals curated, including the type-on-cream restraint and the absence of promotional carnival ([KED Global — dawn delivery pioneer](https://www.kedglobal.com/e-commerce/newsView/ked202412200010), [Marketline — Kurly pioneering dawn delivery](https://www.marketline.com/blog/kurly-pioneering-dawn-delivery-service-market-in-south-korea/)).
|
|
414
|
+
|
|
415
|
+
The financial trajectory mirrors the visual one — quiet, then loud. Series A (2015), Series B (2017), then a string of high-conviction global rounds: **DST Global**, **Sequoia Capital China**, **Hillhouse**, **Aspex Management**, **Anchor Equity Partners**, plus strategic investors **CJ Logistics** and **SK Networks**. December 2021 pre-IPO closed at **$210M on a $3.3B valuation**, total funding around **$761M**. Kurly passed Korea Exchange preliminary IPO screening in **August 2022**, then **postponed the listing in January 2023** as global tech valuations cratered; a smaller pre-IPO round in **May 2023** repriced the company at roughly **2.5 trillion KRW**. The company has been re-targeting a KOSPI listing since early 2024 and posted its **first quarterly profit in Q1 2025**, reframing the IPO conversation around sustained profitability rather than growth-at-all-costs ([TechCrunch — IPO scrapped](https://techcrunch.com/2023/01/04/online-grocery-startup-kurly-scraps-ipo-amid-market-uncertainty/), [Korea Herald — Kurly opts for Korean market](https://www.koreaherald.com/article/2650215), [KED Global — first quarterly profit](https://www.kedglobal.com/earnings/newsView/ked202505130004)).
|
|
416
|
+
|
|
417
|
+
What Kurly refuses: the gameshow ribbons of Coupang, the SuperSale carnival of 11st, the celebrity-endorsement pile-on of legacy home shopping, and the aggressive "타임딜" countdown psychology of generic Korean e-commerce. The brand's entire claim is that **time-pressed working professionals would rather have one curated thing tomorrow at 7am than ten cheap things this afternoon** — and the design system is the visible argument for that bet. Purple is scarce because trust has to be scarce to be legible; photography is generous because the product is the brand; chrome is quiet because the product is loud enough.
|
|
418
|
+
|
|
419
|
+
## 12. Principles
|
|
420
|
+
|
|
421
|
+
1. **Purple is scarce, on purpose.** `#5f0080` appears on the wordmark, primary CTA, `샛별배송` badge, and active states — and almost nowhere else. *UI implication:* at most one purple element per viewport in primary commerce flow; multiple purple CTAs competing on one screen must demote one to neutral or outline.
|
|
422
|
+
2. **Photography is the brand voice.** The product image carries 60% of every card; type is secondary. *UI implication:* never let chrome (badges, ribbons, gradients) cover more than 15% of the product image area. If a design fights the photography, the design is wrong.
|
|
423
|
+
3. **Cream rests, white acts.** Page sections alternate `#f2f5f8` (rest, footer, editorial breathers) and `#ffffff` (active product grids). *UI implication:* don't run three commerce-dense white sections in a row without a cream rest band; the eye fatigues.
|
|
424
|
+
4. **The price triple-stack is a brand moment.** Discount % (red) + final (ink) + original (gray strikethrough) is repeated identically on every card, every PDP, every cart row. *UI implication:* never break the order or weights — even when only two of three are present, preserve their slots.
|
|
425
|
+
5. **Pretendard, three weights, no italics.** 400 / 600 / 700 across the entire system. *UI implication:* if a comp introduces a fourth weight or italic body copy, it has drifted off-system; reject or re-scope.
|
|
426
|
+
6. **`샛별배송` is sacred chrome.** The dawn-delivery badge is the most-repeated brand component on the surface — it carries the operational promise that justifies the premium. *UI implication:* never restyle it for "balance"; it is intentionally the most purple thing on the card.
|
|
427
|
+
7. **Restraint over carnival in promotion.** Sale messaging is bounded — `오늘만 이 가격` rather than countdown timers and screen-shake animations. *UI implication:* no flashing, no screen-fill takeovers, no exclamation chains. If a promo design borrows Coupang's energy, it has betrayed the brand.
|
|
428
|
+
8. **One operational promise, surfaced everywhere.** Every page, every flow, every empty state can answer: *will it be there by 7am?* — yes, no, or by-when. *UI implication:* delivery context is a default, not a detail-screen reveal. Cards, cart, checkout, confirmation all surface the dawn-delivery slot.
|
|
429
|
+
|
|
430
|
+
## 13. Personas
|
|
431
|
+
|
|
432
|
+
*Personas are fictional archetypes informed by publicly described Kurly customer segments (Korean dual-income working professionals, time-pressed parents, premium-grocery early adopters), not individual people.*
|
|
433
|
+
|
|
434
|
+
**서연 (Seoyeon), 34, 강남구.** Marketing director at a Korean conglomerate, husband works in finance, one toddler in daycare. Opens Kurly between 10:30pm and 11:00pm three nights a week — past the cutoff and the morning is broken. Buys organic eggs, French butter, the Sunday roast, the pediatrician-recommended baby food. Doesn't comparison-shop on price; comparison-shops on supplier and harvest date. Will pay 30% premium for the right strawberries.
|
|
435
|
+
|
|
436
|
+
**민준 (Minjun), 39, 판교.** Senior software engineer, wife runs a design studio, two elementary-age kids. Treats Kurly as the "weekday dinner solution" — meal kits, pre-marinated proteins, salad bases. Reads the supplier story on every product at least once. Has zero patience for the marketing language of legacy home shopping; the editorial restraint is exactly why he stayed after a one-week trial in 2019.
|
|
437
|
+
|
|
438
|
+
**지은 (Jieun), 28, 마포구.** Single, works in tech PR, lives alone, cooks for one. Discovered Kurly through Beauty Kurly first — Korean K-beauty editorial commerce — then converted to grocery. Buys small portions, premium snacks, niche imported pantry items (Italian anchovies, Japanese soy sauce, French chocolate). The dawn-delivery promise matters less than the curation: she trusts the merchandiser more than she trusts herself.
|
|
439
|
+
|
|
440
|
+
**Mr. & Mrs. Choi, 61, 잠실.** Empty-nesters, both retired professionals. Daughter set up the account during COVID; they kept using it because the produce quality is consistent and the customer-service tone is calm. Order weekly, primarily fresh fish, hanwoo beef, premium fruit boxes for grandchildren visits. Don't engage with promotions — engage with reliability.
|
|
441
|
+
|
|
442
|
+
## 14. States
|
|
443
|
+
|
|
444
|
+
| State | Treatment |
|
|
445
|
+
|---|---|
|
|
446
|
+
| **Empty (cart)** | Single quiet line (`장바구니가 비어있어요`) + one secondary outline-purple CTA (`상품 보러 가기`). Never an illustration. Never `데이터가 없습니다`. |
|
|
447
|
+
| **Empty (search no results)** | One line in `#565e67` 14px (`검색 결과가 없어요`). Single sub-line suggesting alternative searches. No button — user retypes themselves. |
|
|
448
|
+
| **Empty (filter cleared)** | One line of caption text. No button. The user resets the filter. |
|
|
449
|
+
| **Loading (product grid first paint)** | Skeleton blocks at `#f2f5f8` matching the final card layout — 1:1 thumbnail, 12px brand line, 14px title (2 lines), price stack. Subtle shimmer at 1.2s with 4% white highlight. |
|
|
450
|
+
| **Loading (PDP image)** | Cream `#f2f5f8` placeholder block with center-loading 24px purple `#5f0080` spinner. Maintains 1:1 aspect ratio so layout doesn't reflow. |
|
|
451
|
+
| **Loading (CTA in-flight)** | Button text replaced with 16px white spinner; button background stays `#5f0080`. No disabled state. |
|
|
452
|
+
| **Error (inline field)** | Input border becomes `#e22d2e` 1px, helper text below in `#e22d2e` 12px / 400. One actionable sentence (`주소를 다시 확인해 주세요`). |
|
|
453
|
+
| **Error (toast)** | `#222` background, `#ffffff` 14px / 400 text, 3s auto-dismiss. Bottom-of-screen with 24px inset above bottom tab. One sentence. No icon. |
|
|
454
|
+
| **Error (network)** | Full-screen centered message in `#222` 18px / 700, `#393d41` 14px / 400 sub-line, retry button in Kurly Purple. No illustration. |
|
|
455
|
+
| **Success (cart add)** | Inline 300ms flash of `#f5effa` (purple-50) behind the updated cart icon, then a bottom toast `장바구니에 담겼어요` for 2.5s. |
|
|
456
|
+
| **Success (order complete)** | Dedicated confirmation page — not a toast. Order number, dawn-delivery slot (`내일 새벽 도착 예정`), and a single primary CTA `주문 상세 보기`. Quiet, not celebratory. |
|
|
457
|
+
| **Skeleton** | `#f2f5f8` blocks at exact final dimensions matching the product card layout. Shimmer 1.2s. Brand-line and price slots stay blank until resolved — never imply a price that hasn't loaded. |
|
|
458
|
+
| **Soldout** | Full-image overlay `rgba(0,0,0,0.5)` with white `일시품절` 14px / 700 centered. Card stays clickable for re-stock notification opt-in. |
|
|
459
|
+
| **Disabled** | Button background `#dfe4eb`, text `#848f9a`. No color inversion. Geometry stays identical so re-enable is frame-stable. |
|
|
460
|
+
|
|
461
|
+
## 15. Motion & Easing
|
|
462
|
+
|
|
463
|
+
**Durations** (named, not raw milliseconds):
|
|
464
|
+
|
|
465
|
+
| Token | Value | Use |
|
|
466
|
+
|---|---|---|
|
|
467
|
+
| `motion-instant` | 0ms | Toggle flips, checkbox state, filter chip select |
|
|
468
|
+
| `motion-fast` | 150ms | Hover lift, button press, inline cart-flash success |
|
|
469
|
+
| `motion-standard` | 250ms | The default — card hover-shadow appearance, dropdown reveal, tab swap |
|
|
470
|
+
| `motion-slow` | 350ms | Modal entry, full-sheet presentation, image lightbox |
|
|
471
|
+
| `motion-page` | 300ms | Route transitions on PDP entry/exit |
|
|
472
|
+
|
|
473
|
+
**Easings:**
|
|
474
|
+
|
|
475
|
+
| Token | Curve | Use |
|
|
476
|
+
|---|---|---|
|
|
477
|
+
| `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Sheets, modals, toasts, cards-on-hover |
|
|
478
|
+
| `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals, modal close, toast auto-fade |
|
|
479
|
+
| `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — expandable accordion, tab content swap |
|
|
480
|
+
|
|
481
|
+
**Spring stance.** Spring and overshoot easings are forbidden across Kurly commerce surfaces. The brand sells trust and dawn-delivery reliability to time-pressed professionals; bouncy motion reads as toy-like and undermines the editorial restraint that justifies the premium price point. The licensed exceptions are (a) the native-platform pull-to-refresh on the mobile app (inherits OS spring) and (b) image carousel snap on PDP galleries (inherits browser-native scroll-snap). Every other transition uses `ease-enter`, `ease-exit`, or `ease-standard`.
|
|
482
|
+
|
|
483
|
+
**Signature motions.**
|
|
484
|
+
|
|
485
|
+
1. **Product card hover-lift.** On desktop hover, card raises with shadow `0px 0px 4px rgba(0,0,0,0.15)` over `motion-fast / ease-enter`. No scale change — the photography stays exactly the same size; only the shadow appears. The restraint is the brand.
|
|
486
|
+
2. **Cart-add flash.** When a product is added, the cart icon's background pulses to `#f5effa` (purple-50) over `motion-fast`, then fades back to default. A bottom toast (`장바구니에 담겼어요`) rises with `motion-standard / ease-enter` and dismisses with `motion-fast / ease-exit`.
|
|
487
|
+
3. **Modal entry.** Modals fade in (opacity 0 → 1) and rise from `y+16px` to `y+0` over `motion-slow / ease-enter`. Backdrop fades from `rgba(0,0,0,0)` to `rgba(0,0,0,0.5)` synchronized. Dismissal is lighter — `motion-fast / ease-exit`.
|
|
488
|
+
4. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. Hover lift becomes immediate shadow toggle; modal cross-fades replace y-rise; cart flash becomes a 1-frame highlight then default. The app stays fully usable; just less kinetic.
|
|
489
|
+
|
|
490
|
+
<!--
|
|
491
|
+
OmD v0.1 Sources — Kurly DESIGN.md
|
|
492
|
+
|
|
493
|
+
Tier 1 — Direct verification (2026-05-08):
|
|
494
|
+
- https://www.kurly.com/main — homepage shell HTML + compiled KPDS CSS
|
|
495
|
+
(https://res.kurly.com/v/2026.05.06.01/_next/static/css/51aa1e65e91a39af.css).
|
|
496
|
+
Confirms: --kpds_ldmw172m: #5f0080 (Kurly Purple primary), full purple ramp
|
|
497
|
+
(#672091, #7e3ab0, #8d4cc4, #9a60ca, #a775d2, #b489d8, #c19edf, #ceb2e6,
|
|
498
|
+
#dcc7ed, #e8dbf3, #f5effa), bright purple promotional ramp (#bd76ff anchor),
|
|
499
|
+
neutral gray scale (#1c1c1c → #222 → #393d41 → #464c52 → #565e67 → #848f9a
|
|
500
|
+
→ #a7b2bc → #bcc4cc → #cbd1d7 → #dfe4eb → #eceff3 → #f2f5f8), semantic colors
|
|
501
|
+
(#e22d2e sale red, #fa622f coral, #029568 success, #216ba5 info), shadow tokens
|
|
502
|
+
(0px 2px 2px rgba(0,0,0,0.03), 0px 0px 4px rgba(0,0,0,0.15),
|
|
503
|
+
2px 2px 10px rgba(0,0,0,0.10), 0px 0px 30px rgba(0,0,0,0.25),
|
|
504
|
+
0px 4px 10px rgba(0,0,0,0.40)), font stack
|
|
505
|
+
Pretendard / Pretendard Variable / system fallback.
|
|
506
|
+
- https://www.kurly.com/main — meta description + og tags. Confirms:
|
|
507
|
+
"Better Life for All", "건강한 식재료부터 믿을 수 있는 뷰티, 라이프스타일 상품까지.
|
|
508
|
+
나와 내 가족이 사고 싶은 상품을 판매합니다. 내일 아침 문 앞에서 만나요!",
|
|
509
|
+
Organization name "Kurly", customer support phone +82-1644-1107.
|
|
510
|
+
|
|
511
|
+
Tier 2 — Cross-check:
|
|
512
|
+
- https://getdesign.md/kurly — no record (queried 2026-05-08, "No designs found").
|
|
513
|
+
- styles.refero.design — not separately queried (no record observed in Tier 1
|
|
514
|
+
links; future migration sweep should verify).
|
|
515
|
+
|
|
516
|
+
Tier 2 (Philosophy / founders):
|
|
517
|
+
- https://en.wikipedia.org/wiki/Sophie_Kim — confirms Sophie Kim (Kim Seul-ah,
|
|
518
|
+
김슬아), b. 1983 Ulsan, Wellesley 2006 cum laude, Goldman Sachs HK 2007,
|
|
519
|
+
McKinsey 2010, Temasek 2012, Bain Korea 2013, founded The Farmers 2014,
|
|
520
|
+
Market Kurly launch 2015 with 30 SKUs, rebrand to Kurly Inc. 2018.
|
|
521
|
+
- https://www.kedglobal.com/chief-executives/newsView/ked202201190017 —
|
|
522
|
+
Kurly CEO Sophie Kim profile, founder background, premium positioning.
|
|
523
|
+
- https://www.kedglobal.com/e-commerce/newsView/ked202412200010 —
|
|
524
|
+
S.Korea's dawn delivery pioneer Kurly, luxury goods strategy.
|
|
525
|
+
- https://www.marketline.com/blog/kurly-pioneering-dawn-delivery-service-market-in-south-korea/
|
|
526
|
+
— dawn delivery pioneer framing, 새벽배송 origin.
|
|
527
|
+
- https://techcrunch.com/2023/01/04/online-grocery-startup-kurly-scraps-ipo-amid-market-uncertainty/
|
|
528
|
+
— January 2023 IPO postponement; KOSPI preliminary screening passed Aug 2022.
|
|
529
|
+
- https://techcrunch.com/2021/12/19/kurly-lands-210m-pre-ipo-at-a-3-3b-valuation-just-months-after-its-last-funding/
|
|
530
|
+
— Dec 2021 pre-IPO $210M at $3.3B valuation, total $761M.
|
|
531
|
+
- https://www.koreaherald.com/article/2650215 — Kurly opts for Korean market
|
|
532
|
+
for IPO (KOSPI rather than NYSE).
|
|
533
|
+
- https://www.kedglobal.com/earnings/newsView/ked202505130004 —
|
|
534
|
+
first-ever quarterly profit Q1 2025.
|
|
535
|
+
- Investor list (DST Global, Sequoia Capital China, Hillhouse, Aspex,
|
|
536
|
+
Anchor Equity Partners, MiraeAsset, CJ Logistics, SK Networks) —
|
|
537
|
+
Crunchbase + KED Global + TechCrunch, cross-referenced.
|
|
538
|
+
|
|
539
|
+
Re-verification status:
|
|
540
|
+
- Kurly Purple #5f0080 verified directly from compiled KPDS CSS variable
|
|
541
|
+
--kpds_ldmw172m, May 2026. The brand has shipped this hex consistently
|
|
542
|
+
since at least the 2018 Kurly Inc. rebrand.
|
|
543
|
+
- Sophie Kim career timeline: widely reported in KR/EN press; Wikipedia
|
|
544
|
+
reflects published profile interviews, not independently audited.
|
|
545
|
+
- Investor and valuation figures: TechCrunch/KED Global at retrieval date.
|
|
546
|
+
Pre-IPO repricings have been frequent; verify before publishing as live.
|
|
547
|
+
- Q1 2025 first-ever quarterly profit: KED Global May 2025; subsequent
|
|
548
|
+
quarters not re-checked.
|
|
549
|
+
|
|
550
|
+
Personas (§13) are fictional archetypes informed by publicly described Kurly
|
|
551
|
+
customer segments (KR dual-income working professionals, time-pressed parents,
|
|
552
|
+
premium-grocery early adopters). Any resemblance to specific individuals is
|
|
553
|
+
unintended.
|
|
554
|
+
|
|
555
|
+
Interpretive claims (editorial, not documented Kurly statements):
|
|
556
|
+
- "Photography is the brand voice" / "purple is scarce because trust has to
|
|
557
|
+
be scarce to be legible" (§11, §12) — editorial readings of observed design
|
|
558
|
+
decisions, not sourced brand-team statements.
|
|
559
|
+
- The spring-forbidden stance (§15) — derived from the overall brand posture
|
|
560
|
+
(editorial restraint, premium curation, refusal of carnival promotion) as
|
|
561
|
+
expressed in the live KPDS shadow tokens and the absence of overshoot
|
|
562
|
+
easings in compiled CSS; not a documented KPDS rule.
|
|
563
|
+
- "내일의 장보기, 오늘 끝." voice sample (§10) — illustrative pattern in
|
|
564
|
+
Kurly register, not a verified live tagline.
|
|
565
|
+
-->
|
|
566
|
+
|
|
567
|
+
---
|
|
568
|
+
|
|
569
|
+
**Verified:** 2026-05-08 (Tier 1 live + Tier 2 cross-check)
|
|
570
|
+
**Tier 1 sources:** kurly.com/main (homepage Next.js shell + KPDS compiled CSS at res.kurly.com — Kurly Purple `#5f0080` 6px / 16px·600 Primary CTA + cream `#f2f5f8` neutral fill + Pretendard product font); kurly.com/shopping/categories/list (category surface — same Next.js shell, 4-col product grid pattern + 샛별배송 purple badge convention).
|
|
571
|
+
**Tier 2 sources:** getdesign.md/kurly — no record. styles.refero.design — not separately queried.
|
|
572
|
+
**Tier 2 (Philosophy/founders):** Wikipedia (Sophie Kim), KED Global (CEO profile, dawn delivery, Q1 2025 first profit), Marketline (dawn delivery pioneer framing), TechCrunch (2021 pre-IPO $210M @ $3.3B, 2023 IPO postponement), Korea Herald (KOSPI listing path).
|
|
573
|
+
**Style ref:** `karrot` (KR retail neighbor format, retained for §10-15 cadence).
|
|
574
|
+
**Conflicts unresolved:** none.
|