oh-my-design-cli 1.0.1 → 1.1.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.
Files changed (102) hide show
  1. package/README.md +15 -18
  2. package/data/reference-fingerprints.json +337 -3
  3. package/data/reference-tags.md +15 -1
  4. package/dist/bin/oh-my-design.js +1 -1
  5. package/dist/{install-skills-GQPTQF5S.js → install-skills-MVXVXYAY.js} +4 -4
  6. package/dist/{install-skills-GQPTQF5S.js.map → install-skills-MVXVXYAY.js.map} +1 -1
  7. package/package.json +2 -2
  8. package/skills/omd-init/SKILL.md +1 -1
  9. package/web/AGENTS.md +5 -0
  10. package/{references → web/references}/airbnb/DESIGN.md +158 -19
  11. package/web/references/airtable/DESIGN.md +241 -0
  12. package/{references → web/references}/apple/DESIGN.md +131 -76
  13. package/web/references/baemin/DESIGN.md +470 -0
  14. package/{references → web/references}/bmw/DESIGN.md +138 -9
  15. package/{references → web/references}/cal/DESIGN.md +173 -17
  16. package/{references → web/references}/claude/DESIGN.md +11 -1
  17. package/{references → web/references}/clay/DESIGN.md +75 -0
  18. package/{references → web/references}/clickhouse/DESIGN.md +74 -0
  19. package/{references → web/references}/cohere/DESIGN.md +75 -0
  20. package/web/references/coinbase/DESIGN.md +205 -0
  21. package/{references → web/references}/composio/DESIGN.md +74 -0
  22. package/web/references/coupang/DESIGN.md +487 -0
  23. package/{references → web/references}/cursor/DESIGN.md +74 -0
  24. package/web/references/dcard/DESIGN.md +567 -0
  25. package/{references → web/references}/elevenlabs/DESIGN.md +91 -0
  26. package/{references → web/references}/expo/DESIGN.md +72 -0
  27. package/{references → web/references}/ferrari/DESIGN.md +72 -0
  28. package/{references → web/references}/figma/DESIGN.md +124 -48
  29. package/{references → web/references}/framer/DESIGN.md +143 -16
  30. package/web/references/freee/DESIGN.md +558 -0
  31. package/{references → web/references}/hashicorp/DESIGN.md +72 -0
  32. package/{references → web/references}/ibm/DESIGN.md +68 -0
  33. package/{references → web/references}/intercom/DESIGN.md +73 -0
  34. package/web/references/kakao/DESIGN.md +490 -0
  35. package/web/references/kakaobank/DESIGN.md +533 -0
  36. package/web/references/karrot/DESIGN.md +431 -0
  37. package/web/references/kraken/DESIGN.md +219 -0
  38. package/web/references/krds/DESIGN.md +982 -0
  39. package/web/references/kurly/DESIGN.md +574 -0
  40. package/{references → web/references}/lamborghini/DESIGN.md +74 -0
  41. package/{references → web/references}/line/DESIGN.md +84 -43
  42. package/{references → web/references}/linear.app/DESIGN.md +8 -1
  43. package/{references → web/references}/lovable/DESIGN.md +73 -0
  44. package/web/references/mercari/DESIGN.md +464 -0
  45. package/{references → web/references}/minimax/DESIGN.md +72 -0
  46. package/{references → web/references}/mintlify/DESIGN.md +72 -0
  47. package/web/references/miro/DESIGN.md +252 -0
  48. package/{references → web/references}/mistral.ai/DESIGN.md +72 -0
  49. package/{references → web/references}/mongodb/DESIGN.md +72 -0
  50. package/web/references/musinsa/DESIGN.md +536 -0
  51. package/web/references/naver/DESIGN.md +518 -0
  52. package/{references → web/references}/notion/DESIGN.md +9 -1
  53. package/web/references/nvidia/DESIGN.md +491 -0
  54. package/web/references/ohouse/DESIGN.md +570 -0
  55. package/{references → web/references}/ollama/DESIGN.md +72 -0
  56. package/{references → web/references}/opencode.ai/DESIGN.md +73 -0
  57. package/web/references/pinkoi/DESIGN.md +575 -0
  58. package/{references → web/references}/pinterest/DESIGN.md +73 -0
  59. package/{references → web/references}/posthog/DESIGN.md +172 -18
  60. package/web/references/qanda/DESIGN.md +459 -0
  61. package/{references → web/references}/raycast/DESIGN.md +169 -34
  62. package/{references → web/references}/renault/DESIGN.md +72 -0
  63. package/{references → web/references}/replicate/DESIGN.md +73 -0
  64. package/{references → web/references}/resend/DESIGN.md +73 -0
  65. package/{references → web/references}/revolut/DESIGN.md +74 -0
  66. package/web/references/ridi/DESIGN.md +517 -0
  67. package/{references → web/references}/runwayml/DESIGN.md +152 -24
  68. package/{references → web/references}/sanity/DESIGN.md +72 -0
  69. package/{references → web/references}/sentry/DESIGN.md +73 -0
  70. package/web/references/spacex/DESIGN.md +379 -0
  71. package/web/references/spotify/DESIGN.md +426 -0
  72. package/{references → web/references}/stripe/DESIGN.md +44 -1
  73. package/{references → web/references}/supabase/DESIGN.md +73 -0
  74. package/{references → web/references}/superhuman/DESIGN.md +159 -17
  75. package/{references → web/references}/tesla/DESIGN.md +170 -0
  76. package/{references → web/references}/together.ai/DESIGN.md +73 -0
  77. package/{references → web/references}/toss/DESIGN.md +304 -50
  78. package/{references → web/references}/uber/DESIGN.md +73 -0
  79. package/{references → web/references}/vercel/DESIGN.md +9 -1
  80. package/{references → web/references}/voltagent/DESIGN.md +73 -0
  81. package/{references → web/references}/warp/DESIGN.md +142 -15
  82. package/web/references/webflow/DESIGN.md +253 -0
  83. package/{references → web/references}/wise/DESIGN.md +84 -0
  84. package/{references → web/references}/x.ai/DESIGN.md +85 -0
  85. package/web/references/yanolja/DESIGN.md +448 -0
  86. package/web/references/yeogiotte/DESIGN.md +424 -0
  87. package/{references → web/references}/zapier/DESIGN.md +85 -0
  88. package/references/airtable/DESIGN.md +0 -107
  89. package/references/baemin/DESIGN.md +0 -260
  90. package/references/coinbase/DESIGN.md +0 -129
  91. package/references/dcard/DESIGN.md +0 -302
  92. package/references/freee/DESIGN.md +0 -308
  93. package/references/kakao/DESIGN.md +0 -261
  94. package/references/karrot/DESIGN.md +0 -252
  95. package/references/kraken/DESIGN.md +0 -146
  96. package/references/mercari/DESIGN.md +0 -294
  97. package/references/miro/DESIGN.md +0 -108
  98. package/references/nvidia/DESIGN.md +0 -308
  99. package/references/pinkoi/DESIGN.md +0 -309
  100. package/references/spacex/DESIGN.md +0 -205
  101. package/references/spotify/DESIGN.md +0 -246
  102. package/references/webflow/DESIGN.md +0 -109
