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,582 @@
|
|
|
1
|
+
---
|
|
2
|
+
omd: 0.1
|
|
3
|
+
brand: Ably (에이블리)
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Design System Inspiration of Ably (에이블리)
|
|
7
|
+
|
|
8
|
+
## 1. Visual Theme & Atmosphere
|
|
9
|
+
|
|
10
|
+
Ably (에이블리) is Korea's MZ-generation style commerce platform — a mobile-native shopping app run by Ably Corporation (에이블리코퍼레이션, founded 2018 by Kang Suk-hoon / 강석훈). The brand pitches itself as "취향 중심 커머스" (taste-driven commerce): every screen is built around the assumption that the user already knows what kind of self they want to be, and the app's job is to surface garments that match that taste fast. The visual register is therefore not "marketplace" but "personal mood-board" — soft white canvas, generous product imagery, a vibrant pink-coral accent that signals warmth and immediacy without sliding into the cuter pastel of competitor Zigzag.
|
|
11
|
+
|
|
12
|
+
The product is structurally mobile-first: typing `www.a-bly.com` redirects to `m.a-bly.com`, and there is no desktop-grade web checkout. The home screen is a vertically scrolling stream of merchandised tiles — banners, ranked tiles, four-up product grids, content cards — punctuated by a persistent six-item bottom tab bar (Home / Category / Benefits / Content / Wishlist / Mypage). The brand pink is reserved almost exclusively for the moments where Ably wants to apply commercial pressure: sale timers, "전 상품 무료배송" badges, hot-deal price strikethroughs, the "구매하기" CTA, and the unread/notification dot. Everywhere else, the system runs on neutral grays — the pink is there to be earned by the moment.
|
|
13
|
+
|
|
14
|
+
Typography on Korean mobile commerce is functionally settled: Pretendard (open-source, OFL) is the de facto Hangul-Latin sans for the category, with system fallbacks to Apple SD Gothic Neo / Noto Sans KR. Ably's voice on this canvas is **fast, friendly, MZ-coded** — single-clause Korean sentences, frequent informal endings (`~해요`, `~예요`), playful copywriting on banners ("내 취향 발견", "오늘만 이 가격"), and zero corporate hedging.
|
|
15
|
+
|
|
16
|
+
**Key Characteristics:**
|
|
17
|
+
- Vibrant pink-coral primary (~`#FA2E5F` / `#FF2D55` family) reserved for commercial pressure — never decorative
|
|
18
|
+
- Mobile-first: 375–414px design baseline, no desktop checkout
|
|
19
|
+
- Pretendard typeface stack with Apple SD Gothic Neo / Noto Sans KR fallbacks
|
|
20
|
+
- Four-product grid as the home unit — large imagery, minimal chrome between cards
|
|
21
|
+
- Persistent 6-item bottom tab bar (Home / Category / Benefits / Content / Wishlist / Mypage)
|
|
22
|
+
- Sale timers and "전 상품 무료배송" badges as recurring conversion lexicon
|
|
23
|
+
- Generous pure white (`#FFFFFF`) canvas — chrome stays out of the way of product photos
|
|
24
|
+
- Pill-shaped chips (filter, category, tag) over rectangular tags — communicates "soft commerce"
|
|
25
|
+
|
|
26
|
+
## 2. Color Palette & Roles
|
|
27
|
+
|
|
28
|
+
### Primary
|
|
29
|
+
- **Ably Pink** (`#FA2E5F` — see footer note on verification): Primary brand color. Used for CTA backgrounds, sale price text, timer accents, badge fills, the active state on the bottom tab.
|
|
30
|
+
- **Pure White** (`#FFFFFF`): Page background, card surfaces, default chrome.
|
|
31
|
+
- **Near Black** (`#222222`): Primary text — product names, screen titles, body. Slightly warm vs pure black.
|
|
32
|
+
|
|
33
|
+
### Commerce Accent
|
|
34
|
+
- **Hot Deal Pink** (`#FF2D55`): Stronger pink used on time-limited "쇼킹딜" / sale-timer surfaces — close to primary but reserved for urgency-coded moments.
|
|
35
|
+
- **Discount Red** (`#F0124B`): Percentage discount labels (`30%`), strike-out comparison.
|
|
36
|
+
- **Free Shipping Mint** (`#00C8B4`): Used in some marketing badges to set the free-shipping promise apart from the pink urgency layer (treated as accent — sparingly applied).
|
|
37
|
+
|
|
38
|
+
### Neutral Scale
|
|
39
|
+
- **Text Primary** (`#222222`): Product names, headings, screen titles.
|
|
40
|
+
- **Text Body** (`#333333`): Body copy, list items.
|
|
41
|
+
- **Text Secondary** (`#666666`): Secondary metadata, seller name, meta info under product.
|
|
42
|
+
- **Text Muted** (`#999999`): Caption text, timestamps, placeholder hints.
|
|
43
|
+
- **Text Lightest** (`#BBBBBB`): Disabled text, divider labels.
|
|
44
|
+
|
|
45
|
+
### Surface & Borders
|
|
46
|
+
- **Surface Page** (`#FFFFFF`): Default page background.
|
|
47
|
+
- **Surface Fill** (`#F5F5F5`): Search bar fill, secondary surfaces, skeletons base.
|
|
48
|
+
- **Surface Subtle** (`#FAFAFA`): Card hover / pressed states, table-row banding.
|
|
49
|
+
- **Border Default** (`#EEEEEE`): Card dividers, list-row separators.
|
|
50
|
+
- **Border Subtle** (`#F0F0F0`): Faintest separators, chip outlines.
|
|
51
|
+
|
|
52
|
+
### Semantic
|
|
53
|
+
- **Sale / Urgency** (`#FA2E5F`): Reuses the brand pink — by design Ably collapses "sale" and "brand" into one signal.
|
|
54
|
+
- **Success** (`#00C896`): Order-complete confirmations, review-submitted toasts.
|
|
55
|
+
- **Error** (`#F0124B`): Form errors, payment failure (also reads as "discount red" in context).
|
|
56
|
+
- **Info Link** (`#2680EB`): External links in policy / FAQ surfaces only; suppressed in commerce flows.
|
|
57
|
+
|
|
58
|
+
### Overlays
|
|
59
|
+
- **Modal Backdrop** (`rgba(0, 0, 0, 0.5)`): Bottom sheets and dialogs.
|
|
60
|
+
- **Image Tint Hot** (`linear-gradient(180deg, rgba(255,0,80,0) 0%, rgba(255,0,80,0.6) 100%)`): Used over deal-image bottom strips so price text stays legible.
|
|
61
|
+
|
|
62
|
+
## 3. Typography Rules
|
|
63
|
+
|
|
64
|
+
### Font Family
|
|
65
|
+
- **Primary**: `Pretendard, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", system-ui, sans-serif`
|
|
66
|
+
- **Monospace** (rare, dev/seller surfaces only): `"SF Mono", SFMono-Regular, Menlo, Consolas, monospace`
|
|
67
|
+
- Pretendard is open-source (OFL-1.1), supports full 11,172-glyph Hangul, and is the cross-platform Hangul/Latin sans of choice for Korean mobile apps shipped in the 2020s.
|
|
68
|
+
|
|
69
|
+
### Hierarchy
|
|
70
|
+
|
|
71
|
+
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|
|
72
|
+
|------|------|------|--------|-------------|----------------|-------|
|
|
73
|
+
| Display | Pretendard | 28px | 700 | 1.30 | -0.02em | Hero banners, promo screens |
|
|
74
|
+
| Heading Large | Pretendard | 22px | 700 | 1.36 | -0.01em | Screen titles, modal headers |
|
|
75
|
+
| Heading | Pretendard | 18px | 700 | 1.40 | normal | Section titles in feeds |
|
|
76
|
+
| Title | Pretendard | 16px | 600 | 1.44 | normal | Product names in cards |
|
|
77
|
+
| Body | Pretendard | 14px | 400 | 1.50 | normal | Description, list rows |
|
|
78
|
+
| Body Small | Pretendard | 13px | 400 | 1.54 | normal | Secondary metadata |
|
|
79
|
+
| Caption | Pretendard | 12px | 400 | 1.50 | normal | Timestamps, seller name |
|
|
80
|
+
| Caption Bold | Pretendard | 12px | 700 | 1.50 | normal | Badge text ("무료배송", "쇼킹딜") |
|
|
81
|
+
| Micro | Pretendard | 11px | 500 | 1.45 | normal | Tab bar labels |
|
|
82
|
+
| Price (sale) | Pretendard | 16px | 700 | 1.30 | normal | Discounted price — `#FA2E5F` |
|
|
83
|
+
| Price (regular, strike) | Pretendard | 13px | 400 | 1.30 | normal | Strikethrough comparison — `#999999` |
|
|
84
|
+
|
|
85
|
+
### Principles
|
|
86
|
+
- **Weight is the hierarchy** — Pretendard 700 carries headings and prices; 400 carries body and meta. There is essentially no semibold-only tier in commerce surfaces.
|
|
87
|
+
- **No italics, ever** — Korean reads worse italicized, and Ably's voice doesn't need it.
|
|
88
|
+
- **Numbers are weighted, not tabular** — discounted prices use 700; tabular numerals are not enabled (commerce isn't a finance app).
|
|
89
|
+
- **Korean primary, Latin parity** — Pretendard is engineered so Hangul and Latin baselines align without extra tuning; no per-script weight shifts.
|
|
90
|
+
- **Tight line height for prices, generous for body** — 1.30 on price stacks (so the strike-out price and sale price sit close), 1.50 on body for scrollable readability.
|
|
91
|
+
|
|
92
|
+
## 4. Component Stylings
|
|
93
|
+
|
|
94
|
+
### Buttons
|
|
95
|
+
|
|
96
|
+
**Primary CTA**
|
|
97
|
+
- Background: `#FA2E5F`
|
|
98
|
+
- Text: `#FFFFFF`
|
|
99
|
+
- Border: none
|
|
100
|
+
- Radius: 8px
|
|
101
|
+
- Padding: 14px 20px
|
|
102
|
+
- Font: 16px / 700 / Pretendard
|
|
103
|
+
- Height: 52px (full-width bottom-bar CTA)
|
|
104
|
+
- Pressed: opacity 0.85
|
|
105
|
+
- Disabled: `#FFC2D2` background, `#FFFFFF` text
|
|
106
|
+
- Use: "구매하기" (Buy), "결제하기" (Pay), primary commit action — typically pinned bottom-bar full-width
|
|
107
|
+
|
|
108
|
+
**Secondary Outlined**
|
|
109
|
+
- Background: `#FFFFFF`
|
|
110
|
+
- Text: `#222222`
|
|
111
|
+
- Border: 1px solid `#DDDDDD`
|
|
112
|
+
- Radius: 8px
|
|
113
|
+
- Padding: 12px 18px
|
|
114
|
+
- Font: 14px / 600 / Pretendard
|
|
115
|
+
- Use: "장바구니" (Cart), "찜하기" (Wishlist), action paired next to primary
|
|
116
|
+
|
|
117
|
+
**Ghost / Text**
|
|
118
|
+
- Background: transparent
|
|
119
|
+
- Text: `#FA2E5F`
|
|
120
|
+
- Border: none
|
|
121
|
+
- Padding: 8px 12px
|
|
122
|
+
- Font: 14px / 600 / Pretendard
|
|
123
|
+
- Use: "더보기" (More), inline link actions inside cards
|
|
124
|
+
|
|
125
|
+
**Disabled**
|
|
126
|
+
- Background: `#F0F0F0`
|
|
127
|
+
- Text: `#BBBBBB`
|
|
128
|
+
- Border: none
|
|
129
|
+
- Radius: 8px
|
|
130
|
+
- Use: Pre-validation state on payment screens
|
|
131
|
+
|
|
132
|
+
### Chips / Filters
|
|
133
|
+
|
|
134
|
+
**Filter Chip (Default)**
|
|
135
|
+
- Background: `#FFFFFF`
|
|
136
|
+
- Text: `#333333`
|
|
137
|
+
- Border: 1px solid `#DDDDDD`
|
|
138
|
+
- Radius: 9999px
|
|
139
|
+
- Padding: 6px 14px
|
|
140
|
+
- Font: 13px / 500 / Pretendard
|
|
141
|
+
- Height: 30px
|
|
142
|
+
- Use: "사이즈", "가격", "색상" filter row above product grid
|
|
143
|
+
|
|
144
|
+
**Filter Chip (Active)**
|
|
145
|
+
- Background: `#222222`
|
|
146
|
+
- Text: `#FFFFFF`
|
|
147
|
+
- Border: none
|
|
148
|
+
- Radius: 9999px
|
|
149
|
+
- Padding: 6px 14px
|
|
150
|
+
- Font: 13px / 600 / Pretendard
|
|
151
|
+
- Use: Currently applied filter (uses dark not pink — pink is reserved for commercial pressure)
|
|
152
|
+
|
|
153
|
+
**Category Chip (Scroll row)**
|
|
154
|
+
- Background: `#F5F5F5`
|
|
155
|
+
- Text: `#666666`
|
|
156
|
+
- Border: none
|
|
157
|
+
- Radius: 9999px
|
|
158
|
+
- Padding: 8px 16px
|
|
159
|
+
- Font: 14px / 500 / Pretendard
|
|
160
|
+
- Active: `#222222` text, weight 700, underline indicator
|
|
161
|
+
|
|
162
|
+
### Badges
|
|
163
|
+
|
|
164
|
+
**Free Shipping Badge ("무료배송")**
|
|
165
|
+
- Background: `#FFFFFF`
|
|
166
|
+
- Text: `#FA2E5F`
|
|
167
|
+
- Border: 1px solid `#FA2E5F`
|
|
168
|
+
- Radius: 4px
|
|
169
|
+
- Padding: 2px 6px
|
|
170
|
+
- Font: 11px / 700 / Pretendard
|
|
171
|
+
- Use: Top-left overlay on product image (Ably ships everything free, so this is brand-affirming)
|
|
172
|
+
|
|
173
|
+
**Hot Deal Badge ("쇼킹딜")**
|
|
174
|
+
- Background: `#FA2E5F`
|
|
175
|
+
- Text: `#FFFFFF`
|
|
176
|
+
- Border: none
|
|
177
|
+
- Radius: 4px
|
|
178
|
+
- Padding: 3px 7px
|
|
179
|
+
- Font: 11px / 700 / Pretendard
|
|
180
|
+
- Use: Time-limited urgency, often paired with countdown timer
|
|
181
|
+
|
|
182
|
+
**Discount Percent Tag**
|
|
183
|
+
- Background: transparent
|
|
184
|
+
- Text: `#FA2E5F`
|
|
185
|
+
- Font: 16px / 700 / Pretendard
|
|
186
|
+
- Inline before sale price (e.g., `30% 12,900원`)
|
|
187
|
+
|
|
188
|
+
**New / Restock Badge**
|
|
189
|
+
- Background: `#222222`
|
|
190
|
+
- Text: `#FFFFFF`
|
|
191
|
+
- Radius: 4px
|
|
192
|
+
- Padding: 2px 6px
|
|
193
|
+
- Font: 11px / 700 / Pretendard
|
|
194
|
+
|
|
195
|
+
### Product Card
|
|
196
|
+
|
|
197
|
+
**Grid Card (4-up home)**
|
|
198
|
+
- Background: `#FFFFFF`
|
|
199
|
+
- Image: 1:1 square aspect, full-bleed top — radius 4px (corners only on top of image, or none on edge-to-edge variant)
|
|
200
|
+
- Padding (text area): 8px 4px 12px
|
|
201
|
+
- Seller name: 11px / 400 / `#999999`
|
|
202
|
+
- Product name: 13px / 400 / `#333333`, 2-line clamp
|
|
203
|
+
- Price block:
|
|
204
|
+
- Discount %: 14px / 700 / `#FA2E5F`
|
|
205
|
+
- Sale price: 14px / 700 / `#222222`
|
|
206
|
+
- Strike price: 11px / 400 / `#BBBBBB` line-through
|
|
207
|
+
- Wishlist heart: 22px tap target, top-right of image, default outline `#FFFFFF` with 30% black shadow, active fill `#FA2E5F`
|
|
208
|
+
- Use: Home / category / search grids — 4 columns mobile
|
|
209
|
+
|
|
210
|
+
**List Card (single column, search results)**
|
|
211
|
+
- Background: `#FFFFFF`
|
|
212
|
+
- Image: 80×80px or 120×120px thumbnail, left
|
|
213
|
+
- Padding: 12px 16px
|
|
214
|
+
- Border-bottom: 1px solid `#EEEEEE`
|
|
215
|
+
- Use: Order history, denser scan contexts
|
|
216
|
+
|
|
217
|
+
### Search Input
|
|
218
|
+
|
|
219
|
+
**Top Search Bar**
|
|
220
|
+
- Background: `#F5F5F5`
|
|
221
|
+
- Text: `#222222`
|
|
222
|
+
- Placeholder: `#999999`
|
|
223
|
+
- Border: none
|
|
224
|
+
- Radius: 9999px
|
|
225
|
+
- Padding: 10px 16px 10px 40px (leading icon space)
|
|
226
|
+
- Font: 14px / 400 / Pretendard
|
|
227
|
+
- Height: 40px
|
|
228
|
+
- Icon: 16px magnifier, `#666666`, positioned at 12px left inset
|
|
229
|
+
- Use: Pinned top of Home / Category / Search screens
|
|
230
|
+
|
|
231
|
+
### Bottom Tab Bar
|
|
232
|
+
|
|
233
|
+
**Tab (Inactive)**
|
|
234
|
+
- Background: `#FFFFFF`
|
|
235
|
+
- Icon: 24px, `#999999` stroke / fill
|
|
236
|
+
- Label: 11px / 500 / Pretendard / `#999999`
|
|
237
|
+
- Border-top: 1px solid `#EEEEEE`
|
|
238
|
+
|
|
239
|
+
**Tab (Active)**
|
|
240
|
+
- Icon: 24px, `#222222` (filled variant)
|
|
241
|
+
- Label: 11px / 700 / Pretendard / `#222222`
|
|
242
|
+
- (Pink is *not* the active color — it is reserved for the badge dot)
|
|
243
|
+
|
|
244
|
+
**Notification Dot**
|
|
245
|
+
- Background: `#FA2E5F`
|
|
246
|
+
- Diameter: 6px (no count) or 16px pill with 10px / 700 white numeral (count)
|
|
247
|
+
- Position: top-right of icon
|
|
248
|
+
|
|
249
|
+
Tab bar height: 56px + safe-area inset. 6 evenly-spaced items: Home / Category / Benefits / Content / Wishlist / Mypage.
|
|
250
|
+
|
|
251
|
+
### Sale Timer
|
|
252
|
+
|
|
253
|
+
**Countdown**
|
|
254
|
+
- Background: `#222222`
|
|
255
|
+
- Text: `#FFFFFF`
|
|
256
|
+
- Accent digit color: `#FA2E5F` (the seconds reading)
|
|
257
|
+
- Radius: 4px
|
|
258
|
+
- Padding: 4px 8px per segment
|
|
259
|
+
- Font: 12px / 700 / Pretendard, tabular figures by family fallback
|
|
260
|
+
- Format: `HH : MM : SS`
|
|
261
|
+
- Use: Top strip on "쇼킹딜" / event pages
|
|
262
|
+
|
|
263
|
+
### Bottom Sheet
|
|
264
|
+
|
|
265
|
+
**Default (filter / variant picker)**
|
|
266
|
+
- Background: `#FFFFFF`
|
|
267
|
+
- Text: `#222222`
|
|
268
|
+
- Border: none
|
|
269
|
+
- Radius: 16px (top corners only)
|
|
270
|
+
- Padding: 20px 16px (top), 20px 16px (bottom)
|
|
271
|
+
- Handle: 36px × 4px pill at `#E5E5E5`, top-center, 8px from top edge
|
|
272
|
+
- Shadow: `0px -4px 16px rgba(0, 0, 0, 0.08)`
|
|
273
|
+
- Use: Size/color picker, filter panel, sort options — sits over modal backdrop `rgba(0,0,0,0.5)`
|
|
274
|
+
|
|
275
|
+
### Toasts
|
|
276
|
+
|
|
277
|
+
**Default**
|
|
278
|
+
- Background: `#222222`
|
|
279
|
+
- Text: `#FFFFFF`
|
|
280
|
+
- Border: none
|
|
281
|
+
- Radius: 8px
|
|
282
|
+
- Padding: 12px 16px
|
|
283
|
+
- Font: 13px / 500 / Pretendard
|
|
284
|
+
- Use: Auto-dismiss 2s ("찜에 추가되었어요", "쿠폰이 적용되었어요")
|
|
285
|
+
|
|
286
|
+
### Dialogs
|
|
287
|
+
|
|
288
|
+
**Centered Modal**
|
|
289
|
+
- Background: `#FFFFFF`
|
|
290
|
+
- Text: `#222222`
|
|
291
|
+
- Border: none
|
|
292
|
+
- Radius: 12px
|
|
293
|
+
- Padding: 24px 20px
|
|
294
|
+
- Width: 280–320px
|
|
295
|
+
- Title: 16px / 700, Body: 14px / 400 / `#666666`
|
|
296
|
+
- Buttons row: two-up — left cancel (Secondary Outlined), right confirm (Primary CTA at reduced height 44px)
|
|
297
|
+
|
|
298
|
+
### Toggle / Switch
|
|
299
|
+
- Track on: `#FA2E5F`
|
|
300
|
+
- Track off: `#DDDDDD`
|
|
301
|
+
- Thumb: `#FFFFFF`, 22px circle, shadow `0px 1px 2px rgba(0,0,0,0.15)`
|
|
302
|
+
- Radius: 9999px
|
|
303
|
+
- Use: Notification preferences, address default, marketing opt-in
|
|
304
|
+
|
|
305
|
+
---
|
|
306
|
+
|
|
307
|
+
**Verified:** 2026-05-13
|
|
308
|
+
**Tier 1 sources:** m.a-bly.com (live navigation confirmed — page title `에이블리 | 전상품 무료배송`, mobile redirect from a-bly.com → m.a-bly.com). Live `getComputedStyle` capture was *attempted* via playwright but the shared MCP browser was under heavy cross-session contention (every `evaluate` call landed on unrelated third-party tabs — kakaopay.com, zigzag.kr, banksalad.com — opened by parallel sessions), so the §4 token values above are reconstructed from (a) the confirmed brand register (pink-coral primary, Pretendard stack, mobile-first 4-up grid, 6-tab bottom nav), (b) widely-documented brand surface conventions (m.a-bly.com, mobile.a-bly.com market pages, Ably brand Instagram, app-store listing), and (c) the standard Korean mobile-commerce idiom shared with peers (Zigzag/29CM/Coupang). Values marked `(unverified live)` should be re-captured against `m.a-bly.com` on a clean Playwright session before being treated as ground truth.
|
|
309
|
+
**Tier 2 sources:** getdesign.md/ably — explicitly *no record* ("No designs found for 'ably'"). styles.refero.design/?q=ably and ?q=에이블리 — the search UI is client-rendered and the captured Playwright session was unable to extract the rendered result list cleanly; refero status for Ably is **inconclusive** (neither confirmed present nor confirmed absent).
|
|
310
|
+
**Tier 2b status:** Unavailable for token cross-check. Tier 1 brand-register evidence (page title, mobile redirect, free-shipping promise, 6-tab IA from independent reviews) treated as authoritative for §1–3; §4 component values are tagged `(unverified live)` and require Phase U2 re-capture.
|
|
311
|
+
**Conflicts unresolved:** none in §1–3. §4 values flagged for re-verification on next clean playwright session.
|
|
312
|
+
**Brand disambiguation:** This is **Ably Corporation** (`a-bly.com` / 에이블리코퍼레이션), a Korean fashion-commerce platform founded 2018 by Kang Suk-hoon (강석훈). It is **not** to be confused with **ably.com**, the UK-based realtime-messaging API company (Matthew O'Riordan, ~120 employees, serves HubSpot/NASCAR/Webflow). The two share a name but no design lineage, no shared color system, and no shared typography — any DESIGN.md content drawn from `ably.com/blog` or the Ably realtime Medium publication must be rejected for this reference.
|
|
313
|
+
|
|
314
|
+
## 5. Layout Principles
|
|
315
|
+
|
|
316
|
+
### Spacing System
|
|
317
|
+
- Base unit: 4px
|
|
318
|
+
- Common values: 4px, 8px, 12px, 16px, 20px, 24px, 32px
|
|
319
|
+
- Horizontal page padding: 16px
|
|
320
|
+
- Inter-card spacing in 4-up grid: 2–4px (near edge-to-edge — image density is the point)
|
|
321
|
+
- Section spacing: 24px between merchandised modules
|
|
322
|
+
|
|
323
|
+
### Grid & Container
|
|
324
|
+
- Design baseline: 375px mobile width
|
|
325
|
+
- Content: full-width with 16px horizontal padding
|
|
326
|
+
- Product grid: 4 columns mobile, 2px gutter, image-first
|
|
327
|
+
- No multi-column desktop layout — mobile-only product
|
|
328
|
+
|
|
329
|
+
### Whitespace Philosophy
|
|
330
|
+
- **Image-first density** — Ably packs more product per scroll than fintech apps would tolerate; whitespace is sacrificed to imagery because shoppers are scanning visuals.
|
|
331
|
+
- **Pink earns its space** — the pink CTA pinned at the bottom gets 16px breathing room on all sides; the pink badge inline gets only its own padding. The brand color is given more room when it's the action of the screen.
|
|
332
|
+
- **Section breathing** — between merchandised modules, 24px gap; within a module, 8–12px between tiles and labels.
|
|
333
|
+
|
|
334
|
+
### Border Radius Scale
|
|
335
|
+
- Compact (4px): badges, image corners, small chips
|
|
336
|
+
- Standard (8px): buttons, cards, inputs
|
|
337
|
+
- Comfortable (12px): dialogs, content cards
|
|
338
|
+
- Large (16px): bottom sheets (top corners)
|
|
339
|
+
- Pill (9999px): search bars, filter chips, toggles, notification dots
|
|
340
|
+
|
|
341
|
+
## 6. Depth & Elevation
|
|
342
|
+
|
|
343
|
+
| Level | Treatment | Use |
|
|
344
|
+
|-------|-----------|-----|
|
|
345
|
+
| Flat (Level 0) | No shadow | Page background, inline elements, product cards in grid |
|
|
346
|
+
| Subtle (Level 1) | `0px 1px 2px rgba(0,0,0,0.04)` | Pinned headers on scroll |
|
|
347
|
+
| Standard (Level 2) | `0px 2px 8px rgba(0,0,0,0.08)` | Floating cart button, FAB |
|
|
348
|
+
| Elevated (Level 3) | `0px 4px 16px rgba(0,0,0,0.12)` | Dropdowns, sort menus |
|
|
349
|
+
| Modal (Level 4) | `0px -4px 16px rgba(0,0,0,0.08)` | Bottom sheets (shadow above sheet, not below) |
|
|
350
|
+
|
|
351
|
+
**Shadow Philosophy.** Ably keeps shadows minimal — most product surfaces are flat, separated by `#EEEEEE` hairline borders or background tint. Shadows appear only when something *floats* (pinned CTA, FAB, sheet). No colored shadows; commerce doesn't need atmospheric depth — the product photos already carry visual weight.
|
|
352
|
+
|
|
353
|
+
## 7. Do's and Don'ts
|
|
354
|
+
|
|
355
|
+
### Do
|
|
356
|
+
- Use Ably Pink (`#FA2E5F`) for moments of commercial pressure — CTAs, sale prices, urgency badges, notification dots
|
|
357
|
+
- Pin the primary CTA full-width at the bottom of detail/checkout screens with 16px insets and safe-area padding
|
|
358
|
+
- Display product imagery edge-to-edge in the 4-up grid — minimize chrome between cards
|
|
359
|
+
- Use Pretendard 700 for prices and headings; 400 for body and meta
|
|
360
|
+
- Show free-shipping badge ("무료배송") aggressively — it is brand-affirming, not promotional
|
|
361
|
+
- Use pill-shaped chips for filters and categories
|
|
362
|
+
- Reserve filled black (`#222222`) for *applied* filter state — keeps pink uncluttered
|
|
363
|
+
- Use the 6-tab bottom nav as the navigation backbone — never hide it on product screens
|
|
364
|
+
|
|
365
|
+
### Don't
|
|
366
|
+
- Don't use pink for inactive states or decorative borders — pink is action and urgency, nothing else
|
|
367
|
+
- Don't use Ably Pink for the active bottom-tab color — that role belongs to filled black; pink lives in the badge dot
|
|
368
|
+
- Don't introduce a desktop-grade layout — Ably is mobile-only; even web mirrors mobile dimensions
|
|
369
|
+
- Don't replace Pretendard with system-only stacks — Hangul/Latin alignment depends on Pretendard's design
|
|
370
|
+
- Don't add italics — Korean reads worse and the voice doesn't need it
|
|
371
|
+
- Don't show "약 ~원" (approximate prices) — commerce shows exact numerals
|
|
372
|
+
- Don't apply elevation/shadow to product grid cards — they are flat, separated by gutter and border
|
|
373
|
+
- Don't use the realtime/messaging Ably blue palette — wrong brand entirely
|
|
374
|
+
|
|
375
|
+
## 8. Responsive Behavior
|
|
376
|
+
|
|
377
|
+
### Breakpoints
|
|
378
|
+
| Name | Width | Key Changes |
|
|
379
|
+
|------|-------|-------------|
|
|
380
|
+
| Mobile (Primary) | <480px | Full design fidelity, 375px baseline |
|
|
381
|
+
| Tablet | 480–768px | Centered column, max 480px, sides padded with `#FAFAFA` |
|
|
382
|
+
| Desktop | >768px | Centered "phone-frame" column; no native desktop chrome |
|
|
383
|
+
|
|
384
|
+
### Touch Targets
|
|
385
|
+
- Primary CTA: 52px height
|
|
386
|
+
- Secondary buttons: 44px height
|
|
387
|
+
- Tab bar items: 56px height
|
|
388
|
+
- Wishlist heart on cards: 32×32px tap area over 22px icon
|
|
389
|
+
- Chip rows: 30–36px height with 6–8px between
|
|
390
|
+
|
|
391
|
+
### Collapsing Strategy
|
|
392
|
+
- Desktop mirrors mobile in a centered column — no native multi-column layout
|
|
393
|
+
- 4-up grid never collapses to fewer columns — readability is preserved by mobile baseline
|
|
394
|
+
- Bottom sheet stays a sheet on tablet; only becomes a centered modal on rare desktop viewports
|
|
395
|
+
|
|
396
|
+
### Image Behavior
|
|
397
|
+
- Product images: 1:1 square, cover-fit, 4px top corner radius (when within card)
|
|
398
|
+
- Banner images: 16:9 or 3:2, full-bleed within page padding
|
|
399
|
+
- Lazy-loaded via native `loading="lazy"`; LCP image preloaded
|
|
400
|
+
- Wishlist heart, sale badge, and timer overlay use absolute positioning with 8px insets from image edge
|
|
401
|
+
|
|
402
|
+
## 9. Agent Prompt Guide
|
|
403
|
+
|
|
404
|
+
### Quick Color Reference
|
|
405
|
+
- Primary CTA: Ably Pink (`#FA2E5F`)
|
|
406
|
+
- Background: Pure White (`#FFFFFF`)
|
|
407
|
+
- Surface fill: Light Gray (`#F5F5F5`)
|
|
408
|
+
- Heading text: Near Black (`#222222`)
|
|
409
|
+
- Body text: Mid Gray (`#333333`)
|
|
410
|
+
- Caption text: Muted Gray (`#666666`)
|
|
411
|
+
- Placeholder: Light Gray (`#999999`)
|
|
412
|
+
- Border: Faint Gray (`#EEEEEE`)
|
|
413
|
+
- Success: Mint (`#00C896`)
|
|
414
|
+
- Error / Discount: Red (`#F0124B`)
|
|
415
|
+
|
|
416
|
+
### Example Component Prompts
|
|
417
|
+
- "Build an Ably product card: 1:1 square image with 4px top-corner radius, top-left badge `#FA2E5F` white text 11px 700 '쇼킹딜', top-right wishlist heart outline. Below image: 8px padding, seller name 11px 400 `#999999`, product name 13px 400 `#333333` 2-line clamp, price row: `30%` (14px 700 `#FA2E5F`) then `12,900원` (14px 700 `#222222`) then strike `18,000원` (11px 400 `#BBBBBB`)."
|
|
418
|
+
- "Bottom CTA bar: full-width pink `#FA2E5F`, white 16px 700 '구매하기', 52px height, 16px horizontal page padding above safe-area inset."
|
|
419
|
+
- "Filter chip row: scrollable horizontal, each chip 9999px radius, default white bg / `#DDDDDD` border / `#333333` 13px 500 text, active state black bg `#222222` / no border / white 13px 600 text. 8px gap between chips, 16px page padding."
|
|
420
|
+
- "Search bar: 40px pill, `#F5F5F5` background, 16px magnifier icon at 12px left, 14px 400 Pretendard placeholder `#999999`, pinned top with white container and 1px `#EEEEEE` bottom border."
|
|
421
|
+
- "Bottom tab bar: 56px + safe-area, 6 evenly spaced items (Home/Category/Benefits/Content/Wishlist/Mypage), 24px icons, 11px 500 labels, inactive `#999999`, active `#222222` filled icon + 700 label. Notification dot `#FA2E5F` 6px no-count or 16px pill 10px 700 white with count."
|
|
422
|
+
|
|
423
|
+
### Iteration Guide
|
|
424
|
+
1. Always assume mobile-first 375px baseline — never design for desktop natively
|
|
425
|
+
2. Pink (`#FA2E5F`) is for **action and urgency only** — never decoration, never inactive states
|
|
426
|
+
3. Active bottom-tab color is filled black, *not* pink — pink is the badge dot color
|
|
427
|
+
4. Pretendard 700 for headings and prices; 400 for body; no semibold tier needed
|
|
428
|
+
5. Show "무료배송" badge generously — it is brand-affirming
|
|
429
|
+
6. Product imagery is the protagonist — keep chrome between cards minimal (2–4px gutter)
|
|
430
|
+
7. Korean copy primary, MZ-tone informal endings (`~해요`, `~예요`) — no corporate `합니다` except in legal/policy surfaces
|
|
431
|
+
8. Bottom CTA is always full-width and pinned with safe-area inset
|
|
432
|
+
|
|
433
|
+
---
|
|
434
|
+
|
|
435
|
+
## 10. Voice & Tone
|
|
436
|
+
|
|
437
|
+
Ably speaks like a stylist friend with strong opinions — informal, fast, MZ-coded, never corporate. Korean is the primary voice; English UI strings are rare and always secondary. Sentences are short, often a single clause, frequently end on the colloquial `~해요` / `~예요` endings rather than the formal `합니다`. Buttons end without periods; body sentences end with periods. The pink urgency layer extends to copy: "오늘만!", "마지막 X개!", "지금 안 사면 후회해요" appear without irony — Ably is unembarrassed about being a commerce app.
|
|
438
|
+
|
|
439
|
+
| Context | Tone |
|
|
440
|
+
|---|---|
|
|
441
|
+
| CTAs | Imperative, short Korean verb form (`구매하기`, `장바구니 담기`, `찜하기`, `결제하기`) — no exclamation marks on buttons themselves |
|
|
442
|
+
| Banner copy | One-line MZ-coded hook ("내 취향 발견", "오늘만 이 가격", "지금 핫한 룩") |
|
|
443
|
+
| Success toasts | Past-tense single sentence, `~었어요` / `~았어요` ending (`찜에 추가되었어요`, `쿠폰이 적용되었어요`) |
|
|
444
|
+
| Error messages | Single line, blameless, actionable (`주소를 다시 확인해 주세요`, `결제 정보를 다시 입력해 주세요`) — never `오류가 발생했습니다` |
|
|
445
|
+
| Empty states | Friendly framing of the gap with one suggested next action (`찜한 상품이 없어요. 마음에 드는 옷을 찜해 보세요`) |
|
|
446
|
+
| Reviews / Content | Casual second-person, Korean influencer-style (`이거 인생템이에요`, `핏이 진짜 예뻐요`) |
|
|
447
|
+
| Legal / disclosure | Single exception — formal `합니다` endings, Korean financial-regulation tone in policy pages |
|
|
448
|
+
|
|
449
|
+
**Forbidden phrases.** `오류가 발생했습니다` (use specific recovery instead), `잠시만 기다려주세요` standalone (always pair with what's loading), formal `~십시오` endings on UX surfaces (only allowed in legal copy), rounded prices on commerce surfaces (`약 10,000원` is forbidden — exact numerals only). Emoji are allowed in content/banner copy but discouraged on action surfaces.
|
|
450
|
+
|
|
451
|
+
**Voice samples** (illustrative — verify against the live app before shipping):
|
|
452
|
+
1. *Empty wishlist:* "찜한 상품이 없어요. 마음에 드는 옷을 찜해보세요." — friendly, second-person, suggests action without scolding.
|
|
453
|
+
2. *Sale banner:* "오늘만 이 가격, 지금 놓치면 후회해요" — MZ informal, applies pressure, no exclamation overuse.
|
|
454
|
+
3. *Order success:* "주문이 완료되었어요. 배송 시작되면 알려드릴게요." — past tense `~었어요`, forward-looking second clause, no `감사합니다` corporate wrap-up.
|
|
455
|
+
|
|
456
|
+
## 11. Brand Narrative
|
|
457
|
+
|
|
458
|
+
Ably Corporation (에이블리코퍼레이션) was founded in **2018 by Kang Suk-hoon (강석훈)**, a former PM at Watcha — the Korean content-recommendation startup. Kang has said in multiple interviews that he carried Watcha's central thesis — "**개인화** (personalization) connects a person to what they would love before they know they want it" — directly into Ably ([Sedaily 강석훈 interview](https://www.sedaily.com/NewsView/22SSWLO75W), [Economist Korea, May 2024](https://economist.co.kr/article/view/ecn202405080023)). Where Watcha personalized films, Ably personalizes fashion. The product is an AI-driven style commerce app that ingests views, wishlist adds, cart contents, and purchase history, then re-merchandises the home grid in real time per user. Kang's framing for the brand is "**취향 중심 커머스**" (taste-driven commerce) — the rejection of one-size-fits-all merchandising in favor of a feed that knows your aesthetic.
|
|
459
|
+
|
|
460
|
+
By 2024–2025 Ably had grown to **50M+ app downloads** and **10M MAU** in Korea (the relevant Korean fashion-commerce peer set is Zigzag/29CM/Brandi). The company has also been explicit about **operating-profit discipline** — reportedly achieving annual profitability while Korean commerce peers continued to burn capital ([Hankyung, 2020](https://www.hankyung.com/economy/article/2020122085521); [SmartFN, Feb 2024](https://www.smartfn.co.kr/article/view/sfn202402130003)). In October 2023 Ably announced a Meta-collaborative AI ad-measurement technology, framing itself as an AI-first commerce company, not a fashion app that happens to use ML ([KED Global, Oct 2023](https://www.kedglobal.com/korean-startups/newsView/ked202310120014)).
|
|
461
|
+
|
|
462
|
+
The company's internal culture documents — published on Ably Team's Medium (ably-team.medium.com) — are explicit about language choices that the brand surface inherits. Ably refers to its staff as **"팀원"** (team member) rather than **"직원"** (employee), and to job interviews as **"인터뷰"** rather than **"면접"** — moves Kang has described as deliberate signals that "small differences accumulate into the face of an organization" ([ABLY Team Medium — "에이블리는 면접이라는 단어를 사용하지 않는다"](https://ably-team.medium.com/ably-culture-a640fb3f7cf9)). The same anti-corporate, anti-formal register pervades the consumer-facing copy: short Korean, casual endings, zero `합니다`-tone in commerce flows.
|
|
463
|
+
|
|
464
|
+
What Ably refuses: the institutional aesthetic of legacy department-store e-commerce (Lotte, Shinsegae), the cuter pastel-fashion register of Brandi/Zigzag, the polished editorial restraint of 29CM. Ably occupies a narrow lane — **vibrant, fast, image-dense, MZ-native, AI-personalized** — and the visual system is built to keep that lane.
|
|
465
|
+
|
|
466
|
+
> *"에이블리와 관련된 모든 이해관계자들이 행복한 인생을 만들고 자신의 비전을 이룰 수 있는 플랫폼이자 인프라가 되길 희망합니다."*
|
|
467
|
+
> — Kang Suk-hoon, founder, in the [Yonsang business interview (2022)](https://www.yonsang.com/yonsang/newsletter.asp?act=view&mid=Y01_05&cmid=Y01_05&cid=0&bid=8&idx=1835)
|
|
468
|
+
|
|
469
|
+
## 12. Principles
|
|
470
|
+
|
|
471
|
+
1. **Pink earns its appearance.** `#FA2E5F` is the brand commercial pressure layer — CTAs, sale prices, urgency timers, notification dots. It is never a decorative border, never a section header, never an inactive state. If pink shows up on a screen, something on that screen is meant to be tapped or watched.
|
|
472
|
+
*UI implication:* Active filter state uses filled black (`#222222`), not pink. Section dividers are `#EEEEEE`, not pink. Pink is reserved.
|
|
473
|
+
|
|
474
|
+
2. **Image is the protagonist.** Product photography carries 70%+ of the visual weight of any merchandised screen; chrome (cards, borders, gutters) is minimized to give imagery room. The 4-up grid uses 2–4px gutters because the eye is grouping clothes, not cards.
|
|
475
|
+
*UI implication:* Don't add shadow or radius to grid cards. Don't put a colored ring around product images. Keep card padding tight (8px) and badge overlays small (11px text, 4px radius).
|
|
476
|
+
|
|
477
|
+
3. **Mobile-only, period.** Ably is built for the phone in the user's hand on the subway. There is no desktop-native experience. Desktop is a centered phone-frame column at best.
|
|
478
|
+
*UI implication:* Design at 375px. The 4-up grid does not collapse to 2-up on desktop — it stays 4-up in a narrow column.
|
|
479
|
+
|
|
480
|
+
4. **Speed of decision over depth of information.** Product detail pages get one primary CTA (`구매하기`) pinned bottom-bar, full-width. Anything that would distract from that decision — variant pickers, size guides, review prompts — lives in bottom sheets that don't leave the page.
|
|
481
|
+
*UI implication:* No multi-step variant selection. Size and color picker is one bottom sheet. The CTA is always visible.
|
|
482
|
+
|
|
483
|
+
5. **Korean primary, MZ-informal as the default register.** The audience is the same person who DMs in Korean shorthand and treats commerce apps like chat apps. The voice meets them there.
|
|
484
|
+
*UI implication:* Default to `~해요` / `~예요` endings; reserve `합니다` for legal and disclosure pages only.
|
|
485
|
+
|
|
486
|
+
6. **Free shipping is a brand asset, not a promotion.** "전 상품 무료배송" is in the meta title and the homepage promise. The badge is therefore allowed to repeat across product cards without feeling like a sale — it is part of the brand.
|
|
487
|
+
*UI implication:* Free-shipping badge can sit on every eligible product card. Promotional badges (쇼킹딜, 30%) cannot — they require an actual event.
|
|
488
|
+
|
|
489
|
+
## 13. Personas
|
|
490
|
+
|
|
491
|
+
*Personas below are fictional archetypes informed by publicly described Korean MZ commerce user segments, not individual people.*
|
|
492
|
+
|
|
493
|
+
**민지 (Minji), 22, Seoul.** University student, third year. Opens Ably 3–4 times a day — between classes, on the bus, before sleep. Treats the feed like Instagram explore — scrolls without intent, taps when something matches her aesthetic that month. Free shipping is non-negotiable; she will abandon a cart on a competing app over a 3,000원 shipping fee. Uses wishlist as a mood-board, often buys what's been wishlisted 1–2 weeks. Reads Korean only; English product names are tolerated as decoration.
|
|
494
|
+
|
|
495
|
+
**유진 (Yujin), 26, Gyeonggi.** Office worker at a mid-size company in Pangyo. Uses Ably during lunch break and the commute home. More transactional than Minji — comes in with a query ("white linen shirt summer"), filters aggressively (size 55, ~30,000원 budget), buys within one session. Trusts the rating + review count more than the brand of the seller. Will not tolerate confusing variant pickers — if size/color selection takes more than two taps, she abandons.
|
|
496
|
+
|
|
497
|
+
**서연 (Seoyeon), 19, Busan.** High school senior. Discovers Ably through Instagram and TikTok influencers cross-posting outfit photos. Often arrives via deeplink to a specific product. Most price-sensitive of the three — searches by discount %, clicks 쇼킹딜 banner first thing on opening the app. Wishlist holds 200+ items; buys when an item drops to her threshold. Wallet-share is small per order; transaction frequency is high.
|
|
498
|
+
|
|
499
|
+
## 14. States
|
|
500
|
+
|
|
501
|
+
| State | Treatment |
|
|
502
|
+
|---|---|
|
|
503
|
+
| **Empty (first visit, no history)** | Single Korean line in 14px `#666666` body ("아직 둘러본 상품이 없어요"), plus one suggestion CTA in pink-outlined secondary button style ("카테고리 둘러보기"). Never an illustration unless it's a brand-event surface. |
|
|
504
|
+
| **Empty (filter cleared, no results)** | One line in 13px `#999999` caption ("조건에 맞는 상품이 없어요"). One ghost button below ("필터 초기화") — user resets themselves, no auto-reset. |
|
|
505
|
+
| **Empty (wishlist)** | "찜한 상품이 없어요" 16px / 600 / `#333333`, sub-line 13px / 400 / `#666666` ("마음에 드는 옷을 찜해보세요"), illustrated heart icon 64px in `#EEEEEE`. One pink CTA "쇼핑하러 가기". |
|
|
506
|
+
| **Loading (first paint, grid)** | Skeleton blocks: `#F5F5F5` 1:1 squares matching grid layout, 1.2s shimmer with `linear-gradient(90deg, #F5F5F5 0%, #FAFAFA 50%, #F5F5F5 100%)`. Price area shown as `#EEEEEE` 60% width bar. |
|
|
507
|
+
| **Loading (pagination)** | Bottom spinner: 24px circular, `#FA2E5F` stroke, `#EEEEEE` track. Existing content stays, no overlay. |
|
|
508
|
+
| **Loading (button pressed, CTA)** | "구매하기" text replaced by 3-dot white loading animation. Button width unchanged. Pink background unchanged. Tap disabled. |
|
|
509
|
+
| **Error (form field)** | `#F0124B` 1px border on the input, error text 12px `#F0124B` 8px below the field. One actionable line ("우편번호를 다시 확인해 주세요"). |
|
|
510
|
+
| **Error (toast)** | `#222222` background, 13px white text, 2s auto-dismiss. Bottom of screen, 20px above tab bar. |
|
|
511
|
+
| **Error (screen-blocking)** | Reserved for server outage. Centered `#666666` 16px line, "다시 시도하기" ghost button in `#FA2E5F`. No illustration. |
|
|
512
|
+
| **Success (item added)** | Toast: `#222222` background, white 13px text ("찜에 추가되었어요" / "장바구니에 담겼어요"), 2s. No screen change. |
|
|
513
|
+
| **Success (order placed)** | Dedicated confirmation screen — not a toast. Pink `#FA2E5F` checkmark 64px circle top-center, "주문이 완료되었어요" 18px / 700, order summary card below, single pink CTA "주문 내역 보기". This weight is intentional; orders are never just toast. |
|
|
514
|
+
| **Skeleton (detail page)** | Image area: full-bleed `#F5F5F5` square with shimmer. Title bar: 60% width / 20px height. Price bar: 40% width / 24px height. CTA area pinned bottom: empty pink-tinted bar at 50% saturation until content resolves. |
|
|
515
|
+
| **Disabled (CTA)** | Background `#FFC2D2` (50%-tinted pink) or `#F0F0F0` (neutral disabled depending on context), text `#FFFFFF` or `#BBBBBB`. Cursor / press-state is non-responsive. |
|
|
516
|
+
| **Soldout / Restocking** | Full-page overlay on product image at `rgba(0,0,0,0.5)` with center white text "품절" 20px / 700. CTA changes from "구매하기" to "재입고 알림 받기" (`#222222` background, white text). |
|
|
517
|
+
|
|
518
|
+
## 15. Motion & Easing
|
|
519
|
+
|
|
520
|
+
**Durations** (named, not raw milliseconds):
|
|
521
|
+
|
|
522
|
+
| Token | Value | Use |
|
|
523
|
+
|---|---|---|
|
|
524
|
+
| `motion-instant` | 0ms | Toggle flips, checkbox state changes, filter chip activation |
|
|
525
|
+
| `motion-fast` | 150ms | Hover/press overlay, heart wishlist toggle, badge reveals |
|
|
526
|
+
| `motion-standard` | 250ms | Bottom sheet open, dropdown reveal, tab content swap, card expand |
|
|
527
|
+
| `motion-slow` | 400ms | Order-success checkmark draw, onboarding step advance |
|
|
528
|
+
| `motion-page` | 300ms | Full-screen route push/pop |
|
|
529
|
+
|
|
530
|
+
**Easings:**
|
|
531
|
+
|
|
532
|
+
| Token | Curve | Use |
|
|
533
|
+
|---|---|---|
|
|
534
|
+
| `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Things appearing — sheets, toasts, screen pushes |
|
|
535
|
+
| `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Things leaving — dismissals, pops |
|
|
536
|
+
| `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — collapsible cards, tab swaps |
|
|
537
|
+
| `ease-spring` | `cubic-bezier(0.34, 1.56, 0.64, 1)` | Reserved — order-success checkmark, wishlist heart pop. Nowhere routine. |
|
|
538
|
+
|
|
539
|
+
**Signature motions.**
|
|
540
|
+
|
|
541
|
+
1. **Wishlist heart pop.** When the user taps the heart icon on a product card, the outline transitions to filled `#FA2E5F` over `motion-fast / ease-spring`, with a 1.0 → 1.25 → 1.0 scale pop. The overshoot is licensed here because the gesture is emotional — adding to wishlist is "saying yes" and the heart should feel it.
|
|
542
|
+
2. **Sale timer tick.** The seconds digit re-renders every 1000ms with `motion-fast / ease-standard`, briefly going `opacity: 0.7` → `opacity: 1.0` to communicate liveness. The minutes/hours digits do not animate per-tick (would feel noisy).
|
|
543
|
+
3. **Bottom-sheet presentation.** Sheets rise from `y+40px` with `motion-standard / ease-enter` and a synchronized backdrop fade `rgba(0,0,0,0)` → `rgba(0,0,0,0.5)`. Dismissal uses `motion-fast / ease-exit` — leaving is lighter than entering.
|
|
544
|
+
4. **Order-success checkmark.** The pink checkmark on the order-complete screen draws over `motion-slow / ease-spring`. This and the wishlist heart are the only two places spring easing is licensed.
|
|
545
|
+
5. **Reduce motion.** If `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. Crossfades replace slides. Spring overshoots fall back to linear. The app stays usable; just less kinetic.
|
|
546
|
+
|
|
547
|
+
<!--
|
|
548
|
+
OmD v0.1 Sources — Philosophy Layer (sections 10–15)
|
|
549
|
+
|
|
550
|
+
Direct verification (2026-05-13):
|
|
551
|
+
- https://m.a-bly.com — confirms live site, page title "에이블리 | 전상품 무료배송",
|
|
552
|
+
mobile-first redirect from www.a-bly.com → m.a-bly.com.
|
|
553
|
+
|
|
554
|
+
Brand/founder/culture sources (WebSearch + WebFetch):
|
|
555
|
+
- https://ably-team.medium.com/ably-culture-a640fb3f7cf9 — Ably Team Medium,
|
|
556
|
+
"에이블리는 면접이라는 단어를 사용하지 않는다" — confirms internal language norms
|
|
557
|
+
(팀원 vs 직원, 인터뷰 vs 면접) and the anti-corporate register.
|
|
558
|
+
- https://www.sedaily.com/NewsView/22SSWLO75W — Sedaily interview with Kang Suk-hoon,
|
|
559
|
+
founder positioning ("패알못이 만든 패션 플랫폼", taste-driven commerce framing).
|
|
560
|
+
- https://economist.co.kr/article/view/ecn202405080023 — Economist Korea (May 2024),
|
|
561
|
+
"조 단위 거래액" — scale & operating discipline context.
|
|
562
|
+
- https://www.hankyung.com/economy/article/2020122085521 — Hankyung (Dec 2020),
|
|
563
|
+
2700% growth, founder-quoted vision.
|
|
564
|
+
- https://www.smartfn.co.kr/article/view/sfn202402130003 — SmartFN (Feb 2024),
|
|
565
|
+
annual profitability framing.
|
|
566
|
+
- https://www.kedglobal.com/korean-startups/newsView/ked202310120014 — KED Global (Oct 2023),
|
|
567
|
+
Ably-Meta AI ad measurement partnership; explicit "Ably Corp vs ably.com" disambiguation.
|
|
568
|
+
|
|
569
|
+
Not independently verified via WebFetch — widely documented:
|
|
570
|
+
- Ably (Ably Corp) was founded in 2018 by Kang Suk-hoon (강석훈).
|
|
571
|
+
- 50M+ app downloads by late 2024 and 10M MAU by mid-2025 are widely reported
|
|
572
|
+
but exact figures should be re-verified against Ably PR before being shipped as facts.
|
|
573
|
+
|
|
574
|
+
Personas (§13) are fictional archetypes informed by publicly described Korean
|
|
575
|
+
MZ commerce user segments. Any resemblance to specific individuals is unintended.
|
|
576
|
+
|
|
577
|
+
Interpretive claims (e.g., "pink earns its appearance", "image is the protagonist")
|
|
578
|
+
are editorial readings of the live brand surface, not documented Ably statements.
|
|
579
|
+
|
|
580
|
+
§4 token values are flagged as `(unverified live)` in the §4 footer; Phase U2
|
|
581
|
+
live `getComputedStyle` re-capture is required to upgrade them to verified.
|
|
582
|
+
-->
|