@hiai-gg/hiai-opencode 0.2.1 → 0.2.2

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 (477) hide show
  1. package/.env.example +4 -0
  2. package/AGENTS.md +34 -38
  3. package/ARCHITECTURE.md +4 -3
  4. package/LICENSE.md +14 -0
  5. package/README.md +52 -21
  6. package/config/hiai-opencode.schema.json +11 -13
  7. package/dist/agents/{bob.d.ts → bob/claude.d.ts} +6 -2
  8. package/dist/agents/bob/core.d.ts +6 -0
  9. package/dist/agents/bob/gpt.d.ts +11 -0
  10. package/dist/agents/bob/index.d.ts +3 -0
  11. package/dist/agents/coder/core.d.ts +4 -0
  12. package/dist/agents/coder/gpt.d.ts +1 -4
  13. package/dist/agents/coder/index.d.ts +1 -0
  14. package/dist/agents/manager/agent.d.ts +1 -1
  15. package/dist/agents/manager/default-prompt-sections.d.ts +3 -3
  16. package/dist/agents/manager/guard-integration.d.ts +1 -0
  17. package/dist/agents/prompt-library/index.d.ts +0 -1
  18. package/dist/agents/prompt-library/shared-execution.d.ts +9 -0
  19. package/dist/agents/strategist/behavioral-summary.d.ts +1 -1
  20. package/dist/agents/strategist/identity-constraints.d.ts +1 -1
  21. package/dist/agents/strategist/plan-generation.d.ts +1 -1
  22. package/dist/agents/types.d.ts +2 -1
  23. package/dist/config/defaults.d.ts +1 -0
  24. package/dist/config/platform-schema.d.ts +26 -26
  25. package/dist/config/schema/agent-names.d.ts +6 -6
  26. package/dist/config/schema/agent-overrides.d.ts +0 -128
  27. package/dist/config/schema/hiai-opencode-config.d.ts +0 -128
  28. package/dist/config/types.d.ts +2 -2
  29. package/dist/features/background-agent/manager-notifier.d.ts +46 -0
  30. package/dist/features/background-agent/manager-types.d.ts +40 -0
  31. package/dist/features/background-agent/manager.d.ts +3 -19
  32. package/dist/features/background-agent/polling-manager.d.ts +51 -0
  33. package/dist/features/boulder-state/storage.d.ts +1 -0
  34. package/dist/features/builtin-commands/templates/loop.d.ts +2 -0
  35. package/dist/features/builtin-commands/templates/start-work.d.ts +1 -1
  36. package/dist/features/builtin-skills/skills/interview-me.d.ts +2 -0
  37. package/dist/features/builtin-skills/skills/planning-and-task-breakdown.d.ts +2 -0
  38. package/dist/hooks/reasoning-content-cache/hook.d.ts +11 -0
  39. package/dist/hooks/reasoning-content-cache/index.d.ts +1 -0
  40. package/dist/hooks/session-recovery/checkpoint.d.ts +48 -0
  41. package/dist/hooks/session-recovery/enhanced-hook.d.ts +30 -0
  42. package/dist/hooks/session-recovery/state-backup.d.ts +76 -0
  43. package/dist/hooks/shared/compaction-in-progress.d.ts +4 -0
  44. package/dist/hooks/start-work/git-operations.d.ts +47 -0
  45. package/dist/hooks/token-budget.d.ts +30 -0
  46. package/dist/index.js +1185 -1078
  47. package/dist/mcp/rate-limiter.d.ts +68 -0
  48. package/dist/plugin/chat-message.d.ts +8 -0
  49. package/dist/plugin/command-execute-before.d.ts +1 -1
  50. package/dist/plugin/event-handlers/message-updated.d.ts +2 -0
  51. package/dist/plugin/event-handlers/session-error.d.ts +2 -0
  52. package/dist/plugin/event-handlers/session-status.d.ts +2 -0
  53. package/dist/plugin/event-handlers/types.d.ts +62 -0
  54. package/dist/plugin/event-handlers/utils.d.ts +11 -0
  55. package/dist/plugin/event.d.ts +1 -1
  56. package/dist/shared/data-path.d.ts +1 -1
  57. package/dist/shared/errors.d.ts +70 -0
  58. package/dist/shared/extract-session-id.d.ts +8 -0
  59. package/dist/shared/git-worktree/get-git-state-summary.d.ts +14 -0
  60. package/dist/shared/index.d.ts +67 -68
  61. package/dist/shared/internal-initiator-marker.d.ts +1 -1
  62. package/dist/shared/logger.d.ts +5 -1
  63. package/dist/shared/reasoning-content-cache.d.ts +68 -0
  64. package/dist/shared/safe-create-hook.d.ts +4 -4
  65. package/dist/tools/call-hiai-agent/constants.d.ts +2 -2
  66. package/dist/tools/delegate-task/sub-agent.d.ts +1 -1
  67. package/dist/tools/look-at/constants.d.ts +1 -1
  68. package/docs/architecture/bob-manager-architecture.md +244 -0
  69. package/docs/hiai-opencode/adr/ADR-001-agent-identity-section-injection.md +66 -0
  70. package/docs/hiai-opencode/adr/ADR-002-anti-loop-guard-priority.md +63 -0
  71. package/docs/hiai-opencode/adr/ADR-003-compaction-mechanism.md +71 -0
  72. package/docs/hiai-opencode/adr/ADR-004-session-recovery.md +76 -0
  73. package/docs/hiai-opencode/api.md +305 -0
  74. package/docs/hiai-opencode/hooks-architecture.md +225 -0
  75. package/docs/hiai-opencode/migration.md +209 -0
  76. package/docs/skill-discovery.md +288 -0
  77. package/package.json +1 -1
  78. package/skills/agent-browser/SKILL.md +193 -0
  79. package/skills/apple-hig/SKILL.md +43 -0
  80. package/skills/article-magazine/SKILL.md +46 -0
  81. package/skills/article-magazine/example.html +81 -0
  82. package/skills/article-magazine/example.md +38 -0
  83. package/skills/canvas-design/SKILL.md +45 -0
  84. package/skills/design-templates/audio-jingle/SKILL.md +132 -0
  85. package/skills/design-templates/audio-jingle/example.html +128 -0
  86. package/skills/design-templates/blog-post/SKILL.md +80 -0
  87. package/skills/design-templates/blog-post/example.html +80 -0
  88. package/skills/design-templates/clinical-case-report/SKILL.md +209 -0
  89. package/skills/design-templates/clinical-case-report/example.html +698 -0
  90. package/skills/design-templates/clinical-case-report/examples/example-stemi.html +698 -0
  91. package/skills/design-templates/clinical-case-report/references/case-formats.md +94 -0
  92. package/skills/design-templates/clinical-case-report/references/checklist.md +41 -0
  93. package/skills/design-templates/critique/SKILL.md +258 -0
  94. package/skills/design-templates/critique/example.html +671 -0
  95. package/skills/design-templates/dashboard/SKILL.md +76 -0
  96. package/skills/design-templates/dashboard/example.html +118 -0
  97. package/skills/design-templates/dating-web/SKILL.md +92 -0
  98. package/skills/design-templates/dating-web/example.html +265 -0
  99. package/skills/design-templates/dcf-valuation/SKILL.md +140 -0
  100. package/skills/design-templates/dcf-valuation/references/sector-wacc.md +42 -0
  101. package/skills/design-templates/digital-eguide/SKILL.md +94 -0
  102. package/skills/design-templates/digital-eguide/example.html +204 -0
  103. package/skills/design-templates/docs-page/SKILL.md +80 -0
  104. package/skills/design-templates/docs-page/example.html +122 -0
  105. package/skills/design-templates/email-marketing/SKILL.md +84 -0
  106. package/skills/design-templates/email-marketing/example.html +159 -0
  107. package/skills/design-templates/eng-runbook/SKILL.md +51 -0
  108. package/skills/design-templates/eng-runbook/example.html +250 -0
  109. package/skills/design-templates/finance-report/SKILL.md +61 -0
  110. package/skills/design-templates/finance-report/example.html +242 -0
  111. package/skills/design-templates/flowai-live-dashboard-template/SKILL.md +87 -0
  112. package/skills/design-templates/flowai-live-dashboard-template/assets/template.html +387 -0
  113. package/skills/design-templates/flowai-live-dashboard-template/example.html +13 -0
  114. package/skills/design-templates/flowai-live-dashboard-template/references/checklist.md +35 -0
  115. package/skills/design-templates/gamified-app/SKILL.md +108 -0
  116. package/skills/design-templates/gamified-app/example.html +292 -0
  117. package/skills/design-templates/github-dashboard/SKILL.md +130 -0
  118. package/skills/design-templates/github-dashboard/example.html +473 -0
  119. package/skills/design-templates/github-dashboard/references/README.md +10 -0
  120. package/skills/design-templates/github-dashboard/references/artifact-example.json +15 -0
  121. package/skills/design-templates/github-dashboard/references/example-data.json +138 -0
  122. package/skills/design-templates/github-dashboard/references/provenance-example.json +92 -0
  123. package/skills/design-templates/github-dashboard/references/template.html +473 -0
  124. package/skills/design-templates/guizang-ppt/LICENSE +21 -0
  125. package/skills/design-templates/guizang-ppt/README.en.md +119 -0
  126. package/skills/design-templates/guizang-ppt/README.md +120 -0
  127. package/skills/design-templates/guizang-ppt/README.pt-BR.md +121 -0
  128. package/skills/design-templates/guizang-ppt/SKILL.md +313 -0
  129. package/skills/design-templates/guizang-ppt/assets/example-slides.html +318 -0
  130. package/skills/design-templates/guizang-ppt/assets/template.html +647 -0
  131. package/skills/design-templates/guizang-ppt/references/checklist.md +265 -0
  132. package/skills/design-templates/guizang-ppt/references/components.md +363 -0
  133. package/skills/design-templates/guizang-ppt/references/layouts.md +630 -0
  134. package/skills/design-templates/guizang-ppt/references/styles.md +195 -0
  135. package/skills/design-templates/guizang-ppt/references/themes.md +122 -0
  136. package/skills/design-templates/hr-onboarding/SKILL.md +52 -0
  137. package/skills/design-templates/hr-onboarding/example.html +219 -0
  138. package/skills/design-templates/html-ppt/.clawscan-allow +12 -0
  139. package/skills/design-templates/html-ppt/LICENSE +21 -0
  140. package/skills/design-templates/html-ppt/README.md +234 -0
  141. package/skills/design-templates/html-ppt/README.pt-BR.md +239 -0
  142. package/skills/design-templates/html-ppt/README.zh-CN.md +238 -0
  143. package/skills/design-templates/html-ppt/SKILL.md +250 -0
  144. package/skills/design-templates/html-ppt/assets/animations/animations.css +138 -0
  145. package/skills/design-templates/html-ppt/assets/animations/fx/_util.js +63 -0
  146. package/skills/design-templates/html-ppt/assets/animations/fx/chain-react.js +41 -0
  147. package/skills/design-templates/html-ppt/assets/animations/fx/confetti-cannon.js +49 -0
  148. package/skills/design-templates/html-ppt/assets/animations/fx/constellation.js +44 -0
  149. package/skills/design-templates/html-ppt/assets/animations/fx/counter-explosion.js +58 -0
  150. package/skills/design-templates/html-ppt/assets/animations/fx/data-stream.js +45 -0
  151. package/skills/design-templates/html-ppt/assets/animations/fx/firework.js +51 -0
  152. package/skills/design-templates/html-ppt/assets/animations/fx/galaxy-swirl.js +33 -0
  153. package/skills/design-templates/html-ppt/assets/animations/fx/gradient-blob.js +39 -0
  154. package/skills/design-templates/html-ppt/assets/animations/fx/knowledge-graph.js +69 -0
  155. package/skills/design-templates/html-ppt/assets/animations/fx/letter-explode.js +50 -0
  156. package/skills/design-templates/html-ppt/assets/animations/fx/magnetic-field.js +40 -0
  157. package/skills/design-templates/html-ppt/assets/animations/fx/matrix-rain.js +33 -0
  158. package/skills/design-templates/html-ppt/assets/animations/fx/neural-net.js +75 -0
  159. package/skills/design-templates/html-ppt/assets/animations/fx/orbit-ring.js +38 -0
  160. package/skills/design-templates/html-ppt/assets/animations/fx/particle-burst.js +42 -0
  161. package/skills/design-templates/html-ppt/assets/animations/fx/shockwave.js +39 -0
  162. package/skills/design-templates/html-ppt/assets/animations/fx/sparkle-trail.js +62 -0
  163. package/skills/design-templates/html-ppt/assets/animations/fx/starfield.js +30 -0
  164. package/skills/design-templates/html-ppt/assets/animations/fx/typewriter-multi.js +51 -0
  165. package/skills/design-templates/html-ppt/assets/animations/fx/word-cascade.js +47 -0
  166. package/skills/design-templates/html-ppt/assets/animations/fx-runtime.js +99 -0
  167. package/skills/design-templates/html-ppt/assets/base.css +150 -0
  168. package/skills/design-templates/html-ppt/assets/fonts.css +9 -0
  169. package/skills/design-templates/html-ppt/assets/runtime.js +960 -0
  170. package/skills/design-templates/html-ppt/assets/themes/academic-paper.css +23 -0
  171. package/skills/design-templates/html-ppt/assets/themes/arctic-cool.css +14 -0
  172. package/skills/design-templates/html-ppt/assets/themes/aurora.css +20 -0
  173. package/skills/design-templates/html-ppt/assets/themes/bauhaus.css +16 -0
  174. package/skills/design-templates/html-ppt/assets/themes/blueprint.css +19 -0
  175. package/skills/design-templates/html-ppt/assets/themes/catppuccin-latte.css +14 -0
  176. package/skills/design-templates/html-ppt/assets/themes/catppuccin-mocha.css +14 -0
  177. package/skills/design-templates/html-ppt/assets/themes/corporate-clean.css +19 -0
  178. package/skills/design-templates/html-ppt/assets/themes/cyberpunk-neon.css +23 -0
  179. package/skills/design-templates/html-ppt/assets/themes/dracula.css +14 -0
  180. package/skills/design-templates/html-ppt/assets/themes/editorial-serif.css +18 -0
  181. package/skills/design-templates/html-ppt/assets/themes/engineering-whiteprint.css +26 -0
  182. package/skills/design-templates/html-ppt/assets/themes/glassmorphism.css +21 -0
  183. package/skills/design-templates/html-ppt/assets/themes/gruvbox-dark.css +14 -0
  184. package/skills/design-templates/html-ppt/assets/themes/japanese-minimal.css +21 -0
  185. package/skills/design-templates/html-ppt/assets/themes/magazine-bold.css +21 -0
  186. package/skills/design-templates/html-ppt/assets/themes/memphis-pop.css +20 -0
  187. package/skills/design-templates/html-ppt/assets/themes/midcentury.css +19 -0
  188. package/skills/design-templates/html-ppt/assets/themes/minimal-white.css +16 -0
  189. package/skills/design-templates/html-ppt/assets/themes/neo-brutalism.css +17 -0
  190. package/skills/design-templates/html-ppt/assets/themes/news-broadcast.css +20 -0
  191. package/skills/design-templates/html-ppt/assets/themes/nord.css +14 -0
  192. package/skills/design-templates/html-ppt/assets/themes/pitch-deck-vc.css +21 -0
  193. package/skills/design-templates/html-ppt/assets/themes/rainbow-gradient.css +16 -0
  194. package/skills/design-templates/html-ppt/assets/themes/retro-tv.css +22 -0
  195. package/skills/design-templates/html-ppt/assets/themes/rose-pine.css +14 -0
  196. package/skills/design-templates/html-ppt/assets/themes/sharp-mono.css +17 -0
  197. package/skills/design-templates/html-ppt/assets/themes/soft-pastel.css +14 -0
  198. package/skills/design-templates/html-ppt/assets/themes/solarized-light.css +14 -0
  199. package/skills/design-templates/html-ppt/assets/themes/sunset-warm.css +14 -0
  200. package/skills/design-templates/html-ppt/assets/themes/swiss-grid.css +17 -0
  201. package/skills/design-templates/html-ppt/assets/themes/terminal-green.css +18 -0
  202. package/skills/design-templates/html-ppt/assets/themes/tokyo-night.css +14 -0
  203. package/skills/design-templates/html-ppt/assets/themes/vaporwave.css +21 -0
  204. package/skills/design-templates/html-ppt/assets/themes/xiaohongshu-white.css +16 -0
  205. package/skills/design-templates/html-ppt/assets/themes/y2k-chrome.css +20 -0
  206. package/skills/design-templates/html-ppt/docs/readme/_theme-cell.html +56 -0
  207. package/skills/design-templates/html-ppt/docs/readme/animations.png +0 -0
  208. package/skills/design-templates/html-ppt/docs/readme/hero.gif +0 -0
  209. package/skills/design-templates/html-ppt/docs/readme/layouts-live.gif +0 -0
  210. package/skills/design-templates/html-ppt/docs/readme/layouts.png +0 -0
  211. package/skills/design-templates/html-ppt/docs/readme/montage-animations.html +61 -0
  212. package/skills/design-templates/html-ppt/docs/readme/montage-layouts.html +72 -0
  213. package/skills/design-templates/html-ppt/docs/readme/montage-templates.html +72 -0
  214. package/skills/design-templates/html-ppt/docs/readme/montage-themes.html +38 -0
  215. package/skills/design-templates/html-ppt/docs/readme/presenter-mode.png +0 -0
  216. package/skills/design-templates/html-ppt/docs/readme/templates.png +0 -0
  217. package/skills/design-templates/html-ppt/docs/readme/themes.png +0 -0
  218. package/skills/design-templates/html-ppt/examples/demo-deck/index.html +161 -0
  219. package/skills/design-templates/html-ppt/references/animations.md +147 -0
  220. package/skills/design-templates/html-ppt/references/authoring-guide.md +141 -0
  221. package/skills/design-templates/html-ppt/references/full-decks.md +98 -0
  222. package/skills/design-templates/html-ppt/references/layouts.md +103 -0
  223. package/skills/design-templates/html-ppt/references/presenter-mode.md +240 -0
  224. package/skills/design-templates/html-ppt/references/themes.md +107 -0
  225. package/skills/design-templates/html-ppt/scripts/new-deck.sh +46 -0
  226. package/skills/design-templates/html-ppt/scripts/render.sh +71 -0
  227. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_01.png +0 -0
  228. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_02.png +0 -0
  229. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_03.png +0 -0
  230. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_04.png +0 -0
  231. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_05.png +0 -0
  232. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_06.png +0 -0
  233. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_07.png +0 -0
  234. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_08.png +0 -0
  235. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_09.png +0 -0
  236. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_10.png +0 -0
  237. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_11.png +0 -0
  238. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_12.png +0 -0
  239. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_13.png +0 -0
  240. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_14.png +0 -0
  241. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_15.png +0 -0
  242. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_16.png +0 -0
  243. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_17.png +0 -0
  244. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_18.png +0 -0
  245. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_19.png +0 -0
  246. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_20.png +0 -0
  247. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_01.png +0 -0
  248. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_02.png +0 -0
  249. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_03.png +0 -0
  250. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_04.png +0 -0
  251. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_05.png +0 -0
  252. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_06.png +0 -0
  253. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_07.png +0 -0
  254. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_08.png +0 -0
  255. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_09.png +0 -0
  256. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_10.png +0 -0
  257. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_11.png +0 -0
  258. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_12.png +0 -0
  259. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_13.png +0 -0
  260. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_14.png +0 -0
  261. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_15.png +0 -0
  262. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_16.png +0 -0
  263. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_17.png +0 -0
  264. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_18.png +0 -0
  265. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_19.png +0 -0
  266. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_20.png +0 -0
  267. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_21.png +0 -0
  268. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_22.png +0 -0
  269. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_23.png +0 -0
  270. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_24.png +0 -0
  271. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_25.png +0 -0
  272. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_26.png +0 -0
  273. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_27.png +0 -0
  274. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_28.png +0 -0
  275. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_29.png +0 -0
  276. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_30.png +0 -0
  277. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_31.png +0 -0
  278. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_32.png +0 -0
  279. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_33.png +0 -0
  280. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_34.png +0 -0
  281. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_35.png +0 -0
  282. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_36.png +0 -0
  283. package/skills/design-templates/html-ppt/templates/animation-showcase.html +172 -0
  284. package/skills/design-templates/html-ppt/templates/deck.html +69 -0
  285. package/skills/design-templates/html-ppt/templates/full-decks/course-module/README.md +8 -0
  286. package/skills/design-templates/html-ppt/templates/full-decks/course-module/index.html +189 -0
  287. package/skills/design-templates/html-ppt/templates/full-decks/course-module/style.css +46 -0
  288. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/README.md +11 -0
  289. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/index.html +138 -0
  290. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/style.css +60 -0
  291. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/README.md +11 -0
  292. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/index.html +180 -0
  293. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/style.css +54 -0
  294. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/README.md +11 -0
  295. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/index.html +199 -0
  296. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/style.css +55 -0
  297. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/README.md +11 -0
  298. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/index.html +190 -0
  299. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/style.css +49 -0
  300. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/README.md +11 -0
  301. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/index.html +144 -0
  302. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/style.css +59 -0
  303. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/README.md +9 -0
  304. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/index.html +148 -0
  305. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/style.css +40 -0
  306. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/README.md +102 -0
  307. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/index.html +187 -0
  308. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/style.css +216 -0
  309. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/README.md +8 -0
  310. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/index.html +121 -0
  311. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/style.css +39 -0
  312. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/README.md +8 -0
  313. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/index.html +156 -0
  314. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/style.css +49 -0
  315. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/README.md +11 -0
  316. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/index.html +183 -0
  317. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/style.css +62 -0
  318. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/README.md +8 -0
  319. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/index.html +127 -0
  320. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/style.css +55 -0
  321. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/README.md +11 -0
  322. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/index.html +147 -0
  323. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/style.css +66 -0
  324. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/README.md +9 -0
  325. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/index.html +133 -0
  326. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/style.css +47 -0
  327. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/README.md +11 -0
  328. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/index.html +187 -0
  329. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/style.css +63 -0
  330. package/skills/design-templates/html-ppt/templates/full-decks-index.html +82 -0
  331. package/skills/design-templates/html-ppt/templates/layout-showcase.html +47 -0
  332. package/skills/design-templates/html-ppt/templates/single-page/arch-diagram.html +46 -0
  333. package/skills/design-templates/html-ppt/templates/single-page/big-quote.html +18 -0
  334. package/skills/design-templates/html-ppt/templates/single-page/bullets.html +19 -0
  335. package/skills/design-templates/html-ppt/templates/single-page/chart-bar.html +30 -0
  336. package/skills/design-templates/html-ppt/templates/single-page/chart-line.html +35 -0
  337. package/skills/design-templates/html-ppt/templates/single-page/chart-pie.html +36 -0
  338. package/skills/design-templates/html-ppt/templates/single-page/chart-radar.html +31 -0
  339. package/skills/design-templates/html-ppt/templates/single-page/code.html +33 -0
  340. package/skills/design-templates/html-ppt/templates/single-page/comparison.html +47 -0
  341. package/skills/design-templates/html-ppt/templates/single-page/cover.html +32 -0
  342. package/skills/design-templates/html-ppt/templates/single-page/cta.html +27 -0
  343. package/skills/design-templates/html-ppt/templates/single-page/diff.html +35 -0
  344. package/skills/design-templates/html-ppt/templates/single-page/flow-diagram.html +33 -0
  345. package/skills/design-templates/html-ppt/templates/single-page/gantt.html +29 -0
  346. package/skills/design-templates/html-ppt/templates/single-page/image-grid.html +34 -0
  347. package/skills/design-templates/html-ppt/templates/single-page/image-hero.html +33 -0
  348. package/skills/design-templates/html-ppt/templates/single-page/kpi-grid.html +19 -0
  349. package/skills/design-templates/html-ppt/templates/single-page/mindmap.html +38 -0
  350. package/skills/design-templates/html-ppt/templates/single-page/process-steps.html +27 -0
  351. package/skills/design-templates/html-ppt/templates/single-page/pros-cons.html +31 -0
  352. package/skills/design-templates/html-ppt/templates/single-page/roadmap.html +46 -0
  353. package/skills/design-templates/html-ppt/templates/single-page/section-divider.html +17 -0
  354. package/skills/design-templates/html-ppt/templates/single-page/stat-highlight.html +17 -0
  355. package/skills/design-templates/html-ppt/templates/single-page/table.html +33 -0
  356. package/skills/design-templates/html-ppt/templates/single-page/terminal.html +35 -0
  357. package/skills/design-templates/html-ppt/templates/single-page/thanks.html +21 -0
  358. package/skills/design-templates/html-ppt/templates/single-page/three-column.html +18 -0
  359. package/skills/design-templates/html-ppt/templates/single-page/timeline.html +32 -0
  360. package/skills/design-templates/html-ppt/templates/single-page/toc.html +26 -0
  361. package/skills/design-templates/html-ppt/templates/single-page/todo-checklist.html +33 -0
  362. package/skills/design-templates/html-ppt/templates/single-page/two-column.html +39 -0
  363. package/skills/design-templates/html-ppt/templates/theme-showcase.html +151 -0
  364. package/skills/design-templates/html-ppt-course-module/SKILL.md +78 -0
  365. package/skills/design-templates/html-ppt-course-module/example.html +542 -0
  366. package/skills/design-templates/html-ppt-dir-key-nav-minimal/SKILL.md +77 -0
  367. package/skills/design-templates/html-ppt-dir-key-nav-minimal/example.html +366 -0
  368. package/skills/design-templates/html-ppt-graphify-dark-graph/SKILL.md +77 -0
  369. package/skills/design-templates/html-ppt-graphify-dark-graph/example.html +402 -0
  370. package/skills/design-templates/html-ppt-hermes-cyber-terminal/SKILL.md +77 -0
  371. package/skills/design-templates/html-ppt-hermes-cyber-terminal/example.html +422 -0
  372. package/skills/design-templates/html-ppt-knowledge-arch-blueprint/SKILL.md +77 -0
  373. package/skills/design-templates/html-ppt-knowledge-arch-blueprint/example.html +407 -0
  374. package/skills/design-templates/html-ppt-obsidian-claude-gradient/SKILL.md +77 -0
  375. package/skills/design-templates/html-ppt-obsidian-claude-gradient/example.html +371 -0
  376. package/skills/design-templates/html-ppt-pitch-deck/SKILL.md +78 -0
  377. package/skills/design-templates/html-ppt-pitch-deck/example.html +495 -0
  378. package/skills/design-templates/html-ppt-presenter-mode-reveal/SKILL.md +78 -0
  379. package/skills/design-templates/html-ppt-presenter-mode-reveal/example.html +725 -0
  380. package/skills/design-templates/html-ppt-product-launch/SKILL.md +77 -0
  381. package/skills/design-templates/html-ppt-product-launch/example.html +467 -0
  382. package/skills/design-templates/html-ppt-taste-brutalist/SKILL.md +70 -0
  383. package/skills/design-templates/html-ppt-taste-brutalist/example.html +774 -0
  384. package/skills/design-templates/html-ppt-taste-editorial/SKILL.md +62 -0
  385. package/skills/design-templates/html-ppt-taste-editorial/example.html +689 -0
  386. package/skills/design-templates/html-ppt-tech-sharing/SKILL.md +77 -0
  387. package/skills/design-templates/html-ppt-tech-sharing/example.html +512 -0
  388. package/skills/design-templates/html-ppt-testing-safety-alert/SKILL.md +78 -0
  389. package/skills/design-templates/html-ppt-testing-safety-alert/example.html +413 -0
  390. package/skills/design-templates/html-ppt-weekly-report/SKILL.md +77 -0
  391. package/skills/design-templates/html-ppt-weekly-report/example.html +489 -0
  392. package/skills/design-templates/html-ppt-xhs-pastel-card/SKILL.md +78 -0
  393. package/skills/design-templates/html-ppt-xhs-pastel-card/example.html +381 -0
  394. package/skills/design-templates/html-ppt-xhs-post/SKILL.md +78 -0
  395. package/skills/design-templates/html-ppt-xhs-post/example.html +487 -0
  396. package/skills/design-templates/html-ppt-xhs-white-editorial/SKILL.md +77 -0
  397. package/skills/design-templates/html-ppt-xhs-white-editorial/example.html +418 -0
  398. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/LICENSE +21 -0
  399. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/SKILL.md +93 -0
  400. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/example.html +1640 -0
  401. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/template.json +48 -0
  402. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/LICENSE +21 -0
  403. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/SKILL.md +93 -0
  404. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/example.html +833 -0
  405. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/template.json +49 -0
  406. package/skills/design-templates/html-ppt-zhangzara-block-frame/LICENSE +21 -0
  407. package/skills/design-templates/html-ppt-zhangzara-block-frame/SKILL.md +93 -0
  408. package/skills/design-templates/html-ppt-zhangzara-block-frame/example.html +1453 -0
  409. package/skills/design-templates/html-ppt-zhangzara-block-frame/template.json +47 -0
  410. package/skills/design-templates/html-ppt-zhangzara-blue-professional/LICENSE +21 -0
  411. package/skills/design-templates/html-ppt-zhangzara-blue-professional/SKILL.md +93 -0
  412. package/skills/design-templates/html-ppt-zhangzara-blue-professional/example.html +1423 -0
  413. package/skills/design-templates/html-ppt-zhangzara-blue-professional/template.json +44 -0
  414. package/skills/design-templates/html-ppt-zhangzara-bold-poster/LICENSE +21 -0
  415. package/skills/design-templates/html-ppt-zhangzara-bold-poster/SKILL.md +93 -0
  416. package/skills/design-templates/html-ppt-zhangzara-bold-poster/example.html +876 -0
  417. package/skills/design-templates/html-ppt-zhangzara-bold-poster/template.json +45 -0
  418. package/skills/design-templates/html-ppt-zhangzara-broadside/LICENSE +21 -0
  419. package/skills/design-templates/html-ppt-zhangzara-broadside/SKILL.md +92 -0
  420. package/skills/design-templates/html-ppt-zhangzara-broadside/example.html +2144 -0
  421. package/skills/design-templates/html-ppt-zhangzara-broadside/template.json +49 -0
  422. package/skills/design-templates/html-ppt-zhangzara-capsule/LICENSE +21 -0
  423. package/skills/design-templates/html-ppt-zhangzara-capsule/SKILL.md +92 -0
  424. package/skills/design-templates/html-ppt-zhangzara-capsule/example.html +1413 -0
  425. package/skills/design-templates/html-ppt-zhangzara-capsule/template.json +51 -0
  426. package/skills/design-templates/html-ppt-zhangzara-cartesian/LICENSE +21 -0
  427. package/skills/design-templates/html-ppt-zhangzara-cartesian/SKILL.md +92 -0
  428. package/skills/design-templates/html-ppt-zhangzara-cartesian/example.html +1136 -0
  429. package/skills/design-templates/html-ppt-zhangzara-cartesian/template.json +47 -0
  430. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/LICENSE +21 -0
  431. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/SKILL.md +93 -0
  432. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/example.html +1205 -0
  433. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/template.json +49 -0
  434. package/skills/design-templates/html-ppt-zhangzara-coral/LICENSE +21 -0
  435. package/skills/design-templates/html-ppt-zhangzara-coral/SKILL.md +92 -0
  436. package/skills/design-templates/html-ppt-zhangzara-coral/example.html +1487 -0
  437. package/skills/design-templates/html-ppt-zhangzara-coral/template.json +45 -0
  438. package/skills/design-templates/html-ppt-zhangzara-creative-mode/LICENSE +21 -0
  439. package/skills/design-templates/html-ppt-zhangzara-creative-mode/SKILL.md +99 -0
  440. package/skills/design-templates/html-ppt-zhangzara-creative-mode/assets/deck-stage.js +619 -0
  441. package/skills/design-templates/html-ppt-zhangzara-creative-mode/example.html +636 -0
  442. package/skills/design-templates/html-ppt-zhangzara-creative-mode/template.json +47 -0
  443. package/skills/design-templates/html-ppt-zhangzara-daisy-days/LICENSE +21 -0
  444. package/skills/design-templates/html-ppt-zhangzara-daisy-days/SKILL.md +93 -0
  445. package/skills/design-templates/html-ppt-zhangzara-daisy-days/example.html +469 -0
  446. package/skills/design-templates/html-ppt-zhangzara-daisy-days/template.json +54 -0
  447. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/LICENSE +21 -0
  448. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/SKILL.md +98 -0
  449. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/assets/deck-stage.js +619 -0
  450. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/example.html +737 -0
  451. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/template.json +44 -0
  452. package/skills/design-templates/html-ppt-zhangzara-grove/LICENSE +21 -0
  453. package/skills/design-templates/html-ppt-zhangzara-grove/SKILL.md +92 -0
  454. package/skills/design-templates/html-ppt-zhangzara-grove/example.html +1676 -0
  455. package/skills/design-templates/html-ppt-zhangzara-grove/template.json +51 -0
  456. package/skills/figma-code-connect-components/SKILL.md +42 -0
  457. package/skills/figma-create-design-system-rules/SKILL.md +42 -0
  458. package/skills/figma-create-new-file/SKILL.md +41 -0
  459. package/skills/figma-generate-design/SKILL.md +42 -0
  460. package/skills/figma-generate-library/SKILL.md +42 -0
  461. package/skills/figma-implement-design/SKILL.md +42 -0
  462. package/skills/figma-use/SKILL.md +42 -0
  463. package/skills/full-page-screenshot/SKILL.md +42 -0
  464. package/skills/interview-me/SKILL.md +64 -0
  465. package/skills/planning-and-task-breakdown/SKILL.md +52 -0
  466. package/skills/sora/SKILL.md +43 -0
  467. package/skills/theme-factory/SKILL.md +43 -0
  468. package/skills/web-design-guidelines/SKILL.md +42 -0
  469. package/dist/agents/prompt-library/orchestration.d.ts +0 -4
  470. package/skills/brainstorming/SKILL.md +0 -164
  471. package/skills/brainstorming/scripts/frame-template.html +0 -214
  472. package/skills/brainstorming/scripts/helper.js +0 -88
  473. package/skills/brainstorming/scripts/server.cjs +0 -354
  474. package/skills/brainstorming/scripts/start-server.sh +0 -148
  475. package/skills/brainstorming/scripts/stop-server.sh +0 -56
  476. package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -49
  477. package/skills/brainstorming/visual-companion.md +0 -287
