tribunal-kit 2.4.6 → 3.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 (250) hide show
  1. package/.agent/ARCHITECTURE.md +99 -99
  2. package/.agent/GEMINI.md +52 -52
  3. package/.agent/agents/accessibility-reviewer.md +139 -86
  4. package/.agent/agents/ai-code-reviewer.md +160 -90
  5. package/.agent/agents/backend-specialist.md +164 -127
  6. package/.agent/agents/code-archaeologist.md +115 -73
  7. package/.agent/agents/database-architect.md +130 -110
  8. package/.agent/agents/debugger.md +137 -97
  9. package/.agent/agents/dependency-reviewer.md +78 -30
  10. package/.agent/agents/devops-engineer.md +161 -118
  11. package/.agent/agents/documentation-writer.md +151 -87
  12. package/.agent/agents/explorer-agent.md +117 -99
  13. package/.agent/agents/frontend-reviewer.md +127 -47
  14. package/.agent/agents/frontend-specialist.md +169 -109
  15. package/.agent/agents/game-developer.md +28 -164
  16. package/.agent/agents/logic-reviewer.md +87 -49
  17. package/.agent/agents/mobile-developer.md +151 -103
  18. package/.agent/agents/mobile-reviewer.md +133 -50
  19. package/.agent/agents/orchestrator.md +121 -110
  20. package/.agent/agents/penetration-tester.md +103 -77
  21. package/.agent/agents/performance-optimizer.md +136 -92
  22. package/.agent/agents/performance-reviewer.md +139 -69
  23. package/.agent/agents/product-manager.md +104 -70
  24. package/.agent/agents/product-owner.md +6 -25
  25. package/.agent/agents/project-planner.md +95 -95
  26. package/.agent/agents/qa-automation-engineer.md +174 -87
  27. package/.agent/agents/security-auditor.md +133 -129
  28. package/.agent/agents/seo-specialist.md +160 -99
  29. package/.agent/agents/sql-reviewer.md +132 -44
  30. package/.agent/agents/supervisor-agent.md +137 -109
  31. package/.agent/agents/swarm-worker-contracts.md +17 -17
  32. package/.agent/agents/swarm-worker-registry.md +46 -46
  33. package/.agent/agents/test-coverage-reviewer.md +132 -53
  34. package/.agent/agents/test-engineer.md +0 -21
  35. package/.agent/agents/type-safety-reviewer.md +143 -33
  36. package/.agent/patterns/generator.md +9 -9
  37. package/.agent/patterns/inversion.md +12 -12
  38. package/.agent/patterns/pipeline.md +9 -9
  39. package/.agent/patterns/reviewer.md +13 -13
  40. package/.agent/patterns/tool-wrapper.md +9 -9
  41. package/.agent/rules/GEMINI.md +63 -63
  42. package/.agent/scripts/__pycache__/auto_preview.cpython-311.pyc +0 -0
  43. package/.agent/scripts/__pycache__/bundle_analyzer.cpython-311.pyc +0 -0
  44. package/.agent/scripts/__pycache__/checklist.cpython-311.pyc +0 -0
  45. package/.agent/scripts/__pycache__/dependency_analyzer.cpython-311.pyc +0 -0
  46. package/.agent/scripts/__pycache__/security_scan.cpython-311.pyc +0 -0
  47. package/.agent/scripts/__pycache__/session_manager.cpython-311.pyc +0 -0
  48. package/.agent/scripts/__pycache__/skill_integrator.cpython-311.pyc +0 -0
  49. package/.agent/scripts/__pycache__/swarm_dispatcher.cpython-311.pyc +0 -0
  50. package/.agent/scripts/__pycache__/test_runner.cpython-311.pyc +0 -0
  51. package/.agent/scripts/__pycache__/verify_all.cpython-311.pyc +0 -0
  52. package/.agent/scripts/compress_skills.py +167 -0
  53. package/.agent/scripts/consolidate_skills.py +173 -0
  54. package/.agent/scripts/deep_compress.py +202 -0
  55. package/.agent/scripts/minify_context.py +80 -0
  56. package/.agent/scripts/security_scan.py +1 -1
  57. package/.agent/scripts/strip_tribunal.py +41 -0
  58. package/.agent/skills/agent-organizer/SKILL.md +60 -100
  59. package/.agent/skills/agentic-patterns/SKILL.md +0 -70
  60. package/.agent/skills/ai-prompt-injection-defense/SKILL.md +108 -53
  61. package/.agent/skills/api-patterns/SKILL.md +197 -257
  62. package/.agent/skills/api-security-auditor/SKILL.md +125 -57
  63. package/.agent/skills/app-builder/SKILL.md +326 -50
  64. package/.agent/skills/app-builder/templates/SKILL.md +13 -15
  65. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
  66. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
  67. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
  68. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
  69. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
  70. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
  71. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
  72. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
  73. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
  74. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
  75. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
  76. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
  77. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
  78. package/.agent/skills/appflow-wireframe/SKILL.md +71 -98
  79. package/.agent/skills/architecture/SKILL.md +161 -200
  80. package/.agent/skills/authentication-best-practices/SKILL.md +121 -54
  81. package/.agent/skills/bash-linux/SKILL.md +71 -166
  82. package/.agent/skills/behavioral-modes/SKILL.md +8 -69
  83. package/.agent/skills/brainstorming/SKILL.md +345 -127
  84. package/.agent/skills/building-native-ui/SKILL.md +125 -57
  85. package/.agent/skills/clean-code/SKILL.md +266 -149
  86. package/.agent/skills/code-review-checklist/SKILL.md +0 -62
  87. package/.agent/skills/config-validator/SKILL.md +73 -131
  88. package/.agent/skills/csharp-developer/SKILL.md +434 -73
  89. package/.agent/skills/database-design/SKILL.md +190 -275
  90. package/.agent/skills/deployment-procedures/SKILL.md +81 -158
  91. package/.agent/skills/devops-engineer/SKILL.md +255 -94
  92. package/.agent/skills/devops-incident-responder/SKILL.md +50 -69
  93. package/.agent/skills/doc.md +5 -5
  94. package/.agent/skills/documentation-templates/SKILL.md +19 -63
  95. package/.agent/skills/edge-computing/SKILL.md +75 -165
  96. package/.agent/skills/extract-design-system/SKILL.md +84 -58
  97. package/.agent/skills/framer-motion-expert/SKILL.md +195 -0
  98. package/.agent/skills/frontend-design/SKILL.md +151 -499
  99. package/.agent/skills/game-design-expert/SKILL.md +71 -0
  100. package/.agent/skills/game-engineering-expert/SKILL.md +88 -0
  101. package/.agent/skills/geo-fundamentals/SKILL.md +52 -178
  102. package/.agent/skills/github-operations/SKILL.md +197 -272
  103. package/.agent/skills/gsap-expert/SKILL.md +194 -0
  104. package/.agent/skills/i18n-localization/SKILL.md +60 -172
  105. package/.agent/skills/intelligent-routing/SKILL.md +123 -103
  106. package/.agent/skills/lint-and-validate/SKILL.md +8 -52
  107. package/.agent/skills/llm-engineering/SKILL.md +281 -195
  108. package/.agent/skills/local-first/SKILL.md +76 -159
  109. package/.agent/skills/mcp-builder/SKILL.md +48 -188
  110. package/.agent/skills/mobile-design/SKILL.md +213 -219
  111. package/.agent/skills/motion-engineering/SKILL.md +184 -0
  112. package/.agent/skills/nextjs-react-expert/SKILL.md +184 -203
  113. package/.agent/skills/nodejs-best-practices/SKILL.md +403 -185
  114. package/.agent/skills/observability/SKILL.md +211 -203
  115. package/.agent/skills/parallel-agents/SKILL.md +53 -146
  116. package/.agent/skills/performance-profiling/SKILL.md +171 -151
  117. package/.agent/skills/plan-writing/SKILL.md +49 -153
  118. package/.agent/skills/platform-engineer/SKILL.md +57 -103
  119. package/.agent/skills/playwright-best-practices/SKILL.md +110 -63
  120. package/.agent/skills/powershell-windows/SKILL.md +61 -179
  121. package/.agent/skills/python-patterns/SKILL.md +7 -35
  122. package/.agent/skills/python-pro/SKILL.md +273 -114
  123. package/.agent/skills/react-specialist/SKILL.md +227 -108
  124. package/.agent/skills/readme-builder/SKILL.md +15 -85
  125. package/.agent/skills/realtime-patterns/SKILL.md +216 -243
  126. package/.agent/skills/red-team-tactics/SKILL.md +10 -51
  127. package/.agent/skills/rust-pro/SKILL.md +525 -142
  128. package/.agent/skills/seo-fundamentals/SKILL.md +92 -153
  129. package/.agent/skills/server-management/SKILL.md +110 -166
  130. package/.agent/skills/shadcn-ui-expert/SKILL.md +154 -55
  131. package/.agent/skills/skill-creator/SKILL.md +18 -58
  132. package/.agent/skills/sql-pro/SKILL.md +543 -68
  133. package/.agent/skills/supabase-postgres-best-practices/SKILL.md +28 -68
  134. package/.agent/skills/swiftui-expert/SKILL.md +124 -57
  135. package/.agent/skills/systematic-debugging/SKILL.md +49 -151
  136. package/.agent/skills/tailwind-patterns/SKILL.md +433 -149
  137. package/.agent/skills/tdd-workflow/SKILL.md +63 -169
  138. package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
  139. package/.agent/skills/testing-patterns/SKILL.md +437 -130
  140. package/.agent/skills/trend-researcher/SKILL.md +30 -71
  141. package/.agent/skills/ui-ux-pro-max/SKILL.md +0 -41
  142. package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
  143. package/.agent/skills/vue-expert/SKILL.md +225 -119
  144. package/.agent/skills/vulnerability-scanner/SKILL.md +264 -226
  145. package/.agent/skills/web-accessibility-auditor/SKILL.md +141 -58
  146. package/.agent/skills/web-design-guidelines/SKILL.md +17 -61
  147. package/.agent/skills/webapp-testing/SKILL.md +71 -196
  148. package/.agent/skills/whimsy-injector/SKILL.md +58 -132
  149. package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
  150. package/.agent/workflows/api-tester.md +96 -224
  151. package/.agent/workflows/audit.md +81 -122
  152. package/.agent/workflows/brainstorm.md +69 -105
  153. package/.agent/workflows/changelog.md +65 -97
  154. package/.agent/workflows/create.md +73 -88
  155. package/.agent/workflows/debug.md +80 -111
  156. package/.agent/workflows/deploy.md +119 -92
  157. package/.agent/workflows/enhance.md +80 -91
  158. package/.agent/workflows/fix.md +68 -97
  159. package/.agent/workflows/generate.md +165 -164
  160. package/.agent/workflows/migrate.md +106 -109
  161. package/.agent/workflows/orchestrate.md +103 -86
  162. package/.agent/workflows/performance-benchmarker.md +77 -268
  163. package/.agent/workflows/plan.md +120 -98
  164. package/.agent/workflows/preview.md +39 -96
  165. package/.agent/workflows/refactor.md +105 -97
  166. package/.agent/workflows/review-ai.md +63 -102
  167. package/.agent/workflows/review.md +71 -110
  168. package/.agent/workflows/session.md +53 -113
  169. package/.agent/workflows/status.md +42 -88
  170. package/.agent/workflows/strengthen-skills.md +90 -51
  171. package/.agent/workflows/swarm.md +114 -129
  172. package/.agent/workflows/test.md +125 -102
  173. package/.agent/workflows/tribunal-backend.md +60 -78
  174. package/.agent/workflows/tribunal-database.md +62 -100
  175. package/.agent/workflows/tribunal-frontend.md +62 -82
  176. package/.agent/workflows/tribunal-full.md +56 -100
  177. package/.agent/workflows/tribunal-mobile.md +65 -94
  178. package/.agent/workflows/tribunal-performance.md +62 -105
  179. package/.agent/workflows/ui-ux-pro-max.md +72 -121
  180. package/README.md +11 -15
  181. package/package.json +1 -1
  182. package/.agent/skills/api-patterns/api-style.md +0 -42
  183. package/.agent/skills/api-patterns/auth.md +0 -24
  184. package/.agent/skills/api-patterns/documentation.md +0 -26
  185. package/.agent/skills/api-patterns/graphql.md +0 -41
  186. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  187. package/.agent/skills/api-patterns/response.md +0 -37
  188. package/.agent/skills/api-patterns/rest.md +0 -40
  189. package/.agent/skills/api-patterns/security-testing.md +0 -122
  190. package/.agent/skills/api-patterns/trpc.md +0 -41
  191. package/.agent/skills/api-patterns/versioning.md +0 -22
  192. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  193. package/.agent/skills/app-builder/feature-building.md +0 -53
  194. package/.agent/skills/app-builder/project-detection.md +0 -34
  195. package/.agent/skills/app-builder/scaffolding.md +0 -118
  196. package/.agent/skills/app-builder/tech-stack.md +0 -40
  197. package/.agent/skills/architecture/context-discovery.md +0 -43
  198. package/.agent/skills/architecture/examples.md +0 -94
  199. package/.agent/skills/architecture/pattern-selection.md +0 -68
  200. package/.agent/skills/architecture/patterns-reference.md +0 -50
  201. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  202. package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
  203. package/.agent/skills/database-design/database-selection.md +0 -43
  204. package/.agent/skills/database-design/indexing.md +0 -39
  205. package/.agent/skills/database-design/migrations.md +0 -48
  206. package/.agent/skills/database-design/optimization.md +0 -36
  207. package/.agent/skills/database-design/orm-selection.md +0 -30
  208. package/.agent/skills/database-design/schema-design.md +0 -56
  209. package/.agent/skills/dotnet-core-expert/SKILL.md +0 -103
  210. package/.agent/skills/framer-motion-animations/SKILL.md +0 -74
  211. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  212. package/.agent/skills/frontend-design/color-system.md +0 -329
  213. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  214. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  215. package/.agent/skills/frontend-design/typography-system.md +0 -363
  216. package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
  217. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  218. package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
  219. package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
  220. package/.agent/skills/game-development/SKILL.md +0 -236
  221. package/.agent/skills/game-development/game-art/SKILL.md +0 -185
  222. package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
  223. package/.agent/skills/game-development/game-design/SKILL.md +0 -129
  224. package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
  225. package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
  226. package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
  227. package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
  228. package/.agent/skills/game-development/web-games/SKILL.md +0 -150
  229. package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
  230. package/.agent/skills/mobile-design/decision-trees.md +0 -516
  231. package/.agent/skills/mobile-design/mobile-backend.md +0 -491
  232. package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
  233. package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
  234. package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
  235. package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
  236. package/.agent/skills/mobile-design/mobile-performance.md +0 -767
  237. package/.agent/skills/mobile-design/mobile-testing.md +0 -356
  238. package/.agent/skills/mobile-design/mobile-typography.md +0 -433
  239. package/.agent/skills/mobile-design/platform-android.md +0 -666
  240. package/.agent/skills/mobile-design/platform-ios.md +0 -561
  241. package/.agent/skills/mobile-design/touch-psychology.md +0 -537
  242. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
  243. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
  244. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
  245. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
  246. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
  247. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
  248. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
  249. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
  250. 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.