oh-my-design-cli 1.3.9 → 1.5.1

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.
Files changed (168) hide show
  1. package/README.ja.md +8 -8
  2. package/README.ko.md +7 -7
  3. package/README.md +50 -16
  4. package/README.zh-TW.md +8 -8
  5. package/agents/omd-asset-curator.md +2 -7
  6. package/agents/omd-codex-image.md +49 -0
  7. package/agents/omd-designer-review.md +38 -0
  8. package/agents/omd-final-qa.md +40 -0
  9. package/agents/omd-kr-writer.md +35 -0
  10. package/agents/omd-locale-adapter.md +32 -0
  11. package/agents/omd-master.md +3 -13
  12. package/agents/omd-orchestrator.md +34 -0
  13. package/data/reference-audits/2026-05-14-kr10.md +72 -0
  14. package/data/reference-audits/2026-05-15-kr10.md +124 -0
  15. package/data/reference-fingerprints.json +1409 -254
  16. package/data/research/2026-05-18-agent-landscape.md +69 -0
  17. package/data/research/2026-05-18-kr-style-presets.md +572 -0
  18. package/dist/bin/oh-my-design.js +6 -3
  19. package/dist/bin/oh-my-design.js.map +1 -1
  20. package/dist/{install-skills-MVXVXYAY.js → install-skills-IETT2TBJ.js} +91 -8
  21. package/dist/install-skills-IETT2TBJ.js.map +1 -0
  22. package/package.json +7 -1
  23. package/skills/omd-apply/SKILL.md +0 -1
  24. package/skills/omd-codex-image/SKILL.md +162 -0
  25. package/skills/omd-designer-review/SKILL.md +146 -0
  26. package/skills/omd-final-qa/SKILL.md +153 -0
  27. package/skills/omd-kr-writer/SKILL.md +229 -0
  28. package/skills/omd-locale-adapter/SKILL.md +124 -0
  29. package/skills/omd-orchestrator/SKILL.md +124 -0
  30. package/web/references/17live/DESIGN.md +424 -0
  31. package/web/references/29cm/DESIGN.md +11 -2
  32. package/web/references/ably/DESIGN.md +12 -2
  33. package/web/references/airbnb/DESIGN.md +17 -2
  34. package/web/references/airtable/DESIGN.md +20 -0
  35. package/web/references/alipay/DESIGN.md +456 -0
  36. package/web/references/appier/DESIGN.md +420 -0
  37. package/web/references/apple/DESIGN.md +17 -2
  38. package/web/references/baemin/DESIGN.md +11 -2
  39. package/web/references/banksalad/DESIGN.md +17 -2
  40. package/web/references/bilibili/DESIGN.md +426 -0
  41. package/web/references/bmw/DESIGN.md +14 -0
  42. package/web/references/bunjang/DESIGN.md +308 -0
  43. package/web/references/cal/DESIGN.md +14 -0
  44. package/web/references/catchtable/DESIGN.md +262 -0
  45. package/web/references/channeltalk/DESIGN.md +374 -0
  46. package/web/references/class101/DESIGN.md +433 -0
  47. package/web/references/classum/DESIGN.md +217 -0
  48. package/web/references/claude/DESIGN.md +11 -2
  49. package/web/references/clay/DESIGN.md +19 -0
  50. package/web/references/clickhouse/DESIGN.md +19 -0
  51. package/web/references/cohere/DESIGN.md +20 -0
  52. package/web/references/coinbase/DESIGN.md +14 -0
  53. package/web/references/composio/DESIGN.md +14 -0
  54. package/web/references/cookpad/DESIGN.md +357 -0
  55. package/web/references/coupang/DESIGN.md +17 -2
  56. package/web/references/cursor/DESIGN.md +20 -0
  57. package/web/references/dabang/DESIGN.md +210 -0
  58. package/web/references/dcard/DESIGN.md +11 -2
  59. package/web/references/dji/DESIGN.md +416 -0
  60. package/web/references/elevenlabs/DESIGN.md +20 -0
  61. package/web/references/expo/DESIGN.md +20 -0
  62. package/web/references/fastcampus/DESIGN.md +460 -0
  63. package/web/references/ferrari/DESIGN.md +14 -0
  64. package/web/references/figma/DESIGN.md +17 -2
  65. package/web/references/flex/DESIGN.md +309 -0
  66. package/web/references/framer/DESIGN.md +20 -0
  67. package/web/references/freee/DESIGN.md +16 -2
  68. package/web/references/gangnamunni/DESIGN.md +18 -2
  69. package/web/references/gmarket/DESIGN.md +464 -0
  70. package/web/references/gogoro/DESIGN.md +403 -0
  71. package/web/references/hashicorp/DESIGN.md +19 -0
  72. package/web/references/ibm/DESIGN.md +20 -0
  73. package/web/references/ichef/DESIGN.md +411 -0
  74. package/web/references/inflearn/DESIGN.md +396 -0
  75. package/web/references/intercom/DESIGN.md +14 -0
  76. package/web/references/jumpit/DESIGN.md +366 -0
  77. package/web/references/kakao/DESIGN.md +14 -0
  78. package/web/references/kakaobank/DESIGN.md +17 -2
  79. package/web/references/kakaopay/DESIGN.md +17 -2
  80. package/web/references/kakaot/DESIGN.md +454 -0
  81. package/web/references/karrot/DESIGN.md +16 -2
  82. package/web/references/kbank/DESIGN.md +195 -0
  83. package/web/references/kkday/DESIGN.md +423 -0
  84. package/web/references/kraken/DESIGN.md +14 -0
  85. package/web/references/krds/DESIGN.md +17 -2
  86. package/web/references/kream/DESIGN.md +382 -0
  87. package/web/references/kurly/DESIGN.md +11 -2
  88. package/web/references/lamborghini/DESIGN.md +14 -0
  89. package/web/references/line/DESIGN.md +17 -2
  90. package/web/references/linear.app/DESIGN.md +17 -2
  91. package/web/references/lovable/DESIGN.md +14 -0
  92. package/web/references/lunit/DESIGN.md +249 -0
  93. package/web/references/meituan/DESIGN.md +424 -0
  94. package/web/references/mercari/DESIGN.md +11 -2
  95. package/web/references/millie/DESIGN.md +533 -0
  96. package/web/references/minimax/DESIGN.md +14 -0
  97. package/web/references/mintlify/DESIGN.md +14 -0
  98. package/web/references/miro/DESIGN.md +20 -0
  99. package/web/references/mistral.ai/DESIGN.md +20 -0
  100. package/web/references/money-forward/DESIGN.md +401 -0
  101. package/web/references/mongodb/DESIGN.md +19 -0
  102. package/web/references/musinsa/DESIGN.md +11 -2
  103. package/web/references/myrealtrip/DESIGN.md +445 -0
  104. package/web/references/naver/DESIGN.md +17 -2
  105. package/web/references/naverwebtoon/DESIGN.md +429 -0
  106. package/web/references/note/DESIGN.md +318 -0
  107. package/web/references/notion/DESIGN.md +11 -2
  108. package/web/references/nvidia/DESIGN.md +11 -2
  109. package/web/references/ohouse/DESIGN.md +11 -2
  110. package/web/references/oliveyoung/DESIGN.md +342 -0
  111. package/web/references/ollama/DESIGN.md +14 -0
  112. package/web/references/opencode.ai/DESIGN.md +20 -0
  113. package/web/references/pinkoi/DESIGN.md +11 -2
  114. package/web/references/pinterest/DESIGN.md +19 -0
  115. package/web/references/posthog/DESIGN.md +20 -0
  116. package/web/references/publy/DESIGN.md +511 -0
  117. package/web/references/qanda/DESIGN.md +11 -2
  118. package/web/references/raycast/DESIGN.md +19 -0
  119. package/web/references/remember/DESIGN.md +17 -2
  120. package/web/references/renault/DESIGN.md +14 -0
  121. package/web/references/replicate/DESIGN.md +14 -0
  122. package/web/references/resend/DESIGN.md +20 -0
  123. package/web/references/revolut/DESIGN.md +14 -0
  124. package/web/references/ridi/DESIGN.md +11 -2
  125. package/web/references/runwayml/DESIGN.md +14 -0
  126. package/web/references/sanity/DESIGN.md +20 -0
  127. package/web/references/sentry/DESIGN.md +14 -0
  128. package/web/references/smarthr/DESIGN.md +404 -0
  129. package/web/references/smartnews/DESIGN.md +331 -0
  130. package/web/references/socar/DESIGN.md +17 -2
  131. package/web/references/spacex/DESIGN.md +11 -2
  132. package/web/references/spoon/DESIGN.md +446 -0
  133. package/web/references/spotify/DESIGN.md +14 -0
  134. package/web/references/stripe/DESIGN.md +11 -2
  135. package/web/references/supabase/DESIGN.md +20 -0
  136. package/web/references/superhuman/DESIGN.md +20 -0
  137. package/web/references/tada/DESIGN.md +528 -0
  138. package/web/references/tesla/DESIGN.md +11 -2
  139. package/web/references/together.ai/DESIGN.md +20 -0
  140. package/web/references/toss/DESIGN.md +16 -2
  141. package/web/references/toss-securities/DESIGN.md +193 -0
  142. package/web/references/tossbank/DESIGN.md +519 -0
  143. package/web/references/triple/DESIGN.md +434 -0
  144. package/web/references/tumblbug/DESIGN.md +530 -0
  145. package/web/references/tving/DESIGN.md +259 -0
  146. package/web/references/uber/DESIGN.md +19 -0
  147. package/web/references/upbit/DESIGN.md +276 -0
  148. package/web/references/upstage/DESIGN.md +214 -0
  149. package/web/references/vercel/DESIGN.md +17 -2
  150. package/web/references/voltagent/DESIGN.md +14 -0
  151. package/web/references/wadiz/DESIGN.md +344 -0
  152. package/web/references/wanted/DESIGN.md +16 -2
  153. package/web/references/warp/DESIGN.md +14 -0
  154. package/web/references/watcha/DESIGN.md +425 -0
  155. package/web/references/wavve/DESIGN.md +438 -0
  156. package/web/references/wconcept/DESIGN.md +511 -0
  157. package/web/references/webflow/DESIGN.md +14 -0
  158. package/web/references/wise/DESIGN.md +19 -0
  159. package/web/references/x.ai/DESIGN.md +14 -0
  160. package/web/references/xiaohongshu/DESIGN.md +423 -0
  161. package/web/references/yanolja/DESIGN.md +17 -2
  162. package/web/references/yeogiotte/DESIGN.md +18 -2
  163. package/web/references/yogiyo/DESIGN.md +465 -0
  164. package/web/references/zapier/DESIGN.md +20 -0
  165. package/web/references/zigbang/DESIGN.md +12 -2
  166. package/web/references/zigzag/DESIGN.md +17 -2
  167. package/agents/omd-3d-blender.md +0 -269
  168. package/dist/install-skills-MVXVXYAY.js.map +0 -1
