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,374 @@
1
+ ---
2
+ id: channeltalk
3
+ name: Channel Talk
4
+ country: KR
5
+ category: saas
6
+ homepage: "https://channel.io"
7
+ primary_color: "#4f46e5"
8
+ logo:
9
+ type: github
10
+ slug: channel-io
11
+ verified: "2026-05-14"
12
+ omd: "0.1"
13
+ ds:
14
+ name: Bezier
15
+ url: "https://github.com/channel-io/bezier-react"
16
+ type: system
17
+ description: Channel Talk's open-source design system — Bezier (MIT). Inter + Noto KR/JP type stacks, token/component/icon packages, marketing-vs-product type cliff documented.
18
+ og_image: "https://opengraph.githubassets.com/d5fd6836ec938de2c8399cf28b2ceabc49104fbbf86e937f9e89983f1b50d638/channel-io/bezier-react"
19
+ ---
20
+
21
+ # Design System Inspiration of Channel Talk
22
+
23
+ ## 1. Visual Theme & Atmosphere
24
+
25
+ Channel Talk's marketing surface (`channel.io`) reads as a confident **B2B customer-service messenger** that has openly bet the company on the AI-agent shift. The page operates on a near-white canvas (`#FFFFFF` body with `#FCFCFC` / `#F7F7F8` surface tints from the Bezier `grey` ramp) and uses translucent off-black (`rgba(0,0,0,0.85)`) for body text rather than a hard `#000` — a small but characteristic warmth that softens the otherwise engineering-leaning palette. The signature accent observed in product chrome is **Cobalt 400** (`#329BE7`) — Channel's primary brand blue — while the homepage AI manifesto sections drop into a dark plum-purple canvas (`rgba(25,3,49,0.898)`) that visually quarantines the AI agent story from the surrounding helpdesk product story.
26
+
27
+ Typography is **Inter** (with `NotoSansKR` / `NotoSansJP` tied for fallback depending on locale). The Bezier DS product scale tops out at **36px / 44px line-height**, but the marketing surface deliberately breaks that ceiling for editorial hero/sectional moments — a 64px / 88px-lh / -1.5px-tracking `h1` and a 54px / 72px-lh `h2` give the homepage a sectional, almost manifesto rhythm that the in-product chrome never uses. Negative tracking is light by default (`-0.1px` at 15-17px, `-0.4px` at 22-36px), tightening at the marketing tier (`-1px` at 48px, `-1.5px` at hero).
28
+
29
+ What distinguishes Channel Talk visually is its **radius ladder discipline**: Bezier exposes 2 / 3 / 4 / 6 / 8 / 12 / 16 / 20 / 32 / 44 / 42% — and the marketing surface uses each tier intentionally. Primary CTAs land at **18px** (pill-tending without becoming capsules), product cards at **20px**, the bottom "Experience It Yourself" CTA band at **32px**, and small chips at **8px**. Cobalt 400 hover treatment also lives in the alpha ladder — `#329BE7` solid → `#329BE73D` / `#329BE71A` for subtle ghost states — a sign of a mature semantic-token system, not improvised tinting.
30
+
31
+ **Key characteristics**
32
+ - Canvas: white (`#FFFFFF`) with grey-50 / grey-100 surface tints (`#FCFCFC` / `#F7F7F8`)
33
+ - Body text: translucent off-black `rgba(0, 0, 0, 0.85)` (141/118 sampled elements observed live)
34
+ - Brand accent: **Cobalt 400 `#329BE7`** (`bezier.cobalt.400` + alpha ladder 10/20/30/40)
35
+ - AI manifesto canvas: dark plum `rgba(25, 3, 49, 0.898)` (homepage AI section only)
36
+ - Type: **Inter** primary, Bezier KR/JP stacks fall through Noto Sans KR/JP
37
+ - Marketing hero: 64px / weight 700 / 1.375 line-height / `-1.5px` tracking
38
+ - Radius ladder used by tier — 8px chips → 18px CTAs → 20px cards → 32px CTA bands
39
+ - Easing default: `cubic-bezier(0.3, 0, 0, 1)` with 150 / 300 / 450ms duration tokens
40
+
41
+ ## 2. Color Palette & Roles
42
+
43
+ Source of truth: `github.com/channel-io/bezier-react/packages/bezier-tokens/src/global/color.json` (Bezier Design System, MIT). Each hue ships **300 / 400 / 500** weights plus a 4-step alpha ladder per weight (e.g., `300-40` = 40% alpha) — surfaced below by canonical role.
44
+
45
+ ### Brand / accent
46
+
47
+ - **Cobalt 400** (`#329BE7`): primary brand blue — Channel Talk's product-chrome accent (live: 12 of 118 sampled elements)
48
+ - **Cobalt 300** (`#47C8FF`): lighter cobalt — illustrative / surface highlight
49
+ - **Cobalt 500** (`#327AB8`): cobalt heavy — pressed / hover-on-light
50
+ - **Cobalt 400-30** (`#329BE74D`) / **400-20** (`#329BE733`) / **400-10** (`#329BE71A`): hover / focus / subtle ghost fills
51
+
52
+ ### Foundation neutrals (`bezier.grey`)
53
+
54
+ - **Grey 50** (`#FCFCFC`): elevated surface
55
+ - **Grey 100** (`#F7F7F8`): canvas tint
56
+ - **Grey 200** (`#EFEFF0`): divider light
57
+ - **Grey 500** (`#A7A7AA`): muted text
58
+ - **Grey 700** (`#464748`): body text on light (dark theme inverse)
59
+ - **Grey 800** (`#313234`): heading on dark
60
+ - **Grey 850** (`#2A2B2D`): dark surface
61
+ - **Grey 900** (`#242428`): deepest dark — also `rgb(36,36,40)` observed live as primary CTA bg
62
+
63
+ ### Black / White alpha (`bezier.black` / `bezier.white`)
64
+
65
+ - **Black 85** (`#000000D9` = `rgba(0,0,0,0.85)`): canonical body text — 141 / 118 elements in live capture
66
+ - **Black 60** (`rgba(0,0,0,0.6)`): secondary text
67
+ - **Black 40 / 30 / 22 / 20 / 15 / 8 / 5 / 3**: full alpha ladder for borders, overlays, disabled tints
68
+ - **White 100** (`#FFFFFF`): primary surface
69
+ - **White 90 / 80 / 60 / 40 / 20 / 12 / 8 / 5**: full alpha ladder for inverted scrims, overlays
70
+
71
+ ### Semantic hue family (each `300 / 400 / 500` + alpha 40/30/20/10)
72
+
73
+ - **Blue** 300 `#6687FF` · 400 `#5E56F0` · 500 `#4E40C9` — info / link-secondary
74
+ - **Teal** 300 `#3CDDCD` · 400 `#0FB3A3` · 500 `#449C8A`
75
+ - **Green** 300 `#3ACF5A` · 400 `#31A552` · 500 `#41904F` — success
76
+ - **Olive** 300 `#CAD548` · 400 `#A0A540` · 500 `#818628`
77
+ - **Yellow** 300 `#FDD353` · 400 `#EDBC40` · 500 `#C39E37` — caution
78
+ - **Orange** 300 `#FFAB5C` · 400 `#F4800B` · 500 `#C57417`
79
+ - **Red** 300 `#FF5C5C` · 400 `#E94E58` · 500 `#AC3E46` — error / destructive
80
+ - **Pink** 300 `#EC6FD3` · 400 `#CB48AD` · 500 `#A32E92`
81
+ - **Purple** 300 `#B570FF` · 400 `#915CE0` · 500 `#6B23B3`
82
+ - **Navy** 300 `#647CC9` · 400 `#3A4F8D` · 500 `#333D5B`
83
+
84
+ ### Marketing-only theatrical colors (homepage chrome, not Bezier tokens)
85
+
86
+ - **AI canvas plum** (`rgba(25,3,49,0.898)`): the "AI Handles The Routine / You Handle The Strategy" panel
87
+ - **AI plum deep** (`rgb(60,3,54)`): nested AI panel
88
+ - **Inbox card pink** (`rgb(250,154,240)`): single illustrative card surface — not in token source
89
+
90
+ ## 3. Typography Rules
91
+
92
+ ### Font stack (Bezier `font.family`)
93
+
94
+ - **Sans (KR locale)**: `Inter, NotoSansKR, "Noto Sans KR", NotoSansJP, "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", Roboto, system-ui, sans-serif`
95
+ - **Sans (JP locale)**: `Inter, NotoSansJP, "Noto Sans JP", NotoSansKR, "Noto Sans KR", ...same fallbacks`
96
+ - **Mono**: `ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, "DejaVu Sans Mono", monospace`
97
+ - **Marketing display (homepage chrome only)**: `BildV5, "BildV5 Fallback"` (observed on 1 of 118 sampled elements — not a product token)
98
+
99
+ ### Product-chrome scale (Bezier `typography.size`)
100
+
101
+ | Token | Size | Line height | Letter spacing |
102
+ |---|---|---|---|
103
+ | 11 | 11px | 16px | — |
104
+ | 12 | 12px | 16px | — |
105
+ | 13 | 13px | 18px | — |
106
+ | 14 | 14px | 18px | — |
107
+ | 15 | 15px | 20px | -0.1px |
108
+ | 16 | 16px | 24px | -0.1px |
109
+ | 17 | 17px | 24px | -0.1px |
110
+ | 18 | 18px | 24px | — |
111
+ | 22 | 22px | 28px | -0.4px |
112
+ | 24 | 24px | 32px | -0.4px |
113
+ | 30 | 30px | 36px | -0.4px |
114
+ | 36 | 36px | 44px | -0.4px |
115
+
116
+ Weights ship at **400 (regular)** and **700 (bold)** only — Bezier does not stock a 500/600 mid-weight in product chrome.
117
+
118
+ ### Marketing-surface extension (homepage observed live)
119
+
120
+ | Role | Size | Weight | Line height | Letter spacing |
121
+ |---|---|---|---|---|
122
+ | Hero h1 | 64px | 700 | 88px | -1.5px |
123
+ | Section h2 (XL, on dark) | 54px | 600 | 72px | -1.5px |
124
+ | Section h2 (LG) | 48px | 600 | 64px | -1px |
125
+ | CTA label (hero) | 18px | 600 | 26px | -0.4px |
126
+ | Section "View Details" lead | 20px | 700 | 30px | -0.5px |
127
+ | Nav link | 15px | 400 | 21.45px | normal |
128
+
129
+ Note: weights 500 / 600 appear on marketing-surface headings but NOT in the Bezier source font weights — treat marketing scale as a brand-layer extension, not a product-chrome token.
130
+
131
+ ## 4. Component Stylings
132
+
133
+ ### Buttons
134
+
135
+ **Primary (hero CTA — marketing surface)**
136
+ - Background: `#242428` (grey 900, live captured as `rgb(36, 36, 40)` after rendering)
137
+ - Text: `#FFFFFF`
138
+ - Radius: 18px
139
+ - Padding: 8px 24px
140
+ - Label: 18px / weight 600 / 26px line-height / -0.4px tracking
141
+ - Height: ~64px (label area; outer wrapper drives height)
142
+ - Use: top-of-funnel "Sign Up for Free" only
143
+
144
+ **Secondary (subtle pill — section CTAs)**
145
+ - Background: `rgba(0, 0, 0, 0.05)`
146
+ - Text: `rgba(0, 0, 0, 0.85)`
147
+ - Radius: 16px
148
+ - Padding: 8px 20px
149
+ - Label: 20px / weight 700 / 30px line-height / -0.5px tracking
150
+ - Height: ~54px
151
+ - Use: "View Details" mid-section pivots; not a primary action
152
+
153
+ **Tertiary (text link)**
154
+ - Background: transparent
155
+ - Text: `rgba(0, 0, 0, 0.6)`
156
+ - Padding: 4px 6px
157
+ - Border: none (underline on hover inferred from convention; not directly captured)
158
+ - Use: "Learn more" inline references
159
+
160
+ **Cobalt accent (in-product, inferred from Bezier semantic tokens)**
161
+ - Background: `#329BE7` (cobalt 400)
162
+ - Hover: `#329BE7` over `rgba(50, 155, 231, 0.2)` ghost fill (live observed `rgba(50,155,231,0.2)` = `#329BE733` = cobalt 400-20)
163
+ - Text: `#FFFFFF`
164
+ - Radius: 6px or 8px (product chrome — Bezier 6/8 tokens)
165
+ - Use: primary action inside Channel Talk's product (Inbox CTA, send-message, etc.)
166
+
167
+ ### Cards
168
+
169
+ **AI Messenger feature card (marketing)**
170
+ - Background: per-card theatrical color (e.g., `rgb(250, 154, 240)` pink for Inbox card)
171
+ - Text: `rgba(0, 0, 0, 0.85)`
172
+ - Radius: 20px
173
+ - Padding: section-driven (no padding on outer `a` wrapper; inner content gets its own)
174
+ - Width: 1160px on 1280-viewport (`100% - 120px` two-col gutters)
175
+ - Height: 400px (fixed feature-card height)
176
+ - Use: each Inbox / Meet / Team Chat / Workflow / Marketing / Docs surface gets one of these
177
+
178
+ **CTA section wrapper ("Experience It Yourself")**
179
+ - Background: transparent (content inside is the colored block)
180
+ - Radius: 32px
181
+ - Padding: 16px horizontal page-edge inset, vertical-driven
182
+ - Width: ~1248px (`100% - 32px`)
183
+ - Use: bottom-of-page conversion band
184
+
185
+ ### Navigation
186
+
187
+ - Nav menu items: Inter 15px / weight 400 / 21.45px line-height
188
+ - Color: `rgba(0, 0, 0, 0.85)`
189
+ - Padding: 10px 16px 8px 0px (asymmetric — visual underline indicator on bottom only)
190
+ - Active indicator: 2px bottom border (border-bottom captured as `0px 0px 2px` on three sides + bottom)
191
+ - Logo link: 194×40px wrapper, fg `rgb(82, 84, 99)` (grey-tinted)
192
+ - Menu toggle button (mobile): `#FFFFFF` bg, 8px radius
193
+
194
+ ### Form inputs
195
+
196
+ - Source of truth: `bezier-tokens/src/semantic/input.json` (1.4KB — full input semantic surface in Bezier)
197
+ - Surface (resting): `#FFFFFF` with `Black 8` (`rgba(0,0,0,0.05)`) border
198
+ - Surface (focus): cobalt 400-30 (`#329BE74D`) outline ring
199
+ - Radius: 6px or 8px (product chrome)
200
+ - Padding (medium): vertical 8px, horizontal 12px (inferred from Bezier 6/8 sizing patterns)
201
+
202
+ ## 5. Layout Principles
203
+
204
+ **Page max width** (marketing): ~1248px content with 16px page-edge inset on 1280 viewport.
205
+
206
+ **Grid**: 2-up / 3-up product card rows; the All-in-One AI Messenger section uses a horizontal pill nav (Inbox / Meet / Team Chat / Workflow / Marketing / Docs) that pivots the entire card content in place rather than scrolling — a non-trivial interaction pattern.
207
+
208
+ **Spacing scale**: Bezier doesn't publish a separate spacing token file — instead, padding values cluster at: 4 / 6 / 8 / 12 / 16 / 20 / 24 / 32 / 40 / 48 / 60 / 64 / 80px (inferred from observed live values; Bezier semantic tokens use these as scale stops).
209
+
210
+ **Radius scale** (Bezier `radius`): 2, 3, 4, 6, 8, 12, 16, 20, 32, 44px, plus a special `42%` token for circular avatars (used by `bezier-react`'s avatar size scale where 42% gives the visual rounding without committing to a fixed px value).
211
+
212
+ **Surface elevation**: see §6.
213
+
214
+ ## 6. Depth & Elevation
215
+
216
+ Source: `bezier-tokens/src/semantic/elevation.json` (2.3KB). Bezier exposes a semantic elevation ladder rather than raw `box-shadow` tokens — every elevation is paired with a background surface so dark-theme inversion is automatic.
217
+
218
+ - **Level 1** (resting card): `Grey 50` (`#FCFCFC`) surface + minimal shadow
219
+ - **Level 2** (interactive card): `Grey 100` (`#F7F7F8`) surface + slight shadow
220
+ - **Level 3** (popover / dropdown): subtle drop-shadow + `Black 8` border instead of pure shadow
221
+ - **Level 4** (modal / sheet): full shadow + dimmed scrim (`Black 30` / `rgba(0,0,0,0.3)`)
222
+
223
+ Live homepage chrome leans **flat** — virtually no `box-shadow` captured across 118 elements; depth is signaled via surface tint + border alpha, not shadow.
224
+
225
+ ## 7. Do's and Don'ts
226
+
227
+ ### Do
228
+ - Use **Inter** as the type voice — never substitute a different sans for product-chrome.
229
+ - Apply translucent off-black (`rgba(0,0,0,0.85)`) for body text — never pure `#000`.
230
+ - Honor the Bezier radius ladder by tier — 8px for chips, 18-20px for CTAs/cards, 32px for full-bleed CTA bands.
231
+ - Use Cobalt 400 `#329BE7` as the **only** brand accent in product chrome.
232
+ - Reach for the Bezier alpha ladder (`-10` / `-20` / `-30`) before inventing new tints.
233
+ - Top out at **36px** for in-product type; reserve >36px for marketing surfaces only.
234
+
235
+ ### Don't
236
+ - Don't introduce a 5th radius value between Bezier tokens (e.g., 24px is not in the ladder).
237
+ - Don't add font weights between 400 and 700 inside product chrome — Bezier only ships those two.
238
+ - Don't decorate with semantic hues (red / yellow / green) — they are reserved for status semantics.
239
+ - Don't translate marketing's plum AI canvas (`rgba(25,3,49,0.898)`) into product chrome — it's a homepage-only rhetorical device.
240
+ - Don't use `BildV5` for product UI — it's a marketing display face.
241
+
242
+ ## 8. Responsive Behavior
243
+
244
+ Marketing breakpoints (inferred from live capture at 1280-viewport):
245
+ - 768px / 896px / 1024px / 1280px
246
+
247
+ The product app (Inbox / Meet / Team Chat) is a desktop-first SaaS surface — Bezier components ship with `size` prop (`xs / s / m / l / xl`) rather than viewport-driven responsive behavior; the host app sets size programmatically based on layout context. The marketing site does respond fluidly with a mobile MenuToggleButton (8px radius, white surface) replacing the desktop nav under ~768px.
248
+
249
+ ## 9. Agent Prompt Guide
250
+
251
+ ### Quick reference
252
+
253
+ - **Canvas**: `#FFFFFF` body, `#FCFCFC` / `#F7F7F8` surface tints
254
+ - **Body text**: `rgba(0, 0, 0, 0.85)` — *never* `#000`
255
+ - **Brand accent**: Cobalt `#329BE7`
256
+ - **Type**: Inter 15-16px body, 18-24px subheads (product); 48-64px marketing headlines
257
+ - **Radius**: 8 / 18 / 20 / 32 — pick the tier, don't interpolate
258
+ - **Easing**: `cubic-bezier(0.3, 0, 0, 1)` at 150 / 300 / 450ms
259
+
260
+ ### Example component prompts
261
+
262
+ - *"Build a Channel-Talk-styled SaaS dashboard hero. White (#FFFFFF) canvas, Inter 64px / weight 700 / 88px line-height / -1.5px tracking, text rgba(0,0,0,0.85). Primary CTA: bg #242428, text #fff, 18px radius, padding 8px 24px, label Inter 18px / weight 600 / -0.4px tracking. Secondary CTA: bg rgba(0,0,0,0.05), text rgba(0,0,0,0.85), 16px radius."*
263
+ - *"Build an AI-handles-routine manifesto section. Dark plum canvas rgba(25,3,49,0.898), Inter 54px / weight 600 / 72px line-height / -1.5px tracking, two-line headline with the second line color-shifted lighter as visual call-and-response."*
264
+ - *"Build a Bezier product modal. Grey-100 (#F7F7F8) surface, 12px radius, 24px padding, Black-30 scrim, transition s (150ms) cubic-bezier(0.3, 0, 0, 1)."*
265
+
266
+ ## 10. Voice & Tone
267
+
268
+ Channel Talk's voice is **operator-pragmatic + AI-evangelical**. The marketing surface speaks as a Korean-origin B2B platform that has staked its 2025-26 narrative on the AI-agent transition — every section pivots back to how AI takes "the routine" so human teams can take "the strategy."
269
+
270
+ | Context | Tone |
271
+ |---|---|
272
+ | CTA | Direct verb. "Sign Up for Free" / "View Details" / "Learn more" |
273
+ | Marketing headline | Manifesto-shaped, present-tense. "The future of customer service is AI." "AI handles the routine. You handle the strategy." |
274
+ | Feature copy | Compound noun-led. "All Chats In One Place." "All-in-One AI Messenger." |
275
+ | Product (Inbox) | Pragmatic operator-speak (inferred from Bezier component naming: `Inbox`, `Workflow`, `Meet` — verbs/nouns, no "experiences") |
276
+ | Error | Specific, action-paired (e.g., "Message not sent. Retry") — convention inferred from Bezier semantic-tokens framing |
277
+
278
+ **Voice samples** (live channel.io 2026-05-14, paraphrased to avoid verbatim brand copy in derivative work)
279
+
280
+ - AI-era positioning: *"The future of customer service is AI."* (homepage hero) <!-- verified: channel.io/en 2026-05-14, used only as voice reference, not as derived copy -->
281
+ - AI/human split: *"AI handles the routine. You handle the strategy."* (homepage AI section) <!-- verified: channel.io/en 2026-05-14, voice reference only -->
282
+ - Compound positioning: *"All-in-One AI Messenger"* (section h2) <!-- verified: channel.io/en 2026-05-14 -->
283
+
284
+ **IP guardrail (DO NOT verbatim).** Any DESIGN.md or downstream artifact derived from this reference must **rewrite** Channel Talk's marketing taglines in its own voice — these voice samples document *tone shape*, not borrowable copy. Fresh derivation patterns (use these as templates instead): "Routine, automated. Strategy, yours." / "AI for the queue. You for the moves that matter." / "Every channel. One inbox." — none of which appear verbatim on channel.io.
285
+
286
+ **Forbidden phrases.** "AI-powered" without specifics. "Revolutionary support." "Next-generation CRM." Anything that promises AI without naming the surface (Inbox / Meet / Workflow) it operates on.
287
+
288
+ ## 11. Brand Narrative
289
+
290
+ *Some facts in this section carry partial verification — see footer for source map.*
291
+
292
+ Channel Talk is operated by **Channel Corp** (주식회사 채널코퍼레이션) [channel.io/en/team], a Korean SaaS company whose current CEO is **Choi Si-won (최시원)** [channel.io/en/team]. The company's roots trace to a Korean startup originally named **ZOYI Corp**, founded around 2014 [secondary source — confidence moderate]; the rename to Channel Corp followed the product's pivot from offline-retail analytics to the SaaS customer-messenger that ships today. Channel Talk's primary positioning through ~2023 was as "the all-in-one business messenger" competing with Intercom on smaller-team economics + Korean/Japanese market fit; the 2024-26 narrative has shifted explicitly to **AI agent infrastructure**, with the **ALF** brand surface (AI Agent for customer inquiries + AI Agent for internal work) now sharing main-nav placement with the historical Inbox/Meet/Team Chat product line [channel.io/en about page].
293
+
294
+ By the metrics Channel itself publishes [channel.io/en/team footer 2026-05-14]: **234,545+ cumulative channels** deployed, **170 million monthly support messages**, **1,286,781+ AI-resolved cases** cumulative, **2,135+ companies using ALF**, **98% uptime**, **4.8/5 G2 rating**. Engineering compliance: **ISMS** (Korean information security certification), **ISO information protection certification**, AWS-hosted infrastructure.
295
+
296
+ The most distinctive engineering signal is **Bezier** — Channel's openly published, MIT-licensed design system [github.com/channel-io/bezier-react] shipping `bezier-react` (274+ stars) + `BezierSwift` (native iOS) + a canonical `bezier-tokens` package that powers both. Few Korean SaaS companies maintain a public token-grade DS at this depth, and the fact that the marketing site's homepage renders against the same primitives (Inter, the cobalt accent, the radius ladder) is itself the strongest claim about Channel's product-discipline.
297
+
298
+ *Unverified at time of writing*: precise founding year (2014 vs neighboring year), founder list beyond current CEO, total funding raised, exact HQ city within Korea. These are flagged in the verification footer for a follow-up UPDATE pass.
299
+
300
+ ## 12. Principles
301
+
302
+ 1. **One brand color does the lifting.** Cobalt 400 (`#329BE7`) is the only brand accent — semantic hues (red/yellow/green/blue) are reserved for status. *UI implication*: don't decorate with the semantic palette; pick cobalt or nothing.
303
+ 2. **Inter, always — Noto fills the locale gap.** Korean and Japanese product rendering must keep Inter primary; Noto Sans KR/JP only resolves CJK characters Inter doesn't ship. *UI implication*: never substitute a single Korean-first stack — break the dual-locale resolution.
304
+ 3. **Radius is a ladder, not a slider.** 2 → 3 → 4 → 6 → 8 → 12 → 16 → 20 → 32 → 44px. *UI implication*: pick the rung that matches component scale; never interpolate (24 is not a Bezier rung).
305
+ 4. **Translucent off-black over pure black.** Body text is `rgba(0,0,0,0.85)`. *UI implication*: the 0.15 alpha is a deliberate atmospheric softening — preserve it on light surfaces.
306
+ 5. **Marketing breaks the product ceiling on purpose.** 64px hero, 54-48px section headlines, 600-weight intermediate — all marketing-only. *UI implication*: never bring those tokens into product chrome; the visual cliff between marketing and product is part of the brand register.
307
+ 6. **Dark theme is paired surface + elevation.** Bezier ships dark-theme as a full semantic mirror, not a CSS filter. *UI implication*: every elevation level has a paired light/dark surface — never invert color without inverting elevation.
308
+
309
+ ## 13. Personas
310
+
311
+ *Personas are fictional archetypes informed by publicly visible Channel Talk user segments (Korean/Japanese DTC ecommerce, K-beauty, SaaS support, mid-market team CS leads) — not real individuals.*
312
+
313
+ **Yoonseo Han, 31, Seoul.** Customer-experience lead at a K-beauty DTC brand on Cafe24. Has the Channel Talk Inbox open in a pinned tab from 09:00 to 19:00 KST. Just turned ALF on for tier-1 FAQs (size exchange, shipping ETA) — measures the deflection weekly and reports it to her CCO.
314
+
315
+ **Ren Takahashi, 38, Tokyo.** Support manager at a B2B SaaS that uses Channel Talk for both customer Inbox and internal Team Chat. Cares deeply about JP/KR locale resolution (Inter + Noto), keyboard-shortcut macros, and the team-handoff UX when ALF escalates to a human agent.
316
+
317
+ **Jiwon Park, 27, Seongnam.** Frontline CS agent on a 5-person team. Lives in Inbox. Will defect to any tool with cleaner conversation-history scroll-back and faster `cmd+k` search. Doesn't care about the AI narrative — cares that ALF closed 60 of her 100 daily tickets so she can focus on the 40 that need her.
318
+
319
+ **Sungho Lee, 44, Busan.** RevOps lead at a mid-market commerce platform. Integrated Channel Talk with Channel's Meet (Call) for outbound retention plays. Reads the weekly Workflow dashboard. Reports cost-per-resolved-ticket to the founder.
320
+
321
+ ## 14. States
322
+
323
+ | State | Treatment |
324
+ |---|---|
325
+ | **Empty (no conversations)** | Cobalt-tinted illustrated panel + single CTA "Connect a channel" (inferred from Bezier `EmptyContent` component name) |
326
+ | **Empty (ALF disabled)** | Subtle prompt: "Turn on ALF to deflect tier-1 tickets" + single cobalt CTA |
327
+ | **Loading (conversation history)** | Skeleton message bubbles in `Grey 100` (`#F7F7F8`) — no shimmer animation, just static surface tint (Bezier's flat depth signature) |
328
+ | **Loading (ALF response)** | Three-dot typing indicator with ALF avatar (cobalt accent ring) |
329
+ | **Error (sync failure)** | Top-of-Inbox banner in `Red 400` (`#E94E58`) at `red-400-20` alpha fill + "Retry" link |
330
+ | **Error (ALF escalation needed)** | Inline below message bubble, `Yellow 400` (`#EDBC40`) status dot + "Hand off to human" CTA |
331
+ | **Success (ticket closed)** | Subtle row tint shift to `Green 400` at `green-400-10` (`#31A5521A`) — no animation |
332
+ | **Success (ALF resolved)** | Resolution badge on conversation row — cobalt outlined chip |
333
+ | **Skeleton (inbox list)** | `Grey 100` row blocks, no shimmer, transition fades when real content lands |
334
+ | **Disabled (no permission)** | Component opacity 40% + permission tooltip on hover |
335
+ | **Loading (ALF reasoning trace)** | Per-step expandable trace: "Searching knowledge base..." → "Drafting response..." → "Awaiting confirmation" |
336
+
337
+ ## 15. Motion & Easing
338
+
339
+ | Token | Value | Use |
340
+ |---|---|---|
341
+ | `transition.duration.s` | 150ms | Hover, focus, small surface tints |
342
+ | `transition.duration.m` | 300ms | Modal open, popover, sheet |
343
+ | `transition.duration.l` | 450ms | Page transitions, large surface swaps |
344
+ | `transition.timing-function.default` | `cubic-bezier(0.3, 0, 0, 1)` | All transitions unless overridden |
345
+
346
+ Bezier ships exactly **one** easing curve as default — `cubic-bezier(0.3, 0, 0, 1)` — a sharp-out / soft-in shape that arrives quickly then settles. No bouncy or elastic curves in the source. The marketing site's section transitions (the AI-Messenger card pivots between Inbox / Meet / Team Chat / Workflow) appear to use the `m` duration with the default ease.
347
+
348
+ `prefers-reduced-motion: reduce` → durations collapse toward 0ms, transforms become opacity-only (convention; not explicitly documented in source but consistent with Bezier's accessibility framing).
349
+
350
+ ---
351
+
352
+ **Verified:** 2026-05-14
353
+ **Tier 1 sources (live + canonical DS):**
354
+ - `channel.io/en` — live DOM via CDP (Chrome DevTools Protocol over localhost:9222) 2026-05-14, 118 element samples with full `getComputedStyle` capture (proof file: `assets/_reference/.live-inspect-proof.json`, 10 raw_samples retained ≥ 5-minimum threshold)
355
+ - `github.com/channel-io/bezier-react/tree/main/packages/bezier-tokens/src/global` — canonical Bezier DS token JSON files (color 6.7KB, font 3.0KB, typography 2.7KB, radius 463B, transition 945B, opacity 66B, z-index 361B) fetched via `gh api` 2026-05-14
356
+ - `github.com/channel-io/bezier-react/tree/main/packages/bezier-tokens/src/semantic` — elevation 2.3KB + input 1.5KB + light-theme/dark-theme directories
357
+
358
+ **Tier 2 sources:** `styles.refero.design/?q=channel+talk` and `getdesign.md/channeltalk` not consulted this pass (Bezier is the Tier-1 canonical source, making Tier-2 third-party indexes redundant for this reference); to be checked in a follow-up UPDATE.
359
+
360
+ **Tier 2 (Philosophy/founders):** `channel.io/en/about` (positioning + metrics + tagline), `channel.io/en/team` (CEO + metrics + compliance). Founder list beyond current CEO, exact founding year, total funding raised — *unverified* at this pass, flagged in §11 and below.
361
+
362
+ **Style ref:** `intercom` (closest peer: B2B customer messaging + AI agent positioning; warm dual-product chrome ↔ cobalt-disciplined product chrome contrast deliberate).
363
+
364
+ **Conflicts unresolved:**
365
+ - Founding year: secondary sources suggest ZOYI Corp lineage ~2014; Channel-side surfaces consulted do not confirm year. Flag for UPDATE.
366
+ - Founder list: only current CEO Choi Si-won verified from Channel surfaces; co-founders not enumerated.
367
+ - Total funding / HQ city: not extractable from channel.io surfaces consulted; Crunchbase blocked WebFetch (403); requires Tier 2 source on UPDATE pass.
368
+
369
+ **IP guardrails applied:**
370
+ - §10 voice samples documented for tone-shape reference only, **not derivable as verbatim copy** in downstream DESIGN.md generations. Fresh derivation patterns provided inline.
371
+ - Brand assets (logo, marketing photography) NOT mirrored into `assets/_reference/`; only computed-style raw samples + canonical Bezier DS token JSON (MIT-licensed, redistribution-permitted) captured.
372
+ - Bezier tokens are MIT-licensed at source — reproduction in this DESIGN.md is within license terms with attribution.
373
+
374
+ **Earlier mistakes reverted:** none (first capture of this reference).