oh-my-design-cli 1.1.0 → 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.
@@ -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
+ -->