@@ -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.
@@ -1,3 +1,17 @@
1
+ ---
2
+ id: minimax
3
+ name: Minimax
4
+ country: US
5
+ category: ai
6
+ homepage: "https://www.minimaxi.com"
7
+ primary_color: "#000000"
8
+ logo:
9
+ type: simpleicons
10
+ slug: minimax
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ---
14
+
1
15
  # Design System Inspiration of MiniMax
2
16
 
3
17
  ## 1. Visual Theme & Atmosphere
@@ -1,3 +1,17 @@
1
+ ---
2
+ id: mintlify
3
+ name: Mintlify
4
+ country: US
5
+ category: productivity
6
+ homepage: "https://mintlify.com"
7
+ primary_color: "#0d9373"
8
+ logo:
9
+ type: simpleicons
10
+ slug: mintlify
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ---
14
+
1
15
  # Design System Inspiration of Mintlify
2
16
 
3
17
  ## 1. Visual Theme & Atmosphere
@@ -1,3 +1,23 @@
1
+ ---
2
+ id: miro
3
+ name: Miro
4
+ country: US
5
+ category: design-tools
6
+ homepage: "https://miro.com"
7
+ primary_color: "#ffd02f"
8
+ logo:
9
+ type: simpleicons
10
+ slug: miro
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ds:
14
+ name: Mirotone
15
+ url: "https://mirotone.xyz"
16
+ type: system
17
+ description: Miro's CSS component library for apps built on the Miro platform.
18
+ og_image: "https://www.mirotone.xyz/cover.png"
19
+ ---
20
+
1
21
  # Design System Inspiration of Miro
2
22
 
3
23
  ## 1. Visual Theme & Atmosphere
@@ -1,3 +1,23 @@
1
+ ---
2
+ id: mistral.ai
3
+ name: Mistral AI
4
+ country: FR
5
+ category: ai
6
+ homepage: "https://mistral.ai"
7
+ primary_color: "#ff7000"
8
+ logo:
9
+ type: simpleicons
10
+ slug: mistralai
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ds:
14
+ name: Mistral Brand
15
+ url: "https://mistral.ai/brand"
16
+ type: brand
17
+ description: Mistral AI's logo, colors, typography, and brand asset kit.
18
+ og_image: "https://mistral.ai/-/brand/opengraph-image-1robrb.png"
19
+ ---
20
+
1
21
  # Design System Inspiration of Mistral AI
2
22
 
3
23
  ## 1. Visual Theme & Atmosphere