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
package/data/reference-tags.md
CHANGED
|
@@ -80,6 +80,17 @@ Use this table to match user descriptions to reference candidates. Pick 3-6 refe
|
|
|
80
80
|
| wise | #9fe870 | Fintech | bold, fresh, optimistic, nature-inspired, lime, green |
|
|
81
81
|
| x.ai | #ffffff | AI | brutalist, dark, minimal, terminal, engineering, restrained |
|
|
82
82
|
| zapier | #ff4f00 | Productivity | warm, approachable, professional, organic, energetic, orange |
|
|
83
|
+
| coupang | #E94B22 | E-commerce | direct, transactional, deal-driven, results-first, utility, dense |
|
|
84
|
+
| kakaobank | #FFE300 | Fintech | friendly, plain-spoken, warm, formal-when-needed, personal, trustworthy |
|
|
85
|
+
| krds | #256EF4 | Government | polite, predictable, accessible, clear, neutral, civic |
|
|
86
|
+
| kurly | #5F0080 | E-commerce | calm, curated, operational, warm, restrained, editorial |
|
|
87
|
+
| musinsa | #000000 | E-commerce | editorial, compact, declarative, monochrome, magazine |
|
|
88
|
+
| naver | #03C75A | Consumer | pragmatic, neutral, factual, clinical, utility |
|
|
89
|
+
| ohouse | #35C5F0 | Consumer | warm, observational, sensory, spatial, aspirational, calm |
|
|
90
|
+
| qanda | #FF5500 | Consumer | warm, encouraging, low-pressure, calm, reassuring, tutor-like |
|
|
91
|
+
| ridi | #3D3D3D | Consumer | calm, literate, editorial, low-pressure, bookish, respectful |
|
|
92
|
+
| yanolja | #F54B1E | Travel | friendly, casual, energetic, playful, conversational, leisure |
|
|
93
|
+
| yeogiotte | #1D8BFF | Travel | plain, polite, hospitable, confident, factual |
|
|
83
94
|
|
|
84
95
|
## Shortcut Mappings
|
|
85
96
|
|
|
@@ -95,7 +106,10 @@ Common user descriptions → recommended references:
|
|
|
95
106
|
- "크리에이티브, 디자인" → figma, framer, clay, replicate, miro
|
|
96
107
|
- "럭셔리, 프리미엄" → apple, stripe, superhuman, ferrari, resend
|
|
97
108
|
- "AI, LLM 서비스" → claude, cohere, mistral.ai, together.ai, x.ai
|
|
98
|
-
- "한국 서비스" → toss, karrot, baemin, kakao
|
|
109
|
+
- "한국 서비스" → toss, karrot, baemin, kakao, naver, kakaobank, ohouse, ridi, qanda
|
|
110
|
+
- "한국 이커머스" → coupang, musinsa, kurly
|
|
111
|
+
- "한국 여행" → yeogiotte, yanolja
|
|
112
|
+
- "공공, 행정, 정부" → krds
|
|
99
113
|
- "대만 서비스" → pinkoi, dcard
|
|
100
114
|
- "일본 서비스" → line, mercari, freee
|
|
101
115
|
- "아시아 커머스, 디자이너 마켓" → pinkoi, airbnb, karrot, pinterest
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "oh-my-design-cli",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "Bootstrap oh-my-design skills + agents into your project. After install, talk to your AI coding agent in natural language — no other CLI commands.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
"skills/omd-sync",
|
|
18
18
|
"agents",
|
|
19
19
|
"data",
|
|
20
|
-
"references
|
|
20
|
+
"web/references/*/DESIGN.md",
|
|
21
21
|
".claude/hooks/*.cjs",
|
|
22
22
|
".claude/settings.json",
|
|
23
23
|
"AGENTS.md",
|
|
@@ -40,7 +40,7 @@ DESIGN.md를 모든 UI/디자인 작업의 권위 있는 컨텍스트로 사용
|
|
|
40
40
|
| "이 인터랙션 / 모션 / 포커스 / 모바일 / 지각 성능 / 섹션별 UX 약점" | dispatch `omd-ux-engineer` | 코드 레벨 인터랙션 감사 + fix |
|
|
41
41
|
| "랜딩 / 메인 화면 / 페이지 *전체*를 전문가 의견으로 개선" | dispatch `omd-ux-writer` + `omd-ux-engineer` (병렬) | 두 트랙 동시 — writing + engineering |
|
|
42
42
|
| "이게 왜 안 좋은지 critique / postmortem / root cause" | dispatch `omd-critic` | 비판적 분석 |
|
|
43
|
-
| "DESIGN.md 만들어 / reference 골라 /
|
|
43
|
+
| "DESIGN.md 만들어 / reference 골라 / 카탈로그에서 추천" | dispatch `omd-init` skill (또는 omd-add-reference) | reference 매칭 |
|
|
44
44
|
| "preference 정리 / 누적된 교정 반영 / DESIGN.md 업데이트" | dispatch `omd-learn` skill | fold-in 로직 |
|
|
45
45
|
| "이 한 줄 / 이 컬러 / 이 spacing 좀" 단발 명확 | **인라인 처리** | 분명한 단일 변경 |
|
|
46
46
|
| 위 어디에도 안 맞는 자유로운 디자인 작업 | 인라인 처리 후 Phase 3 (교정 캡처) | 일반 케이스 |
|
|
@@ -128,7 +128,7 @@ test -d "${RUN_DIR}" && test -f "${RUN_DIR}/task.md" && echo "OK" || echo "FAIL"
|
|
|
128
128
|
|
|
129
129
|
다음 파일을 Read 툴로 전체 로드:
|
|
130
130
|
|
|
131
|
-
- `.claude/data/reference-fingerprints.json` —
|
|
131
|
+
- `.claude/data/reference-fingerprints.json` — reference fingerprint (tone keywords, visual theme, antipatterns, signature motion, has_personas, category)
|
|
132
132
|
- `.claude/data/reference-tags.md` — 사람-읽기용 keyword 매트릭스
|
|
133
133
|
- `.claude/data/vocabulary.json` — controlled vocab
|
|
134
134
|
|
|
@@ -160,14 +160,14 @@ DESIGN.md가 없어서 reference 한 개를 골라 부트스트랩할게요. <ta
|
|
|
160
160
|
|
|
161
161
|
이대로 가시려면 go (또는 <top1.id>).
|
|
162
162
|
다른 후보: <top2.id> (한 줄 이유) · <top3.id> (...) · <top4.id> (...) · <top5.id> (...)
|
|
163
|
-
본인이 아는 다른 reference면 한 줄로 id만 (예: vercel) —
|
|
163
|
+
본인이 아는 다른 reference면 한 줄로 id만 (예: vercel) — reference 카탈로그에 없으면 알려드립니다.
|
|
164
164
|
```
|
|
165
165
|
|
|
166
166
|
### 3.6 사용자 응답 처리
|
|
167
167
|
|
|
168
168
|
- `go` 또는 reference id (top-5 안) → 그 id로 master spawn
|
|
169
169
|
- 다른 reference id (top-5 밖이지만 카탈로그 안) → 동일하게 진행
|
|
170
|
-
- 카탈로그에 없는 id → "해당 id는
|
|
170
|
+
- 카탈로그에 없는 id → "해당 id는 reference 카탈로그에 없어요. top-5 중에서 골라주세요."
|
|
171
171
|
- `중단` → 종료
|
|
172
172
|
|
|
173
173
|
## Step 4 — Master 호출 (handoff loop)
|
package/skills/omd-init/SKILL.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: omd:init
|
|
3
|
-
description: "프로젝트 루트에 DESIGN.md를 부트스트랩 —
|
|
3
|
+
description: "프로젝트 루트에 DESIGN.md를 부트스트랩 — 실제 기업 레퍼런스 중 컨텍스트 매칭으로 추천하고 선택된 레퍼런스의 톤&매너를 보존한 variation을 생성. DESIGN.md 부재 상태에서의 UI 작업 또는 '디자인 시스템 세팅', 'set up our design system', 「デザインシステムを作って」, 「建立設計系統」류의 요청에 트리거. CLAUDE.md / AGENTS.md / Cursor rule shim도 함께 설치."
|
|
4
4
|
---
|
|
5
5
|
|
|
6
6
|
# omd:init — DESIGN.md Bootstrap
|
|
@@ -56,7 +56,7 @@ omd init prepare --ref <id> --description "<원본 description>" --json
|
|
|
56
56
|
```
|
|
57
57
|
|
|
58
58
|
이게 하는 일:
|
|
59
|
-
- `references/<id>/DESIGN.md` 경로 확정 (JSON에 `reference_md` 필드로 전체 내용 포함)
|
|
59
|
+
- `web/references/<id>/DESIGN.md` 경로 확정 (JSON에 `reference_md` 필드로 전체 내용 포함)
|
|
60
60
|
- 기존 `DESIGN.md`가 있으면 → `DESIGN_DEPRECATED.md`로 rename (메타 헤더 자동 삽입)
|
|
61
61
|
- `.omd/init-context.json` 작성 (`delta_set`, `description` 담김)
|
|
62
62
|
|
package/web/AGENTS.md
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
<!-- BEGIN:nextjs-agent-rules -->
|
|
2
|
+
# This is NOT the Next.js you know
|
|
3
|
+
|
|
4
|
+
This version has breaking changes — APIs, conventions, and file structure may all differ from your training data. Read the relevant guide in `node_modules/next/dist/docs/` before writing any code. Heed deprecation notices.
|
|
5
|
+
<!-- END:nextjs-agent-rules -->
|
|
@@ -0,0 +1,445 @@
|
|
|
1
|
+
---
|
|
2
|
+
omd: 0.1
|
|
3
|
+
brand: 29CM
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Design System Inspiration of 29CM
|
|
7
|
+
|
|
8
|
+
## 1. Visual Theme & Atmosphere
|
|
9
|
+
|
|
10
|
+
29CM is the editorial select-shop of Korean e-commerce — a curated department store that happens to live online, whose homepage reads more like the cover of a printed lookbook than the landing page of a retailer. The signature surface is pure white (`#ffffff`) carrying pure black (`#000000`) display type and quietly minimal chrome: no shadows, no gradients, no decorative iconography. The composition leans on the photography to do the heavy lifting and on typography to do the directing. Where Musinsa is street-utility and Ohouse is interior-lifestyle, 29CM is the magazine — generous margins, oversized image columns, captions that read like editorial blurbs, and an unmistakable belief that white space is the most expensive material in the room.
|
|
11
|
+
|
|
12
|
+
The defining typographic move is **Pretendard Variable** running across the entire surface in a tight three-step hierarchy: 30px/700 category headlines, 22px/700 editorial card titles, 12-15px body. There is no display-only face, no decorative weight; the same Korean sans does the magazine title, the product price, and the footer note. Buttons are unornamented — the workhorse CTA is a 1px `#C4C4C4` outlined pill on white with 4px corners ("더보기"), and the floating help affordances ("FAQ", "1:1 문의") are solid `#000000` rectangles with white text and 2px radius, treated like editorial captions rather than UI controls. There is no "primary blue", no accent purple, no brand red. The brand color is the absence of color.
|
|
13
|
+
|
|
14
|
+
Image presentation is the second signature: full-bleed editorial photography sets the rhythm, each PT (Presentation) or Showcase tile leads with one large image and one Korean sentence underneath as caption. Prices are demoted — set at 12px/700, sitting under a 12px/400 product title in muted `rgba(93,93,93,0.64)` (a soft grey nearly invisible until you look for it). The visual order is: photo first, story second, product third, price last. That ordering is the brand's whole thesis.
|
|
15
|
+
|
|
16
|
+
**Key Characteristics:**
|
|
17
|
+
- Pretendard Variable across all surfaces — one font, three weights (400 / 700 / 800), no display companion
|
|
18
|
+
- Pure `#ffffff` page background, pure `#000000` ink — no off-whites, no warm neutrals
|
|
19
|
+
- Three-tier display hierarchy: 30px section headline / 22px card title / 12-15px body & price
|
|
20
|
+
- Border-radius restraint: 2px for inverted CTAs, 4px for ghost buttons, 0px on most editorial chrome
|
|
21
|
+
- Muted secondary text via `rgba(93,93,93,0.64)` — a single transparent grey, not a swatch
|
|
22
|
+
- 1px solid `#C4C4C4` outlines for ghost buttons — never colored, never thicker
|
|
23
|
+
- 12px/700 prices, 12px/400 product names — both subordinate to the image
|
|
24
|
+
- Generous editorial padding: 20-48px page margins, multi-line lh ≈ 1.36-1.5 on Korean body
|
|
25
|
+
- No shadow system on the homepage — elevation reads as "raised image", not "elevated card"
|
|
26
|
+
- Lowercase, English-leaning category labels (`Special-Order`, `Showcase`, `Lookbook`, `29Magazine`) at 24-30px/700 — the brand's editorial register made literal
|
|
27
|
+
|
|
28
|
+
## 2. Color Palette & Roles
|
|
29
|
+
|
|
30
|
+
### Primary
|
|
31
|
+
- **Pure Black** (`#000000`): Body ink, headings, inverted CTA backgrounds, footer headings. The brand's only "color" in the strictest sense.
|
|
32
|
+
- **Pure White** (`#ffffff`): Page background, ghost-button background, inverted-CTA text. Total white — not `#fafafa`, not `#f5f5f5`.
|
|
33
|
+
|
|
34
|
+
### Greys (functional, not branded)
|
|
35
|
+
- **Muted Grey 64%** (`rgba(93, 93, 93, 0.64)`): Secondary captions, "옵션비 별도" hints, badge counts, inactive nav items. The single most-used non-primary color on the site, and it is a transparency, not a swatch — meaning the actual rendered colour shifts with whatever sits behind it.
|
|
36
|
+
- **Outline Grey** (`#c4c4c4`): The only border colour used for ghost-style buttons and editorial tile dividers. Mid-light, neutral, no warm tint.
|
|
37
|
+
|
|
38
|
+
### Accent / State (sparse)
|
|
39
|
+
- **Sale Red** (`#ff0066` / `#ff003c` family): Appears only on discount badges and percent-off pills on product cards. Never used for UI affordances or CTAs.
|
|
40
|
+
- **Brand Black on Brand Black**: Floating help CTAs ("FAQ", "1:1 문의") use `#000000` background with `#ffffff` text — the inverse of the page, treated as a high-contrast, low-frequency control.
|
|
41
|
+
|
|
42
|
+
### What 29CM Explicitly Does Not Use
|
|
43
|
+
- No brand blue, brand purple, or brand red. The category buttons that read "FAQ"/"1:1 문의" are not "primary" — they are inverted black, the same as the footer.
|
|
44
|
+
- No tinted neutrals (no `#fafafa`, no warm cream). Backgrounds are `#ffffff`, full stop.
|
|
45
|
+
- No semantic colour system beyond the discount-red badge. There is no success-green, warning-yellow, or info-blue on the marketing surface.
|
|
46
|
+
|
|
47
|
+
## 3. Typography Rules
|
|
48
|
+
|
|
49
|
+
### Font Family
|
|
50
|
+
- **Primary**: `Pretendard Variable`, with fallback chain `ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"`
|
|
51
|
+
- **Single-family system**: There is no separate display face, no serif companion, no monospace. Pretendard Variable handles 100% of legible surfaces.
|
|
52
|
+
|
|
53
|
+
### Hierarchy
|
|
54
|
+
|
|
55
|
+
| Role | Size | Weight | Line Height | Notes |
|
|
56
|
+
|------|------|--------|-------------|-------|
|
|
57
|
+
| Section Headline (Special-Order / 29Magazine) | 30px | 700 | ~1.13 | Lowercase-English / mixed Korean editorial headlines |
|
|
58
|
+
| Sub-Headline (lower category) | 24px | 700 | ~1.21 | Smaller category nav items |
|
|
59
|
+
| Editorial Card Title | 22px | 700 | 29.92px (1.36) | The signature card title — PT subjects, themed collections |
|
|
60
|
+
| Editorial Body / Description | 15px | 400 | 22.5px (1.50) | Card descriptions, editorial blurbs |
|
|
61
|
+
| Nav Link (primary) | 16px | 200-800 | normal | 200 = inactive secondary, 800 = active "BEST" / current section |
|
|
62
|
+
| Floating CTA ("FAQ", "1:1 문의") | 15px | 400 | normal | Black bg, white text, 2px radius |
|
|
63
|
+
| Ghost CTA ("더보기") | 14px | 700 | normal | White bg, 1px `#c4c4c4` border |
|
|
64
|
+
| Footer Heading | 13px | 700 | 18.2px (1.40) | Caps Latin section labels — `NOTICE`, `ABOUT US`, `MY ORDER`, `HELP` |
|
|
65
|
+
| Product Name (card) | 12px | 400 | 16.32px (1.36) | Black ink, restrained, sits under the image |
|
|
66
|
+
| Product Price | 12px | 700 | 16.32px (1.36) | Same size as the name — price never dominates the card |
|
|
67
|
+
| Price Caption ("옵션비 별도") | 12px | 400 | 16.32px (1.36) | In `rgba(93,93,93,0.64)` grey |
|
|
68
|
+
|
|
69
|
+
### Principles
|
|
70
|
+
|
|
71
|
+
- **One family, three weights.** Pretendard Variable at 400 (body, captions), 700 (titles, prices, ghost CTAs), and 800 (active navigation). 200 appears on inactive secondary nav as a quiet hint. There is no italic; emphasis is by weight, never style.
|
|
72
|
+
- **Editorial card title = 22px/700.** This is the unit of voice. Most magazine-style tiles on the homepage carry one 22-29px Korean sentence at weight 700, then a 15px/400 description in the same line-height ratio. The pair is the brand's grammar.
|
|
73
|
+
- **Latin labels at large sizes, Korean at body sizes.** Category navigation uses English (`Special-Order`, `Showcase`, `PT`, `29Magazine`) at display sizes (24-30px), while Korean dominates body and editorial copy. The mixing is intentional — the English serves as a magazine table-of-contents register.
|
|
74
|
+
- **Prices are never the loudest thing on a card.** 12px/700 is by design subordinate to the 22px title and the photo. Where Coupang puts price first, 29CM puts price last.
|
|
75
|
+
- **Letter-spacing is `normal` almost everywhere.** No tight tracking, no display-tracking compensation. The font is well-cut enough to carry display sizes without spacing intervention.
|
|
76
|
+
- **Line-height ≈ 1.36-1.50.** Korean bodies need air; the editorial register needs more. 1.36 on titles, 1.50 on prose — never tighter.
|
|
77
|
+
|
|
78
|
+
## 4. Component Stylings
|
|
79
|
+
|
|
80
|
+
### Buttons
|
|
81
|
+
|
|
82
|
+
**Ghost Outline (the workhorse — "더보기")**
|
|
83
|
+
- Background: `#ffffff`
|
|
84
|
+
- Text: `#000000`
|
|
85
|
+
- Border: `1px solid #c4c4c4`
|
|
86
|
+
- Radius: 4px
|
|
87
|
+
- Padding: 16px 16px 16px 20px (asymmetric — slightly larger left for trailing-arrow icon)
|
|
88
|
+
- Height: 52px
|
|
89
|
+
- Font: 14px Pretendard Variable weight 700
|
|
90
|
+
- Use: "더보기 / View more" on every editorial section ending, primary "load more" affordance
|
|
91
|
+
|
|
92
|
+
**Inverted Solid (floating help — "FAQ", "1:1 문의")**
|
|
93
|
+
- Background: `#000000`
|
|
94
|
+
- Text: `#ffffff`
|
|
95
|
+
- Border: none
|
|
96
|
+
- Radius: 2px
|
|
97
|
+
- Padding: 4px 8px 4px 14px (asymmetric — leading icon space)
|
|
98
|
+
- Height: 31px
|
|
99
|
+
- Font: 15px Pretendard Variable weight 400
|
|
100
|
+
- Use: Fixed-position floating help controls on the bottom-right; the only persistent solid-fill control on the site
|
|
101
|
+
|
|
102
|
+
**Category Pill (navigation count badges — "63", "175", "6K")**
|
|
103
|
+
- Background: transparent
|
|
104
|
+
- Text: `rgba(93, 93, 93, 0.64)`
|
|
105
|
+
- Border: none
|
|
106
|
+
- Radius: 4px (inherited from container)
|
|
107
|
+
- Padding: 0
|
|
108
|
+
- Height: 52px (tap target, not visual height)
|
|
109
|
+
- Font: 16px Pretendard Variable weight 400
|
|
110
|
+
- Use: Category nav row count badges — number-only, large tap target, no visual chrome
|
|
111
|
+
|
|
112
|
+
**Sale Discount Pill** (product card overlay)
|
|
113
|
+
- Background: `#ffffff` or transparent
|
|
114
|
+
- Text: `#ff0066` (sale red)
|
|
115
|
+
- Border: none
|
|
116
|
+
- Radius: 0px
|
|
117
|
+
- Font: 12px weight 700
|
|
118
|
+
- Use: Percent-off badge on product cards, often paired with the price
|
|
119
|
+
|
|
120
|
+
### Cards & Containers
|
|
121
|
+
|
|
122
|
+
**Editorial Tile** (PT / Showcase / Magazine)
|
|
123
|
+
- Background: `#ffffff`
|
|
124
|
+
- Border: none
|
|
125
|
+
- Radius: 0px on the outer container; image inherits 0px (square / hard-edged)
|
|
126
|
+
- Padding: image full-bleed; caption block has 16-20px top padding
|
|
127
|
+
- Shadow: none — relies on photography and whitespace for separation
|
|
128
|
+
- Title: 22px / 700 / `#000000` / lh 29.92px sitting directly under the image
|
|
129
|
+
- Body: 15px / 400 / `#000000` / lh 22.5px
|
|
130
|
+
- Use: The dominant homepage unit — themed brand stories, lookbooks, editor curations
|
|
131
|
+
|
|
132
|
+
**Product Card**
|
|
133
|
+
- Background: `#ffffff`
|
|
134
|
+
- Border: none
|
|
135
|
+
- Radius: 0px
|
|
136
|
+
- Image: square or 4:5 portrait, 0px radius
|
|
137
|
+
- Title: 12px / 400 / `#000000` directly under the image
|
|
138
|
+
- Price: 12px / 700 / `#000000` (or red `#ff0066` if on sale)
|
|
139
|
+
- Caption ("옵션비 별도", "무료배송"): 12px / 400 / `rgba(93,93,93,0.64)`
|
|
140
|
+
- Spacing: 8-12px between rows of the card meta block
|
|
141
|
+
- Use: Standard catalog item — image-first, text small, no chrome
|
|
142
|
+
|
|
143
|
+
### Inputs & Forms
|
|
144
|
+
|
|
145
|
+
- Background: `#ffffff`
|
|
146
|
+
- Border: none on the homepage search affordance; bottom-rule only on focus
|
|
147
|
+
- Radius: 0px
|
|
148
|
+
- Font: Pretendard Variable
|
|
149
|
+
- Style: Editorial — search reads as a header-bar input, not a boxed UI control. When boxed elsewhere (PDP, checkout) it uses a 1px `#c4c4c4` border and 4px radius matching the ghost button.
|
|
150
|
+
|
|
151
|
+
### Navigation
|
|
152
|
+
|
|
153
|
+
- Header background: `#ffffff` (transparent over hero on scroll)
|
|
154
|
+
- Layout: logo center / utility links left and right at 16px / weight 200
|
|
155
|
+
- Primary category row: 16-30px Latin labels, weight 700-800 active, 200 inactive
|
|
156
|
+
- Logo: 29CM wordmark — see Logo asset
|
|
157
|
+
- Sticky behaviour: header stays, drops the secondary category row after scroll
|
|
158
|
+
- Mobile: hamburger toggle, full-screen sheet with same hierarchy
|
|
159
|
+
|
|
160
|
+
### Footer
|
|
161
|
+
|
|
162
|
+
- Background: `#ffffff`
|
|
163
|
+
- Padding: 20px 48px 48px (asymmetric — tight top, generous bottom)
|
|
164
|
+
- Section headings: 13px / weight 700 / `#000000`, all-caps Latin (`NOTICE`, `ABOUT US`, `MY ORDER`, `MY ACCOUNT`, `HELP`)
|
|
165
|
+
- Body links: ~13-14px / weight 400 / `#000000`
|
|
166
|
+
- No background tint, no top border — the footer is just more whitespace with denser type
|
|
167
|
+
|
|
168
|
+
### Decorative Elements
|
|
169
|
+
|
|
170
|
+
- **No iconography on hero/editorial surfaces.** Decorative graphics are intentionally absent; the image is the decoration.
|
|
171
|
+
- **Trailing-arrow on ghost CTAs.** "더보기" buttons carry a thin `>` chevron at the right — the only systematic icon use on marketing surfaces.
|
|
172
|
+
- **Sale red as the single accent.** When a percent-off ribbon appears on a product, it is the only chromatic moment on that tile. The restraint makes it work.
|
|
173
|
+
|
|
174
|
+
---
|
|
175
|
+
|
|
176
|
+
**Verified:** 2026-05-13 (omd:add-reference CREATE)
|
|
177
|
+
**Tier 1 sources:** www.29cm.co.kr/ (live DOM inspect, Pretendard Variable + #000/#fff + 22px/700 editorial cards + 1px `#c4c4c4` ghost CTAs + 2px-radius floating black CTAs — confirmed via getComputedStyle on home surface, scroll-loaded editorial tiles, footer, and floating help affordances)
|
|
178
|
+
**Tier 2 sources:** getdesign.md/29cm — *no entry returned* ("No designs found for '29cm'"); styles.refero.design/?q=29cm — *no 29CM-tagged styles found* (search returned generic editorial/gallery references unrelated to 29CM)
|
|
179
|
+
**Conflicts unresolved:** none — Tier 2 was silent on every claim, so Tier 1 live observation is the sole source. Token values in this section come exclusively from live `getComputedStyle()` on www.29cm.co.kr 2026-05-13.
|
|
180
|
+
|
|
181
|
+
## 5. Layout Principles
|
|
182
|
+
|
|
183
|
+
### Spacing System
|
|
184
|
+
- Base unit: 4px (derived from 4-8-12-16-20-24-32-48 cascade observed in padding values)
|
|
185
|
+
- Page horizontal margin: 48px desktop, ~16-20px mobile
|
|
186
|
+
- Editorial tile gap: 24-32px between major sections
|
|
187
|
+
- Card meta gap (image → title → price): 8-12px between rows
|
|
188
|
+
- Footer block padding: 20px top / 48px bottom — asymmetric, generous at the bottom
|
|
189
|
+
|
|
190
|
+
### Grid & Container
|
|
191
|
+
- Max content width: ~1280px centered, with full-bleed exceptions for hero editorial
|
|
192
|
+
- Editorial grid: 2-column on tablet, 3-4 column on desktop for product tiles, 1-2 column for PT/Magazine stories
|
|
193
|
+
- Hero: typically full-bleed image with 30px/700 caption sitting beneath, not overlaid
|
|
194
|
+
- Category nav row: horizontal scroll on mobile, fully visible on desktop
|
|
195
|
+
|
|
196
|
+
### Whitespace Philosophy
|
|
197
|
+
- **Whitespace is the brand asset.** 29CM treats empty space the way Apple treats it on iPhone hero pages — as proof that the curation was tight enough to remove rather than add.
|
|
198
|
+
- **Photography is the second voice.** Image columns are oversized relative to text columns; captions stay short and well-set rather than competing with the image.
|
|
199
|
+
- **Price is not the destination.** The vertical rhythm of a product card — image, title, price — keeps price last so the user reads narrative before number.
|
|
200
|
+
|
|
201
|
+
### Border Radius Scale
|
|
202
|
+
- 0px: Images, editorial tiles, search inputs, category labels — most surfaces
|
|
203
|
+
- 2px: Inverted black CTAs (`FAQ`, `1:1 문의`) — the smallest radius in the system, used on the highest-contrast control
|
|
204
|
+
- 4px: Ghost outline buttons (`더보기`), boxed form inputs on PDP
|
|
205
|
+
- No pill shapes, no >8px radii anywhere on the marketing surface
|
|
206
|
+
|
|
207
|
+
## 6. Depth & Elevation
|
|
208
|
+
|
|
209
|
+
| Level | Treatment | Use |
|
|
210
|
+
|-------|-----------|-----|
|
|
211
|
+
| Flat (Level 0) | No shadow, no border | Page background, editorial tiles, product cards — the dominant state |
|
|
212
|
+
| Outline (Level 1) | `1px solid #c4c4c4` | Ghost CTAs, boxed form inputs |
|
|
213
|
+
| Inverted (Level 2) | `#000000` background on `#ffffff` page | Floating help CTAs, footer headings — "elevation by colour inversion" |
|
|
214
|
+
| Image-as-elevation | Photography on white | Editorial tiles — the photograph itself reads as the lifted layer, no shadow needed |
|
|
215
|
+
| Focus | 2px black outline offset | Keyboard focus ring on interactive elements |
|
|
216
|
+
|
|
217
|
+
**Shadow Philosophy.** 29CM's marketing surface has no shadow system. The page is flat by design — depth comes from photographic content sitting on white, not from CSS box-shadows. The closest thing to "elevation" is the high-contrast inverted black CTA, which reads as an editorial pull-quote callout rather than a UI button. Adding a `0px 4px 8px rgba(0,0,0,0.1)` shadow to a 29CM tile would immediately look off-brand — it would push the page from "magazine" toward "SaaS dashboard".
|
|
218
|
+
|
|
219
|
+
## 7. Do's and Don'ts
|
|
220
|
+
|
|
221
|
+
### Do
|
|
222
|
+
- Use Pretendard Variable on every text element — there is no second face.
|
|
223
|
+
- Pair every editorial tile with one photograph and one short Korean caption at 22px/700.
|
|
224
|
+
- Use `#000000` and `#ffffff` as the only structural colours; `rgba(93,93,93,0.64)` for muted captions.
|
|
225
|
+
- Keep border-radius at 0px, 2px, or 4px — nothing above 4px on marketing surfaces.
|
|
226
|
+
- Subordinate price (12px/700) to title and image; never invert this order.
|
|
227
|
+
- Lean on whitespace for separation — 24-48px between sections, not borders or dividers.
|
|
228
|
+
- Use the inverted black CTA (`#000000` bg / `#ffffff` text / 2px radius) sparingly for high-priority, persistent affordances only.
|
|
229
|
+
- Mix Latin labels (Special-Order, Showcase, 29Magazine) at display sizes with Korean body copy at smaller sizes.
|
|
230
|
+
|
|
231
|
+
### Don't
|
|
232
|
+
- Don't add box-shadows to editorial tiles or product cards — the homepage is flat.
|
|
233
|
+
- Don't introduce a brand blue, brand red, or brand purple for CTAs. The brand "colour" is monochrome.
|
|
234
|
+
- Don't use pill-shaped buttons or radii above 8px anywhere on marketing surfaces.
|
|
235
|
+
- Don't promote price to the top of a card or to the largest size — image first, price last.
|
|
236
|
+
- Don't use italic for emphasis; emphasis is by weight (400 → 700).
|
|
237
|
+
- Don't tint backgrounds (`#fafafa`, `#f5f5f5`) — 29CM is pure white.
|
|
238
|
+
- Don't compose hero text overlaid on photography; 29CM almost always sets caption *below* the image, not on top.
|
|
239
|
+
- Don't use decorative iconography on hero — the image is the decoration.
|
|
240
|
+
|
|
241
|
+
## 8. Responsive Behavior
|
|
242
|
+
|
|
243
|
+
### Breakpoints
|
|
244
|
+
| Name | Width | Key Changes |
|
|
245
|
+
|------|-------|-------------|
|
|
246
|
+
| Mobile | <768px | 1-column editorial tiles, 2-column product grid, hamburger nav, 16-20px page margin |
|
|
247
|
+
| Tablet | 768-1024px | 2-column editorial, 3-column product grid, condensed nav |
|
|
248
|
+
| Desktop | 1024-1440px | 2-3 column editorial, 4-column product grid, full top nav row |
|
|
249
|
+
| Large Desktop | >1440px | 1280px max centered content, generous margins flanking |
|
|
250
|
+
|
|
251
|
+
### Touch Targets
|
|
252
|
+
- Category badge buttons: 52px tap height even when visually smaller
|
|
253
|
+
- Floating CTAs ("FAQ", "1:1 문의"): 31px height — minimum acceptable on mobile, paired with 8-12px padding
|
|
254
|
+
- Editorial tiles: full tile is tappable, no separate "view" button
|
|
255
|
+
|
|
256
|
+
### Collapsing Strategy
|
|
257
|
+
- Section headlines: 30px → 22px on mobile, weight 700 maintained
|
|
258
|
+
- Nav row: full horizontal list → hamburger sheet
|
|
259
|
+
- Product grid: 4-column → 2-column on mobile, image-aspect maintained
|
|
260
|
+
- Page margin: 48px → 16-20px on mobile
|
|
261
|
+
- Floating help CTA: stays bottom-right at all viewports — the one consistent control
|
|
262
|
+
|
|
263
|
+
### Image Behavior
|
|
264
|
+
- Editorial photography: full-bleed at all sizes; aspect ratio held
|
|
265
|
+
- Product cards: square or 4:5 portrait, maintained on mobile
|
|
266
|
+
- No lazy-load skeletons styled as cards — placeholder is a flat grey block, no shimmer
|
|
267
|
+
|
|
268
|
+
## 9. Agent Prompt Guide
|
|
269
|
+
|
|
270
|
+
### Quick Token Reference
|
|
271
|
+
- Page background: `#ffffff`
|
|
272
|
+
- Body text: `#000000`
|
|
273
|
+
- Muted text: `rgba(93,93,93,0.64)` (transparent grey on white = `#5d5d5d` at 64% opacity)
|
|
274
|
+
- Outline grey: `#c4c4c4`
|
|
275
|
+
- Sale red: `#ff0066` family (badge-only)
|
|
276
|
+
- Primary CTA: inverted black — `#000000` bg, `#ffffff` text, 2px radius
|
|
277
|
+
- Secondary CTA: ghost — `#ffffff` bg, `#000000` text, `1px solid #c4c4c4`, 4px radius
|
|
278
|
+
- Font family: `Pretendard Variable, ui-sans-serif, system-ui, sans-serif`
|
|
279
|
+
- Section headline: 30px / 700 / lh 1.13
|
|
280
|
+
- Editorial title: 22px / 700 / lh 29.92px
|
|
281
|
+
- Editorial body: 15px / 400 / lh 22.5px
|
|
282
|
+
- Product name: 12px / 400
|
|
283
|
+
- Product price: 12px / 700
|
|
284
|
+
|
|
285
|
+
### Example Component Prompts
|
|
286
|
+
- "Create an editorial tile: full-bleed photograph on top, then 16px gap, then 22px Pretendard Variable weight 700 Korean headline in `#000000`, then 8px gap, then 15px weight 400 description in `#000000`. No border, no shadow, no radius. White page background."
|
|
287
|
+
- "Build a 'View more' ghost button: white background, 1px solid `#c4c4c4` border, 4px radius, 14px Pretendard Variable weight 700 black text, padding 16px 16px 16px 20px, height 52px. Trailing chevron `>` right-aligned."
|
|
288
|
+
- "Build a product card: square photograph at 0px radius, then 12px Pretendard Variable weight 400 product name in `#000000`, then 12px weight 700 price in `#000000` directly below. Caption row '옵션비 별도' in 12px weight 400 `rgba(93,93,93,0.64)`. No card border, no shadow."
|
|
289
|
+
- "Floating help CTA: `#000000` background, `#ffffff` text, 2px radius, padding 4px 8px 4px 14px, height 31px, 15px Pretendard Variable weight 400. Fixed bottom-right, 24px inset."
|
|
290
|
+
- "Footer: white background, padding 20px 48px 48px. Column headings in 13px Pretendard Variable weight 700 uppercase Latin (`NOTICE`, `ABOUT US`, `HELP`). Link body 13-14px weight 400 black. No background tint, no top border."
|
|
291
|
+
|
|
292
|
+
### Iteration Guide
|
|
293
|
+
1. Always use Pretendard Variable — it is the brand font; do not substitute Noto Sans KR or Apple SD Gothic Neo unless the runtime cannot load Pretendard.
|
|
294
|
+
2. Default to `#000000` on `#ffffff`. Reach for `rgba(93,93,93,0.64)` only for secondary captions. Reach for any other colour only if you can name a specific brand reason.
|
|
295
|
+
3. Editorial card titles are 22px/700 with 29.92px line-height. This pair is the single most distinctive typographic unit in the system — replicate it precisely.
|
|
296
|
+
4. Product price is 12px/700 and lives under the title, not above. Inverting this order is the most common mistake when adapting other commerce designs to 29CM.
|
|
297
|
+
5. Radius scale is 0 / 2 / 4 — never 8, never pill. The 4px ghost button is the largest radius on the marketing surface.
|
|
298
|
+
6. White space is the brand. If a layout feels "empty", you are probably close to correct. Resist the urge to fill.
|
|
299
|
+
7. The inverted black CTA is high-cost. Use it once or twice per screen at most.
|
|
300
|
+
8. Photography does the visual heavy lifting. If you have weak imagery, no amount of typography will recover the 29CM register.
|
|
301
|
+
|
|
302
|
+
---
|
|
303
|
+
|
|
304
|
+
## 10. Voice & Tone
|
|
305
|
+
|
|
306
|
+
29CM speaks like an editor curating a magazine, not a marketer running a sale — calm, considered, never excited, never urgent. The brand book (`Guide to better 29CM`) defines the voice as personable but quiet: the brand persona is described as "착하지만 엉뚱한" (kind but offbeat), and the tone is treated as a deliberate craft layer that must stay consistent across every product caption, push notification, and email. Korean is the primary voice; English appears only as section labels and category names (`Special-Order`, `Showcase`, `29Magazine`) borrowed from print-magazine convention.
|
|
307
|
+
|
|
308
|
+
| Context | Tone |
|
|
309
|
+
|---|---|
|
|
310
|
+
| Editorial card titles | Short Korean phrases, often poetic or sensory (`나폴리의 산들바람`, `쿨링 시스템`). No imperatives. |
|
|
311
|
+
| Editorial card body | One sensory sentence + invitation. `스치는 바람처럼 여유로운 여름을 담은 지노키오의 여름 컬렉션을 같이 구경해요.` — the verb endings (`~해요`) are friendly-formal, never `~합니다`. |
|
|
312
|
+
| Product names | Brand-led, restrained — `[29CM 단독] (uni)Breeze 아이보리 솔리드 파자마`. Brackets carry exclusivity markers. |
|
|
313
|
+
| CTAs | `더보기`, `자세히 보기`, `장바구니 담기`. Bare verb-stems with `~기` endings. Never English (`SHOP NOW`), never exclamatory. |
|
|
314
|
+
| Price captions | Bare numerals + `원` later in the line. Modifier captions (`옵션비 별도`, `무료배송`) sit quietly under the price in muted grey. |
|
|
315
|
+
| PT (Presentation) copy | Long-form editorial — opens with a thesis sentence, then product context, then story. Reads like a Brunch essay. |
|
|
316
|
+
| Push / email | Same magazine register — `오늘의 컬렉션을 큐레이션했어요` rather than `세일 시작! 지금 클릭!`. |
|
|
317
|
+
| Empty states | Single Korean line explaining the absence — `아직 찜한 상품이 없어요`. Never `데이터가 없습니다`. |
|
|
318
|
+
|
|
319
|
+
**Forbidden phrases.** `최저가`, `초특가`, `긴급세일`, `오늘만`, English exclamatory CTAs (`SHOP NOW!`, `BUY!`), emoji of any kind on marketing surfaces, urgency-driven countdowns (`마감 임박!`), and the corporate-formal `~합니다` ending on consumer-facing voice. (`~합니다` is reserved for legal disclosure pages only.) Stacked superlatives on a single product (`프리미엄 럭셔리 시그니처 컬렉션`) read as Coupang-grade promo and are off-brand.
|
|
320
|
+
|
|
321
|
+
## 11. Brand Narrative
|
|
322
|
+
|
|
323
|
+
29CM was founded in **2011** as a media-commerce hybrid — the **C stands for Commerce** and the **M stands for Media** — under the parent operator Cafe24's incubator before passing through several owners. The name itself encodes the thesis: **29 centimeters** is, in the brand's own framing, *"the closest distance at which two people can open their hearts"* — the editorial premise that shopping is less about transaction than about taste, and that 29CM stands at conversational distance from its customer rather than retail distance ([NamuWiki / Asiance](https://blog.asiance.com/2021/03/24/vertical-platform-for-mz-generation/)). The brand's official identity statement is **"Guide to Better Choice"** — a curated selection promise rather than a discount promise.
|
|
324
|
+
|
|
325
|
+
The company was acquired by **Musinsa (무신사)** in **2021** and now operates as the editorial counterweight inside the Musinsa group: where Musinsa is street-utility and scale, 29CM is curation and editorial depth, with a dedicated PT (Presentation) format introduced in 2013 that publishes ~1.5 long-form brand stories per week ([29CM Brunch — likenoothers](https://brunch.co.kr/@likenoothers/11)). The 2023 Seongsu offline store and the [2023 BX renewal](https://designcompass.org/2023/08/21/29cm-seongsu/) reinforced the editorial framing — the wordmark uses dotted "2" and "9" digits to express the brand's *"착하지만 엉뚱한"* (kind-but-offbeat) personality, and the visual identity centres on a ruler-mark motif that frames the wordmark "like a container for the brand".
|
|
326
|
+
|
|
327
|
+
The internal brand book is titled **`Guide to better 29CM, 더 나은 29CM를 위한 가이드북`** — roughly 180 pages, with four parts: "우리다운 방식" (our way), "우리의 초상" (our portrait — brand persona as a person, complete with imagined clothes and weekend habits), "우리만의 목소리" (our voice — tone-and-manner guide for copy), and "그들의 취향" (their taste — nine taste-based customer personas, explicitly rejecting demographic segmentation) ([29CM Brand Book — Brunch](https://brunch.co.kr/@likenoothers/11)).
|
|
328
|
+
|
|
329
|
+
What 29CM refuses: discount-led merchandising (no permanent sale banners), demographic segmentation (age/gender bins are replaced by taste-based personas), urgency theatre (no countdowns, no "마감 임박"), and decorative chrome (no gradients, no shadows, no brand colour beyond black-on-white). What it embraces: long-form editorial inside the storefront, photography as the primary voice, Korean as the primary language with English borrowed from magazine convention, and the conviction that the customer is a reader first and a buyer second.
|
|
330
|
+
|
|
331
|
+
## 12. Principles
|
|
332
|
+
|
|
333
|
+
1. **The image is the headline.** Every editorial tile leads with a photograph at 22px-headline scale of visual weight. The Korean caption sits underneath, never overlaid. If the image cannot carry the tile, the tile is not ready.
|
|
334
|
+
*UI implication:* Reserve the top 60-70% of every editorial unit for photography. Captions are subordinates, not co-headlines.
|
|
335
|
+
|
|
336
|
+
2. **Price is the punctuation, not the verb.** Product prices render at 12px/700 — the same size as the product name. Promoting price violates the editorial hierarchy and reframes the page as discount commerce.
|
|
337
|
+
*UI implication:* Price never exceeds product-name size on a card. Discount red is a single accent, used sparingly on percent badges only.
|
|
338
|
+
|
|
339
|
+
3. **Whitespace is more expensive than ink.** 29CM's curation is proven by what is removed, not what is added. Page margins of 48px, section gaps of 32px, and an absence of dividers are the brand's structural commitment.
|
|
340
|
+
*UI implication:* Default to more padding, fewer borders. If a layout reads "spacious", you are likely close to correct.
|
|
341
|
+
|
|
342
|
+
4. **One face, three weights, no italic.** Pretendard Variable is the entire typographic system. Emphasis is by weight (400 → 700 → 800). Adding a serif companion or a display face dilutes the editorial register.
|
|
343
|
+
*UI implication:* Reject design contributions that introduce a second family. Bold is the only emphasis primitive.
|
|
344
|
+
|
|
345
|
+
5. **Korean is the primary voice; English is the section label.** Body copy, captions, error states, and onboarding are Korean. English appears at display sizes for navigation categories — borrowed from print-magazine convention, not adopted as parallel UI language.
|
|
346
|
+
*UI implication:* Avoid English microcopy in body strings. Reserve English for top-level category names where it functions as decoration.
|
|
347
|
+
|
|
348
|
+
6. **Restraint is the brand.** The only "colour" is the discount-red badge. The only "elevation" is colour inversion. The only iconography is a trailing chevron. Every additional visual element competes with the photography.
|
|
349
|
+
*UI implication:* Before adding a shadow, a border, an icon, or a colour — name a specific editorial reason. If there isn't one, remove.
|
|
350
|
+
|
|
351
|
+
7. **The customer is a reader.** PT, Showcase, and 29Magazine treat brand stories as long-form editorial. The site rewards browsing time, not click-through speed. Conversion follows attention; attention follows curation.
|
|
352
|
+
*UI implication:* Allow long pages. Don't compress brand stories into "view more" gated cards. The full editorial is the funnel.
|
|
353
|
+
|
|
354
|
+
## 13. Personas
|
|
355
|
+
|
|
356
|
+
*Personas below are fictional archetypes informed by 29CM's stated taste-based segmentation (9 personas defined in the internal brand book) and publicly described 29CM user profiles. Not individual people.*
|
|
357
|
+
|
|
358
|
+
**지윤 (Jiyoon), 29, Seoul.** Marketing manager at a small lifestyle startup. Opens 29CM on her phone during the commute and on desktop at lunch. Reads PT pieces front-to-back before adding anything to cart — the editorial is the reason she's there. Owns one item from at least 12 different niche Korean brands, none of which she would have discovered on Musinsa. Resists discount notifications; deletes the app immediately if it starts pushing "오늘만" banners.
|
|
359
|
+
|
|
360
|
+
**민호 (Minho), 34, Seongsu.** Industrial designer. Treats 29CM as a curated showroom rather than a shop. Goes to the Seongsu offline store on weekends to handle objects in person, then buys online a week later. Will spend ₩280,000 on a single ceramic vase without flinching but considers a ₩9,900 cable organizer beneath consideration. The brand-story PT format is the deciding factor on every purchase above ₩100,000.
|
|
361
|
+
|
|
362
|
+
**서연 (Seoyeon), 26, Busan.** Recent grad, working her first office job. Uses 29CM as her "taste education" — she follows specific brand collections that 29CM has curated and slowly builds a wardrobe around them. Knows the difference between 29Magazine and Showcase. Reads Lookbook on Sunday evenings like other people read magazines. Has never used a 29CM coupon code.
|
|
363
|
+
|
|
364
|
+
**현우 (Hyeonwoo), 41, Gangnam.** Senior consultant. Buys gifts on 29CM — for partners, clients, parents. The site's editorial framing solves a problem ordinary commerce can't: it produces gift recommendations that feel "considered" rather than "expensive". Trusts the 29CM curation enough to buy without comparison shopping. Reads PT for vocabulary he can use in the card.
|
|
365
|
+
|
|
366
|
+
## 14. States
|
|
367
|
+
|
|
368
|
+
| State | Treatment |
|
|
369
|
+
|---|---|
|
|
370
|
+
| **Empty (wishlist / cart)** | Single Korean line of `#000000` 15px weight 400 body text explaining the absence (`아직 찜한 상품이 없어요`, `장바구니가 비어있어요`), plus one ghost outline CTA below (`상품 둘러보기`). Never an illustration, never a mascot. |
|
|
371
|
+
| **Empty (search / filter)** | One line of 14px `rgba(93,93,93,0.64)` caption (`검색 결과가 없어요`). No button — user adjusts filters themselves. |
|
|
372
|
+
| **Loading (first paint)** | Flat grey blocks at `#f5f5f5` (functional, not styled) at the final layout's geometry. No shimmer animation on editorial tiles — would compete with photography. |
|
|
373
|
+
| **Loading (more products)** | Bottom-of-list 3-dot loader in `#000000`. No overlay, no skeleton — the existing list stays visible. |
|
|
374
|
+
| **Error (inline field)** | 1px `#ff003c` border on the input, error text below in `#ff003c` 13px weight 400. One sentence (`이메일 형식이 올바르지 않아요`). Friendly-formal `~요` ending. |
|
|
375
|
+
| **Error (toast)** | `#000000` background, `#ffffff` 14px weight 400 text, 2px radius matching the inverted CTA, bottom-center placement, 3s auto-dismiss. No icon. |
|
|
376
|
+
| **Error (screen-blocking)** | Reserved for server outage. White screen, centered single-line message in `#000000` 16px weight 700, ghost CTA below (`다시 시도하기`). No illustration. |
|
|
377
|
+
| **Success (inline)** | Brief 200ms flash of the `#000000`/`#ffffff` inversion on the affected control — toggle flip, like-button activation. No green checkmark on routine UI. |
|
|
378
|
+
| **Success (purchase confirmation)** | Dedicated confirmation screen. Black-on-white order number in 22px/700, item summary below in 15px/400, single ghost CTA (`주문 내역 보기`). Money figures rendered in 22px/700 with comma separators. |
|
|
379
|
+
| **Skeleton** | `#f5f5f5` blocks at final dimensions, 0px radius (matching the editorial-tile and product-card geometry). 1.0s fade pulse, never shimmer. Never used on prices — those render as `--` until resolved. |
|
|
380
|
+
| **Disabled** | Button opacity drops to 0.4. Border colour does not change — disabled ghost buttons retain `#c4c4c4` border so geometry stays stable when re-enabled. |
|
|
381
|
+
| **Sale badge active** | `#ff0066` text on white tile corner — the single chromatic state on the marketing surface. Used for percent-off only, never for "NEW" or "BEST" (those are weight-only treatments in nav). |
|
|
382
|
+
|
|
383
|
+
## 15. Motion & Easing
|
|
384
|
+
|
|
385
|
+
**Durations** (named, not raw milliseconds):
|
|
386
|
+
|
|
387
|
+
| Token | Value | Use |
|
|
388
|
+
|---|---|---|
|
|
389
|
+
| `motion-instant` | 0ms | Toggle flips, like-button state changes |
|
|
390
|
+
| `motion-quick` | 150ms | Hover state on ghost buttons, focus ring fades |
|
|
391
|
+
| `motion-standard` | 250ms | Default — image hover scale, sheet opens, tile reveal |
|
|
392
|
+
| `motion-editorial` | 400ms | Editorial transitions — hero image cross-fade, PT chapter advance |
|
|
393
|
+
| `motion-page` | 350ms | Full-screen route transitions |
|
|
394
|
+
|
|
395
|
+
**Easings:**
|
|
396
|
+
|
|
397
|
+
| Token | Curve | Use |
|
|
398
|
+
|---|---|---|
|
|
399
|
+
| `ease-out` | `cubic-bezier(0.2, 0.0, 0.0, 1.0)` | Appearing — sheets enter, tiles reveal, hovers settle |
|
|
400
|
+
| `ease-in` | `cubic-bezier(0.4, 0.0, 1.0, 1.0)` | Leaving — dismissals, pops |
|
|
401
|
+
| `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1.0)` | Two-way transitions — accordion expand, tab content |
|
|
402
|
+
| `linear` | `linear` | Image scrubbing in editorial galleries — preserves perceptual neutrality |
|
|
403
|
+
|
|
404
|
+
**Signature motions.**
|
|
405
|
+
|
|
406
|
+
1. **Image hover scale.** Hovering an editorial tile scales the image to 1.04 over `motion-standard` with `ease-out`; the surrounding tile chrome does not move. The motion is photographic, not interface — the photograph leans toward the cursor.
|
|
407
|
+
2. **Tile reveal on scroll.** Editorial tiles fade in from opacity 0 with a 12px upward translate over `motion-editorial` with `ease-out`. The stagger between tiles is 80-120ms, mimicking page-turn rhythm rather than dashboard pop-in.
|
|
408
|
+
3. **CTA hover (ghost outline).** The `#c4c4c4` border darkens to `#000000` over `motion-quick`, no fill change. The change is felt, not announced — typical of editorial restraint.
|
|
409
|
+
4. **CTA hover (inverted black).** Background lightens 4% over `motion-quick`. No transform, no shadow added. The brand never animates depth.
|
|
410
|
+
5. **Reduce motion.** If `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. Image hover scale disables. Cross-fades replace translates. The site stays usable; just less kinetic.
|
|
411
|
+
|
|
412
|
+
<!--
|
|
413
|
+
OmD v0.1 Sources — Philosophy Layer (sections 10-15)
|
|
414
|
+
|
|
415
|
+
Direct verification via WebFetch / live inspect (2026-05-13):
|
|
416
|
+
- https://www.29cm.co.kr/ — confirmed homepage tagline "감도 깊은 취향 셀렉트샵 29CM",
|
|
417
|
+
editorial tile structure, Pretendard Variable typography, monochrome palette,
|
|
418
|
+
inverted-black FAQ/1:1 CTA pattern (live getComputedStyle 2026-05-13).
|
|
419
|
+
- https://brunch.co.kr/@likenoothers/11 — confirmed brand book title
|
|
420
|
+
"Guide to better 29CM, 더 나은 29CM를 위한 가이드북", 4-part structure (우리다운
|
|
421
|
+
방식 / 우리의 초상 / 우리만의 목소리 / 그들의 취향), 9 taste-based personas,
|
|
422
|
+
"착하지만 엉뚱한" persona description.
|
|
423
|
+
- https://designcompass.org/2023/08/21/29cm-seongsu/ — confirmed wordmark dot
|
|
424
|
+
motif, ruler-mark visual identity, "변하지 않는 본질" framing, "Guide to
|
|
425
|
+
Better Choice" mission language.
|
|
426
|
+
- https://blog.asiance.com/2021/03/24/vertical-platform-for-mz-generation/ —
|
|
427
|
+
confirmed "C = Commerce, M = Media" name etymology and editorial commerce
|
|
428
|
+
positioning, Musinsa acquisition timeline.
|
|
429
|
+
|
|
430
|
+
Tier 2 (getdesign.md/refero) returned no 29CM-specific entries — §4 token
|
|
431
|
+
values are sourced exclusively from Tier 1 live inspect.
|
|
432
|
+
|
|
433
|
+
Not independently verified — widely documented public facts used:
|
|
434
|
+
- 29CM founding year (2011), Musinsa acquisition (2021).
|
|
435
|
+
- "29CM = 29 centimeters = closest distance to open hearts" — brand's own
|
|
436
|
+
framing as referenced in Asiance and NamuWiki; treated as brand-stated
|
|
437
|
+
mythology rather than externally documented etymology.
|
|
438
|
+
|
|
439
|
+
Personas (§13) are fictional archetypes informed by 29CM's stated taste-based
|
|
440
|
+
9-persona segmentation. Any resemblance to specific individuals is unintended.
|
|
441
|
+
|
|
442
|
+
Interpretive claims (e.g., "the image is the headline", "whitespace is more
|
|
443
|
+
expensive than ink") are editorial readings of the live design surface, not
|
|
444
|
+
documented 29CM statements.
|
|
445
|
+
-->
|