tribunal-kit 3.0.0 → 4.0.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 (233) hide show
  1. package/.agent/ARCHITECTURE.md +99 -99
  2. package/.agent/GEMINI.md +52 -52
  3. package/.agent/agents/accessibility-reviewer.md +187 -220
  4. package/.agent/agents/ai-code-reviewer.md +199 -233
  5. package/.agent/agents/backend-specialist.md +215 -238
  6. package/.agent/agents/code-archaeologist.md +161 -181
  7. package/.agent/agents/database-architect.md +184 -207
  8. package/.agent/agents/debugger.md +191 -218
  9. package/.agent/agents/dependency-reviewer.md +103 -136
  10. package/.agent/agents/devops-engineer.md +218 -238
  11. package/.agent/agents/documentation-writer.md +201 -221
  12. package/.agent/agents/explorer-agent.md +160 -180
  13. package/.agent/agents/frontend-reviewer.md +160 -194
  14. package/.agent/agents/frontend-specialist.md +248 -237
  15. package/.agent/agents/game-developer.md +48 -52
  16. package/.agent/agents/logic-reviewer.md +116 -149
  17. package/.agent/agents/mobile-developer.md +200 -223
  18. package/.agent/agents/mobile-reviewer.md +162 -195
  19. package/.agent/agents/orchestrator.md +181 -211
  20. package/.agent/agents/penetration-tester.md +157 -174
  21. package/.agent/agents/performance-optimizer.md +183 -203
  22. package/.agent/agents/performance-reviewer.md +178 -211
  23. package/.agent/agents/precedence-reviewer.md +213 -0
  24. package/.agent/agents/product-manager.md +142 -162
  25. package/.agent/agents/product-owner.md +6 -25
  26. package/.agent/agents/project-planner.md +142 -162
  27. package/.agent/agents/qa-automation-engineer.md +225 -242
  28. package/.agent/agents/security-auditor.md +174 -194
  29. package/.agent/agents/seo-specialist.md +193 -213
  30. package/.agent/agents/sql-reviewer.md +161 -194
  31. package/.agent/agents/supervisor-agent.md +184 -203
  32. package/.agent/agents/swarm-worker-contracts.md +17 -17
  33. package/.agent/agents/swarm-worker-registry.md +46 -46
  34. package/.agent/agents/test-coverage-reviewer.md +160 -193
  35. package/.agent/agents/test-engineer.md +0 -21
  36. package/.agent/agents/type-safety-reviewer.md +175 -208
  37. package/.agent/patterns/generator.md +9 -9
  38. package/.agent/patterns/inversion.md +12 -12
  39. package/.agent/patterns/pipeline.md +9 -9
  40. package/.agent/patterns/reviewer.md +13 -13
  41. package/.agent/patterns/tool-wrapper.md +9 -9
  42. package/.agent/rules/GEMINI.md +63 -63
  43. package/.agent/scripts/append_flow.js +72 -0
  44. package/.agent/scripts/case_law_manager.py +525 -0
  45. package/.agent/scripts/compress_skills.py +167 -0
  46. package/.agent/scripts/consolidate_skills.py +173 -0
  47. package/.agent/scripts/deep_compress.py +202 -0
  48. package/.agent/scripts/minify_context.py +80 -0
  49. package/.agent/scripts/security_scan.py +1 -1
  50. package/.agent/scripts/skill_evolution.py +563 -0
  51. package/.agent/scripts/strip_tribunal.py +41 -0
  52. package/.agent/skills/agent-organizer/SKILL.md +100 -126
  53. package/.agent/skills/agentic-patterns/SKILL.md +0 -70
  54. package/.agent/skills/ai-prompt-injection-defense/SKILL.md +134 -160
  55. package/.agent/skills/api-patterns/SKILL.md +123 -215
  56. package/.agent/skills/api-security-auditor/SKILL.md +143 -177
  57. package/.agent/skills/app-builder/SKILL.md +334 -50
  58. package/.agent/skills/app-builder/templates/SKILL.md +13 -15
  59. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
  60. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
  61. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
  62. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
  63. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
  64. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
  65. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
  66. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
  67. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
  68. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
  69. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
  70. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
  71. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
  72. package/.agent/skills/appflow-wireframe/SKILL.md +95 -121
  73. package/.agent/skills/architecture/SKILL.md +169 -331
  74. package/.agent/skills/authentication-best-practices/SKILL.md +139 -173
  75. package/.agent/skills/bash-linux/SKILL.md +129 -154
  76. package/.agent/skills/behavioral-modes/SKILL.md +8 -69
  77. package/.agent/skills/brainstorming/SKILL.md +436 -104
  78. package/.agent/skills/building-native-ui/SKILL.md +152 -174
  79. package/.agent/skills/clean-code/SKILL.md +331 -360
  80. package/.agent/skills/code-review-checklist/SKILL.md +0 -62
  81. package/.agent/skills/config-validator/SKILL.md +115 -141
  82. package/.agent/skills/csharp-developer/SKILL.md +468 -528
  83. package/.agent/skills/database-design/SKILL.md +104 -369
  84. package/.agent/skills/deployment-procedures/SKILL.md +119 -145
  85. package/.agent/skills/devops-engineer/SKILL.md +295 -332
  86. package/.agent/skills/devops-incident-responder/SKILL.md +87 -113
  87. package/.agent/skills/doc.md +5 -5
  88. package/.agent/skills/documentation-templates/SKILL.md +27 -63
  89. package/.agent/skills/edge-computing/SKILL.md +131 -157
  90. package/.agent/skills/extract-design-system/SKILL.md +108 -134
  91. package/.agent/skills/framer-motion-expert/SKILL.md +111 -855
  92. package/.agent/skills/frontend-design/SKILL.md +151 -499
  93. package/.agent/skills/game-design-expert/SKILL.md +79 -105
  94. package/.agent/skills/game-engineering-expert/SKILL.md +96 -122
  95. package/.agent/skills/geo-fundamentals/SKILL.md +97 -124
  96. package/.agent/skills/github-operations/SKILL.md +279 -314
  97. package/.agent/skills/gsap-expert/SKILL.md +119 -826
  98. package/.agent/skills/i18n-localization/SKILL.md +113 -138
  99. package/.agent/skills/intelligent-routing/SKILL.md +167 -127
  100. package/.agent/skills/lint-and-validate/SKILL.md +16 -52
  101. package/.agent/skills/llm-engineering/SKILL.md +344 -357
  102. package/.agent/skills/local-first/SKILL.md +128 -154
  103. package/.agent/skills/mcp-builder/SKILL.md +92 -118
  104. package/.agent/skills/mobile-design/SKILL.md +213 -219
  105. package/.agent/skills/motion-engineering/SKILL.md +184 -0
  106. package/.agent/skills/nextjs-react-expert/SKILL.md +99 -698
  107. package/.agent/skills/nodejs-best-practices/SKILL.md +498 -559
  108. package/.agent/skills/observability/SKILL.md +293 -330
  109. package/.agent/skills/parallel-agents/SKILL.md +96 -122
  110. package/.agent/skills/performance-profiling/SKILL.md +217 -254
  111. package/.agent/skills/plan-writing/SKILL.md +92 -118
  112. package/.agent/skills/platform-engineer/SKILL.md +97 -123
  113. package/.agent/skills/playwright-best-practices/SKILL.md +137 -162
  114. package/.agent/skills/powershell-windows/SKILL.md +112 -146
  115. package/.agent/skills/project-idioms/SKILL.md +87 -0
  116. package/.agent/skills/python-patterns/SKILL.md +15 -35
  117. package/.agent/skills/python-pro/SKILL.md +148 -754
  118. package/.agent/skills/react-specialist/SKILL.md +123 -827
  119. package/.agent/skills/readme-builder/SKILL.md +23 -85
  120. package/.agent/skills/realtime-patterns/SKILL.md +269 -304
  121. package/.agent/skills/red-team-tactics/SKILL.md +18 -51
  122. package/.agent/skills/rust-pro/SKILL.md +623 -701
  123. package/.agent/skills/seo-fundamentals/SKILL.md +129 -154
  124. package/.agent/skills/server-management/SKILL.md +164 -190
  125. package/.agent/skills/shadcn-ui-expert/SKILL.md +181 -206
  126. package/.agent/skills/skill-creator/SKILL.md +24 -56
  127. package/.agent/skills/sql-pro/SKILL.md +579 -633
  128. package/.agent/skills/supabase-postgres-best-practices/SKILL.md +35 -66
  129. package/.agent/skills/swiftui-expert/SKILL.md +151 -176
  130. package/.agent/skills/systematic-debugging/SKILL.md +92 -118
  131. package/.agent/skills/tailwind-patterns/SKILL.md +516 -576
  132. package/.agent/skills/tdd-workflow/SKILL.md +111 -137
  133. package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
  134. package/.agent/skills/testing-patterns/SKILL.md +512 -573
  135. package/.agent/skills/trend-researcher/SKILL.md +30 -71
  136. package/.agent/skills/ui-ux-pro-max/SKILL.md +8 -41
  137. package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
  138. package/.agent/skills/vue-expert/SKILL.md +127 -866
  139. package/.agent/skills/vulnerability-scanner/SKILL.md +354 -269
  140. package/.agent/skills/web-accessibility-auditor/SKILL.md +168 -193
  141. package/.agent/skills/web-design-guidelines/SKILL.md +25 -61
  142. package/.agent/skills/webapp-testing/SKILL.md +119 -145
  143. package/.agent/skills/whimsy-injector/SKILL.md +58 -132
  144. package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
  145. package/.agent/workflows/api-tester.md +151 -151
  146. package/.agent/workflows/audit.md +127 -138
  147. package/.agent/workflows/brainstorm.md +110 -110
  148. package/.agent/workflows/changelog.md +112 -112
  149. package/.agent/workflows/create.md +124 -124
  150. package/.agent/workflows/debug.md +165 -189
  151. package/.agent/workflows/deploy.md +180 -189
  152. package/.agent/workflows/enhance.md +128 -151
  153. package/.agent/workflows/fix.md +114 -135
  154. package/.agent/workflows/generate.md +13 -4
  155. package/.agent/workflows/migrate.md +160 -160
  156. package/.agent/workflows/orchestrate.md +168 -168
  157. package/.agent/workflows/performance-benchmarker.md +114 -123
  158. package/.agent/workflows/plan.md +173 -173
  159. package/.agent/workflows/preview.md +80 -80
  160. package/.agent/workflows/refactor.md +161 -183
  161. package/.agent/workflows/review-ai.md +101 -129
  162. package/.agent/workflows/review.md +116 -116
  163. package/.agent/workflows/session.md +94 -94
  164. package/.agent/workflows/status.md +79 -79
  165. package/.agent/workflows/strengthen-skills.md +138 -139
  166. package/.agent/workflows/swarm.md +179 -179
  167. package/.agent/workflows/test.md +189 -211
  168. package/.agent/workflows/tribunal-backend.md +94 -113
  169. package/.agent/workflows/tribunal-database.md +95 -115
  170. package/.agent/workflows/tribunal-frontend.md +96 -118
  171. package/.agent/workflows/tribunal-full.md +93 -133
  172. package/.agent/workflows/tribunal-mobile.md +95 -119
  173. package/.agent/workflows/tribunal-performance.md +110 -133
  174. package/.agent/workflows/ui-ux-pro-max.md +122 -143
  175. package/README.md +30 -1
  176. package/bin/tribunal-kit.js +175 -12
  177. package/package.json +25 -4
  178. package/.agent/skills/api-patterns/api-style.md +0 -42
  179. package/.agent/skills/api-patterns/auth.md +0 -24
  180. package/.agent/skills/api-patterns/documentation.md +0 -26
  181. package/.agent/skills/api-patterns/graphql.md +0 -41
  182. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  183. package/.agent/skills/api-patterns/response.md +0 -37
  184. package/.agent/skills/api-patterns/rest.md +0 -40
  185. package/.agent/skills/api-patterns/security-testing.md +0 -122
  186. package/.agent/skills/api-patterns/trpc.md +0 -41
  187. package/.agent/skills/api-patterns/versioning.md +0 -22
  188. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  189. package/.agent/skills/app-builder/feature-building.md +0 -53
  190. package/.agent/skills/app-builder/project-detection.md +0 -34
  191. package/.agent/skills/app-builder/scaffolding.md +0 -118
  192. package/.agent/skills/app-builder/tech-stack.md +0 -40
  193. package/.agent/skills/architecture/context-discovery.md +0 -43
  194. package/.agent/skills/architecture/examples.md +0 -94
  195. package/.agent/skills/architecture/pattern-selection.md +0 -68
  196. package/.agent/skills/architecture/patterns-reference.md +0 -50
  197. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  198. package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
  199. package/.agent/skills/database-design/database-selection.md +0 -43
  200. package/.agent/skills/database-design/indexing.md +0 -39
  201. package/.agent/skills/database-design/migrations.md +0 -48
  202. package/.agent/skills/database-design/optimization.md +0 -36
  203. package/.agent/skills/database-design/orm-selection.md +0 -30
  204. package/.agent/skills/database-design/schema-design.md +0 -56
  205. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  206. package/.agent/skills/frontend-design/color-system.md +0 -329
  207. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  208. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  209. package/.agent/skills/frontend-design/typography-system.md +0 -363
  210. package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
  211. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  212. package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
  213. package/.agent/skills/mobile-design/decision-trees.md +0 -516
  214. package/.agent/skills/mobile-design/mobile-backend.md +0 -491
  215. package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
  216. package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
  217. package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
  218. package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
  219. package/.agent/skills/mobile-design/mobile-performance.md +0 -767
  220. package/.agent/skills/mobile-design/mobile-testing.md +0 -356
  221. package/.agent/skills/mobile-design/mobile-typography.md +0 -433
  222. package/.agent/skills/mobile-design/platform-android.md +0 -666
  223. package/.agent/skills/mobile-design/platform-ios.md +0 -561
  224. package/.agent/skills/mobile-design/touch-psychology.md +0 -537
  225. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
  226. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
  227. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
  228. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
  229. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
  230. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
  231. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
  232. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
  233. package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
