oh-my-design-cli 1.5.0 → 1.6.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/AGENTS.md +1 -0
- package/README.ko.md +1 -1
- package/README.md +9 -9
- package/agents/omd-master.md +13 -1
- package/data/reference-fingerprints.json +1428 -523
- package/package.json +5 -4
- package/scripts/ctx-prime.cjs +266 -0
- package/skills/omd-harness/SKILL.md +135 -7
- package/skills/omd-kr-writer/SKILL.md +1 -1
- package/web/references/17live/DESIGN.md +424 -0
- package/web/references/alipay/DESIGN.md +456 -0
- package/web/references/appier/DESIGN.md +420 -0
- package/web/references/bilibili/DESIGN.md +426 -0
- package/web/references/class101/DESIGN.md +433 -0
- package/web/references/cookpad/DESIGN.md +357 -0
- package/web/references/dji/DESIGN.md +416 -0
- package/web/references/gogoro/DESIGN.md +403 -0
- package/web/references/ichef/DESIGN.md +411 -0
- package/web/references/kakaopay/DESIGN.md +1 -1
- package/web/references/kakaot/DESIGN.md +454 -0
- package/web/references/kkday/DESIGN.md +423 -0
- package/web/references/meituan/DESIGN.md +424 -0
- package/web/references/millie/DESIGN.md +533 -0
- package/web/references/money-forward/DESIGN.md +401 -0
- package/web/references/myrealtrip/DESIGN.md +445 -0
- package/web/references/naverwebtoon/DESIGN.md +429 -0
- package/web/references/note/DESIGN.md +318 -0
- package/web/references/publy/DESIGN.md +511 -0
- package/web/references/smarthr/DESIGN.md +404 -0
- package/web/references/smartnews/DESIGN.md +331 -0
- package/web/references/spoon/DESIGN.md +446 -0
- package/web/references/tada/DESIGN.md +528 -0
- package/web/references/tossbank/DESIGN.md +519 -0
- package/web/references/triple/DESIGN.md +434 -0
- package/web/references/tumblbug/DESIGN.md +530 -0
- package/web/references/watcha/DESIGN.md +425 -0
- package/web/references/wavve/DESIGN.md +438 -0
- package/web/references/wconcept/DESIGN.md +511 -0
- package/web/references/xiaohongshu/DESIGN.md +423 -0
- package/web/references/yogiyo/DESIGN.md +465 -0
|
@@ -0,0 +1,533 @@
|
|
|
1
|
+
---
|
|
2
|
+
id: millie
|
|
3
|
+
name: Millie
|
|
4
|
+
display_name_kr: 밀리의서재
|
|
5
|
+
country: KR
|
|
6
|
+
category: education
|
|
7
|
+
homepage: "https://www.millie.co.kr"
|
|
8
|
+
primary_color: "#1b6dda"
|
|
9
|
+
logo:
|
|
10
|
+
type: favicon
|
|
11
|
+
slug: "https://www.google.com/s2/favicons?domain=millie.co.kr&sz=128"
|
|
12
|
+
verified: "2026-05-27"
|
|
13
|
+
omd: "0.1"
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
# Design System Inspiration of Millie (밀리의서재)
|
|
17
|
+
|
|
18
|
+
## 1. Visual Theme & Atmosphere
|
|
19
|
+
|
|
20
|
+
Millie's Library is Korea's largest reading-subscription service, and its interface behaves like a calm digital bookshelf -- a content storefront where book covers are the color and everything else stays quiet. The page opens on a clean white canvas (`#ffffff`) with a warm near-black body text (`#242424`) and a confident reading blue (`#1b6dda`) that functions as the universal interactive accent. This isn't a flat library catalog; it's a streaming-service-for-books feel, where the home tab ("투데이" — Today) is a curated, editorial feed of book covers, audiobook tiles, and original-content promotions, much like a video platform's home screen reimagined for reading.
|
|
21
|
+
|
|
22
|
+
The book cover is the hero. Millie's design system treats every cover thumbnail as the primary unit of color and meaning -- a dense, scrollable grid of portrait rectangles, each carrying the publisher's art. The chrome around them is deliberately muted: white surfaces, `#f2f2f2` section fills, and a restrained type system built on Pretendard Variable so that nothing competes with the covers. Where a single saturated brand color appears, it is the reading blue -- on the primary subscription CTA, on active tabs, on links. A small constellation of secondary accents (a soft purple `#a451f7`, a warm coral `#ff5b4f`, a highlight yellow `#ffc004`) appears on promotional cards and category tags, but always in service of organizing content, never as decoration for its own sake.
|
|
23
|
+
|
|
24
|
+
What defines Millie visually is the streaming-app posture applied to books: a personalized, cover-forward feed; soft rounded chips and pill toggles (10px radius on category tabs); and a generous, comfortable type scale optimized for browsing on a phone in the evening. The mood is warm and inviting rather than institutional -- reading should feel like a daily habit, not homework.
|
|
25
|
+
|
|
26
|
+
**Key Characteristics:**
|
|
27
|
+
- Reading Blue (`#1b6dda`) as the primary interactive accent -- subscription CTA, active tabs, links
|
|
28
|
+
- Warm near-black body text (`#242424`) on a clean white canvas -- not pure `#000`
|
|
29
|
+
- Pretendard Variable as the system face -- Korean-Latin co-equal rendering
|
|
30
|
+
- Cover-forward, streaming-style feed: book covers carry the color, chrome recedes
|
|
31
|
+
- Soft secondary accents (purple `#a451f7`, coral `#ff5b4f`, yellow `#ffc004`) for content organization
|
|
32
|
+
- Rounded chrome: 10px radius category tabs, 4px buttons, 100px pill controls
|
|
33
|
+
- Comfortable browsing type scale -- evening-on-a-phone reading posture
|
|
34
|
+
- `#f2f2f2` surface fills for nested sections and feed separation
|
|
35
|
+
|
|
36
|
+
## 2. Color Palette & Roles
|
|
37
|
+
|
|
38
|
+
### Primary
|
|
39
|
+
- **Reading Blue** (`#1b6dda`): Primary interactive color -- subscription CTA, active tab, links, selection. The workhorse of every tappable accent (observed `rgb(27,109,218)`).
|
|
40
|
+
- **Pure White** (`#ffffff`): Page canvas, card surfaces, button text on blue, navigation background.
|
|
41
|
+
- **Warm Near-Black** (`#242424`): Primary heading + body text color. Warm dark gray, softer than pure black (observed `rgb(36,36,36)` — the most-used color on the surface).
|
|
42
|
+
|
|
43
|
+
### Secondary / Content Accents
|
|
44
|
+
- **Soft Purple** (`#a451f7`): Original-content tags, premium-feature highlights, audiobook accents (observed `rgb(164,81,247)`).
|
|
45
|
+
- **Warm Coral** (`#ff5b4f`): Time-limited promotion, "오늘의 추천", urgency tags (observed `rgb(255,91,79)`).
|
|
46
|
+
- **Highlight Yellow** (`#ffc004`): Star ratings, "베스트" / highlight badges (observed `rgb(255,192,4)`).
|
|
47
|
+
- **System Blue** (`#007aff`): iOS-native control blue, used on platform-supplied controls only (observed `rgb(0,122,255)`).
|
|
48
|
+
|
|
49
|
+
### Neutral Scale
|
|
50
|
+
- **Gray 800** (`#333333`): Strong labels, dark button fill (login chip `#333`).
|
|
51
|
+
- **Gray 700** (`#555555`): Secondary headings, emphasized labels.
|
|
52
|
+
- **Gray 600** (`#6f6f6f`): Body secondary text, descriptions, metadata (observed `rgb(111,111,111)`).
|
|
53
|
+
- **Gray 500** (`#8b8b8b`): Caption text, secondary labels (observed `rgb(139,139,139)`).
|
|
54
|
+
- **Gray 400** (`#c1c1c1`): Placeholder text, disabled icons (observed `rgb(193,193,193)`).
|
|
55
|
+
- **Gray 200** (`#ececec`): Default border, dividers (observed `rgb(236,236,236)`).
|
|
56
|
+
- **Gray 100** (`#f2f2f2`): Secondary background, section fill, card fill.
|
|
57
|
+
- **Gray 50** (`#f7f7f7`): Lightest surface fill for nested sections.
|
|
58
|
+
|
|
59
|
+
### Surface & Overlays
|
|
60
|
+
- **Surface Fill**: `#f2f2f2`. Section backgrounds, feed separators, image placeholders.
|
|
61
|
+
- **Scrim Dark**: `rgba(0,0,0,0.3)`. Image overlays, cover-gradient veils, modal scrim.
|
|
62
|
+
- **Scrim Light**: `rgba(0,0,0,0.15)`. Subtle dividers over imagery.
|
|
63
|
+
|
|
64
|
+
## 3. Typography Rules
|
|
65
|
+
|
|
66
|
+
### Font Family
|
|
67
|
+
- **Primary**: `"Pretendard Variable", "Pretendard Fallback", "Pretendard Fallback Android", sans-serif` (observed live on `www.millie.co.kr`, 2026-05)
|
|
68
|
+
- **Design Principle**: No bespoke wordmark webfont on product surfaces. Pretendard Variable carries the entire system; weight contrast (400 / 600 / 700) builds hierarchy. Korean and Latin render co-equally in the same line.
|
|
69
|
+
|
|
70
|
+
### Hierarchy
|
|
71
|
+
|
|
72
|
+
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|
|
73
|
+
|------|------|------|--------|-------------|----------------|-------|
|
|
74
|
+
| Display | Pretendard | 28px | 700 | 38px | -0.4px | Editorial banner / original-content title |
|
|
75
|
+
| Heading Large | Pretendard | 22px | 700 | 30px | -0.4px | Feed section title ("지금 인기 있는 책") |
|
|
76
|
+
| Heading | Pretendard | 18px | 700 | 26px | -0.3px | Sub-section header, shelf label |
|
|
77
|
+
| Title | Pretendard | 16px | 600 | 24px | -0.3px | Book detail title, modal header |
|
|
78
|
+
| Body Large | Pretendard | 16px | 400 | 24px | -0.2px | Book description, reading text |
|
|
79
|
+
| Body | Pretendard | 14px | 400 | 22px | -0.2px | Default body, listing metadata |
|
|
80
|
+
| Tab Label | Pretendard | 14px | 600 | 20px | -0.2px | Active/inactive category tab |
|
|
81
|
+
| Caption | Pretendard | 13px | 400 | 18px | -0.2px | Author / publisher, review counts |
|
|
82
|
+
| Caption Bold | Pretendard | 13px | 700 | 18px | -0.2px | Badge / tag labels |
|
|
83
|
+
| Micro | Pretendard | 12px | 500 | 16px | -0.2px | Fine print, control labels |
|
|
84
|
+
|
|
85
|
+
### Principles
|
|
86
|
+
- **Comfortable browsing scale**: Body sits at 14-16px with generous leading — the system assumes evening phone browsing, not dense data scanning.
|
|
87
|
+
- **Three weights**: 400 (body), 600 (tabs / titles), 700 (headings / emphasis). Light is avoided on Korean glyphs.
|
|
88
|
+
- **Warm dark, not pure black**: Headings and body use `#242424`, a warm near-black, to feel inviting rather than clinical. Pure `#000` is reserved for high-contrast moments.
|
|
89
|
+
- **Tight Korean tracking**: `-0.2px` to `-0.4px` letter-spacing for editorial compactness on titles.
|
|
90
|
+
- **Covers carry color, type stays neutral**: Type tokens avoid the brand blue except on links and tab labels — the book cover is the chromatic event.
|
|
91
|
+
|
|
92
|
+
## 4. Component Stylings
|
|
93
|
+
|
|
94
|
+
### Buttons
|
|
95
|
+
|
|
96
|
+
**Primary (Reading Blue)**
|
|
97
|
+
- Background: `#1b6dda`
|
|
98
|
+
- Text: `#ffffff`
|
|
99
|
+
- Border: none
|
|
100
|
+
- Radius: 8px
|
|
101
|
+
- Padding: 14px 20px
|
|
102
|
+
- Font: 16px / 700 / Pretendard
|
|
103
|
+
- Hover: `#1860c2`
|
|
104
|
+
- Pressed: `#1554ad`
|
|
105
|
+
- Disabled: `#c1c1c1` background, `#ffffff` text
|
|
106
|
+
- Use: Primary subscription CTA -- `무료체험 시작하기`, `구독하기`, `읽기`
|
|
107
|
+
|
|
108
|
+
**Dark (Neutral Solid)**
|
|
109
|
+
- Background: `#333333`
|
|
110
|
+
- Text: `#ffffff`
|
|
111
|
+
- Border: none
|
|
112
|
+
- Radius: 4px
|
|
113
|
+
- Padding: 0px 12px
|
|
114
|
+
- Font: 12px / 400 / Pretendard
|
|
115
|
+
- Height: 32px
|
|
116
|
+
- Use: Compact chrome actions -- `로그인`, header utility buttons
|
|
117
|
+
|
|
118
|
+
**Outline (Blue Border)**
|
|
119
|
+
- Background: `#ffffff`
|
|
120
|
+
- Text: `#1b6dda`
|
|
121
|
+
- Border: 1px solid `#1b6dda`
|
|
122
|
+
- Radius: 8px
|
|
123
|
+
- Padding: 14px 20px
|
|
124
|
+
- Font: 16px / 600 / Pretendard
|
|
125
|
+
- Hover: `#f2f6fd` background
|
|
126
|
+
- Use: Secondary CTA -- `책장에 담기`, `샘플 읽기`
|
|
127
|
+
|
|
128
|
+
**Neutral (Gray Fill)**
|
|
129
|
+
- Background: `#f2f2f2`
|
|
130
|
+
- Text: `#333333`
|
|
131
|
+
- Border: none
|
|
132
|
+
- Radius: 8px
|
|
133
|
+
- Padding: 12px 16px
|
|
134
|
+
- Font: 14px / 500 / Pretendard
|
|
135
|
+
- Hover: `#ececec` background
|
|
136
|
+
- Use: Tertiary actions -- share, filter open, more options
|
|
137
|
+
|
|
138
|
+
### Inputs
|
|
139
|
+
|
|
140
|
+
**Default**
|
|
141
|
+
- Background: `#ffffff`
|
|
142
|
+
- Text: `#242424`
|
|
143
|
+
- Border: 1px solid `#ececec`
|
|
144
|
+
- Radius: 8px
|
|
145
|
+
- Padding: 12px 14px
|
|
146
|
+
- Font: 14px / 400 / Pretendard
|
|
147
|
+
- Placeholder: `#c1c1c1`
|
|
148
|
+
- Focus: 1px solid `#1b6dda`
|
|
149
|
+
- Use: Default text input -- login, search-detail forms
|
|
150
|
+
|
|
151
|
+
**Search**
|
|
152
|
+
- Background: `#f2f2f2`
|
|
153
|
+
- Text: `#242424`
|
|
154
|
+
- Border: none
|
|
155
|
+
- Radius: 8px
|
|
156
|
+
- Padding: 12px 16px 12px 40px (left-pad for inline magnifier)
|
|
157
|
+
- Font: 14px / 400 / Pretendard
|
|
158
|
+
- Placeholder: `#8b8b8b` ("제목, 저자, 출판사 검색")
|
|
159
|
+
- Focus: `#ffffff` background, 1px solid `#1b6dda` border
|
|
160
|
+
- Use: Header / discovery search bar
|
|
161
|
+
|
|
162
|
+
**Error**
|
|
163
|
+
- Background: `#ffffff`
|
|
164
|
+
- Text: `#242424`
|
|
165
|
+
- Border: 1px solid `#ff5b4f`
|
|
166
|
+
- Radius: 8px
|
|
167
|
+
- Padding: 12px 14px
|
|
168
|
+
- Font: 14px / 400 / Pretendard
|
|
169
|
+
- Use: Form validation failure -- helper text 13px/400 `#ff5b4f` below
|
|
170
|
+
|
|
171
|
+
### Cards
|
|
172
|
+
|
|
173
|
+
**Book Cover Tile**
|
|
174
|
+
- Background: `#f2f2f2` (placeholder behind cover art)
|
|
175
|
+
- Border: none
|
|
176
|
+
- Radius: 6px
|
|
177
|
+
- Padding: 0px on cover; 8px gap to title/author metadata
|
|
178
|
+
- Image: portrait cover (~2:3), 6px radius, soft `0px 2px 8px rgba(0,0,0,0.08)` shadow
|
|
179
|
+
- Use: Default book unit in the feed grid -- the primary content surface
|
|
180
|
+
|
|
181
|
+
**Feed Card (Editorial)**
|
|
182
|
+
- Background: `#ffffff` (or full-bleed cover-derived gradient)
|
|
183
|
+
- Border: none
|
|
184
|
+
- Radius: 12px
|
|
185
|
+
- Padding: 0px (image) / 16px (text block)
|
|
186
|
+
- Shadow: none
|
|
187
|
+
- Use: Curated "투데이" feed promotions, original-content banners
|
|
188
|
+
|
|
189
|
+
**Audiobook Card**
|
|
190
|
+
- Background: `#ffffff`
|
|
191
|
+
- Border: 1px solid `#ececec`
|
|
192
|
+
- Radius: 12px
|
|
193
|
+
- Padding: 16px
|
|
194
|
+
- Use: Audiobook entry with play affordance -- purple `#a451f7` play-button accent
|
|
195
|
+
|
|
196
|
+
### Badges & Tags
|
|
197
|
+
|
|
198
|
+
**Category Tab (Active)**
|
|
199
|
+
- Background: `#333333`
|
|
200
|
+
- Text: `#ffffff`
|
|
201
|
+
- Border: none
|
|
202
|
+
- Radius: 10px
|
|
203
|
+
- Padding: 0px 10px
|
|
204
|
+
- Font: 14px / 600 / Pretendard
|
|
205
|
+
- Height: 32px
|
|
206
|
+
- Use: Active genre/category filter ("종합", "소설", "경제경영")
|
|
207
|
+
|
|
208
|
+
**Category Tab (Inactive)**
|
|
209
|
+
- Background: `#f2f2f2`
|
|
210
|
+
- Text: `#6f6f6f`
|
|
211
|
+
- Border: none
|
|
212
|
+
- Radius: 10px
|
|
213
|
+
- Padding: 0px 10px
|
|
214
|
+
- Font: 14px / 400 / Pretendard
|
|
215
|
+
- Height: 32px
|
|
216
|
+
- Use: Inactive genre/category filter
|
|
217
|
+
|
|
218
|
+
**Original Tag (Purple)**
|
|
219
|
+
- Background: `#a451f7`
|
|
220
|
+
- Text: `#ffffff`
|
|
221
|
+
- Border: none
|
|
222
|
+
- Radius: 4px
|
|
223
|
+
- Padding: 3px 6px
|
|
224
|
+
- Font: 11px / 700 / Pretendard
|
|
225
|
+
- Use: "밀리 오리지널" original-content flag
|
|
226
|
+
|
|
227
|
+
**Promotion Tag (Coral)**
|
|
228
|
+
- Background: `#ff5b4f`
|
|
229
|
+
- Text: `#ffffff`
|
|
230
|
+
- Border: none
|
|
231
|
+
- Radius: 4px
|
|
232
|
+
- Padding: 3px 6px
|
|
233
|
+
- Font: 11px / 700 / Pretendard
|
|
234
|
+
- Use: "오늘만", time-limited promotion flag. Used scarcely.
|
|
235
|
+
|
|
236
|
+
**Rating (Yellow)**
|
|
237
|
+
- Background: transparent
|
|
238
|
+
- Text: `#ffc004` (star fill) + `#6f6f6f` (count)
|
|
239
|
+
- Border: none
|
|
240
|
+
- Radius: 0px
|
|
241
|
+
- Padding: 0px
|
|
242
|
+
- Font: 13px / 400 / Pretendard
|
|
243
|
+
- Use: Star rating + review count on book detail
|
|
244
|
+
|
|
245
|
+
### Pill Control
|
|
246
|
+
|
|
247
|
+
**Floating Pill (Scrim)**
|
|
248
|
+
- Background: `rgba(0,0,0,0.3)`
|
|
249
|
+
- Text: `#ffffff`
|
|
250
|
+
- Border: none
|
|
251
|
+
- Radius: 100px
|
|
252
|
+
- Padding: 4px 10px
|
|
253
|
+
- Font: 16px / 400 / Pretendard
|
|
254
|
+
- Use: "자동 재생 중지", carousel position indicator over imagery
|
|
255
|
+
|
|
256
|
+
### Navigation
|
|
257
|
+
- Top header: `#ffffff` background, ~56px height, no heavy border. Wordmark left (밀리의서재), search + utility right.
|
|
258
|
+
- Category nav: horizontal-scroll genre tabs, 14px, active = `#333` fill / 10px radius, inactive = `#f2f2f2` fill.
|
|
259
|
+
- Bottom tab bar (mobile): 4-5 items -- `투데이`, `검색`, `내 서재`, `더보기`. Active label `#1b6dda` / icon filled, inactive `#8b8b8b`. Reading blue marks the active tab.
|
|
260
|
+
|
|
261
|
+
## 5. Layout Principles
|
|
262
|
+
|
|
263
|
+
### Spacing System
|
|
264
|
+
- Base unit: 4px
|
|
265
|
+
- Scale: 4px, 8px, 12px, 16px, 20px, 24px, 32px, 40px, 56px
|
|
266
|
+
- Global gutter (mobile): 16px each side
|
|
267
|
+
- Global gutter (desktop): 20-24px each side, max content width ~1080px
|
|
268
|
+
- Inter-cover horizontal spacing: 12px between covers in a shelf carousel
|
|
269
|
+
- Inter-section vertical spacing: 32-40px between feed sections on "투데이"
|
|
270
|
+
|
|
271
|
+
### Grid & Container
|
|
272
|
+
- Mobile: horizontal cover carousels (3-3.5 covers visible) stacked vertically into feed sections
|
|
273
|
+
- Tablet: 4-5 covers per shelf
|
|
274
|
+
- Desktop: 6-7 covers per shelf, centered ~1080px column
|
|
275
|
+
- The feed is the homepage -- a vertical stack of horizontally-scrolling shelves, streaming-service style
|
|
276
|
+
- Detail pages: single-column, cover + metadata + description + reviews
|
|
277
|
+
|
|
278
|
+
### Whitespace Philosophy
|
|
279
|
+
- **Covers breathe in shelves**: Horizontal gaps between covers (12px) and vertical gaps between shelves (32-40px) are the system's primary rhythm.
|
|
280
|
+
- **Comfortable, not dense**: Evening phone browsing earns generous leading and section gaps — Millie is a leisure habit, not a productivity tool.
|
|
281
|
+
- **Let the cover lead**: Chrome padding stays minimal so the cover art dominates each tile.
|
|
282
|
+
|
|
283
|
+
### Border Radius Scale
|
|
284
|
+
- Subtle (4px): Buttons (dark/compact), small tags
|
|
285
|
+
- Standard (6px): Book cover tiles
|
|
286
|
+
- Comfortable (8px): Primary buttons, inputs, neutral chips
|
|
287
|
+
- Soft (10px): Category tabs
|
|
288
|
+
- Large (12px): Feed cards, audiobook cards
|
|
289
|
+
- Pill (100px): Floating scrim controls, carousel indicators
|
|
290
|
+
|
|
291
|
+
## 6. Depth & Elevation
|
|
292
|
+
|
|
293
|
+
| Level | Treatment | Use |
|
|
294
|
+
|-------|-----------|-----|
|
|
295
|
+
| Flat (Level 0) | No shadow | Page background, feed sections, default chrome |
|
|
296
|
+
| Cover (Level 1) | `0px 2px 8px rgba(0,0,0,0.08)` | Book cover tiles — the signature lift that makes covers feel physical |
|
|
297
|
+
| Soft (Level 2) | `0px 2px 12px rgba(0,0,0,0.10)` | Sticky header on scroll, dropdown menus |
|
|
298
|
+
| Floating (Level 3) | `0px 4px 16px rgba(0,0,0,0.12)` | Bottom sheets, modal dialogs, snackbar |
|
|
299
|
+
|
|
300
|
+
**Shadow Philosophy**: Millie's signature elevation is the soft drop-shadow under each book cover — it makes a flat thumbnail feel like a physical book on a shelf, the one place the system spends shadow generously. Elsewhere, shadows are restrained and neutral (pure-black low-opacity), reserved for elements that must detach from the feed. No brand-tinted shadows.
|
|
301
|
+
|
|
302
|
+
## 7. Do's and Don'ts
|
|
303
|
+
|
|
304
|
+
### Do
|
|
305
|
+
- Use Reading Blue (`#1b6dda`) for the subscription CTA, active tabs, and links
|
|
306
|
+
- Use warm near-black `#242424` for headings and body — not pure `#000`
|
|
307
|
+
- Give book covers the signature `0px 2px 8px rgba(0,0,0,0.08)` lift
|
|
308
|
+
- Apply secondary accents (purple/coral/yellow) for content organization, scarcely
|
|
309
|
+
- Use 10px radius on category tabs, 8px on buttons, 100px on scrim pills
|
|
310
|
+
- Build a cover-forward feed of horizontal shelves — streaming-service posture
|
|
311
|
+
- Keep type comfortable (14-16px) with generous leading for evening browsing
|
|
312
|
+
|
|
313
|
+
### Don't
|
|
314
|
+
- Don't use the brand blue as decoration — reserve it for interactive elements
|
|
315
|
+
- Don't use pure `#000` for body text — warm `#242424` is the brand's softness
|
|
316
|
+
- Don't let chrome compete with cover art for color attention
|
|
317
|
+
- Don't apply purple/coral/yellow as primary CTA fills — those organize content
|
|
318
|
+
- Don't make the layout dense — Millie is leisure reading, not a data dashboard
|
|
319
|
+
- Don't drop the cover shadow — flat covers lose the physical-book warmth
|
|
320
|
+
- Don't mix sharp 0px corners into chrome — the system is consistently rounded
|
|
321
|
+
|
|
322
|
+
## 8. Responsive Behavior
|
|
323
|
+
|
|
324
|
+
### Breakpoints
|
|
325
|
+
| Name | Width | Key Changes |
|
|
326
|
+
|------|-------|-------------|
|
|
327
|
+
| Mobile | <768px | Vertical feed of horizontal cover shelves, bottom tab bar |
|
|
328
|
+
| Tablet | 768-1024px | More covers per shelf, optional side margins |
|
|
329
|
+
| Desktop | >1024px | Centered ~1080px column, 6-7 covers per shelf, top nav |
|
|
330
|
+
|
|
331
|
+
### Touch Targets
|
|
332
|
+
- Primary CTA buttons: 48px height
|
|
333
|
+
- Category tabs: 32px height
|
|
334
|
+
- Bottom tab bar items: 56px height
|
|
335
|
+
- Book cover tile: full cover + metadata tap area
|
|
336
|
+
|
|
337
|
+
### Collapsing Strategy
|
|
338
|
+
- Desktop multi-shelf grid → mobile single-column vertical feed of carousels
|
|
339
|
+
- Filter side-rail → mobile bottom-sheet filter
|
|
340
|
+
- Reader (book content) view collapses to full-screen single-column with adjustable type
|
|
341
|
+
|
|
342
|
+
### Image Behavior
|
|
343
|
+
- Book covers: ~2:3 portrait, 6px radius, soft shadow, lazy-loaded with `#f2f2f2` placeholder
|
|
344
|
+
- Editorial banners: 16:9 or full-bleed, gradient scrim for text legibility
|
|
345
|
+
- Author / publisher logos: square 1:1, small
|
|
346
|
+
|
|
347
|
+
## 9. Agent Prompt Guide
|
|
348
|
+
|
|
349
|
+
### Quick Color Reference
|
|
350
|
+
- Primary CTA: Reading Blue (`#1b6dda`)
|
|
351
|
+
- CTA Hover: Blue Dark (`#1860c2`)
|
|
352
|
+
- Background: Pure White (`#ffffff`)
|
|
353
|
+
- Surface fill: Gray 100 (`#f2f2f2`)
|
|
354
|
+
- Heading text: Warm Near-Black (`#242424`)
|
|
355
|
+
- Body secondary: Gray 600 (`#6f6f6f`)
|
|
356
|
+
- Caption: Gray 500 (`#8b8b8b`)
|
|
357
|
+
- Placeholder: Gray 400 (`#c1c1c1`)
|
|
358
|
+
- Border: Gray 200 (`#ececec`)
|
|
359
|
+
- Original tag: Purple (`#a451f7`)
|
|
360
|
+
- Promotion tag: Coral (`#ff5b4f`)
|
|
361
|
+
- Rating: Yellow (`#ffc004`)
|
|
362
|
+
|
|
363
|
+
### Example Component Prompts
|
|
364
|
+
- "Create a Millie book cover tile: ~2:3 portrait cover with 6px radius and 0px 2px 8px rgba(0,0,0,0.08) shadow on #f2f2f2 placeholder. Below: 8px gap, title 14px Pretendard 600 #242424 (2 lines, ellipsis), 2px gap, author 13px 400 #6f6f6f. Optional purple 밀리 오리지널 tag, 11px/700 #fff on #a451f7, 4px radius."
|
|
365
|
+
- "Build a primary subscription CTA: #1b6dda background, white text, 16px weight 700 Pretendard, padding 14px 20px, 8px radius, full-width. Hover #1860c2. Label '무료체험 시작하기'."
|
|
366
|
+
- "Design a category tab bar: horizontal scroll, 8px gap, 32px height. Active: #333 bg, white 14px/600, 10px radius, 0 10px padding. Inactive: #f2f2f2 bg, #6f6f6f 14px/400."
|
|
367
|
+
- "Create a Millie '투데이' feed section: 22px/700 #242424 section title, 12px gap, horizontal carousel of book cover tiles, 12px inter-cover gap, 32-40px gap to next section."
|
|
368
|
+
- "Design a floating carousel control: rgba(0,0,0,0.3) bg, white 16px text, 100px radius, 4px 10px padding, '자동 재생 중지' label."
|
|
369
|
+
|
|
370
|
+
### Iteration Guide
|
|
371
|
+
1. Reading blue `#1b6dda` is the interactive accent — CTA, active tab, links
|
|
372
|
+
2. Body and headings are warm `#242424`, never pure `#000`
|
|
373
|
+
3. Book covers carry the color; chrome stays neutral white / `#f2f2f2`
|
|
374
|
+
4. Secondary accents (purple/coral/yellow) organize content, used scarcely
|
|
375
|
+
5. Radius scale: 4px tags, 6px covers, 8px buttons, 10px tabs, 12px feed cards, 100px pills
|
|
376
|
+
6. Cover tiles get the signature soft shadow — flat covers lose the physical warmth
|
|
377
|
+
7. Comfortable 14-16px type, generous leading — evening phone browsing posture
|
|
378
|
+
|
|
379
|
+
---
|
|
380
|
+
|
|
381
|
+
## 10. Voice & Tone
|
|
382
|
+
|
|
383
|
+
Millie speaks like a friendly librarian-curator who wants reading to feel effortless and a little bit delightful. The voice is warm, encouraging, and lightly playful — reading is positioned as a daily habit and a small luxury, not a chore. Korean copy favors soft, inviting endings (`-요`, `-해요`) and gentle imperatives (`읽어보세요`, `담아두기`) over institutional `-ㅂ니다`. The brand's positioning line leans into habit and small daily growth — *"독서와 무제한 친해지리"* (befriend reading, without limit) — and the slogan *"당신의 일상을 1밀리+"* plays on the brand name as a unit of incremental daily improvement.
|
|
384
|
+
|
|
385
|
+
| Context | Tone |
|
|
386
|
+
|---|---|
|
|
387
|
+
| CTAs | Inviting Korean (`무료체험 시작하기`, `지금 읽기`, `내 서재에 담기`) |
|
|
388
|
+
| Subscription / paywall | Benefit-forward, low-pressure (`30일 무료로 둘러보세요`). Never `지금 결제하지 않으면 손해!`. |
|
|
389
|
+
| Feed section headers | Warm editorial (`지금 인기 있는 책`, `오늘의 추천`, `밀리 오리지널`). |
|
|
390
|
+
| Empty states | Gentle + suggestion (`아직 담은 책이 없어요` + `책 둘러보기`). Never `데이터가 없습니다`. |
|
|
391
|
+
| Error messages | Blameless + actionable (`잠시 후 다시 시도해 주세요`). No `오류가 발생했습니다` boilerplate. |
|
|
392
|
+
| Reading completion | Celebratory but quiet (`완독을 축하해요!`). |
|
|
393
|
+
| Notifications | Habit nudges (`오늘 5분만 읽어볼까요?`), low-frequency, friendly. |
|
|
394
|
+
|
|
395
|
+
**Forbidden phrases.** `지금 결제 안 하면 손해`, `마지막 기회!!!`, `데이터가 없습니다`, `오류가 발생했습니다`, `불편을 드려 죄송합니다`. The brand avoids high-pressure urgency — it sells a calm habit, not a flash deal. Emoji are allowed sparingly in habit nudges and completion celebrations, never in error states or paywall copy.
|
|
396
|
+
|
|
397
|
+
**Voice samples.**
|
|
398
|
+
|
|
399
|
+
- `독서와 무제한 친해지리` — Google Play subtitle / brand positioning. <!-- cited: play.google.com Millie listing, 2026-05 -->
|
|
400
|
+
- `당신의 일상을 1밀리+` — brand campaign slogan playing on the brand name. <!-- cited: millie.insight.wanted.co.kr, 2026-05 -->
|
|
401
|
+
- `밀리 오리지널` — original-content section label. <!-- illustrative: standard Millie content-category pattern -->
|
|
402
|
+
- `완독을 축하해요!` — reading-completion celebration. <!-- illustrative: standard Millie habit-loop pattern -->
|
|
403
|
+
- `무료체험 시작하기` — primary subscription CTA. <!-- illustrative: standard Millie CTA pattern -->
|
|
404
|
+
|
|
405
|
+
## 11. Brand Narrative
|
|
406
|
+
|
|
407
|
+
Millie's Library (밀리의서재) launched in 2017 as Korea's first e-book subscription service — an "unlimited reading" model that let members read across a deep catalog of books, magazines, and (increasingly) audiobooks for a flat monthly fee. The premise rejected the per-title purchase model that had kept Korean digital reading niche, reframing reading as a streaming-style subscription habit. The home experience is built around discovery and personalization rather than a static catalog, which is why "투데이" (Today) — a curated, cover-forward feed — is the default tab rather than a search box ([play.google.com — 밀리의 서재](https://play.google.com/store/apps/details?id=kr.co.millie.millieshelf), [namu.wiki — 밀리의 서재](https://namu.wiki/w/%EB%B0%80%EB%A6%AC%EC%9D%98%20%EC%84%9C%EC%9E%AC)).
|
|
408
|
+
|
|
409
|
+
The company grew into the dominant Korean reading-subscription platform and was acquired by **KT** (operated as ㈜kt 밀리의서재), anchoring it inside a major Korean telecom while it expanded into original content, audiobooks, and "밀리 오리지널" exclusives ([millie.town — corporate](https://www.millie.town/)). The brand voice and campaign work consistently lean into the idea of reading as a small, compounding daily habit — captured in the slogan *"당신의 일상을 1밀리+"*, which turns the brand name into a unit of incremental daily growth ([millie.insight.wanted.co.kr](https://millie.insight.wanted.co.kr/)).
|
|
410
|
+
|
|
411
|
+
What Millie refuses: the cold catalog UX of legacy e-book stores, the high-pressure urgency of flash-sale commerce, and the institutional seriousness that makes reading feel like homework. Instead it borrows the warm, personalized, cover-forward posture of a video-streaming home screen and points it at books — soft rounded chrome, a calm reading blue, warm near-black type, and a feed that makes the next book always one scroll away.
|
|
412
|
+
|
|
413
|
+
## 12. Principles
|
|
414
|
+
|
|
415
|
+
1. **The feed is the front door.** The default surface is a personalized, cover-forward "투데이" feed, not a search box or a static catalog. *UI implication:* discovery surfaces lead with curated shelves; search is a tool, not the home.
|
|
416
|
+
2. **Covers carry the color.** Book cover art is the chromatic event; chrome stays neutral white and `#f2f2f2`. *UI implication:* never tint chrome to compete with covers; the brand blue appears only on interactive elements.
|
|
417
|
+
3. **Warm, not clinical.** Body and headings use warm near-black `#242424`, chrome is softly rounded, and shadows make covers feel physical. *UI implication:* never substitute pure `#000` for body text; never flatten the cover shadow.
|
|
418
|
+
4. **Calm over urgency.** The subscription is sold as a relaxed habit, not a flash deal. *UI implication:* paywall and promo copy stay low-pressure; coral urgency tags are scarce and never aggressive.
|
|
419
|
+
5. **Reading blue is interaction, not decoration.** `#1b6dda` marks tappable elements — CTA, active tab, links. *UI implication:* if blue appears on a non-interactive surface, it has drifted; restate as neutral or a secondary content accent.
|
|
420
|
+
6. **A streaming posture for books.** Horizontal cover shelves, autoplay banners, personalized rows — the video-platform pattern reimagined for reading. *UI implication:* default to shelf carousels stacked vertically, not a flat paginated grid.
|
|
421
|
+
|
|
422
|
+
## 13. Personas
|
|
423
|
+
|
|
424
|
+
*Personas are fictional archetypes informed by Millie's publicly described user base (Korean adults building a digital reading habit across e-books and audiobooks), not individual people.*
|
|
425
|
+
|
|
426
|
+
**지은 (Jieun), 32, Seoul.** Marketing manager, commutes 40 minutes each way. Listens to audiobooks on the subway, reads e-books before bed. Opens the "투데이" feed nightly to see what's recommended. Subscribed after the 30-day free trial and never cancelled — the flat fee removed the friction of choosing what to buy.
|
|
427
|
+
|
|
428
|
+
**현수 (Hyunsoo), 45, Daejeon.** Office worker and father of two. Reads business and self-development titles; tracks his completion count like a fitness streak. Responds to gentle "오늘 5분만 읽어볼까요?" nudges. Values the warm, uncluttered interface — he finds dense catalog apps stressful.
|
|
429
|
+
|
|
430
|
+
**유리 (Yuri), 24, Seoul.** University student. Came for the magazines and 밀리 오리지널 exclusives, stayed for the audiobooks she plays while studying. Browses entirely on her phone, treats the cover feed like a Netflix home screen for books.
|
|
431
|
+
|
|
432
|
+
**민재 (Minjae), 28, Busan.** Software engineer. Skeptical of subscription creep but kept Millie because the unlimited model means he never hesitates to start a book he might abandon. Reads fiction in the reader view with a custom type size and a warm sepia background.
|
|
433
|
+
|
|
434
|
+
## 14. States
|
|
435
|
+
|
|
436
|
+
| State | Treatment |
|
|
437
|
+
|---|---|
|
|
438
|
+
| **Empty (empty 내 서재)** | Single gentle line (`아직 담은 책이 없어요`) in 14px/400 `#6f6f6f`, 12px gap, primary-blue CTA `책 둘러보기`. No harsh empty illustration — optionally a soft small graphic. |
|
|
439
|
+
| **Empty (search no results)** | One line `'{검색어}'에 대한 결과가 없어요` in 14px/400 `#6f6f6f`, then recommended shelves below. Never a full-screen dead-end. |
|
|
440
|
+
| **Empty (filter cleared)** | `조건에 맞는 책이 없어요` in 14px/400 `#8b8b8b`. No CTA — user adjusts filters. |
|
|
441
|
+
| **Loading (feed)** | Skeleton shelves at `#f2f2f2`: cover-rectangle placeholders in a row, two short text lines below each. Shimmer 1.2s, 6% white highlight. No spinner overlay. |
|
|
442
|
+
| **Loading (cover art)** | `#f2f2f2` placeholder rectangle at the cover's 2:3 ratio with 6px radius until the image resolves. |
|
|
443
|
+
| **Loading (subscribe action)** | Primary button text swaps to a 24px `#ffffff` spinner on the `#1b6dda` button — geometry unchanged for frame-stability. |
|
|
444
|
+
| **Error (inline form)** | Input border becomes `#ff5b4f` 1px, helper text 13px/400 `#ff5b4f` below. One actionable sentence (`이메일을 다시 확인해 주세요`). |
|
|
445
|
+
| **Error (toast)** | `#242424` background, white 14px/500 text, 8px radius, 3s auto-dismiss. Bottom of screen, 16px above bottom tab bar. One sentence. No icon. |
|
|
446
|
+
| **Error (network / blocking)** | Centered: 16px/700 `#242424` headline (`연결이 불안정해요`), 14px/400 `#6f6f6f` subline, retry button in primary-blue style. |
|
|
447
|
+
| **Success (added to library)** | Bottom snackbar: `#242424` bg, white 14px/500 `내 서재에 담았어요`, blue-text `보러가기` button on right. 3s auto-dismiss. |
|
|
448
|
+
| **Success (book completed)** | Quiet celebration screen / sheet: `완독을 축하해요!` 22px/700 `#242424`, completion stat, optional share. Low-key, not confetti-heavy. |
|
|
449
|
+
| **Skeleton** | `#f2f2f2` blocks at exact cover and text dimensions. Shimmer 1.2s. Title and author slots blank until resolved. |
|
|
450
|
+
| **Disabled** | Button bg drops to `#c1c1c1`, text stays `#ffffff`. No outline tricks. |
|
|
451
|
+
|
|
452
|
+
## 15. Motion & Easing
|
|
453
|
+
|
|
454
|
+
**Durations** (named, not raw milliseconds):
|
|
455
|
+
|
|
456
|
+
| Token | Value | Use |
|
|
457
|
+
|---|---|---|
|
|
458
|
+
| `motion-instant` | 0ms | Toggle flips, checkbox states |
|
|
459
|
+
| `motion-fast` | 150ms | Hover, focus, button press dim, small reveals |
|
|
460
|
+
| `motion-standard` | 240ms | Default — shelf scroll snaps, tab switches, card expand |
|
|
461
|
+
| `motion-slow` | 360ms | Sheet presentations, completion-screen entry |
|
|
462
|
+
| `motion-page` | 300ms | Route push/pop |
|
|
463
|
+
| `motion-autoplay` | 5000ms | "투데이" hero-banner autoplay dwell |
|
|
464
|
+
|
|
465
|
+
**Easings:**
|
|
466
|
+
|
|
467
|
+
| Token | Curve | Use |
|
|
468
|
+
|---|---|---|
|
|
469
|
+
| `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Sheets, snackbars, route entries |
|
|
470
|
+
| `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals, snackbar auto-close |
|
|
471
|
+
| `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — expandable cards, tab content |
|
|
472
|
+
| `ease-gentle-spring` | `cubic-bezier(0.34, 1.2, 0.64, 1)` | Reserved — completion celebration, "담기" confirm bounce. Gentle, never bouncy. |
|
|
473
|
+
|
|
474
|
+
**Signature motions.**
|
|
475
|
+
|
|
476
|
+
1. **Hero autoplay.** The "투데이" hero banner cross-fades between promotions on `motion-autoplay` dwell; a floating `rgba(0,0,0,0.3)` pill (`자동 재생 중지`) lets users pause. Transition is a soft cross-fade with `ease-standard`, never a hard cut.
|
|
477
|
+
2. **Cover-to-detail.** Tapping a cover lifts it (`scale 1.0 → 1.02`, `motion-fast`) then transitions into the detail view (`motion-page / ease-enter`); the cover shadow deepens slightly to imply pick-up.
|
|
478
|
+
3. **Add-to-library confirm.** A small gentle-spring bounce on the bookmark icon (`ease-gentle-spring`) plus the snackbar — the one place spring is licensed, and only gently.
|
|
479
|
+
4. **Shelf scroll.** Horizontal cover carousels use momentum scroll with soft snap to cover edges (`motion-standard`). No elastic overscroll bounce beyond the OS default.
|
|
480
|
+
5. **Reduce motion.** Under `prefers-reduced-motion: reduce`, autoplay pauses by default, all `motion-*` collapse to `motion-instant`, and cross-fades replace slides. The feed stays fully usable.
|
|
481
|
+
|
|
482
|
+
<!--
|
|
483
|
+
OmD v0.1 Sources — Philosophy Layer (sections 10–15)
|
|
484
|
+
|
|
485
|
+
Tier 1 — Direct verification (MCP playwright, 2026-05-27):
|
|
486
|
+
- https://www.millie.co.kr/ (live "투데이" home surface). Confirmed:
|
|
487
|
+
body font-family "Pretendard Variable", "Pretendard Fallback", ...;
|
|
488
|
+
body color rgb(36,36,36) = #242424 (dominant, ~3,416 occurrences);
|
|
489
|
+
body bg #ffffff; interactive blue rgb(27,109,218) = #1b6dda
|
|
490
|
+
(~66 occurrences); secondary accents purple rgb(164,81,247) = #a451f7,
|
|
491
|
+
coral rgb(255,91,79) = #ff5b4f, yellow rgb(255,192,4) = #ffc004;
|
|
492
|
+
surface fill #f2f2f2; border #ececec; login chip #333 bg / 4px radius;
|
|
493
|
+
category tab #333 bg / 10px radius / 14px·600; floating scrim pill
|
|
494
|
+
rgba(0,0,0,0.3) / 100px radius.
|
|
495
|
+
|
|
496
|
+
Tier 2 — Press / secondary (WebSearch, 2026-05):
|
|
497
|
+
- https://play.google.com/store/apps/details?id=kr.co.millie.millieshelf
|
|
498
|
+
— "독서와 무제한 친해지리" positioning; reading-subscription model.
|
|
499
|
+
- https://www.millie.town/ — corporate (㈜kt 밀리의서재), KT ownership.
|
|
500
|
+
- https://millie.insight.wanted.co.kr/ — "당신의 일상을 1밀리+" slogan.
|
|
501
|
+
- https://namu.wiki/w/밀리의 서재 — Korea's largest reading platform,
|
|
502
|
+
e-books / audiobooks / magazines, 밀리 오리지널 originals.
|
|
503
|
+
|
|
504
|
+
ASSUMED-VS-VERIFIED NOTE: The task brief assumed primary blue #3D5AFE.
|
|
505
|
+
Live inspect found the dominant interactive blue is #1b6dda
|
|
506
|
+
(rgb(27,109,218)), NOT #3D5AFE. The DESIGN.md uses the live-verified
|
|
507
|
+
#1b6dda as primary_color. The assumed #3D5AFE does not appear as a
|
|
508
|
+
dominant token on the current live surface.
|
|
509
|
+
|
|
510
|
+
Personas (§13) are fictional archetypes informed by Millie's publicly
|
|
511
|
+
described user base (Korean adults building a digital reading habit).
|
|
512
|
+
Any resemblance to specific individuals is unintended.
|
|
513
|
+
|
|
514
|
+
Interpretive claims (editorial, not documented Millie statements):
|
|
515
|
+
- "A streaming posture for books" framing (§11, §12) — editorial reading
|
|
516
|
+
of the cover-forward "투데이" feed pattern.
|
|
517
|
+
- The 6 numbered principles (§12) — synthesized from observed surface
|
|
518
|
+
behavior + brand positioning; not a published design-principles list.
|
|
519
|
+
- Component-internal geometry beyond the observed tokens (button padding,
|
|
520
|
+
card radii, shadow values) is reconciled from the live rounded-chrome
|
|
521
|
+
surface treatment; re-verify in a stable session before treating as
|
|
522
|
+
authoritative DS specs.
|
|
523
|
+
- The spring stance (§15) — derived from the calm brand posture, not a
|
|
524
|
+
documented Millie motion rule.
|
|
525
|
+
-->
|
|
526
|
+
|
|
527
|
+
---
|
|
528
|
+
|
|
529
|
+
**Verified:** 2026-05-27 (omd:add-reference initial create — Tier 1 live inspect / Tier 2 press confirmed)
|
|
530
|
+
**Tier 1 sources:** www.millie.co.kr ("투데이" live playwright inspect — Pretendard Variable, body `#242424` on `#fff`, interactive blue `#1b6dda`, secondary purple `#a451f7` / coral `#ff5b4f` / yellow `#ffc004`, surface `#f2f2f2`, border `#ececec`, category tab `#333`/10px, scrim pill 100px).
|
|
531
|
+
**Tier 2 sources:** getdesign.md/millie — not checked. styles.refero.design — not checked. Google Play + millie.town + Wanted Insight + Namu Wiki (2017 reading-subscription launch, KT ownership, "독서와 무제한 친해지리" / "당신의 일상을 1밀리+" positioning, 밀리 오리지널).
|
|
532
|
+
**Style ref:** `toss` (KR product tone scaffolding).
|
|
533
|
+
**Conflicts unresolved:** Assumed primary `#3D5AFE` (from task brief) NOT confirmed — live inspect found dominant interactive blue `#1b6dda`. Resolved in favor of Tier 1 live value `#1b6dda`. Component-internal geometry reconciled from surface treatment; re-run Tier 2 (getdesign/refero) to lock token values.
|