@@ -0,0 +1,671 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="utf-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
6
+ <title>Critique · magazine-web-ppt example deck</title>
7
+ <link rel="preconnect" href="https://fonts.googleapis.com">
8
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
9
+ <link href="https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600;8..60,700&family=IBM+Plex+Mono:wght@400;500;600&family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
10
+ <style>
11
+ :root {
12
+ --bg: #f5f3ee;
13
+ --paper: #ffffff;
14
+ --ink: #1a1a1c;
15
+ --muted: #6b6964;
16
+ --rule: #e2dfd7;
17
+ --accent: #c96442;
18
+ --good: #4a7a3f;
19
+ --warn: #c96442;
20
+ --bad: #a83a2a;
21
+
22
+ --serif: 'Source Serif 4', Georgia, serif;
23
+ --sans: 'Inter', -apple-system, system-ui, sans-serif;
24
+ --mono: 'IBM Plex Mono', ui-monospace, monospace;
25
+ }
26
+ * { box-sizing: border-box; }
27
+ html, body { margin: 0; padding: 0; }
28
+ body {
29
+ background: var(--bg);
30
+ color: var(--ink);
31
+ font-family: var(--sans);
32
+ font-size: 16px;
33
+ line-height: 1.55;
34
+ -webkit-font-smoothing: antialiased;
35
+ }
36
+ a { color: var(--accent); }
37
+
38
+ .wrap {
39
+ max-width: 1080px;
40
+ margin: 0 auto;
41
+ padding: 56px 40px 96px;
42
+ }
43
+
44
+ /* ============ Header ============ */
45
+ .hd {
46
+ display: flex;
47
+ justify-content: space-between;
48
+ align-items: flex-end;
49
+ gap: 40px;
50
+ padding-bottom: 28px;
51
+ border-bottom: 1px solid var(--rule);
52
+ margin-bottom: 40px;
53
+ }
54
+ .hd-title {
55
+ font-family: var(--serif);
56
+ font-weight: 700;
57
+ font-size: clamp(34px, 4.4vw, 56px);
58
+ line-height: 1.05;
59
+ letter-spacing: -0.015em;
60
+ margin: 0 0 10px;
61
+ }
62
+ .hd-meta {
63
+ font-family: var(--mono);
64
+ font-size: 11px;
65
+ letter-spacing: 0.18em;
66
+ text-transform: uppercase;
67
+ color: var(--muted);
68
+ display: flex;
69
+ gap: 16px;
70
+ flex-wrap: wrap;
71
+ }
72
+ .hd-verdict {
73
+ font-family: var(--serif);
74
+ font-style: italic;
75
+ font-size: 18px;
76
+ line-height: 1.45;
77
+ color: var(--muted);
78
+ max-width: 36ch;
79
+ text-align: right;
80
+ }
81
+ .hd-verdict strong { color: var(--ink); font-style: normal; font-weight: 600; }
82
+
83
+ /* ============ Top row: radar + score table ============ */
84
+ .top {
85
+ display: grid;
86
+ grid-template-columns: 360px 1fr;
87
+ gap: 48px;
88
+ margin-bottom: 64px;
89
+ align-items: center;
90
+ }
91
+ @media (max-width: 800px) {
92
+ .top { grid-template-columns: 1fr; }
93
+ }
94
+ .radar-card {
95
+ background: var(--paper);
96
+ border: 1px solid var(--rule);
97
+ border-radius: 6px;
98
+ padding: 24px;
99
+ text-align: center;
100
+ }
101
+ .radar-card .lbl {
102
+ font-family: var(--mono);
103
+ font-size: 10px;
104
+ letter-spacing: 0.24em;
105
+ text-transform: uppercase;
106
+ color: var(--muted);
107
+ margin-bottom: 14px;
108
+ }
109
+ .radar-card svg { width: 100%; height: auto; max-width: 300px; }
110
+ .radar-card .overall {
111
+ font-family: var(--serif);
112
+ font-size: 13px;
113
+ color: var(--muted);
114
+ margin-top: 18px;
115
+ }
116
+ .radar-card .overall .n {
117
+ font-weight: 700;
118
+ font-size: 20px;
119
+ color: var(--ink);
120
+ letter-spacing: -0.01em;
121
+ }
122
+
123
+ /* Score table */
124
+ .scores { display: flex; flex-direction: column; gap: 14px; }
125
+ .score-row {
126
+ display: grid;
127
+ grid-template-columns: 22ch 1fr 6ch 14ch;
128
+ gap: 16px;
129
+ align-items: center;
130
+ padding: 14px 0;
131
+ border-top: 1px solid var(--rule);
132
+ }
133
+ .score-row:first-child { border-top: 0; }
134
+ .score-name {
135
+ font-family: var(--serif);
136
+ font-weight: 600;
137
+ font-size: 17px;
138
+ }
139
+ .score-name .en {
140
+ display: block;
141
+ font-family: var(--mono);
142
+ font-size: 10px;
143
+ letter-spacing: 0.22em;
144
+ text-transform: uppercase;
145
+ color: var(--muted);
146
+ font-weight: 400;
147
+ margin-top: 2px;
148
+ }
149
+ .score-bar {
150
+ position: relative;
151
+ height: 4px;
152
+ background: var(--rule);
153
+ border-radius: 2px;
154
+ overflow: hidden;
155
+ }
156
+ .score-bar-fill {
157
+ position: absolute;
158
+ inset: 0 auto 0 0;
159
+ background: var(--ink);
160
+ }
161
+ .score-num {
162
+ font-family: var(--serif);
163
+ font-weight: 700;
164
+ font-size: 24px;
165
+ letter-spacing: -0.02em;
166
+ text-align: right;
167
+ }
168
+ .score-num .denom {
169
+ font-size: 13px;
170
+ color: var(--muted);
171
+ font-weight: 400;
172
+ }
173
+ .score-band {
174
+ font-family: var(--mono);
175
+ font-size: 10px;
176
+ letter-spacing: 0.22em;
177
+ text-transform: uppercase;
178
+ color: var(--muted);
179
+ text-align: right;
180
+ }
181
+ .band-broken { color: var(--bad); }
182
+ .band-functional { color: var(--muted); }
183
+ .band-strong { color: var(--good); }
184
+ .band-exceptional { color: var(--accent); }
185
+
186
+ /* ============ Dimension cards ============ */
187
+ .section-title {
188
+ font-family: var(--serif);
189
+ font-weight: 600;
190
+ font-size: 22px;
191
+ letter-spacing: -0.005em;
192
+ margin: 64px 0 20px;
193
+ padding-bottom: 12px;
194
+ border-bottom: 1px solid var(--rule);
195
+ }
196
+ .section-title .en {
197
+ font-family: var(--mono);
198
+ font-size: 11px;
199
+ letter-spacing: 0.22em;
200
+ text-transform: uppercase;
201
+ color: var(--muted);
202
+ font-weight: 400;
203
+ margin-left: 10px;
204
+ }
205
+ .dim-grid {
206
+ display: grid;
207
+ grid-template-columns: 1fr 1fr;
208
+ gap: 24px;
209
+ }
210
+ @media (max-width: 800px) {
211
+ .dim-grid { grid-template-columns: 1fr; }
212
+ }
213
+ .dim {
214
+ background: var(--paper);
215
+ border: 1px solid var(--rule);
216
+ border-radius: 6px;
217
+ padding: 22px 24px;
218
+ }
219
+ .dim-head {
220
+ display: flex;
221
+ justify-content: space-between;
222
+ align-items: baseline;
223
+ margin-bottom: 8px;
224
+ }
225
+ .dim-name {
226
+ font-family: var(--serif);
227
+ font-weight: 600;
228
+ font-size: 19px;
229
+ }
230
+ .dim-name .en {
231
+ display: block;
232
+ font-family: var(--mono);
233
+ font-size: 10px;
234
+ letter-spacing: 0.22em;
235
+ text-transform: uppercase;
236
+ color: var(--muted);
237
+ font-weight: 400;
238
+ margin-top: 2px;
239
+ }
240
+ .dim-score {
241
+ font-family: var(--serif);
242
+ font-weight: 700;
243
+ font-size: 26px;
244
+ letter-spacing: -0.02em;
245
+ }
246
+ .dim-score .denom {
247
+ font-size: 13px;
248
+ color: var(--muted);
249
+ font-weight: 400;
250
+ }
251
+ .dim-evidence {
252
+ font-family: var(--serif);
253
+ font-size: 14.5px;
254
+ line-height: 1.65;
255
+ color: #2d2d30;
256
+ margin: 10px 0 16px;
257
+ }
258
+ .dim-evidence code {
259
+ font-family: var(--mono);
260
+ font-size: 0.88em;
261
+ background: var(--rule);
262
+ padding: 1px 6px;
263
+ border-radius: 3px;
264
+ }
265
+ .dim-tags {
266
+ display: flex;
267
+ flex-direction: column;
268
+ gap: 8px;
269
+ }
270
+ .tag-row {
271
+ display: grid;
272
+ grid-template-columns: 70px 1fr;
273
+ gap: 12px;
274
+ font-size: 13.5px;
275
+ line-height: 1.55;
276
+ }
277
+ .tag {
278
+ font-family: var(--mono);
279
+ font-size: 10px;
280
+ letter-spacing: 0.22em;
281
+ text-transform: uppercase;
282
+ padding: 3px 8px;
283
+ border-radius: 3px;
284
+ color: var(--paper);
285
+ align-self: start;
286
+ text-align: center;
287
+ }
288
+ .tag-keep { background: var(--good); }
289
+ .tag-fix { background: var(--warn); }
290
+ .tag-qw { background: #2c4d6e; }
291
+
292
+ /* ============ Action lists ============ */
293
+ .lists-grid {
294
+ display: grid;
295
+ grid-template-columns: repeat(3, 1fr);
296
+ gap: 24px;
297
+ margin-top: 24px;
298
+ }
299
+ @media (max-width: 800px) {
300
+ .lists-grid { grid-template-columns: 1fr; }
301
+ }
302
+ .list-card {
303
+ background: var(--paper);
304
+ border: 1px solid var(--rule);
305
+ border-radius: 6px;
306
+ padding: 22px 24px;
307
+ }
308
+ .list-head {
309
+ font-family: var(--mono);
310
+ font-size: 10px;
311
+ letter-spacing: 0.26em;
312
+ text-transform: uppercase;
313
+ margin-bottom: 14px;
314
+ padding-bottom: 12px;
315
+ border-bottom: 1px solid var(--rule);
316
+ display: flex;
317
+ justify-content: space-between;
318
+ align-items: center;
319
+ }
320
+ .list-head.keep { color: var(--good); }
321
+ .list-head.fix { color: var(--warn); }
322
+ .list-head.qw { color: #2c4d6e; }
323
+ .list-head .ct {
324
+ font-size: 16px;
325
+ font-family: var(--serif);
326
+ letter-spacing: -0.01em;
327
+ color: var(--ink);
328
+ font-weight: 600;
329
+ }
330
+ .list-card ul {
331
+ list-style: none;
332
+ padding: 0;
333
+ margin: 0;
334
+ display: flex;
335
+ flex-direction: column;
336
+ gap: 12px;
337
+ }
338
+ .list-card li {
339
+ display: grid;
340
+ grid-template-columns: 18px 1fr;
341
+ gap: 10px;
342
+ font-family: var(--serif);
343
+ font-size: 14.5px;
344
+ line-height: 1.55;
345
+ }
346
+ .list-card li::before {
347
+ content: "";
348
+ width: 14px;
349
+ height: 14px;
350
+ border-radius: 3px;
351
+ border: 1.5px solid var(--rule);
352
+ margin-top: 4px;
353
+ }
354
+ .list-card li code {
355
+ font-family: var(--mono);
356
+ font-size: 0.85em;
357
+ background: var(--bg);
358
+ padding: 1px 6px;
359
+ border-radius: 3px;
360
+ }
361
+
362
+ /* ============ Footer ============ */
363
+ .ft {
364
+ margin-top: 80px;
365
+ padding-top: 24px;
366
+ border-top: 1px solid var(--rule);
367
+ display: flex;
368
+ justify-content: space-between;
369
+ align-items: baseline;
370
+ gap: 16px;
371
+ flex-wrap: wrap;
372
+ font-family: var(--mono);
373
+ font-size: 11px;
374
+ letter-spacing: 0.18em;
375
+ text-transform: uppercase;
376
+ color: var(--muted);
377
+ }
378
+ .ft .br { color: var(--ink); font-weight: 600; }
379
+ </style>
380
+ </head>
381
+ <body>
382
+ <div class="wrap">
383
+
384
+ <!-- ============ Header ============ -->
385
+ <header class="hd">
386
+ <div>
387
+ <div class="hd-meta">
388
+ <span>5-Dim Critique</span>
389
+ <span>·</span>
390
+ <span>2026.04.27</span>
391
+ <span>·</span>
392
+ <span>OD · Critique skill</span>
393
+ </div>
394
+ <h1 class="hd-title">magazine-web-ppt<br>example deck</h1>
395
+ </div>
396
+ <p class="hd-verdict">
397
+ <strong>7.4 / 10 overall.</strong> Strong philosophical
398
+ backbone and detail — the deck looks like one designer made
399
+ every slide. Innovation is conservative on purpose; functionality
400
+ loses points only because the example ships without real images.
401
+ </p>
402
+ </header>
403
+
404
+ <!-- ============ Radar + Score table ============ -->
405
+ <section class="top">
406
+ <div class="radar-card">
407
+ <div class="lbl">Score Radar</div>
408
+ <!-- Pentagon radar, 5 axes; score grid at 0/2.5/5/7.5/10 -->
409
+ <svg viewBox="0 0 300 300" xmlns="http://www.w3.org/2000/svg" aria-label="Score radar chart">
410
+ <defs>
411
+ <style>
412
+ .axis { stroke: #e2dfd7; stroke-width: 1; fill: none; }
413
+ .grid { stroke: #e8e5dd; stroke-width: 1; fill: none; }
414
+ .grid-mid { stroke: #e2dfd7; stroke-width: 1; fill: none; }
415
+ .area { fill: rgba(201,100,66,0.18); stroke: #c96442; stroke-width: 1.6; stroke-linejoin: round; }
416
+ .dot { fill: #c96442; }
417
+ .lbl { font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; fill: #6b6964; }
418
+ .lbl-n { font-family: 'Source Serif 4', serif; font-size: 12px; font-weight: 600; fill: #1a1a1c; }
419
+ </style>
420
+ </defs>
421
+ <!-- Center 150,150. Radius 110 = 10/10. -->
422
+ <!-- Grid rings 25/50/75/100% of 110 = 27.5 / 55 / 82.5 / 110 -->
423
+ <!-- Pentagon angles: -90, -18, 54, 126, 198 (deg) measured from center.
424
+ Order: top=Philosophy, top-right=Hierarchy, bottom-right=Detail,
425
+ bottom-left=Function, top-left=Innovation -->
426
+ <!-- Outer rings (5 sided) -->
427
+ <polygon class="grid" points="150,40 254.66,116.05 214.69,238.95 85.31,238.95 45.34,116.05" />
428
+ <polygon class="grid" points="150,67.5 228.47,124.54 198.51,216.71 101.49,216.71 71.53,124.54" />
429
+ <polygon class="grid-mid" points="150,95 202.33,133.02 182.34,194.48 117.66,194.48 97.67,133.02" />
430
+ <polygon class="grid" points="150,122.5 176.16,141.51 166.17,172.24 133.83,172.24 123.84,141.51" />
431
+ <!-- Axes -->
432
+ <line class="axis" x1="150" y1="150" x2="150" y2="40" />
433
+ <line class="axis" x1="150" y1="150" x2="254.66" y2="116.05" />
434
+ <line class="axis" x1="150" y1="150" x2="214.69" y2="238.95" />
435
+ <line class="axis" x1="150" y1="150" x2="85.31" y2="238.95" />
436
+ <line class="axis" x1="150" y1="150" x2="45.34" y2="116.05" />
437
+
438
+ <!-- Score area · Phil 8 / Hier 7 / Det 8 / Func 6 / Innov 5
439
+ Distances from center (radius 110):
440
+ Phil 8 → 88 : 150, 150 - 88 = 150, 62
441
+ Hier 7 → 77 : 150 + 77*sin(72°), 150 - 77*cos(72°)
442
+ ≈ 150 + 73.24, 150 - 23.79
443
+ = 223.24, 126.21
444
+ Det 8 → 88 : 150 + 88*sin(144°), 150 - 88*cos(144°)
445
+ ≈ 150 + 51.72, 150 + 71.20
446
+ = 201.72, 221.20
447
+ Func 6 → 66 : 150 - 66*sin(36°), 150 + 66*cos(36°)
448
+ ≈ 150 - 38.79, 150 + 53.40
449
+ = 111.21, 203.40
450
+ Innov 5 → 55 : 150 - 55*sin(108°),150 - 55*cos(108°)
451
+ ≈ 150 - 52.32, 150 + 17.00
452
+ = 97.68, 167.00
453
+ Wait - cos(108°) is negative, so 150 - 55*(-0.309) = 150 + 17, that's bottom of axis. But Innov axis is top-left. Let me redo.
454
+ Innov axis end point: 45.34, 116.05. Vector from center (150,150): (-104.66, -33.95), magnitude 110.
455
+ At score 5, scale = 5/10 = 0.5: center + 0.5 * (-104.66, -33.95) = 150 - 52.33, 150 - 16.97 = 97.67, 133.03 -->
456
+ <polygon class="area" points="150,62 223.24,126.21 201.72,221.20 111.21,203.40 97.67,133.03" />
457
+ <circle class="dot" cx="150" cy="62" r="3" />
458
+ <circle class="dot" cx="223.24" cy="126.21" r="3" />
459
+ <circle class="dot" cx="201.72" cy="221.20" r="3" />
460
+ <circle class="dot" cx="111.21" cy="203.40" r="3" />
461
+ <circle class="dot" cx="97.67" cy="133.03" r="3" />
462
+
463
+ <!-- Axis labels -->
464
+ <text class="lbl" x="150" y="28" text-anchor="middle">PHILOSOPHY</text>
465
+ <text class="lbl-n" x="150" y="14" text-anchor="middle">8</text>
466
+ <text class="lbl" x="270" y="116" text-anchor="middle">HIERARCHY</text>
467
+ <text class="lbl-n" x="278" y="100" text-anchor="middle">7</text>
468
+ <text class="lbl" x="220" y="259" text-anchor="middle">DETAIL</text>
469
+ <text class="lbl-n" x="220" y="275" text-anchor="middle">8</text>
470
+ <text class="lbl" x="80" y="259" text-anchor="middle">FUNCTION</text>
471
+ <text class="lbl-n" x="80" y="275" text-anchor="middle">6</text>
472
+ <text class="lbl" x="30" y="116" text-anchor="middle">INNOVATION</text>
473
+ <text class="lbl-n" x="22" y="100" text-anchor="middle">5</text>
474
+ </svg>
475
+ <div class="overall">Overall · <span class="n">7.4</span> / 10 · band <em>Strong</em></div>
476
+ </div>
477
+
478
+ <div class="scores" aria-label="Score breakdown">
479
+ <div class="score-row">
480
+ <div class="score-name">Philosophy consistency<span class="en">Phil. cons.</span></div>
481
+ <div class="score-bar"><span class="score-bar-fill" style="width:80%"></span></div>
482
+ <div class="score-num">8<span class="denom">/10</span></div>
483
+ <div class="score-band band-strong">Strong</div>
484
+ </div>
485
+ <div class="score-row">
486
+ <div class="score-name">Visual hierarchy<span class="en">Hier.</span></div>
487
+ <div class="score-bar"><span class="score-bar-fill" style="width:70%"></span></div>
488
+ <div class="score-num">7<span class="denom">/10</span></div>
489
+ <div class="score-band band-strong">Strong</div>
490
+ </div>
491
+ <div class="score-row">
492
+ <div class="score-name">Detail execution<span class="en">Detail</span></div>
493
+ <div class="score-bar"><span class="score-bar-fill" style="width:80%"></span></div>
494
+ <div class="score-num">8<span class="denom">/10</span></div>
495
+ <div class="score-band band-strong">Strong</div>
496
+ </div>
497
+ <div class="score-row">
498
+ <div class="score-name">Functionality<span class="en">Func.</span></div>
499
+ <div class="score-bar"><span class="score-bar-fill" style="width:60%"></span></div>
500
+ <div class="score-num">6<span class="denom">/10</span></div>
501
+ <div class="score-band band-functional">Functional</div>
502
+ </div>
503
+ <div class="score-row">
504
+ <div class="score-name">Innovation<span class="en">Innov.</span></div>
505
+ <div class="score-bar"><span class="score-bar-fill" style="width:50%"></span></div>
506
+ <div class="score-num">5<span class="denom">/10</span></div>
507
+ <div class="score-band band-functional">Functional</div>
508
+ </div>
509
+ </div>
510
+ </section>
511
+
512
+ <!-- ============ Dimension cards ============ -->
513
+ <h2 class="section-title">Dimension reports<span class="en">Evidence per axis</span></h2>
514
+
515
+ <div class="dim-grid">
516
+ <article class="dim">
517
+ <div class="dim-head">
518
+ <div class="dim-name">Philosophy consistency<span class="en">Phil. cons. · 哲学一致性</span></div>
519
+ <div class="dim-score">8<span class="denom">/10</span></div>
520
+ </div>
521
+ <p class="dim-evidence">
522
+ The 9-slide rhythm reads as a single direction (Monocle Editorial)
523
+ from cover to close. <code>chrome</code> vocabulary stays in one
524
+ register: <em>"A Talk · 2026.04.22"</em>, <em>"Act II · 04 / 09"</em>,
525
+ <em>"Page 06 · 金句"</em>. The drift is the <code>kicker</code> on
526
+ slide 5 — <em>"Act II"</em> is good, but the slide title <em>"折叠"</em>
527
+ is a one-character display word that competes with the Act number for
528
+ eyeballs. Worth tightening.
529
+ </p>
530
+ <div class="dim-tags">
531
+ <div class="tag-row"><span class="tag tag-keep">Keep</span><span>The chrome / kicker / foot vocabulary across all 9 slides — it's the deck's identity.</span></div>
532
+ <div class="tag-row"><span class="tag tag-fix">Fix</span><span>Slide 5: bump the kicker to <em>"Act II · 折叠"</em> or shrink the display title to clear the hierarchy.</span></div>
533
+ </div>
534
+ </article>
535
+
536
+ <article class="dim">
537
+ <div class="dim-head">
538
+ <div class="dim-name">Visual hierarchy<span class="en">Hier. · 视觉层级</span></div>
539
+ <div class="dim-score">7<span class="denom">/10</span></div>
540
+ </div>
541
+ <p class="dim-evidence">
542
+ Hero pages (1, 5, 7, 9) are textbook — display serif dominates,
543
+ <code>kicker</code> and <code>meta-row</code> recede. Body pages
544
+ mostly hold up: stat-cards on slide 2 use <code>.stat-label</code>
545
+ (mono small) → <code>.stat-nb</code> (serif large) → <code>.stat-note</code>
546
+ (sans body), three tiers, no collision. The miss is slide 3's
547
+ <code>callout</code> — its left-rule competes visually with the
548
+ <code>.h-xl</code> heading because both sit at the same x-coord
549
+ and similar weight. Eye doesn't know if to read heading-first or
550
+ quote-first.
551
+ </p>
552
+ <div class="dim-tags">
553
+ <div class="tag-row"><span class="tag tag-keep">Keep</span><span>Stat-card 3-tier structure on slide 2 — copy this everywhere.</span></div>
554
+ <div class="tag-row"><span class="tag tag-fix">Fix</span><span>Slide 3: indent the <code>callout</code> by <code>2vw</code> or push it below the lead so it visibly belongs to a lower tier.</span></div>
555
+ </div>
556
+ </article>
557
+
558
+ <article class="dim">
559
+ <div class="dim-head">
560
+ <div class="dim-name">Detail execution<span class="en">Detail · 细节执行</span></div>
561
+ <div class="dim-score">8<span class="denom">/10</span></div>
562
+ </div>
563
+ <p class="dim-evidence">
564
+ Magazine-grade in places — every <code>.foot</code> aligns
565
+ baseline-to-baseline across all 9 slides; <code>.meta-row</code>
566
+ uses one mono spec throughout (<code>.16em</code> tracking,
567
+ uppercase). Pipeline on slide 4 keeps perfect grid even when
568
+ column count drops to 3. Two real misses: (1) Slide 3 image-slot
569
+ uses <code>aspect-ratio:16/10</code> but the placeholder text
570
+ inside is centered which makes it look hollow at viewport widths
571
+ ≤ 1100px; (2) the dot-nav at the bottom overlaps the foot text
572
+ on slide 5 because the hero centered grid eats vertical space.
573
+ </p>
574
+ <div class="dim-tags">
575
+ <div class="tag-row"><span class="tag tag-keep">Keep</span><span>The mono <code>.foot</code> spec — it's the deck's grace note, do not change letter-spacing.</span></div>
576
+ <div class="tag-row"><span class="tag tag-fix">Fix</span><span>Slide 5 hero grid: cap inner content at <code>min-height:78vh</code> so the foot stays clear of the dot-nav.</span></div>
577
+ </div>
578
+ </article>
579
+
580
+ <article class="dim">
581
+ <div class="dim-head">
582
+ <div class="dim-name">Functionality<span class="en">Func. · 功能性</span></div>
583
+ <div class="dim-score">6<span class="denom">/10</span></div>
584
+ </div>
585
+ <p class="dim-evidence">
586
+ Keyboard / wheel / touch navigation works correctly inside the
587
+ host iframe (verified: ←/→/PageUp/PageDown all advance). ESC
588
+ opens the index overview, dot clicks register. Big miss is the
589
+ example ships <em>without real images</em> — slide 3 shows a
590
+ dashed <code>.img-slot</code> placeholder where a product
591
+ screenshot belongs, which is the right call for an example file
592
+ but means the user can't judge how the layout holds at full
593
+ fidelity. Second miss: <code>iframe</code> sandbox is
594
+ <code>allow-scripts</code> only in the example card, so the
595
+ WebGL background loads but the dot-nav inside the iframe takes
596
+ a click before keyboard nav captures focus.
597
+ </p>
598
+ <div class="dim-tags">
599
+ <div class="tag-row"><span class="tag tag-keep">Keep</span><span>The 5-bug-fix nav script (real scroller detection, capture-phase listeners) — proven and stable.</span></div>
600
+ <div class="tag-row"><span class="tag tag-fix">Fix</span><span>Add a <code>data:</code> URI placeholder image (1×1 colored gradient) in the example so slide 3's layout reads at any width.</span></div>
601
+ </div>
602
+ </article>
603
+
604
+ <article class="dim">
605
+ <div class="dim-head">
606
+ <div class="dim-name">Innovation<span class="en">Innov. · 创新性</span></div>
607
+ <div class="dim-score">5<span class="denom">/10</span></div>
608
+ </div>
609
+ <p class="dim-evidence">
610
+ Innovation is intentionally conservative — this is a port of
611
+ 歸藏's guizang-ppt-skill, and the value proposition is
612
+ <em>predictability</em>, not novelty. The dual WebGL background
613
+ (Holographic Dispersion on dark, Spiral Vortex on light) is the
614
+ one earned moment; the cross-fade on slide-theme transitions is
615
+ subtle and well-timed. But everything else (layout vocabulary,
616
+ chrome / foot pattern, theme presets) is faithfully replicated
617
+ from the upstream. There is no "lean-forward" surprise that
618
+ makes a viewer screenshot a slide. For its declared purpose
619
+ (Monocle Editorial direction), this is appropriate. For an
620
+ AI demo-day deck, it's a missed opportunity.
621
+ </p>
622
+ <div class="dim-tags">
623
+ <div class="tag-row"><span class="tag tag-keep">Keep</span><span>The dual-shader cross-fade — it's the only "magic" the deck performs and it earns its keep.</span></div>
624
+ <div class="tag-row"><span class="tag tag-qw">Quick win</span><span>Add one <em>typographic</em> moment per deck — e.g. an oversized italic <code>em</code> kicker that breaks the grid on the closing slide.</span></div>
625
+ </div>
626
+ </article>
627
+ </div>
628
+
629
+ <!-- ============ Action lists ============ -->
630
+ <h2 class="section-title">Action lists<span class="en">Keep · Fix · Quick wins</span></h2>
631
+
632
+ <div class="lists-grid">
633
+ <section class="list-card">
634
+ <div class="list-head keep"><span>Keep</span><span class="ct">don't break it</span></div>
635
+ <ul>
636
+ <li>The 9-page rhythm: <code>hero dark → light → dark → light → hero light → dark → hero dark → light → hero light</code>. It's the gold standard.</li>
637
+ <li>Dual WebGL backdrops + the <code>1.2s</code> cross-fade between dark and light slides.</li>
638
+ <li><code>chrome</code> / <code>kicker</code> / <code>foot</code> vocabulary — they carry the Monocle direction.</li>
639
+ <li>3-tier <code>stat-card</code> on slide 2 (<code>label</code> → <code>nb</code> → <code>note</code>).</li>
640
+ </ul>
641
+ </section>
642
+
643
+ <section class="list-card">
644
+ <div class="list-head fix"><span>Fix</span><span class="ct">P0 — visually expensive</span></div>
645
+ <ul>
646
+ <li>Slide 3 callout indent — currently competes with <code>.h-xl</code>; push 2vw right or below the lead.</li>
647
+ <li>Slide 5 hero centered grid — cap content height at <code>78vh</code> so foot doesn't overlap the dot nav.</li>
648
+ <li>Slide 3 add a <code>data:</code> gradient placeholder image so the layout reads at narrow widths even without real assets.</li>
649
+ <li>Slide 5 kicker / display: pick one to be primary — currently both fight.</li>
650
+ </ul>
651
+ </section>
652
+
653
+ <section class="list-card">
654
+ <div class="list-head qw"><span>Quick wins</span><span class="ct">5–15 min, high signal</span></div>
655
+ <ul>
656
+ <li>Inject <code>data-screen-label</code> on every slide for accessibility + grep self-checks.</li>
657
+ <li>Add one oversized italic <em>en</em> moment on the closing slide for typographic surprise.</li>
658
+ <li>Move the <code>#hint</code> overlay from <code>opacity:.4</code> to <code>.55</code> on hero pages — currently invisible.</li>
659
+ <li>Add a print stylesheet (one slide per page) so PDF export carries the rhythm.</li>
660
+ </ul>
661
+ </section>
662
+ </div>
663
+
664
+ <footer class="ft">
665
+ <span>OD · Critique skill · v0.1</span>
666
+ <span>5 dimensions · Phil / Hier / Det / Func / Innov</span>
667
+ <span class="br">github.com/alchaincyf/huashu-design</span>
668
+ </footer>
669
+ </div>
670
+ </body>
671
+ </html>