@@ -1,433 +0,0 @@
1
- # Mobile Typography Reference
2
-
3
- > Type scale, system fonts, Dynamic Type, accessibility, and dark mode typography.
4
- > **Typography failures are the #1 cause of unreadable mobile apps.**
5
-
6
- ---
7
-
8
- ## 1. Mobile Typography Fundamentals
9
-
10
- ### Why Mobile Type is Different
11
-
12
- ```
13
- DESKTOP: MOBILE:
14
- ├── 20-30" viewing distance ├── 12-15" viewing distance
15
- ├── Large viewport ├── Small viewport, narrow
16
- ├── Hover for details ├── Tap/scroll for details
17
- ├── Controlled lighting ├── Variable (outdoor, etc.)
18
- ├── Fixed font size ├── User-controlled sizing
19
- └── Long reading sessions └── Quick scanning
20
- ```
21
-
22
- ### Mobile Type Rules
23
-
24
- | Rule | Desktop | Mobile |
25
- |------|---------|--------|
26
- | **Minimum body size** | 14px | 16px (14pt/14sp) |
27
- | **Maximum line length** | 75 characters | 40-60 characters |
28
- | **Line height** | 1.4-1.5 | 1.4-1.6 (more generous) |
29
- | **Font weight** | Varies | Regular dominant, bold sparingly |
30
- | **Contrast** | AA (4.5:1) | AA minimum, AAA preferred |
31
-
32
- ---
33
-
34
- ## 2. System Fonts
35
-
36
- ### iOS: SF Pro Family
37
-
38
- ```
39
- San Francisco (SF) Family:
40
- ├── SF Pro Display: Large text (≥ 20pt)
41
- ├── SF Pro Text: Body text (< 20pt)
42
- ├── SF Pro Rounded: Friendly contexts
43
- ├── SF Mono: Monospace
44
- └── SF Compact: Apple Watch, compact UI
45
-
46
- Features:
47
- ├── Optical sizing (auto-adjusts)
48
- ├── Dynamic tracking (spacing)
49
- ├── Tabular/proportional figures
50
- ├── Excellent legibility
51
- ```
52
-
53
- ### Android: Roboto Family
54
-
55
- ```
56
- Roboto Family:
57
- ├── Roboto: Default sans-serif
58
- ├── Roboto Flex: Variable font
59
- ├── Roboto Serif: Serif option
60
- ├── Roboto Mono: Monospace
61
- ├── Roboto Condensed: Narrow spaces
62
-
63
- Features:
64
- ├── Optimized for screens
65
- ├── Wide language support
66
- ├── Multiple weights
67
- ├── Good at small sizes
68
- ```
69
-
70
- ### When to Use System Fonts
71
-
72
- ```
73
- ✅ USE system fonts when:
74
- ├── Brand doesn't mandate custom font
75
- ├── Reading efficiency is priority
76
- ├── App feels native/integrated important
77
- ├── Performance is critical
78
- ├── Wide language support needed
79
-
80
- ❌ AVOID system fonts when:
81
- ├── Brand identity requires custom
82
- ├── Design differentiation needed
83
- ├── Editorial/magazine style
84
- └── (But still support accessibility)
85
- ```
86
-
87
- ### Custom Font Considerations
88
-
89
- ```
90
- If using custom fonts:
91
- ├── Include all weights needed
92
- ├── Subset for file size
93
- ├── Test at all Dynamic Type sizes
94
- ├── Provide fallback to system
95
- ├── Test rendering quality
96
- └── Check language support
97
- ```
98
-
99
- ---
100
-
101
- ## 3. Type Scale
102
-
103
- ### iOS Type Scale (Built-in)
104
-
105
- | Style | Size | Weight | Line Height |
106
- |-------|------|--------|-------------|
107
- | Large Title | 34pt | Bold | 41pt |
108
- | Title 1 | 28pt | Bold | 34pt |
109
- | Title 2 | 22pt | Bold | 28pt |
110
- | Title 3 | 20pt | Semibold | 25pt |
111
- | Headline | 17pt | Semibold | 22pt |
112
- | Body | 17pt | Regular | 22pt |
113
- | Callout | 16pt | Regular | 21pt |
114
- | Subhead | 15pt | Regular | 20pt |
115
- | Footnote | 13pt | Regular | 18pt |
116
- | Caption 1 | 12pt | Regular | 16pt |
117
- | Caption 2 | 11pt | Regular | 13pt |
118
-
119
- ### Android Type Scale (Material 3)
120
-
121
- | Role | Size | Weight | Line Height |
122
- |------|------|--------|-------------|
123
- | Display Large | 57sp | 400 | 64sp |
124
- | Display Medium | 45sp | 400 | 52sp |
125
- | Display Small | 36sp | 400 | 44sp |
126
- | Headline Large | 32sp | 400 | 40sp |
127
- | Headline Medium | 28sp | 400 | 36sp |
128
- | Headline Small | 24sp | 400 | 32sp |
129
- | Title Large | 22sp | 400 | 28sp |
130
- | Title Medium | 16sp | 500 | 24sp |
131
- | Title Small | 14sp | 500 | 20sp |
132
- | Body Large | 16sp | 400 | 24sp |
133
- | Body Medium | 14sp | 400 | 20sp |
134
- | Body Small | 12sp | 400 | 16sp |
135
- | Label Large | 14sp | 500 | 20sp |
136
- | Label Medium | 12sp | 500 | 16sp |
137
- | Label Small | 11sp | 500 | 16sp |
138
-
139
- ### Creating Custom Scale
140
-
141
- ```
142
- If creating custom scale, use modular ratio:
143
-
144
- Recommended ratios:
145
- ├── 1.125 (Major second): Dense UI
146
- ├── 1.200 (Minor third): Compact
147
- ├── 1.250 (Major third): Balanced (common)
148
- ├── 1.333 (Perfect fourth): Spacious
149
- └── 1.500 (Perfect fifth): Dramatic
150
-
151
- Example with 1.25 ratio, 16px base:
152
- ├── xs: 10px (16 ÷ 1.25 ÷ 1.25)
153
- ├── sm: 13px (16 ÷ 1.25)
154
- ├── base: 16px
155
- ├── lg: 20px (16 × 1.25)
156
- ├── xl: 25px (16 × 1.25 × 1.25)
157
- ├── 2xl: 31px
158
- ├── 3xl: 39px
159
- └── 4xl: 49px
160
- ```
161
-
162
- ---
163
-
164
- ## 4. Dynamic Type / Text Scaling
165
-
166
- ### iOS Dynamic Type (MANDATORY)
167
-
168
- ```swift
169
- // ❌ WRONG: Fixed size (doesn't scale)
170
- Text("Hello")
171
- .font(.system(size: 17))
172
-
173
- // ✅ CORRECT: Dynamic Type
174
- Text("Hello")
175
- .font(.body) // Scales with user setting
176
-
177
- // Custom font with scaling
178
- Text("Hello")
179
- .font(.custom("MyFont", size: 17, relativeTo: .body))
180
- ```
181
-
182
- ### Android Text Scaling (MANDATORY)
183
-
184
- ```
185
- ALWAYS use sp for text:
186
- ├── sp = Scale-independent pixels
187
- ├── Scales with user font preference
188
- ├── dp does NOT scale (don't use for text)
189
-
190
- User can scale from 85% to 200%:
191
- ├── Default (100%): 14sp = 14dp
192
- ├── Largest (200%): 14sp = 28dp
193
-
194
- Test at 200%!
195
- ```
196
-
197
- ### Scaling Challenges
198
-
199
- ```
200
- Problems at large text sizes:
201
- ├── Text overflows containers
202
- ├── Buttons become too tall
203
- ├── Icons look small relative to text
204
- ├── Layouts break
205
-
206
- Solutions:
207
- ├── Use flexible containers (not fixed height)
208
- ├── Allow text wrapping
209
- ├── Scale icons with text
210
- ├── Test at extremes during development
211
- ├── Use scrollable containers for long text
212
- ```
213
-
214
- ---
215
-
216
- ## 5. Typography Accessibility
217
-
218
- ### Minimum Sizes
219
-
220
- | Element | Minimum | Recommended |
221
- |---------|---------|-------------|
222
- | Body text | 14px/pt/sp | 16px/pt/sp |
223
- | Secondary text | 12px/pt/sp | 13-14px/pt/sp |
224
- | Captions | 11px/pt/sp | 12px/pt/sp |
225
- | Buttons | 14px/pt/sp | 14-16px/pt/sp |
226
- | **Nothing smaller** | 11px | - |
227
-
228
- ### Contrast Requirements (WCAG)
229
-
230
- ```
231
- Normal text (< 18pt or < 14pt bold):
232
- ├── AA: 4.5:1 ratio minimum
233
- ├── AAA: 7:1 ratio recommended
234
-
235
- Large text (≥ 18pt or ≥ 14pt bold):
236
- ├── AA: 3:1 ratio minimum
237
- ├── AAA: 4.5:1 ratio recommended
238
-
239
- Logos/decorative: No requirement
240
- ```
241
-
242
- ### Line Height for Accessibility
243
-
244
- ```
245
- WCAG Success Criterion 1.4.12:
246
-
247
- Line height (line spacing): ≥ 1.5×
248
- Paragraph spacing: ≥ 2× font size
249
- Letter spacing: ≥ 0.12× font size
250
- Word spacing: ≥ 0.16× font size
251
-
252
- Mobile recommendation:
253
- ├── Body: 1.4-1.6 line height
254
- ├── Headings: 1.2-1.3 line height
255
- ├── Never below 1.2
256
- ```
257
-
258
- ---
259
-
260
- ## 6. Dark Mode Typography
261
-
262
- ### Color Adjustments
263
-
264
- ```
265
- Light Mode: Dark Mode:
266
- ├── Black text (#000) ├── White/light gray (#E0E0E0)
267
- ├── High contrast ├── Slightly reduced contrast
268
- ├── Full saturation ├── Desaturated colors
269
- └── Dark = emphasis └── Light = emphasis
270
-
271
- RULE: Don't use pure white (#FFF) on dark.
272
- Use off-white (#E0E0E0 to #F0F0F0) to reduce eye strain.
273
- ```
274
-
275
- ### Dark Mode Hierarchy
276
-
277
- | Level | Light Mode | Dark Mode |
278
- |-------|------------|-----------|
279
- | Primary text | #000000 | #E8E8E8 |
280
- | Secondary text | #666666 | #A0A0A0 |
281
- | Tertiary text | #999999 | #707070 |
282
- | Disabled text | #CCCCCC | #505050 |
283
-
284
- ### Weight in Dark Mode
285
-
286
- ```
287
- Dark mode text appears thinner due to halation
288
- (light bleeding into dark background)
289
-
290
- Consider:
291
- ├── Using medium weight for body (instead of regular)
292
- ├── Increasing letter-spacing slightly
293
- ├── Testing on actual OLED displays
294
- └── Using slightly bolder weight than light mode
295
- ```
296
-
297
- ---
298
-
299
- ## 7. Typography Anti-Patterns
300
-
301
- ### ❌ Common Mistakes
302
-
303
- | Mistake | Problem | Fix |
304
- |---------|---------|-----|
305
- | **Fixed font sizes** | Ignores accessibility | Use dynamic sizing |
306
- | **Too small text** | Unreadable | Min 14pt/sp |
307
- | **Low contrast** | Invisible in sunlight | Min 4.5:1 |
308
- | **Long lines** | Hard to track | Max 60 chars |
309
- | **Tight line height** | Cramped, hard to read | Min 1.4× |
310
- | **Too many sizes** | Visual chaos | Max 5-7 sizes |
311
- | **All caps body** | Hard to read | Headlines only |
312
- | **Light gray on white** | Impossible in bright light | Higher contrast |
313
-
314
- ### ❌ AI Typography Mistakes
315
-
316
- ```
317
- AI tends to:
318
- ├── Use fixed px values instead of pt/sp
319
- ├── Skip Dynamic Type support
320
- ├── Use too small text (12-14px body)
321
- ├── Ignore line height settings
322
- ├── Use low contrast "aesthetic" grays
323
- ├── Apply same scale to mobile as desktop
324
- └── Skip testing at large text sizes
325
-
326
- RULE: Typography must SCALE.
327
- Test at smallest and largest settings.
328
- ```
329
-
330
- ---
331
-
332
- ## 8. Font Loading & Performance
333
-
334
- ### Font File Optimization
335
-
336
- ```
337
- Font file sizes matter on mobile:
338
- ├── Full font: 100-300KB per weight
339
- ├── Subset (Latin): 15-40KB per weight
340
- ├── Variable font: 100-200KB (all weights)
341
-
342
- Recommendations:
343
- ├── Subset to needed characters
344
- ├── Use WOFF2 format
345
- ├── Max 2-3 font files
346
- ├── Consider variable fonts
347
- ├── Cache fonts appropriately
348
- ```
349
-
350
- ### Loading Strategy
351
-
352
- ```
353
- 1. SYSTEM FONT FALLBACK
354
- Show system font → swap when custom loads
355
-
356
- 2. FONT DISPLAY SWAP
357
- font-display: swap (CSS)
358
-
359
- 3. PRELOAD CRITICAL FONTS
360
- Preload fonts needed above the fold
361
-
362
- 4. DON'T BLOCK RENDER
363
- Don't wait for fonts to show content
364
- ```
365
-
366
- ---
367
-
368
- ## 9. Typography Checklist
369
-
370
- ### Before Any Text Design
371
-
372
- - [ ] Body text ≥ 16px/pt/sp?
373
- - [ ] Line height ≥ 1.4?
374
- - [ ] Line length ≤ 60 chars?
375
- - [ ] Type scale defined (max 5-7 sizes)?
376
- - [ ] Using pt (iOS) or sp (Android)?
377
-
378
- ### Before Release
379
-
380
- - [ ] Dynamic Type tested (iOS)?
381
- - [ ] Font scaling tested at 200% (Android)?
382
- - [ ] Dark mode contrast checked?
383
- - [ ] Sunlight readability tested?
384
- - [ ] All text has proper hierarchy?
385
- - [ ] Custom fonts have fallbacks?
386
- - [ ] Long text scrolls properly?
387
-
388
- ---
389
-
390
- ## 10. Quick Reference
391
-
392
- ### Typography Tokens
393
-
394
- ```
395
- // iOS
396
- .largeTitle // 34pt, Bold
397
- .title // 28pt, Bold
398
- .title2 // 22pt, Bold
399
- .title3 // 20pt, Semibold
400
- .headline // 17pt, Semibold
401
- .body // 17pt, Regular
402
- .subheadline // 15pt, Regular
403
- .footnote // 13pt, Regular
404
- .caption // 12pt, Regular
405
-
406
- // Android (Material 3)
407
- displayLarge // 57sp
408
- headlineLarge // 32sp
409
- titleLarge // 22sp
410
- bodyLarge // 16sp
411
- labelLarge // 14sp
412
- ```
413
-
414
- ### Minimum Sizes
415
-
416
- ```
417
- Body: 14-16pt/sp (16 preferred)
418
- Secondary: 12-13pt/sp
419
- Caption: 11-12pt/sp
420
- Nothing: < 11pt/sp
421
- ```
422
-
423
- ### Line Height
424
-
425
- ```
426
- Headings: 1.1-1.3
427
- Body: 1.4-1.6
428
- Long text: 1.5-1.75
429
- ```
430
-
431
- ---
432
-
433
- > **Remember:** If users can't read your text, your app is broken. Typography isn't decoration—it's the primary interface. Test on real devices, in real conditions, with accessibility settings enabled.