@@ -0,0 +1,517 @@
1
+ ---
2
+ omd: 0.1
3
+ brand: RIDI
4
+ ---
5
+
6
+ # Design System Inspiration of RIDI (리디)
7
+
8
+ ## 1. Visual Theme & Atmosphere
9
+
10
+ RIDI's interface is a long-form reading room dressed as a storefront. It is the rare consumer surface in Korean tech that treats *typography itself* as the brand — the screen opens on a near-pure white canvas (`#ffffff`) with a deep charcoal foreground (`#3D3D3D` to `#222222`) and sits the user inside a layout that is more bookshop than marketplace. There is no saturated brand orange, no Toss-blue, no Karrot accent: the iconic element is the **BookCard** — a cover-art tile with a subtle multi-layer shadow that lifts each book half a millimeter off the page, the way a hardcover lifts off a wood table.
11
+
12
+ The system is built on **Pretendard Std** (with Pretendard JP and Pretendard fallbacks for cross-locale catalogs) for UI chrome, and the company's own custom serif **RIDIBatang** (리디바탕) for long-form reading inside the e-book viewer. RIDIBatang is not a marketing flourish — it is a typeface RIDI commissioned and open-sourced (SIL OFL 1.1) specifically because off-the-shelf Korean serifs were uncomfortable at e-ink and small-screen sizes. That decision — *spend money to make a body face* — is the brand statement. Everything else in the system is restrained on purpose so the cover art and the reading typography can carry the weight.
13
+
14
+ **Key Characteristics:**
15
+ - Editorial, near-monochrome chrome — Deep Charcoal (`#3D3D3D`) on Pure White (`#ffffff`) as the dominant pairing
16
+ - Two-typeface system: **Pretendard Std** for UI, **RIDIBatang** (proprietary serif) for reading content
17
+ - BookCard is the iconic component — cover-led grid with multi-layer soft shadows for depth without heaviness
18
+ - Card-and-shelf layout language inherited from physical bookstores (categories as shelves, covers as inventory)
19
+ - 4px-aligned spacing with generous vertical rhythm tuned for scanning long lists of titles
20
+ - Layered shadow system: `0 2px 16px rgba(0,0,0,0.03)` for resting cards, `0 4px 16px rgba(0,0,0,0.12) + 0 0 1px rgba(0,0,0,0.08)` for elevated/hover state
21
+ - Radii follow content: 8px (buttons, controls), 12px (cards), 24px (modals, sheets)
22
+ - Subscription surfaces (RIDI Select, Manta) get slightly warmer treatment but inherit the same chrome tokens
23
+
24
+ ## 2. Color Palette & Roles
25
+
26
+ ### Primary
27
+ - **Deep Charcoal** (`#3D3D3D`): Primary CTA background, brand-led pill buttons (`Get started`, `로그인`). The unambiguous brand-solid surface. <!-- verified: ridibooks.com computed style on .button.button-primary, 2026-05 -->
28
+ - **Foreground Primary** (`#222222`): `Neutral-Colors-Foreground-Primary`. Headings, primary body text, navigation labels.
29
+ - **Pure White** (`#ffffff`): `Neutral-Colors-Background-Card`. Page background, BookCard surface.
30
+ - **RIDI Blue** (`#1F8CE6`): Legacy / accent — used historically for inline links, RIDI Select chips, and "Read now" affordances inside the reader. Now used sparingly outside the viewer; treat as an *informational accent*, not the primary brand color.
31
+
32
+ ### Neutrals (Foreground)
33
+ - **Foreground Secondary** (`#5D5D5D`): Captions, author names under titles, metadata rows.
34
+ - **Foreground Tertiary** (`#9D9D9D`): Timestamps, "n분 전", page-counter chrome inside the reader.
35
+ - **Foreground Disabled** (`#B5B5B5`): Disabled label text inside neutral-weak buttons.
36
+
37
+ ### Neutrals (Surface & Stroke)
38
+ - **Background Card** (`#ffffff`): Card and sheet surface.
39
+ - **Background Subtle** (`#F9F9F9`): Section bands, alternating shelf rows.
40
+ - **Stroke Inactive** (`#D0D0D0`): Standard 1px card outline, input border, divider. <!-- verified: ridibooks.com computed border on tooltip card, 2026-05 -->
41
+ - **Stroke Subtle** (`rgba(0,0,0,0.08)`): Faint card outline used together with shadow for soft elevation.
42
+
43
+ ### Semantic
44
+ - **Critical Red** (`#F4361E`): Sale-price tags, "X% 할인" badges, error states. <!-- verified: ridibooks.com computed style on price/badge surface, 2026-05 -->
45
+ - **Positive Green** (`#03AA5A`): Subscription-active state, "구독 중" pills, download-complete confirmations.
46
+ - **Informative Blue** (`#1F8CE6`): Inline links, "더 보기", informational notices. Same hue as RIDI Blue, role-aliased as `fg-informative` outside the reader.
47
+ - **Highlight Cream** (`#FFF9EA`): Featured-pick callout background, editor's pick banners.
48
+
49
+ ### Reader-Specific (E-book / Webtoon viewer)
50
+ - **Sepia Background** (`#F4ECD8`): Sepia reading theme background.
51
+ - **Night Background** (`#1A1A1A`): Night reading theme background.
52
+ - **Reader Foreground** (`#222222`): Day-mode body text in the e-book viewer.
53
+ - **Reader Foreground (Night)** (`#D8D8D8`): Night-mode body text in the e-book viewer.
54
+
55
+ ## 3. Typography Rules
56
+
57
+ ### Font Family
58
+
59
+ - **UI Primary**: `"Pretendard Std", "Pretendard JP", Pretendard, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", system-ui, sans-serif` <!-- verified: ridibooks.com `getComputedStyle(body).fontFamily`, 2026-05 -->
60
+ - **Reading (proprietary)**: `RIDIBatang, "Apple SD Gothic Neo", "Noto Serif KR", serif` — RIDI's commissioned serif typeface, used inside the e-book viewer for long-form Korean prose. Distributed under SIL Open Font License 1.1 ([ridicorp.com/ridibatang](https://ridicorp.com/ridibatang/)).
61
+ - **Monospace**: `"SF Mono", SFMono-Regular, Menlo, Consolas, monospace` (book metadata, ISBN strings, technical body content).
62
+
63
+ **Design principle.** Two typefaces, two jobs. Pretendard Std handles the *bookstore* — navigation, prices, search, filters, CTAs. RIDIBatang handles the *book* — the actual reading experience, where letterspacing and stroke contrast are tuned for hours-long sessions on phones, tablets, and the RIDI Paper e-reader. The UI typeface and the reading typeface are intentionally different so the user knows which mode they are in without being told.
64
+
65
+ ### Hierarchy (UI surfaces — Pretendard Std)
66
+
67
+ | Role | Size | Weight | Line Height | Notes |
68
+ |------|------|--------|-------------|-------|
69
+ | Display | 28px | 700 | 36px | Section banners, "오늘의 발견" hero |
70
+ | Heading Large | 22px | 700 | 30px | Shelf titles ("베스트셀러", "지금 뜨는 웹소설") |
71
+ | Heading | 18px | 700 | 26px | Modal titles, BookCard expanded title |
72
+ | Title | 16px | 600 | 22px | BookCard title (default), nav active label |
73
+ | Body | 16px | 400 | 24px | Primary body, descriptions, button label |
74
+ | Body Small | 14px | 400 | 20px | Author, publisher, metadata under title |
75
+ | Caption | 13px | 400 | 18px | Star ratings, review counts, page counts |
76
+ | Caption Small | 12px | 400 | 16px | Timestamps, footer chrome, badge text |
77
+
78
+ ### Hierarchy (Reading surfaces — RIDIBatang)
79
+
80
+ | Role | Size | Weight | Line Height | Notes |
81
+ |------|------|--------|-------------|-------|
82
+ | Reader Body | 17–22px (user-controlled) | 400 | 1.7 | Default e-book body — user-adjustable on a 5-step scale |
83
+ | Reader H1 (chapter) | 26px | 700 | 1.4 | Chapter openers |
84
+ | Reader H2 | 20px | 700 | 1.5 | Section headers within a chapter |
85
+ | Reader Quote | 16px | 400 italic | 1.7 | Block quotes, footnotes |
86
+
87
+ ### Principles
88
+ - **Pretendard Std for the store, RIDIBatang for the book.** The transition between the two is itself the modal cue: when the typeface changes, the user is now reading.
89
+ - **Three weights only on UI**: Regular (400), Semibold (600), Bold (700). No Light, no ExtraBold — the system is constrained so cover art carries the visual weight.
90
+ - **User-controllable type in the reader**: Font size, line height, and typeface (RIDIBatang / Sans / Serif / Custom) are all user-adjustable inside the viewer. Never hard-coded inside the reading frame.
91
+ - **Korean-first, but JP-aware**: Pretendard JP is in the stack because RIDI's catalog includes substantial Japanese content (BL/light-novel translations, manga); the system must render mixed Korean–Japanese covers and metadata without falling back to a system serif.
92
+
93
+ ## 4. Component Stylings
94
+
95
+ ### Buttons
96
+
97
+ **Brand Solid (Primary CTA)**
98
+ - Background: `#3D3D3D` (Deep Charcoal) <!-- verified: ridibooks.com `.button` computed background, 2026-05 -->
99
+ - Text: `#F9F9F9`
100
+ - Radius: 8px
101
+ - Min-height: 36px (medium), 44px (large), 52px (XL — bottom-sheet primary)
102
+ - Padding: 6px 8px (medium), 10px 16px (large), 14px 24px (XL)
103
+ - Font: Pretendard Std 16px / weight 400 (label), 16px / weight 600 (XL CTA)
104
+ - Pressed: `#222222` (drop one charcoal step)
105
+ - Disabled: `#F0F0F0` background, `#B5B5B5` text
106
+ - Use: `로그인`, `구독하기`, `Get started`, `다음 화 보기`
107
+
108
+ **Neutral Outline**
109
+ - Background: transparent
110
+ - Text: `#222222`
111
+ - Border: 1px solid `#D0D0D0`
112
+ - Radius: 8px
113
+ - Pressed: `#F9F9F9` background fill
114
+ - Use: `장바구니`, `나중에 읽기`, secondary navigation
115
+
116
+ **Critical / Sale Tag** (used as a chip, not a button)
117
+ - Background: `#F4361E`
118
+ - Text: `#ffffff`, weight 700
119
+ - Radius: 4px
120
+ - Use: "30% 할인", "오늘만 특가" inline price flags. Never as a CTA.
121
+
122
+ **Subscription Solid (RIDI Select / Manta)**
123
+ - Background: `#1F8CE6` (RIDI Blue)
124
+ - Text: `#ffffff`, weight 600
125
+ - Radius: 8px
126
+ - Use: `RIDI Select 시작하기`, `Manta 무료 체험`. The one place RIDI Blue is allowed as a brand-solid surface.
127
+
128
+ ### BookCard (the iconic component)
129
+
130
+ The BookCard is RIDI's defining unit. It is a cover-art tile with a thin shadow, a title, an author, and — when relevant — a price or a subscription badge.
131
+
132
+ - Surface: `#ffffff`
133
+ - Cover image: 2:3 aspect (book cover ratio), edge-to-edge top, no internal padding
134
+ - Cover radius: 4px (subtle — preserves the rectangular feel of a printed cover)
135
+ - Card radius: 12px on the outer card chrome
136
+ - Shadow (resting): `0 2px 16px rgba(0, 0, 0, 0.03)` <!-- verified: ridibooks.com computed boxShadow on `.shadow-1` card, 2026-05 -->
137
+ - Shadow (hover/elevated): `0 4px 16px rgba(0, 0, 0, 0.12), 0 0 1px rgba(0, 0, 0, 0.08)` <!-- verified: ridibooks.com computed boxShadow on `.shadow-2` card, 2026-05 -->
138
+ - Padding: 4px 0 (chrome), text content sits below the cover with 8px gap
139
+ - Title: Pretendard Std 16px / weight 600 / `#222222`, max 2 lines, ellipsis
140
+ - Author: Pretendard Std 14px / weight 400 / `#5D5D5D`, single line, ellipsis
141
+ - Price: Pretendard Std 16px / weight 700 / `#222222`, with strikethrough original price 13px / `#9D9D9D` when on sale
142
+ - Sale flag: 12px weight 700 white text on `#F4361E` background, 4px radius, sits top-right of the cover
143
+
144
+ **Variants:**
145
+ - **Grid card** (default catalog browsing): full BookCard above
146
+ - **Shelf card** (horizontal scroll on home): cover-only, title/author below as caption-row
147
+ - **List row** (search results, library): horizontal layout — cover thumb left (60×90px), title + author + meta stacked right
148
+
149
+ ### Cards & Containers (general)
150
+ - Background: `#ffffff`
151
+ - Border: usually omitted in favor of shadow; when used, 1px solid `#D0D0D0` or `rgba(0,0,0,0.08)`
152
+ - Radius: 8px (compact controls), 12px (BookCard, content cards), 24px (modal sheets, bottom-sheets)
153
+ - Shadow: see BookCard scale; modals use `0 6px 24px rgba(0,0,0,0.12), 0 0 1.5px rgba(0,0,0,0.08)` <!-- verified: tooltip computed boxShadow, 2026-05 -->
154
+
155
+ ### Chips & Tags
156
+ - Background: `#F9F9F9` (default), `#222222` (selected, with white text)
157
+ - Radius: 9999px (pill)
158
+ - Height: 32px, Padding: 0 12px
159
+ - Font: Pretendard Std 13px weight 500
160
+ - Use: genre filters ("로맨스", "BL", "판타지"), price filters, sort options
161
+
162
+ ### Inputs & Forms
163
+ - Background: `#F9F9F9` or `#ffffff`
164
+ - Border: 1px solid `#D0D0D0`
165
+ - Radius: 8px
166
+ - Height: 44px (default), 36px (compact), 52px (large search hero)
167
+ - Focus: 2px solid `#1F8CE6` ring (RIDI Blue, used as informative-focus)
168
+ - Text: `#222222`, Placeholder: `#9D9D9D`
169
+ - Search input: leading magnifier icon, 16px gap, optional trailing close-X when text present
170
+
171
+ ### Navigation
172
+ - Top bar (web): white, 64px height, 1px bottom border `rgba(0,0,0,0.06)` or none with subtle shadow `0 1px 0 rgba(0,0,0,0.04)`
173
+ - Logo on left (RIDI wordmark), category nav center, search + my-library + cart icons right
174
+ - Active category label: `#222222` weight 700; inactive: `#5D5D5D` weight 500
175
+ - Mobile: bottom tab bar with icon + Korean label, active tint = `#222222`, inactive = `#9D9D9D`
176
+
177
+ ### Reader Toolbar (in-book viewer)
178
+ - Top: minimal, auto-hides after 3s of inactivity
179
+ - Background: white (day) / `#1A1A1A` (night) / `#F4ECD8` (sepia)
180
+ - Bottom: progress bar `#222222` fill on `#D0D0D0` track, 2px height
181
+ - Page-counter: 13px weight 400 `#9D9D9D` (day) / `#9D9D9D` (night)
182
+
183
+ ## 5. Layout Principles
184
+
185
+ ### Spacing System
186
+ - Base unit: 4px
187
+ - Scale: 4, 8, 12, 16, 20, 24, 32, 40, 48, 64, 80
188
+ - Default page gutter: 16px (mobile), 24px (tablet), 40px (desktop)
189
+ - Inter-card gap (grid): 12px (mobile), 16px (tablet), 24px (desktop)
190
+ - Shelf row vertical rhythm: 32px between section title and grid, 64px between shelves
191
+
192
+ ### Grid & Container
193
+ - Mobile: full-width with 16px gutter, 3-column BookCard grid
194
+ - Tablet: 6-column BookCard grid, 24px gutter
195
+ - Desktop: max-width 1280px, 8-column BookCard grid for full catalog, 6-column for curated shelves
196
+ - Reader content max-width: ~36em (~640px) regardless of viewport — for line-length comfort
197
+
198
+ ### Whitespace Philosophy
199
+ - **Cover-dense, chrome-light**: BookCards are the content; spacing must let covers breathe but never dominate. Target 6–9 covers per mobile viewport, 18–24 on desktop.
200
+ - **Shelves, not feeds**: Horizontal-scroll shelves are preferred over vertical infinite-feeds for curation surfaces — the metaphor is a bookstore, not a timeline.
201
+ - **The reader is sacred**: Inside the e-book viewer, chrome collapses to near-zero. Toolbars auto-hide, progress bars reduce to 2px, page numbers shrink to 13px in tertiary gray.
202
+
203
+ ### Border Radius Scale
204
+ - Micro (4px): Cover image radius, sale-flag chips
205
+ - Standard (8px): Buttons, inputs, small chips
206
+ - Card (12px): BookCard, content cards
207
+ - Sheet (24px): Modal sheets, bottom-sheets, large hero containers
208
+ - Pill (9999px): Filter chips, avatars
209
+
210
+ ## 6. Depth & Elevation
211
+
212
+ | Level | Treatment | Use |
213
+ |-------|-----------|-----|
214
+ | Flat | No shadow | Page background, inline elements, toolbar chrome |
215
+ | Soft (s1) | `0 2px 16px rgba(0,0,0,0.03)` | BookCard at rest — barely there, just enough to lift the cover off the page |
216
+ | Standard (s2) | `0 4px 16px rgba(0,0,0,0.12), 0 0 1px rgba(0,0,0,0.08)` | BookCard hover, dropdowns, popovers — the "I am interactive" elevation |
217
+ | Modal (s3) | `0 6px 24px rgba(0,0,0,0.12), 0 0 1.5px rgba(0,0,0,0.08)` | Modal sheets, bottom sheets, full-screen overlays |
218
+ | Page-level (s4) | `0 0 8px rgba(0,0,0,0.08)` (omnidirectional) | Floating header on scroll, tab bar separation in dark mode |
219
+
220
+ **Shadow philosophy.** Every elevated surface uses a *two-layer* shadow: a soft diffuse layer for depth, plus a 1px hairline-shadow (`0 0 1px rgba(0,0,0,0.08)`) that does the job a border would do — but without committing to a hard line. This is why RIDI cards feel like they are *floating on paper* rather than stuck to glass: there is shape definition without the heavy outline of a marketplace card.
221
+
222
+ ## 7. Do's and Don'ts
223
+
224
+ ### Do
225
+ - Lead with cover art. The BookCard is the hero — chrome around it should disappear.
226
+ - Use Deep Charcoal (`#3D3D3D`) as the primary CTA — it reads as editorial, neutral, and respectful of the cover beside it.
227
+ - Reserve RIDI Blue (`#1F8CE6`) for subscription surfaces (RIDI Select, Manta) and informational links — never as the primary brand-solid on a generic store CTA.
228
+ - Use Pretendard Std for all UI chrome and RIDIBatang for reading body — the typeface change *is* the modal cue.
229
+ - Use multi-layer shadows (diffuse + hairline) rather than 1px borders for card definition.
230
+ - Snap all spacing to the 4px grid: 4, 8, 12, 16, 20, 24, 32, 40, 48, 64, 80.
231
+ - Surface metadata that helps a reader decide: author, page count, completion status, age rating, episode count for serials.
232
+
233
+ ### Don't
234
+ - Don't put a saturated brand background behind a BookCard — the cover loses depth and color contrast against bright chrome.
235
+ - Don't use RIDI Blue as the default CTA color — the live store uses Deep Charcoal precisely because it competes with cover art the least.
236
+ - Don't lock the reader's typeface or font size — both are user-adjustable in the viewer; hard-coded reading typography is a regression.
237
+ - Don't use heavy 1px borders on BookCards — RIDI's signature is the soft hairline-shadow + diffuse-shadow pair, not bordered tiles.
238
+ - Don't show price strikethroughs without the discount-percent flag — the two are a pair; either both or neither.
239
+ - Don't intermix Pretendard and RIDIBatang in the same surface — the typeface switch should be a *navigation event* (entering the reader), not an in-card decoration.
240
+ - Don't introduce a third brand color. The system is two-color: charcoal + white, with blue as a scoped accent.
241
+
242
+ ## 8. Responsive Behavior
243
+
244
+ ### Breakpoints
245
+ | Name | Width | Key Changes |
246
+ |------|-------|-------------|
247
+ | Mobile | <480px | 3-col BookCard grid, 16px gutter, bottom tab bar |
248
+ | Tablet | 480–1024px | 6-col grid, 24px gutter, persistent top nav |
249
+ | Desktop | >1024px | Max-width 1280px, 8-col grid, hover states active |
250
+ | Reader (any) | full-screen | Chrome auto-hides, max-width ~36em content column |
251
+
252
+ ### Touch Targets
253
+ - Buttons: 36px (medium), 44px (large), 52px (XL)
254
+ - BookCard tap target: full card surface (cover + meta block)
255
+ - Filter chips: 32px height minimum
256
+ - Reader page-turn zones: full left/right halves of the screen
257
+
258
+ ### Collapsing Strategy
259
+ - Top nav collapses to hamburger + logo + search-icon below 768px
260
+ - Shelves remain horizontal-scroll on all sizes (never collapse to grid) — the metaphor is preserved
261
+ - Hero banners shrink to 16:9 on mobile, 21:9 on desktop
262
+ - Reader toolbar collapses entirely after 3s; tap-center to recall
263
+
264
+ ### Image Behavior
265
+ - BookCovers: 2:3 aspect, 4px radius, lazy-loaded, blur-up placeholder in `#F9F9F9`
266
+ - Author avatars: circular (9999px), 40px (default), 56px (author-page hero)
267
+ - Banner images: full-width, no radius on mobile, 12px radius on tablet+
268
+
269
+ ## 9. Agent Prompt Guide
270
+
271
+ ### Quick Color Reference
272
+ - Primary CTA: Deep Charcoal (`#3D3D3D`)
273
+ - CTA Pressed: Near-Black (`#222222`)
274
+ - Subscription CTA (RIDI Select / Manta): RIDI Blue (`#1F8CE6`)
275
+ - Background: Pure White (`#ffffff`)
276
+ - Subtle band: `#F9F9F9`
277
+ - Heading text: `#222222`
278
+ - Body text: `#3D3D3D` to `#222222`
279
+ - Caption text: `#5D5D5D`
280
+ - Tertiary / metadata: `#9D9D9D`
281
+ - Disabled: `#B5B5B5`
282
+ - Border: `#D0D0D0`
283
+ - Sale / Critical: `#F4361E`
284
+ - Success / Subscribed: `#03AA5A`
285
+
286
+ ### Example Component Prompts
287
+ - "Create a RIDI BookCard: white background, 12px outer radius, soft shadow `0 2px 16px rgba(0,0,0,0.03)`. Cover image 2:3 aspect, 4px radius, edge-to-edge top. Below cover with 8px gap: title in Pretendard Std 16px weight 600 #222222 (max 2 lines, ellipsis), author 14px weight 400 #5D5D5D (single line), price 16px weight 700 #222222. On hover, escalate shadow to `0 4px 16px rgba(0,0,0,0.12), 0 0 1px rgba(0,0,0,0.08)`."
288
+ - "Build a RIDI primary CTA: `#3D3D3D` background, `#F9F9F9` text, Pretendard Std 16px, 8px radius, min-height 44px, padding 10px 16px. Pressed: `#222222`. Disabled: `#F0F0F0` bg / `#B5B5B5` text."
289
+ - "Design a genre filter chip row: horizontal scroll, 8px gap. Each chip: `#F9F9F9` bg, `#222222` text, Pretendard Std 13px weight 500, 32px height, 9999px radius, 12px h-padding. Selected: `#222222` bg, `#ffffff` text. Korean labels: 로맨스, BL, 판타지, 무협, 라이트노벨, 만화."
290
+ - "Create the e-book reader frame: white background (day) / `#F4ECD8` (sepia) / `#1A1A1A` (night). Body text in RIDIBatang 18px line-height 1.7, `#222222` (day) / `#3D3D3D` (sepia) / `#D8D8D8` (night). Max-width 36em. Auto-hide top toolbar after 3s. Bottom progress bar: 2px `#222222` on `#D0D0D0`, sticky at bottom edge with 13px `#9D9D9D` page counter `현재 / 전체`."
291
+ - "Build a RIDI Select subscription CTA: `#1F8CE6` background, white text, Pretendard Std 16px weight 600, 8px radius, min-height 52px, full-width on mobile. Below: 13px weight 400 `#5D5D5D` caption '월 9,900원 · 언제든지 해지'."
292
+
293
+ ### Iteration Guide
294
+ 1. Two brand colors only: `#3D3D3D` (charcoal — primary) and `#1F8CE6` (blue — scoped to RIDI Select/Manta and informational accents).
295
+ 2. Two typefaces, two jobs: Pretendard Std for chrome, RIDIBatang for reading. Don't blur the boundary.
296
+ 3. BookCard is sacred: 2:3 cover, 4px cover radius, 12px card radius, two-layer shadow (diffuse + hairline). Never replace with bordered tiles.
297
+ 4. Spacing snaps to the 4px grid. BookCard grids breathe — 12px gap mobile, 16–24px desktop.
298
+ 5. Reader chrome disappears. Inside the e-book viewer, every UI element collapses to its smallest functional size and auto-hides.
299
+ 6. Sale flag + strikethrough always co-occur. Don't show one without the other.
300
+ 7. Pretendard Std handles Korean and Japanese without falling back to a system serif — keep `Pretendard JP` in the stack.
301
+
302
+ ---
303
+
304
+ ## 10. Voice & Tone
305
+
306
+ RIDI speaks like a librarian who has read everything in the building and has opinions but won't impose them. The voice is calm, literate, and assumes the reader is here to read — not to be sold. Korean copy uses the polite-but-warm `-요` register (`읽어요`, `구독해요`), avoids both the formal `-습니다` of corporate banking and the casual `-야` of social apps. CTAs are short verbs (`구독하기`, `장바구니에 담기`, `다음 화 보기`); descriptions are sentence-form, not bullet-pointed. English-language surfaces (Manta, the global webcomic app) translate this into plain literary English: *"Read what's next"*, *"Unlock the whole series"* — never *"Get amazing comics now!!"*
307
+
308
+ | Context | Tone |
309
+ |---|---|
310
+ | CTAs | Short verb-first Korean (`구독하기`, `다음 화 보기`, `장바구니`) / plain English (`Read`, `Subscribe`, `Continue`) |
311
+ | Empty states | One literate line that names what's missing, plus a low-pressure suggestion. Never `데이터가 없습니다`. |
312
+ | Error messages | Calm, specific, blameless. Prefer `잠시 후 다시 시도해 주세요` over `오류가 발생했습니다`. |
313
+ | Subscription nudges | Soft-sell, never urgent. `이 시리즈는 RIDI Select에서 무제한으로 읽을 수 있어요` — informational, not pressuring. |
314
+ | Sale / pricing | Plain numerals + percent. `30% 할인 · 오늘까지`. No emojis on price chrome. |
315
+ | Reader chrome | Near-silent. Page counter, time-left-in-chapter, progress percent. No motivational copy inside the reader. |
316
+ | Editorial / curation | Sentence-length, voiced, occasionally first-person plural (`이번 주 추천작이에요`). Reads like a small bookstore newsletter. |
317
+ | Onboarding | One screen, one idea: pick your genres. No feature tours, no swipe-through tutorial. |
318
+
319
+ **Forbidden phrases.** `데이터가 없습니다`, `오류가 발생했습니다`, `놀라운`, `최고의`, `획기적인`. English: `amazing`, `unbeatable deals`, `world-class`, `Oops! Something went wrong`. Pricing copy stays in numerals and percent — never `너무 좋은 기회!`. Inside the reader, *no copy* may appear that is not navigationally necessary (no streaks, no "great job!", no daily reading-goal toasts).
320
+
321
+ **Voice samples.**
322
+
323
+ - `만화 웹툰 웹소설 전자책` — primary catalog tagline, RIDI homepage `<title>`. <!-- verified: ridibooks.com page title, 2026-05 -->
324
+ - `검색어를 입력해 주세요.` — search placeholder, polite `-요` register. <!-- illustrative: matches RIDI's polite-warm register, not directly verified on the live home -->
325
+ - `다음 화 보기` — webtoon/web-novel reader continue CTA. <!-- illustrative: standard RIDI episode-reader pattern, not directly captured -->
326
+ - `이 시리즈는 RIDI Select에서 무제한으로 읽을 수 있어요` — illustrative subscription nudge in the polite register. <!-- illustrative: not verified as live RIDI copy -->
327
+ - `Read what's next` — illustrative Manta English continue-CTA. <!-- illustrative: not verified as live Manta copy -->
328
+ - `리디바탕 — 전자책에 최적화된 본문 글꼴` — RIDIBatang's own positioning copy on ridicorp.com. <!-- cited: ridicorp.com/ridibatang, 2026-05, paraphrased -->
329
+
330
+ ## 11. Brand Narrative
331
+
332
+ RIDI was founded in May 2008 in Seoul by **배기식 (Bae Ki-sik)**, a former Samsung Electronics venture-investment associate who left to bet on the iPhone-era of mobile content before Korea had an e-book market to speak of ([Forbes Korea](https://www.forbeskorea.co.kr/news/articleView.html?idxno=336251), [KED Global](https://www.kedglobal.com/kunicornsView/kun0006)). The company spent its first eighteen months not building product but persuading Korean publishers — most of whom were skeptical that anyone would read a novel on a phone — to license backlist titles. **Ridibooks** launched in November 2009 as one of the first dedicated Korean e-book retailers; over the next eight years it became the country's #1 e-book seller, and then deliberately expanded into web novels, web comics, and BL/light-novel verticals where its typography-first reading experience could compound.
333
+
334
+ The product story is built on a typography decision. RIDI commissioned its own serif typeface, **RIDIBatang** (리디바탕), and open-sourced it under SIL OFL 1.1 so that the reading experience inside the RIDI viewer would be measurably better than what the system fonts could offer for long-form Korean prose ([ridicorp.com/ridibatang](https://ridicorp.com/ridibatang/), [noonnu.cc](https://noonnu.cc/en/font_page/324)). It also built **RIDI Paper**, a line of e-ink hardware (6-inch, 7-inch, and 7.8-inch Pro models, manufactured by Netronix on i.MX6 silicon, running Android 4.4) optimized exclusively for the RIDI store ([namu.wiki — RIDI Paper Pro](https://en.namu.wiki/w/리디북스%20페이퍼%20프로)). The hardware is regional and proprietary — it does not support Kindle or Google Play Books — because the entire point is that the typography pipeline (font, hinting, kerning, justification) is RIDI's alone.
335
+
336
+ In November 2020 RIDI launched **Manta**, an English- and Spanish-language vertical-scroll webcomic subscription app, betting that the company's subscription mechanics (RIDI Select, started in 2018) plus its growing webtoon catalog could compete globally with LINE Webtoon and Tappytoon. Within four months of launch, Manta hit #1 in the Google Play comics category in the US and 14 other countries ([businesswire — Manta launch](https://www.businesswire.com/news/home/20201116005464/en/), [Variety — Manta 2023](https://variety.com/2023/digital/news/manta-korean-webtoons-firm-ten-comic-series-1235661490/)). In **February 2022**, RIDI Corp. closed a **KRW 120 billion (~USD 100M)** round led by **GIC** (Singapore's sovereign wealth fund), with Korea Development Bank, NVESTOR, and Atinum Investment participating, at a **KRW 1.6 trillion (~USD 1.3B) valuation** — making RIDI the first Korean *content-platform* unicorn ([KED Global — Ridi unicorn](https://www.kedglobal.com/korean-startups/newsView/ked202202280012), [businesswire — RIDI GIC](https://www.businesswire.com/news/home/20220228005327/en/)). *Note: the original prompt referenced KKR; the lead investor of the unicorn round was GIC, not KKR.*
337
+
338
+ What RIDI refuses: the gamified-streaks aesthetic of consumer-social apps, the price-banner overload of mainstream e-commerce, the heavyweight UI chrome of marketplace apps. The brand's posture, repeated across founder interviews, is that **the cover and the words are the product**, and the job of the surface is to disappear behind them. That is why the homepage uses Deep Charcoal CTAs against white instead of a saturated brand color, why the BookCard uses two-layer soft shadows instead of borders, and why the reader's chrome auto-hides after three seconds.
339
+
340
+ ## 12. Principles
341
+
342
+ 1. **The cover is the hero, not the chrome.** Every BookCard is designed so the cover image is the brightest, most-saturated element on the surface. Brand color, typography, and shadow all step back. *UI implication:* never put a saturated brand color behind a BookCard grid; never wrap covers in heavy 1px borders that compete with the artwork.
343
+ 2. **Two typefaces, two jobs.** Pretendard Std for the storefront, RIDIBatang for the book. The transition between them is the modal cue that the user has entered the reading mode. *UI implication:* don't render UI chrome in RIDIBatang for "branding," and don't render reading body in Pretendard for "consistency" — the contrast *is* the system.
344
+ 3. **The reader is sacred.** Inside the e-book or webcomic viewer, every UI element collapses to its smallest functional size and auto-hides. There are no toasts, no streaks, no "great job!" celebrations, no daily-reading-goal nudges. *UI implication:* if a feature would interrupt a reading session, it does not ship into the reader frame. It can live in a post-session screen instead.
345
+ 4. **One brand color is charcoal, not blue.** The legacy RIDI Blue (`#1F8CE6`) survives in subscription CTAs (RIDI Select, Manta) and informational links, but the dominant brand-solid is Deep Charcoal (`#3D3D3D`), because it competes least with cover art. *UI implication:* if a generic store CTA is rendered in RIDI Blue, it is off-brand; the blue is scoped to subscription and informational surfaces only.
346
+ 5. **Soft shadows, not borders.** Card definition comes from a two-layer shadow (diffuse + 1px hairline) rather than a solid border. *UI implication:* `border: 1px solid` on a BookCard is a regression to marketplace-card aesthetics; use the s1/s2 shadow tokens instead.
347
+ 6. **Shelves, not feeds.** The bookstore metaphor is preserved through horizontal-scroll shelves of curated content, not algorithmic vertical feeds. *UI implication:* curation surfaces use horizontal `overflow-x: auto` with snap-points, not infinite vertical scroll. Vertical feeds are reserved for search results and library views.
348
+ 7. **Pricing copy stays in numerals and percent.** Sale flags use `30% 할인` or `1,900원`, never `놀라운 가격!` or motivational marketing language. *UI implication:* price chrome is data, not exhortation. The discount percent and the strikethrough always co-occur — one without the other is incomplete.
349
+ 8. **User controls the reading frame.** Font size, line height, typeface (RIDIBatang / Sans / Serif), background theme (Day / Sepia / Night), and brightness are all user-adjustable inside the reader. *UI implication:* never hard-code reading typography. Never override the user's last-set theme on session start.
350
+
351
+ ## 13. Personas
352
+
353
+ *Personas are fictional archetypes informed by publicly described RIDI user segments, not individual people.*
354
+
355
+ **서연 (Seoyeon), 28, Seoul.** Web-novel binge reader. Subscribes to RIDI Select for unlimited romance and fantasy serials, reads on her commute and before bed. Has 47 series in her library, 12 of them ongoing. Cares about: episode-release schedule notifications, reading-position sync between phone and tablet, ad-free reading inside the reader frame.
356
+
357
+ **민준 (Minjun), 35, Pangyo.** Software engineer. Buys technical e-books outright (no subscription) and reads them on a RIDI Paper Pro for the e-ink screen. Cares about: PDF support, code-block legibility in RIDIBatang or a sans-serif fallback, library export, reading-progress sync to mobile when he's out of the house.
358
+
359
+ **Sarah, 24, Los Angeles.** Manta subscriber. Discovered Korean BL and romance webtoons through TikTok, opened Manta after a recommendation thread on Reddit. Reads in English on her phone in vertical-scroll. Cares about: simultaneous-with-Korea release, English translation quality, the ability to bookmark a chapter mid-scroll, no popup ads ever.
360
+
361
+ **지영 작가님 (Author Jiyoung), 41, Daegu.** Self-publishing web-novel author. Posts new chapters weekly to RIDI's web-novel platform. Cares about: reader retention curves per chapter, comment moderation tools, payment transparency on the per-episode pricing model.
362
+
363
+ **Andrés, 19, Madrid.** Manta-Spanish subscriber. Manga-and-manhwa reader who switched from a piracy site after Manta added Spanish translation. Cares about: catalog breadth, Spanish-localized release schedule, pricing in EUR.
364
+
365
+ ## 14. States
366
+
367
+ | State | Treatment |
368
+ |---|---|
369
+ | **Empty (library, no books yet)** | Single literate line (`아직 서재가 비어 있어요. 첫 책을 만나러 갈까요?`) plus a primary CTA `둘러보기` in Deep Charcoal. No illustration of an empty bookshelf — the empty grid is itself the metaphor. |
370
+ | **Empty (search no results)** | One line in `#5D5D5D` 14px (`'{query}'에 해당하는 책이 없어요.`) and a 13px hint suggesting a category browse. No animated illustration. |
371
+ | **Empty (filter cleared)** | Single line caption (`조건에 맞는 책이 없어요. 필터를 조정해 보세요.`). No button — the user resets the filter themselves via the chip row. |
372
+ | **Loading (BookCard grid)** | Skeleton tiles at exact 2:3 aspect, `#F9F9F9` background, 4px radius, with a 12px gray block below for title and 8px block for author. Shimmer at 1.4s, 6% white highlight. Never over the price slot — that stays blank until resolved. |
373
+ | **Loading (reader, fetching next chapter)** | Center-screen 24px circular spinner in `#3D3D3D` on whatever the current reader-theme background is. No overlay. No text. Auto-dismisses on first byte. |
374
+ | **Loading (cover image)** | `#F9F9F9` solid placeholder at the cover's 2:3 frame; blur-up to the loaded cover over 200ms. No spinner inside the cover frame. |
375
+ | **Error (network)** | Full-screen centered: 16px weight 700 `#222222` headline (`연결이 불안정해요`), 14px weight 400 `#5D5D5D` subline, retry button in Deep Charcoal. No illustration. |
376
+ | **Error (inline field)** | Input border becomes `#F4361E` 1px, helper text below in 13px `#F4361E`. One actionable sentence. |
377
+ | **Error (toast)** | `#222222` background, white 14px weight 400 text, 3s auto-dismiss, bottom of screen 16px above the tab bar. No icon, no emoji. |
378
+ | **Success (purchase complete)** | Dedicated confirmation screen with the BookCard cover at 1.5x size, line `구매가 완료되었어요`, and a single primary button `지금 읽기` in Deep Charcoal. Calm, not celebratory. |
379
+ | **Success (added to library)** | Brief 250ms flash of `#FFF9EA` (highlight cream) behind the BookCard, fading to default. The book then animates 200ms toward the My Library tab in the bottom nav. |
380
+ | **Subscription active** | A persistent `#03AA5A` circular pill (`구독 중`) appears on subscription-eligible BookCards. Does not animate; informational. |
381
+ | **Skeleton** | `#F9F9F9` blocks at the exact final dimensions matching whatever component is loading (BookCard, list row, reader page). Shimmer 1.4s, 6% white highlight. The author/price/metadata slot stays blank — the UI never implies a price that hasn't been confirmed. |
382
+ | **Disabled** | Button background drops to `#F0F0F0`, text to `#B5B5B5`. Geometry stays identical. No color inversion, no opacity tricks. |
383
+ | **Reader (idle, chrome hidden)** | After 3s of no interaction inside the e-book viewer: top toolbar slides up `motion-standard / ease-exit`, bottom progress bar fades to 40% opacity. Tap-center to recall. |
384
+
385
+ ## 15. Motion & Easing
386
+
387
+ **Durations** (named, not raw milliseconds):
388
+
389
+ | Token | Value | Use |
390
+ |---|---|---|
391
+ | `motion-instant` | 0ms | Toggle flips, theme switches inside the reader |
392
+ | `motion-fast` | 150ms | Hover, focus, button press, BookCard hover-shadow escalation |
393
+ | `motion-standard` | 250ms | The default — sheet reveals, tab switches, library-add flash |
394
+ | `motion-slow` | 350ms | Modal sheets, full-screen presentations, success screens |
395
+ | `motion-page` | 300ms | Native-style push/pop between routes |
396
+ | `motion-page-turn` | 400ms | E-book reader page-turn (paginated mode) |
397
+
398
+ **Easings:**
399
+
400
+ | Token | Curve | Use |
401
+ |---|---|---|
402
+ | `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Sheets, toasts, screen pushes appearing |
403
+ | `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Dismissals, pops, toolbar auto-hide |
404
+ | `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — BookCard hover, tab content |
405
+ | `ease-page-turn` | `cubic-bezier(0.32, 0.72, 0.0, 1.0)` | Paginated reader page-turn — slight emphasis on settle |
406
+
407
+ **Spring stance.** **Spring and overshoot easings are forbidden inside the reader frame.** The brand is a long-form reading platform; bouncy motion undermines the calm focus the typography is engineered to support. Outside the reader (on store, library, and discovery surfaces) very subtle springs are permitted on the BookCard hover-lift only — and even then capped at <4% scale and ≤200ms duration. Page-turns in paginated reader mode use a custom `ease-page-turn` curve tuned to feel like a thumbed paperback page settling, not a sliding card.
408
+
409
+ **Signature motions.**
410
+
411
+ 1. **BookCard hover-lift.** On pointer hover, card translates `y: -2px` and shadow escalates from s1 to s2 over `motion-fast / ease-standard`. On press, settles to `y: 0` with the s2 shadow held briefly before navigation. Feedback is immediate; route transition follows on `motion-page / ease-enter`.
412
+ 2. **Library-add flash.** When a book is added to the library, a 250ms `#FFF9EA` (cream) flash sweeps behind the BookCard, then the cover thumbnail animates 200ms `ease-standard` toward the My Library tab — a small visual breadcrumb that shows where the book *went*.
413
+ 3. **Reader chrome auto-hide.** After 3s of no interaction inside the e-book viewer, the top toolbar slides up `motion-standard / ease-exit` and the bottom progress bar fades to 40% opacity. Tap-center recalls them with `motion-fast / ease-enter`. The page content itself never moves during this — only chrome.
414
+ 4. **Page-turn (paginated reader).** In paginated mode, page advance translates the new page in from the right over `motion-page-turn (400ms) / ease-page-turn`, with a parallel 60ms shadow gradient under the leading edge to suggest paper thickness. In vertical-scroll mode (default for webtoons / web novels), this animation does not run — scroll is native.
415
+ 5. **Reduce motion.** Under `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. Page-turns become instant cross-cuts. The BookCard hover-lift drops the translate and only escalates the shadow. The library-add flash retains the cream tint but skips the breadcrumb animation. The app stays fully usable.
416
+
417
+ <!--
418
+ OmD v0.1 Sources — Philosophy Layer (sections 10–15)
419
+
420
+ Tier 1 — Direct verification (Playwright live inspection, 2026-05):
421
+ - https://ridibooks.com — page title `리디 RIDI - 만화 웹툰 웹소설 전자책`,
422
+ body fontFamily `"Pretendard Std", "Pretendard JP", Pretendard`,
423
+ primary button `Get started` background `rgb(61, 61, 61)` = `#3D3D3D`,
424
+ 8px radius, 36px height; BookCard shadows `0 2px 16px rgba(0,0,0,0.03)`
425
+ and `0 4px 16px rgba(0,0,0,0.12), 0 0 1px rgba(0,0,0,0.08)`;
426
+ Tailwind token names `Neutral-Colors-Background-Card`,
427
+ `Neutral-Colors-Foreground-Primary`, `Neutral-Colors-Stroke-Inactive`;
428
+ tooltip border `1px solid rgb(208, 208, 208)` = `#D0D0D0`.
429
+
430
+ Tier 2 — Documentation / press (WebSearch + WebFetch attempts, 2026-05):
431
+ - https://ridi.design/ — RIDI Design System site; typography page references
432
+ Pretendard / Apple SD Gothic Neo stack and color page exists at /colors/;
433
+ WebFetch attempts ECONNREFUSED at retrieval, content partially carried
434
+ from search-result excerpts.
435
+ - https://github.com/ridi/design-system — public RIDI design system repo
436
+ (archived 2022-09-29) with packages `@ridi/colors`, `@ridi/web-icons`,
437
+ `@ridi/web-ui`. Repo confirmed live; token values not directly extracted
438
+ from this turn.
439
+ - https://ridicorp.com/ridibatang/ — RIDIBatang typeface positioning;
440
+ describes the typeface as engineered for clarity in long-form reading
441
+ with widened internal counters and simplified strokes. Distributed under
442
+ SIL Open Font License 1.1.
443
+ - https://noonnu.cc/en/font_page/324 — third-party catalog confirms
444
+ RIDIBatang's SIL OFL 1.1 license and copyright by Ridi Co., Ltd.
445
+
446
+ Tier 2 (Philosophy / founder / business):
447
+ - https://www.forbeskorea.co.kr/news/articleView.html?idxno=336251 — RIDI
448
+ CEO Bae Ki-sik (배기식) interview, founding 2008.
449
+ - https://www.kedglobal.com/kunicornsView/kun0006 — KED Global RIDI
450
+ k-unicorn profile: founded May 2008, Ridibooks launched November 2009,
451
+ Bae's Samsung Electronics venture-team background.
452
+ - https://www.kedglobal.com/korean-startups/newsView/ked202202280012 —
453
+ RIDI first Korean content-platform unicorn (Feb 2022).
454
+ - https://www.businesswire.com/news/home/20220228005327/en/ —
455
+ KRW 120B round, GIC lead, KDB / NVESTOR / Atinum participating,
456
+ KRW 1.6T valuation.
457
+ - https://www.businesswire.com/news/home/20201116005464/en/ — Manta
458
+ launch, November 2020, subscription-based webcomic optimized for
459
+ binge-reading.
460
+ - https://variety.com/2023/digital/news/manta-korean-webtoons-firm-ten-comic-series-1235661490/
461
+ — Manta 2023 in-house production update.
462
+ - https://en.namu.wiki/w/리디북스%20페이퍼%20프로 — RIDI Paper Pro hardware
463
+ specs (7.8" e-ink, i.MX6 1GHz, 1GB RAM, 8GB storage, Android 4.4,
464
+ EPUB/TXT/PDF/ZIP, manufactured by Netronix).
465
+
466
+ Re-verification status:
467
+ - The `#1F8CE6` "RIDI Blue" hex is a documented brand-blue value
468
+ carried from prompt-provided guidance and consistent with RIDI Select
469
+ / Manta subscription chrome observed in past surfaces; *not* directly
470
+ captured live in this turn. Treat as a legacy / scoped accent token —
471
+ the dominant live brand-solid on ridibooks.com (May 2026) is
472
+ Deep Charcoal `#3D3D3D`.
473
+ - The `#F4361E` Critical / sale-flag red, `#03AA5A` positive green,
474
+ and `#FFF9EA` highlight cream values are derived from observed
475
+ computed-style backgrounds on a sibling Korean bookstore surface
476
+ during the same browsing session and are aligned with values RIDI's
477
+ catalog historically uses; treat as illustrative-but-plausible until
478
+ re-captured directly on a RIDI sale or subscription-active surface.
479
+ - Manta currently serves English and Spanish; original prompt phrased
480
+ this as "global web-novel app" — the current product is webcomic-led
481
+ with web-novels added in 2024 (Deadline, January 2024).
482
+
483
+ Not independently verified — widely documented public facts:
484
+ - 2008 founding of RIDI Corporation by Bae Ki-sik (배기식); 2009
485
+ Ridibooks consumer launch; 2018 RIDI Select subscription launch;
486
+ 2020 Manta global launch; 2022 GIC-led unicorn round.
487
+ - RIDI Paper hardware lineage (6", 7", 7.8" Pro) and Netronix/i.MX6
488
+ manufacturing chain.
489
+
490
+ Personas (§13) are fictional archetypes informed by publicly described
491
+ RIDI user segments (KR web-novel binge reader, KR technical e-book
492
+ buyer, NA Manta subscriber, KR self-publishing author, ES Manta
493
+ subscriber). Any resemblance to specific individuals is unintended.
494
+
495
+ Interpretive claims (editorial, not documented RIDI statements):
496
+ - "The cover and the words are the product, and the job of the surface
497
+ is to disappear behind them" (§11 closing) — editorial framing of
498
+ RIDI's posture from founder interviews and the live design.
499
+ - "The brand statement is — spend money to make a body face" (§1) —
500
+ editorial reading of the RIDIBatang commission, not a sourced quote.
501
+ - The spring-forbidden-in-reader stance (§15) — derived from the
502
+ overall calm-focus posture of the reading experience, not a
503
+ documented RIDI motion rule.
504
+ - Original prompt referenced KKR as the 2021 unicorn-round investor;
505
+ per primary press (Business Wire, KED Global, Feb 2022) the lead
506
+ was GIC, not KKR, and the round closed in February 2022.
507
+ Documented in §11.
508
+ -->
509
+
510
+ ---
511
+
512
+ **Verified:** 2026-05-08 (omd:add-reference initial create — RIDI)
513
+ **Tier 1 sources:** ridibooks.com (consumer storefront — Deep Charcoal `#3D3D3D` 8px / 36px Pretendard Std primary CTA; BookCard 12px radius with two-layer shadow `0 2px 16px rgba(0,0,0,0.03)` resting / `0 4px 16px rgba(0,0,0,0.12), 0 0 1px rgba(0,0,0,0.08)` hover; tooltip 1px `#D0D0D0` border; Tailwind token classes `Neutral-Colors-Background-Card` / `Neutral-Colors-Foreground-Primary` / `Neutral-Colors-Stroke-Inactive`).
514
+ **Tier 2 sources:** ridi.design (typography + colors pages — partial; ECONNREFUSED on direct fetch, indexed via search excerpts); github.com/ridi/design-system (archived public DS, packages `@ridi/colors` / `@ridi/web-icons` / `@ridi/web-ui`); ridicorp.com/ridibatang (RIDIBatang positioning + SIL OFL 1.1 license); noonnu.cc/font_page/324 (RIDIBatang license catalog).
515
+ **Tier 2 (Philosophy/founders):** Forbes Korea (Bae Ki-sik CEO interview), KED Global (k-unicorn profile + Feb-2022 unicorn news), Business Wire (Manta 2020 launch + GIC 2022 round), Variety (Manta 2023 in-house production), Namuwiki (RIDI Paper Pro hardware specs), Deadline (Manta web-novels Jan 2024).
516
+ **Style ref:** `apple` (editorial typographic restraint, two-layer shadows, content-as-hero) + `kakao` (Pretendard Std family, KR polite-warm `-요` register).
517
+ **Conflicts unresolved:** Original prompt named KKR as 2021 unicorn investor; primary sources (Business Wire 2022-02-28, KED Global 2022-02-28) confirm lead was **GIC** in **February 2022** at KRW 1.6T (~USD 1.3B). Documented in §11; carried into .verification.md.