@hiai-gg/hiai-opencode 0.2.0 → 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 (490) hide show
  1. package/.env.example +4 -0
  2. package/AGENTS.md +40 -44
  3. package/ARCHITECTURE.md +4 -3
  4. package/LICENSE.md +14 -0
  5. package/README.md +61 -30
  6. package/assets/cli/hiai-opencode.mjs +4 -4
  7. package/config/hiai-opencode.schema.json +11 -13
  8. package/dist/agents/{bob.d.ts → bob/claude.d.ts} +6 -2
  9. package/dist/agents/bob/core.d.ts +6 -0
  10. package/dist/agents/bob/gpt.d.ts +11 -0
  11. package/dist/agents/bob/index.d.ts +3 -0
  12. package/dist/agents/coder/core.d.ts +4 -0
  13. package/dist/agents/coder/gpt.d.ts +1 -4
  14. package/dist/agents/coder/index.d.ts +1 -0
  15. package/dist/agents/manager/agent.d.ts +1 -1
  16. package/dist/agents/manager/default-prompt-sections.d.ts +4 -4
  17. package/dist/agents/manager/guard-integration.d.ts +1 -0
  18. package/dist/agents/prompt-library/index.d.ts +0 -1
  19. package/dist/agents/prompt-library/shared-execution.d.ts +9 -0
  20. package/dist/agents/strategist/behavioral-summary.d.ts +1 -1
  21. package/dist/agents/strategist/identity-constraints.d.ts +1 -1
  22. package/dist/agents/strategist/plan-generation.d.ts +1 -1
  23. package/dist/agents/types.d.ts +2 -1
  24. package/dist/config/defaults.d.ts +1 -0
  25. package/dist/config/platform-schema.d.ts +26 -26
  26. package/dist/config/schema/agent-names.d.ts +6 -6
  27. package/dist/config/schema/agent-overrides.d.ts +0 -128
  28. package/dist/config/schema/hiai-opencode-config.d.ts +0 -128
  29. package/dist/config/types.d.ts +2 -2
  30. package/dist/features/background-agent/error-classifier.d.ts +1 -0
  31. package/dist/features/background-agent/manager-notifier.d.ts +46 -0
  32. package/dist/features/background-agent/manager-types.d.ts +40 -0
  33. package/dist/features/background-agent/manager.d.ts +3 -19
  34. package/dist/features/background-agent/polling-manager.d.ts +51 -0
  35. package/dist/features/boulder-state/constants.d.ts +3 -0
  36. package/dist/features/boulder-state/storage.d.ts +95 -0
  37. package/dist/features/boulder-state/types.d.ts +17 -0
  38. package/dist/features/builtin-commands/templates/doctor.d.ts +1 -1
  39. package/dist/features/builtin-commands/templates/loop.d.ts +2 -0
  40. package/dist/features/builtin-commands/templates/start-work.d.ts +1 -1
  41. package/dist/features/builtin-skills/skills/interview-me.d.ts +2 -0
  42. package/dist/features/builtin-skills/skills/planning-and-task-breakdown.d.ts +2 -0
  43. package/dist/hooks/manager/resolve-active-boulder-session.d.ts +5 -0
  44. package/dist/hooks/manager/system-reminder-templates.d.ts +2 -2
  45. package/dist/hooks/reasoning-content-cache/hook.d.ts +11 -0
  46. package/dist/hooks/reasoning-content-cache/index.d.ts +1 -0
  47. package/dist/hooks/session-recovery/checkpoint.d.ts +48 -0
  48. package/dist/hooks/session-recovery/enhanced-hook.d.ts +30 -0
  49. package/dist/hooks/session-recovery/state-backup.d.ts +76 -0
  50. package/dist/hooks/shared/compaction-in-progress.d.ts +4 -0
  51. package/dist/hooks/start-work/context-info-builder.d.ts +2 -0
  52. package/dist/hooks/start-work/git-operations.d.ts +47 -0
  53. package/dist/hooks/start-work/worktree-block.d.ts +2 -1
  54. package/dist/hooks/start-work/worktree-detector.d.ts +45 -0
  55. package/dist/hooks/strategist-md-only/agent-resolution.d.ts +1 -1
  56. package/dist/hooks/strategist-md-only/constants.d.ts +6 -0
  57. package/dist/hooks/token-budget.d.ts +30 -0
  58. package/dist/index.js +1275 -1132
  59. package/dist/mcp/rate-limiter.d.ts +68 -0
  60. package/dist/plugin/chat-message.d.ts +8 -0
  61. package/dist/plugin/command-execute-before.d.ts +1 -1
  62. package/dist/plugin/event-handlers/message-updated.d.ts +2 -0
  63. package/dist/plugin/event-handlers/session-error.d.ts +2 -0
  64. package/dist/plugin/event-handlers/session-status.d.ts +2 -0
  65. package/dist/plugin/event-handlers/types.d.ts +62 -0
  66. package/dist/plugin/event-handlers/utils.d.ts +11 -0
  67. package/dist/plugin/event.d.ts +1 -1
  68. package/dist/shared/data-path.d.ts +1 -1
  69. package/dist/shared/errors.d.ts +70 -0
  70. package/dist/shared/extract-session-id.d.ts +8 -0
  71. package/dist/shared/git-worktree/get-git-state-summary.d.ts +14 -0
  72. package/dist/shared/index.d.ts +67 -68
  73. package/dist/shared/internal-initiator-marker.d.ts +1 -1
  74. package/dist/shared/logger.d.ts +5 -1
  75. package/dist/shared/reasoning-content-cache.d.ts +68 -0
  76. package/dist/shared/safe-create-hook.d.ts +4 -4
  77. package/dist/tools/call-hiai-agent/constants.d.ts +2 -2
  78. package/dist/tools/delegate-task/sub-agent.d.ts +1 -1
  79. package/dist/tools/look-at/constants.d.ts +1 -1
  80. package/docs/architecture/bob-manager-architecture.md +244 -0
  81. package/docs/hiai-opencode/adr/ADR-001-agent-identity-section-injection.md +66 -0
  82. package/docs/hiai-opencode/adr/ADR-002-anti-loop-guard-priority.md +63 -0
  83. package/docs/hiai-opencode/adr/ADR-003-compaction-mechanism.md +71 -0
  84. package/docs/hiai-opencode/adr/ADR-004-session-recovery.md +76 -0
  85. package/docs/hiai-opencode/api.md +305 -0
  86. package/docs/hiai-opencode/hooks-architecture.md +225 -0
  87. package/docs/hiai-opencode/migration.md +209 -0
  88. package/docs/quickstart.md +1 -1
  89. package/docs/skill-discovery.md +288 -0
  90. package/package.json +2 -2
  91. package/skills/agent-browser/SKILL.md +193 -0
  92. package/skills/apple-hig/SKILL.md +43 -0
  93. package/skills/article-magazine/SKILL.md +46 -0
  94. package/skills/article-magazine/example.html +81 -0
  95. package/skills/article-magazine/example.md +38 -0
  96. package/skills/canvas-design/SKILL.md +45 -0
  97. package/skills/design-templates/audio-jingle/SKILL.md +132 -0
  98. package/skills/design-templates/audio-jingle/example.html +128 -0
  99. package/skills/design-templates/blog-post/SKILL.md +80 -0
  100. package/skills/design-templates/blog-post/example.html +80 -0
  101. package/skills/design-templates/clinical-case-report/SKILL.md +209 -0
  102. package/skills/design-templates/clinical-case-report/example.html +698 -0
  103. package/skills/design-templates/clinical-case-report/examples/example-stemi.html +698 -0
  104. package/skills/design-templates/clinical-case-report/references/case-formats.md +94 -0
  105. package/skills/design-templates/clinical-case-report/references/checklist.md +41 -0
  106. package/skills/design-templates/critique/SKILL.md +258 -0
  107. package/skills/design-templates/critique/example.html +671 -0
  108. package/skills/design-templates/dashboard/SKILL.md +76 -0
  109. package/skills/design-templates/dashboard/example.html +118 -0
  110. package/skills/design-templates/dating-web/SKILL.md +92 -0
  111. package/skills/design-templates/dating-web/example.html +265 -0
  112. package/skills/design-templates/dcf-valuation/SKILL.md +140 -0
  113. package/skills/design-templates/dcf-valuation/references/sector-wacc.md +42 -0
  114. package/skills/design-templates/digital-eguide/SKILL.md +94 -0
  115. package/skills/design-templates/digital-eguide/example.html +204 -0
  116. package/skills/design-templates/docs-page/SKILL.md +80 -0
  117. package/skills/design-templates/docs-page/example.html +122 -0
  118. package/skills/design-templates/email-marketing/SKILL.md +84 -0
  119. package/skills/design-templates/email-marketing/example.html +159 -0
  120. package/skills/design-templates/eng-runbook/SKILL.md +51 -0
  121. package/skills/design-templates/eng-runbook/example.html +250 -0
  122. package/skills/design-templates/finance-report/SKILL.md +61 -0
  123. package/skills/design-templates/finance-report/example.html +242 -0
  124. package/skills/design-templates/flowai-live-dashboard-template/SKILL.md +87 -0
  125. package/skills/design-templates/flowai-live-dashboard-template/assets/template.html +387 -0
  126. package/skills/design-templates/flowai-live-dashboard-template/example.html +13 -0
  127. package/skills/design-templates/flowai-live-dashboard-template/references/checklist.md +35 -0
  128. package/skills/design-templates/gamified-app/SKILL.md +108 -0
  129. package/skills/design-templates/gamified-app/example.html +292 -0
  130. package/skills/design-templates/github-dashboard/SKILL.md +130 -0
  131. package/skills/design-templates/github-dashboard/example.html +473 -0
  132. package/skills/design-templates/github-dashboard/references/README.md +10 -0
  133. package/skills/design-templates/github-dashboard/references/artifact-example.json +15 -0
  134. package/skills/design-templates/github-dashboard/references/example-data.json +138 -0
  135. package/skills/design-templates/github-dashboard/references/provenance-example.json +92 -0
  136. package/skills/design-templates/github-dashboard/references/template.html +473 -0
  137. package/skills/design-templates/guizang-ppt/LICENSE +21 -0
  138. package/skills/design-templates/guizang-ppt/README.en.md +119 -0
  139. package/skills/design-templates/guizang-ppt/README.md +120 -0
  140. package/skills/design-templates/guizang-ppt/README.pt-BR.md +121 -0
  141. package/skills/design-templates/guizang-ppt/SKILL.md +313 -0
  142. package/skills/design-templates/guizang-ppt/assets/example-slides.html +318 -0
  143. package/skills/design-templates/guizang-ppt/assets/template.html +647 -0
  144. package/skills/design-templates/guizang-ppt/references/checklist.md +265 -0
  145. package/skills/design-templates/guizang-ppt/references/components.md +363 -0
  146. package/skills/design-templates/guizang-ppt/references/layouts.md +630 -0
  147. package/skills/design-templates/guizang-ppt/references/styles.md +195 -0
  148. package/skills/design-templates/guizang-ppt/references/themes.md +122 -0
  149. package/skills/design-templates/hr-onboarding/SKILL.md +52 -0
  150. package/skills/design-templates/hr-onboarding/example.html +219 -0
  151. package/skills/design-templates/html-ppt/.clawscan-allow +12 -0
  152. package/skills/design-templates/html-ppt/LICENSE +21 -0
  153. package/skills/design-templates/html-ppt/README.md +234 -0
  154. package/skills/design-templates/html-ppt/README.pt-BR.md +239 -0
  155. package/skills/design-templates/html-ppt/README.zh-CN.md +238 -0
  156. package/skills/design-templates/html-ppt/SKILL.md +250 -0
  157. package/skills/design-templates/html-ppt/assets/animations/animations.css +138 -0
  158. package/skills/design-templates/html-ppt/assets/animations/fx/_util.js +63 -0
  159. package/skills/design-templates/html-ppt/assets/animations/fx/chain-react.js +41 -0
  160. package/skills/design-templates/html-ppt/assets/animations/fx/confetti-cannon.js +49 -0
  161. package/skills/design-templates/html-ppt/assets/animations/fx/constellation.js +44 -0
  162. package/skills/design-templates/html-ppt/assets/animations/fx/counter-explosion.js +58 -0
  163. package/skills/design-templates/html-ppt/assets/animations/fx/data-stream.js +45 -0
  164. package/skills/design-templates/html-ppt/assets/animations/fx/firework.js +51 -0
  165. package/skills/design-templates/html-ppt/assets/animations/fx/galaxy-swirl.js +33 -0
  166. package/skills/design-templates/html-ppt/assets/animations/fx/gradient-blob.js +39 -0
  167. package/skills/design-templates/html-ppt/assets/animations/fx/knowledge-graph.js +69 -0
  168. package/skills/design-templates/html-ppt/assets/animations/fx/letter-explode.js +50 -0
  169. package/skills/design-templates/html-ppt/assets/animations/fx/magnetic-field.js +40 -0
  170. package/skills/design-templates/html-ppt/assets/animations/fx/matrix-rain.js +33 -0
  171. package/skills/design-templates/html-ppt/assets/animations/fx/neural-net.js +75 -0
  172. package/skills/design-templates/html-ppt/assets/animations/fx/orbit-ring.js +38 -0
  173. package/skills/design-templates/html-ppt/assets/animations/fx/particle-burst.js +42 -0
  174. package/skills/design-templates/html-ppt/assets/animations/fx/shockwave.js +39 -0
  175. package/skills/design-templates/html-ppt/assets/animations/fx/sparkle-trail.js +62 -0
  176. package/skills/design-templates/html-ppt/assets/animations/fx/starfield.js +30 -0
  177. package/skills/design-templates/html-ppt/assets/animations/fx/typewriter-multi.js +51 -0
  178. package/skills/design-templates/html-ppt/assets/animations/fx/word-cascade.js +47 -0
  179. package/skills/design-templates/html-ppt/assets/animations/fx-runtime.js +99 -0
  180. package/skills/design-templates/html-ppt/assets/base.css +150 -0
  181. package/skills/design-templates/html-ppt/assets/fonts.css +9 -0
  182. package/skills/design-templates/html-ppt/assets/runtime.js +960 -0
  183. package/skills/design-templates/html-ppt/assets/themes/academic-paper.css +23 -0
  184. package/skills/design-templates/html-ppt/assets/themes/arctic-cool.css +14 -0
  185. package/skills/design-templates/html-ppt/assets/themes/aurora.css +20 -0
  186. package/skills/design-templates/html-ppt/assets/themes/bauhaus.css +16 -0
  187. package/skills/design-templates/html-ppt/assets/themes/blueprint.css +19 -0
  188. package/skills/design-templates/html-ppt/assets/themes/catppuccin-latte.css +14 -0
  189. package/skills/design-templates/html-ppt/assets/themes/catppuccin-mocha.css +14 -0
  190. package/skills/design-templates/html-ppt/assets/themes/corporate-clean.css +19 -0
  191. package/skills/design-templates/html-ppt/assets/themes/cyberpunk-neon.css +23 -0
  192. package/skills/design-templates/html-ppt/assets/themes/dracula.css +14 -0
  193. package/skills/design-templates/html-ppt/assets/themes/editorial-serif.css +18 -0
  194. package/skills/design-templates/html-ppt/assets/themes/engineering-whiteprint.css +26 -0
  195. package/skills/design-templates/html-ppt/assets/themes/glassmorphism.css +21 -0
  196. package/skills/design-templates/html-ppt/assets/themes/gruvbox-dark.css +14 -0
  197. package/skills/design-templates/html-ppt/assets/themes/japanese-minimal.css +21 -0
  198. package/skills/design-templates/html-ppt/assets/themes/magazine-bold.css +21 -0
  199. package/skills/design-templates/html-ppt/assets/themes/memphis-pop.css +20 -0
  200. package/skills/design-templates/html-ppt/assets/themes/midcentury.css +19 -0
  201. package/skills/design-templates/html-ppt/assets/themes/minimal-white.css +16 -0
  202. package/skills/design-templates/html-ppt/assets/themes/neo-brutalism.css +17 -0
  203. package/skills/design-templates/html-ppt/assets/themes/news-broadcast.css +20 -0
  204. package/skills/design-templates/html-ppt/assets/themes/nord.css +14 -0
  205. package/skills/design-templates/html-ppt/assets/themes/pitch-deck-vc.css +21 -0
  206. package/skills/design-templates/html-ppt/assets/themes/rainbow-gradient.css +16 -0
  207. package/skills/design-templates/html-ppt/assets/themes/retro-tv.css +22 -0
  208. package/skills/design-templates/html-ppt/assets/themes/rose-pine.css +14 -0
  209. package/skills/design-templates/html-ppt/assets/themes/sharp-mono.css +17 -0
  210. package/skills/design-templates/html-ppt/assets/themes/soft-pastel.css +14 -0
  211. package/skills/design-templates/html-ppt/assets/themes/solarized-light.css +14 -0
  212. package/skills/design-templates/html-ppt/assets/themes/sunset-warm.css +14 -0
  213. package/skills/design-templates/html-ppt/assets/themes/swiss-grid.css +17 -0
  214. package/skills/design-templates/html-ppt/assets/themes/terminal-green.css +18 -0
  215. package/skills/design-templates/html-ppt/assets/themes/tokyo-night.css +14 -0
  216. package/skills/design-templates/html-ppt/assets/themes/vaporwave.css +21 -0
  217. package/skills/design-templates/html-ppt/assets/themes/xiaohongshu-white.css +16 -0
  218. package/skills/design-templates/html-ppt/assets/themes/y2k-chrome.css +20 -0
  219. package/skills/design-templates/html-ppt/docs/readme/_theme-cell.html +56 -0
  220. package/skills/design-templates/html-ppt/docs/readme/animations.png +0 -0
  221. package/skills/design-templates/html-ppt/docs/readme/hero.gif +0 -0
  222. package/skills/design-templates/html-ppt/docs/readme/layouts-live.gif +0 -0
  223. package/skills/design-templates/html-ppt/docs/readme/layouts.png +0 -0
  224. package/skills/design-templates/html-ppt/docs/readme/montage-animations.html +61 -0
  225. package/skills/design-templates/html-ppt/docs/readme/montage-layouts.html +72 -0
  226. package/skills/design-templates/html-ppt/docs/readme/montage-templates.html +72 -0
  227. package/skills/design-templates/html-ppt/docs/readme/montage-themes.html +38 -0
  228. package/skills/design-templates/html-ppt/docs/readme/presenter-mode.png +0 -0
  229. package/skills/design-templates/html-ppt/docs/readme/templates.png +0 -0
  230. package/skills/design-templates/html-ppt/docs/readme/themes.png +0 -0
  231. package/skills/design-templates/html-ppt/examples/demo-deck/index.html +161 -0
  232. package/skills/design-templates/html-ppt/references/animations.md +147 -0
  233. package/skills/design-templates/html-ppt/references/authoring-guide.md +141 -0
  234. package/skills/design-templates/html-ppt/references/full-decks.md +98 -0
  235. package/skills/design-templates/html-ppt/references/layouts.md +103 -0
  236. package/skills/design-templates/html-ppt/references/presenter-mode.md +240 -0
  237. package/skills/design-templates/html-ppt/references/themes.md +107 -0
  238. package/skills/design-templates/html-ppt/scripts/new-deck.sh +46 -0
  239. package/skills/design-templates/html-ppt/scripts/render.sh +71 -0
  240. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_01.png +0 -0
  241. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_02.png +0 -0
  242. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_03.png +0 -0
  243. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_04.png +0 -0
  244. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_05.png +0 -0
  245. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_06.png +0 -0
  246. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_07.png +0 -0
  247. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_08.png +0 -0
  248. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_09.png +0 -0
  249. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_10.png +0 -0
  250. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_11.png +0 -0
  251. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_12.png +0 -0
  252. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_13.png +0 -0
  253. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_14.png +0 -0
  254. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_15.png +0 -0
  255. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_16.png +0 -0
  256. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_17.png +0 -0
  257. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_18.png +0 -0
  258. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_19.png +0 -0
  259. package/skills/design-templates/html-ppt/scripts/verify-output/animation-showcase/animation-showcase_20.png +0 -0
  260. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_01.png +0 -0
  261. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_02.png +0 -0
  262. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_03.png +0 -0
  263. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_04.png +0 -0
  264. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_05.png +0 -0
  265. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_06.png +0 -0
  266. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_07.png +0 -0
  267. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_08.png +0 -0
  268. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_09.png +0 -0
  269. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_10.png +0 -0
  270. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_11.png +0 -0
  271. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_12.png +0 -0
  272. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_13.png +0 -0
  273. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_14.png +0 -0
  274. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_15.png +0 -0
  275. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_16.png +0 -0
  276. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_17.png +0 -0
  277. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_18.png +0 -0
  278. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_19.png +0 -0
  279. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_20.png +0 -0
  280. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_21.png +0 -0
  281. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_22.png +0 -0
  282. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_23.png +0 -0
  283. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_24.png +0 -0
  284. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_25.png +0 -0
  285. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_26.png +0 -0
  286. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_27.png +0 -0
  287. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_28.png +0 -0
  288. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_29.png +0 -0
  289. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_30.png +0 -0
  290. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_31.png +0 -0
  291. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_32.png +0 -0
  292. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_33.png +0 -0
  293. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_34.png +0 -0
  294. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_35.png +0 -0
  295. package/skills/design-templates/html-ppt/scripts/verify-output/theme-showcase/theme-showcase_36.png +0 -0
  296. package/skills/design-templates/html-ppt/templates/animation-showcase.html +172 -0
  297. package/skills/design-templates/html-ppt/templates/deck.html +69 -0
  298. package/skills/design-templates/html-ppt/templates/full-decks/course-module/README.md +8 -0
  299. package/skills/design-templates/html-ppt/templates/full-decks/course-module/index.html +189 -0
  300. package/skills/design-templates/html-ppt/templates/full-decks/course-module/style.css +46 -0
  301. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/README.md +11 -0
  302. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/index.html +138 -0
  303. package/skills/design-templates/html-ppt/templates/full-decks/dir-key-nav-minimal/style.css +60 -0
  304. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/README.md +11 -0
  305. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/index.html +180 -0
  306. package/skills/design-templates/html-ppt/templates/full-decks/graphify-dark-graph/style.css +54 -0
  307. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/README.md +11 -0
  308. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/index.html +199 -0
  309. package/skills/design-templates/html-ppt/templates/full-decks/hermes-cyber-terminal/style.css +55 -0
  310. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/README.md +11 -0
  311. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/index.html +190 -0
  312. package/skills/design-templates/html-ppt/templates/full-decks/knowledge-arch-blueprint/style.css +49 -0
  313. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/README.md +11 -0
  314. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/index.html +144 -0
  315. package/skills/design-templates/html-ppt/templates/full-decks/obsidian-claude-gradient/style.css +59 -0
  316. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/README.md +9 -0
  317. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/index.html +148 -0
  318. package/skills/design-templates/html-ppt/templates/full-decks/pitch-deck/style.css +40 -0
  319. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/README.md +102 -0
  320. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/index.html +187 -0
  321. package/skills/design-templates/html-ppt/templates/full-decks/presenter-mode-reveal/style.css +216 -0
  322. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/README.md +8 -0
  323. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/index.html +121 -0
  324. package/skills/design-templates/html-ppt/templates/full-decks/product-launch/style.css +39 -0
  325. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/README.md +8 -0
  326. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/index.html +156 -0
  327. package/skills/design-templates/html-ppt/templates/full-decks/tech-sharing/style.css +49 -0
  328. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/README.md +11 -0
  329. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/index.html +183 -0
  330. package/skills/design-templates/html-ppt/templates/full-decks/testing-safety-alert/style.css +62 -0
  331. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/README.md +8 -0
  332. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/index.html +127 -0
  333. package/skills/design-templates/html-ppt/templates/full-decks/weekly-report/style.css +55 -0
  334. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/README.md +11 -0
  335. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/index.html +147 -0
  336. package/skills/design-templates/html-ppt/templates/full-decks/xhs-pastel-card/style.css +66 -0
  337. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/README.md +9 -0
  338. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/index.html +133 -0
  339. package/skills/design-templates/html-ppt/templates/full-decks/xhs-post/style.css +47 -0
  340. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/README.md +11 -0
  341. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/index.html +187 -0
  342. package/skills/design-templates/html-ppt/templates/full-decks/xhs-white-editorial/style.css +63 -0
  343. package/skills/design-templates/html-ppt/templates/full-decks-index.html +82 -0
  344. package/skills/design-templates/html-ppt/templates/layout-showcase.html +47 -0
  345. package/skills/design-templates/html-ppt/templates/single-page/arch-diagram.html +46 -0
  346. package/skills/design-templates/html-ppt/templates/single-page/big-quote.html +18 -0
  347. package/skills/design-templates/html-ppt/templates/single-page/bullets.html +19 -0
  348. package/skills/design-templates/html-ppt/templates/single-page/chart-bar.html +30 -0
  349. package/skills/design-templates/html-ppt/templates/single-page/chart-line.html +35 -0
  350. package/skills/design-templates/html-ppt/templates/single-page/chart-pie.html +36 -0
  351. package/skills/design-templates/html-ppt/templates/single-page/chart-radar.html +31 -0
  352. package/skills/design-templates/html-ppt/templates/single-page/code.html +33 -0
  353. package/skills/design-templates/html-ppt/templates/single-page/comparison.html +47 -0
  354. package/skills/design-templates/html-ppt/templates/single-page/cover.html +32 -0
  355. package/skills/design-templates/html-ppt/templates/single-page/cta.html +27 -0
  356. package/skills/design-templates/html-ppt/templates/single-page/diff.html +35 -0
  357. package/skills/design-templates/html-ppt/templates/single-page/flow-diagram.html +33 -0
  358. package/skills/design-templates/html-ppt/templates/single-page/gantt.html +29 -0
  359. package/skills/design-templates/html-ppt/templates/single-page/image-grid.html +34 -0
  360. package/skills/design-templates/html-ppt/templates/single-page/image-hero.html +33 -0
  361. package/skills/design-templates/html-ppt/templates/single-page/kpi-grid.html +19 -0
  362. package/skills/design-templates/html-ppt/templates/single-page/mindmap.html +38 -0
  363. package/skills/design-templates/html-ppt/templates/single-page/process-steps.html +27 -0
  364. package/skills/design-templates/html-ppt/templates/single-page/pros-cons.html +31 -0
  365. package/skills/design-templates/html-ppt/templates/single-page/roadmap.html +46 -0
  366. package/skills/design-templates/html-ppt/templates/single-page/section-divider.html +17 -0
  367. package/skills/design-templates/html-ppt/templates/single-page/stat-highlight.html +17 -0
  368. package/skills/design-templates/html-ppt/templates/single-page/table.html +33 -0
  369. package/skills/design-templates/html-ppt/templates/single-page/terminal.html +35 -0
  370. package/skills/design-templates/html-ppt/templates/single-page/thanks.html +21 -0
  371. package/skills/design-templates/html-ppt/templates/single-page/three-column.html +18 -0
  372. package/skills/design-templates/html-ppt/templates/single-page/timeline.html +32 -0
  373. package/skills/design-templates/html-ppt/templates/single-page/toc.html +26 -0
  374. package/skills/design-templates/html-ppt/templates/single-page/todo-checklist.html +33 -0
  375. package/skills/design-templates/html-ppt/templates/single-page/two-column.html +39 -0
  376. package/skills/design-templates/html-ppt/templates/theme-showcase.html +151 -0
  377. package/skills/design-templates/html-ppt-course-module/SKILL.md +78 -0
  378. package/skills/design-templates/html-ppt-course-module/example.html +542 -0
  379. package/skills/design-templates/html-ppt-dir-key-nav-minimal/SKILL.md +77 -0
  380. package/skills/design-templates/html-ppt-dir-key-nav-minimal/example.html +366 -0
  381. package/skills/design-templates/html-ppt-graphify-dark-graph/SKILL.md +77 -0
  382. package/skills/design-templates/html-ppt-graphify-dark-graph/example.html +402 -0
  383. package/skills/design-templates/html-ppt-hermes-cyber-terminal/SKILL.md +77 -0
  384. package/skills/design-templates/html-ppt-hermes-cyber-terminal/example.html +422 -0
  385. package/skills/design-templates/html-ppt-knowledge-arch-blueprint/SKILL.md +77 -0
  386. package/skills/design-templates/html-ppt-knowledge-arch-blueprint/example.html +407 -0
  387. package/skills/design-templates/html-ppt-obsidian-claude-gradient/SKILL.md +77 -0
  388. package/skills/design-templates/html-ppt-obsidian-claude-gradient/example.html +371 -0
  389. package/skills/design-templates/html-ppt-pitch-deck/SKILL.md +78 -0
  390. package/skills/design-templates/html-ppt-pitch-deck/example.html +495 -0
  391. package/skills/design-templates/html-ppt-presenter-mode-reveal/SKILL.md +78 -0
  392. package/skills/design-templates/html-ppt-presenter-mode-reveal/example.html +725 -0
  393. package/skills/design-templates/html-ppt-product-launch/SKILL.md +77 -0
  394. package/skills/design-templates/html-ppt-product-launch/example.html +467 -0
  395. package/skills/design-templates/html-ppt-taste-brutalist/SKILL.md +70 -0
  396. package/skills/design-templates/html-ppt-taste-brutalist/example.html +774 -0
  397. package/skills/design-templates/html-ppt-taste-editorial/SKILL.md +62 -0
  398. package/skills/design-templates/html-ppt-taste-editorial/example.html +689 -0
  399. package/skills/design-templates/html-ppt-tech-sharing/SKILL.md +77 -0
  400. package/skills/design-templates/html-ppt-tech-sharing/example.html +512 -0
  401. package/skills/design-templates/html-ppt-testing-safety-alert/SKILL.md +78 -0
  402. package/skills/design-templates/html-ppt-testing-safety-alert/example.html +413 -0
  403. package/skills/design-templates/html-ppt-weekly-report/SKILL.md +77 -0
  404. package/skills/design-templates/html-ppt-weekly-report/example.html +489 -0
  405. package/skills/design-templates/html-ppt-xhs-pastel-card/SKILL.md +78 -0
  406. package/skills/design-templates/html-ppt-xhs-pastel-card/example.html +381 -0
  407. package/skills/design-templates/html-ppt-xhs-post/SKILL.md +78 -0
  408. package/skills/design-templates/html-ppt-xhs-post/example.html +487 -0
  409. package/skills/design-templates/html-ppt-xhs-white-editorial/SKILL.md +77 -0
  410. package/skills/design-templates/html-ppt-xhs-white-editorial/example.html +418 -0
  411. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/LICENSE +21 -0
  412. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/SKILL.md +93 -0
  413. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/example.html +1640 -0
  414. package/skills/design-templates/html-ppt-zhangzara-8-bit-orbit/template.json +48 -0
  415. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/LICENSE +21 -0
  416. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/SKILL.md +93 -0
  417. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/example.html +833 -0
  418. package/skills/design-templates/html-ppt-zhangzara-biennale-yellow/template.json +49 -0
  419. package/skills/design-templates/html-ppt-zhangzara-block-frame/LICENSE +21 -0
  420. package/skills/design-templates/html-ppt-zhangzara-block-frame/SKILL.md +93 -0
  421. package/skills/design-templates/html-ppt-zhangzara-block-frame/example.html +1453 -0
  422. package/skills/design-templates/html-ppt-zhangzara-block-frame/template.json +47 -0
  423. package/skills/design-templates/html-ppt-zhangzara-blue-professional/LICENSE +21 -0
  424. package/skills/design-templates/html-ppt-zhangzara-blue-professional/SKILL.md +93 -0
  425. package/skills/design-templates/html-ppt-zhangzara-blue-professional/example.html +1423 -0
  426. package/skills/design-templates/html-ppt-zhangzara-blue-professional/template.json +44 -0
  427. package/skills/design-templates/html-ppt-zhangzara-bold-poster/LICENSE +21 -0
  428. package/skills/design-templates/html-ppt-zhangzara-bold-poster/SKILL.md +93 -0
  429. package/skills/design-templates/html-ppt-zhangzara-bold-poster/example.html +876 -0
  430. package/skills/design-templates/html-ppt-zhangzara-bold-poster/template.json +45 -0
  431. package/skills/design-templates/html-ppt-zhangzara-broadside/LICENSE +21 -0
  432. package/skills/design-templates/html-ppt-zhangzara-broadside/SKILL.md +92 -0
  433. package/skills/design-templates/html-ppt-zhangzara-broadside/example.html +2144 -0
  434. package/skills/design-templates/html-ppt-zhangzara-broadside/template.json +49 -0
  435. package/skills/design-templates/html-ppt-zhangzara-capsule/LICENSE +21 -0
  436. package/skills/design-templates/html-ppt-zhangzara-capsule/SKILL.md +92 -0
  437. package/skills/design-templates/html-ppt-zhangzara-capsule/example.html +1413 -0
  438. package/skills/design-templates/html-ppt-zhangzara-capsule/template.json +51 -0
  439. package/skills/design-templates/html-ppt-zhangzara-cartesian/LICENSE +21 -0
  440. package/skills/design-templates/html-ppt-zhangzara-cartesian/SKILL.md +92 -0
  441. package/skills/design-templates/html-ppt-zhangzara-cartesian/example.html +1136 -0
  442. package/skills/design-templates/html-ppt-zhangzara-cartesian/template.json +47 -0
  443. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/LICENSE +21 -0
  444. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/SKILL.md +93 -0
  445. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/example.html +1205 -0
  446. package/skills/design-templates/html-ppt-zhangzara-cobalt-grid/template.json +49 -0
  447. package/skills/design-templates/html-ppt-zhangzara-coral/LICENSE +21 -0
  448. package/skills/design-templates/html-ppt-zhangzara-coral/SKILL.md +92 -0
  449. package/skills/design-templates/html-ppt-zhangzara-coral/example.html +1487 -0
  450. package/skills/design-templates/html-ppt-zhangzara-coral/template.json +45 -0
  451. package/skills/design-templates/html-ppt-zhangzara-creative-mode/LICENSE +21 -0
  452. package/skills/design-templates/html-ppt-zhangzara-creative-mode/SKILL.md +99 -0
  453. package/skills/design-templates/html-ppt-zhangzara-creative-mode/assets/deck-stage.js +619 -0
  454. package/skills/design-templates/html-ppt-zhangzara-creative-mode/example.html +636 -0
  455. package/skills/design-templates/html-ppt-zhangzara-creative-mode/template.json +47 -0
  456. package/skills/design-templates/html-ppt-zhangzara-daisy-days/LICENSE +21 -0
  457. package/skills/design-templates/html-ppt-zhangzara-daisy-days/SKILL.md +93 -0
  458. package/skills/design-templates/html-ppt-zhangzara-daisy-days/example.html +469 -0
  459. package/skills/design-templates/html-ppt-zhangzara-daisy-days/template.json +54 -0
  460. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/LICENSE +21 -0
  461. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/SKILL.md +98 -0
  462. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/assets/deck-stage.js +619 -0
  463. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/example.html +737 -0
  464. package/skills/design-templates/html-ppt-zhangzara-editorial-tri-tone/template.json +44 -0
  465. package/skills/design-templates/html-ppt-zhangzara-grove/LICENSE +21 -0
  466. package/skills/design-templates/html-ppt-zhangzara-grove/SKILL.md +92 -0
  467. package/skills/design-templates/html-ppt-zhangzara-grove/example.html +1676 -0
  468. package/skills/design-templates/html-ppt-zhangzara-grove/template.json +51 -0
  469. package/skills/figma-code-connect-components/SKILL.md +42 -0
  470. package/skills/figma-create-design-system-rules/SKILL.md +42 -0
  471. package/skills/figma-create-new-file/SKILL.md +41 -0
  472. package/skills/figma-generate-design/SKILL.md +42 -0
  473. package/skills/figma-generate-library/SKILL.md +42 -0
  474. package/skills/figma-implement-design/SKILL.md +42 -0
  475. package/skills/figma-use/SKILL.md +42 -0
  476. package/skills/full-page-screenshot/SKILL.md +42 -0
  477. package/skills/interview-me/SKILL.md +64 -0
  478. package/skills/planning-and-task-breakdown/SKILL.md +52 -0
  479. package/skills/sora/SKILL.md +43 -0
  480. package/skills/theme-factory/SKILL.md +43 -0
  481. package/skills/web-design-guidelines/SKILL.md +42 -0
  482. package/dist/agents/prompt-library/orchestration.d.ts +0 -4
  483. package/skills/brainstorming/SKILL.md +0 -164
  484. package/skills/brainstorming/scripts/frame-template.html +0 -214
  485. package/skills/brainstorming/scripts/helper.js +0 -88
  486. package/skills/brainstorming/scripts/server.cjs +0 -354
  487. package/skills/brainstorming/scripts/start-server.sh +0 -148
  488. package/skills/brainstorming/scripts/stop-server.sh +0 -56
  489. package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -49
  490. package/skills/brainstorming/visual-companion.md +0 -287
@@ -0,0 +1,737 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="utf-8" />
5
+ <title>Editorial Deck Template</title>
6
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
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=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Instrument+Serif:ital@0;1&family=JetBrains+Mono:wght@400;500&display=swap" rel="stylesheet">
10
+ <script src="assets/deck-stage.js"></script>
11
+ <style>
12
+ :root{
13
+ --pink:#F2B6C6;
14
+ --pink-deep:#F2B6C6;
15
+ --cream:#F2D86A;
16
+ --navy:#7A1F35;
17
+ --forest:#7A1F35;
18
+ --burgundy:#7A1F35;
19
+ --lime:#F2D86A;
20
+ --sky:#F2B6C6;
21
+ --terracotta:#F2D86A;
22
+ --butter:#F2D86A;
23
+ --ink:#7A1F35;
24
+ }
25
+ html, body { margin:0; padding:0; background:#7A1F35; }
26
+ body { font-family: "Bricolage Grotesque", sans-serif; color: var(--ink); }
27
+
28
+ deck-stage section {
29
+ width:1920px; height:1080px;
30
+ position:relative;
31
+ overflow:hidden;
32
+ box-sizing:border-box;
33
+ }
34
+
35
+ .mono { font-family:"JetBrains Mono", monospace; }
36
+ .serif { font-family:"Instrument Serif", serif; font-style: italic; font-weight:400; }
37
+ .grotesk { font-family:"Bricolage Grotesque", sans-serif; }
38
+
39
+ .pill {
40
+ display:inline-flex; align-items:center; justify-content:center;
41
+ padding: 0.35em 0.9em;
42
+ border-radius: 999px;
43
+ font-family:"Bricolage Grotesque", sans-serif;
44
+ font-weight:500;
45
+ line-height:1;
46
+ white-space:nowrap;
47
+ }
48
+
49
+ .label {
50
+ font-family:"JetBrains Mono", monospace;
51
+ font-size:24px;
52
+ letter-spacing: 0.15em;
53
+ text-transform: uppercase;
54
+ }
55
+
56
+ .footer {
57
+ position:absolute; left:64px; right:64px; bottom:36px;
58
+ display:flex; justify-content:space-between; align-items:center;
59
+ font-family:"JetBrains Mono", monospace;
60
+ font-size:16px;
61
+ letter-spacing: 0.12em;
62
+ text-transform: uppercase;
63
+ opacity:0.75;
64
+ }
65
+ .footer .dotrow { display:flex; gap:8px; }
66
+ .footer .dotrow i { width:8px; height:8px; border-radius:999px; background: currentColor; opacity:0.3; display:inline-block; }
67
+ .footer .dotrow i.on { opacity:1; }
68
+
69
+ /* ========== SLIDE 1: COVER ========== */
70
+ .s-cover { background: var(--pink); color: var(--ink); }
71
+ .s-cover .pill-cluster {
72
+ position:absolute;
73
+ top:120px; left:64px; right:64px;
74
+ display:flex; flex-wrap:wrap; gap: 22px;
75
+ max-width: 1500px;
76
+ }
77
+ .s-cover .pill-cluster .pill { font-size: 44px; padding: 16px 38px; }
78
+ .s-cover .wordmark {
79
+ position:absolute;
80
+ left:64px; right:64px; bottom:80px;
81
+ font-family:"Bricolage Grotesque", sans-serif;
82
+ font-weight:800;
83
+ font-size: 300px;
84
+ line-height: 0.82;
85
+ letter-spacing:-0.04em;
86
+ color: var(--burgundy);
87
+ display:flex;
88
+ align-items:flex-end;
89
+ flex-wrap:nowrap;
90
+ }
91
+ .s-cover .wordmark .amp { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; font-stretch:normal; }
92
+ .s-cover .meta {
93
+ position:absolute; top:64px; left:64px; right:64px;
94
+ display:flex; justify-content:space-between;
95
+ font-family:"JetBrains Mono", monospace;
96
+ font-size:24px; letter-spacing:0.15em; text-transform:uppercase;
97
+ }
98
+
99
+ /* ========== SLIDE 2: MANIFESTO ========== */
100
+ .s-manifesto { background: var(--cream); color: var(--ink); display:grid; grid-template-columns: 1fr 1fr; }
101
+ .s-manifesto .left { padding: 96px 64px; display:flex; flex-direction:column; justify-content:space-between; }
102
+ .s-manifesto .right {
103
+ background: var(--forest); color: var(--cream);
104
+ padding: 96px 80px;
105
+ display:flex; flex-direction:column; justify-content:space-between;
106
+ position:relative;
107
+ }
108
+ .s-manifesto .chapter {
109
+ font-family:"Instrument Serif", serif; font-style:italic;
110
+ font-size: 240px; line-height:0.9;
111
+ color: var(--burgundy);
112
+ }
113
+ .s-manifesto .chapter sup { font-size: 0.35em; vertical-align: super; opacity:0.6; }
114
+ .s-manifesto .lede {
115
+ font-family:"Bricolage Grotesque", sans-serif;
116
+ font-size: 56px; line-height:1.05;
117
+ font-weight:500; letter-spacing:-0.02em;
118
+ max-width: 720px;
119
+ }
120
+ .s-manifesto .lede em { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; color:var(--terracotta); }
121
+ .s-manifesto .right h3 {
122
+ font-family:"JetBrains Mono", monospace;
123
+ font-size: 24px; letter-spacing:0.18em; text-transform:uppercase;
124
+ margin: 0 0 32px; color: var(--butter); font-weight:500;
125
+ }
126
+ .s-manifesto .right p {
127
+ font-size: 28px; line-height:1.45; max-width:540px; margin:0 0 24px;
128
+ }
129
+ .s-manifesto .right .signature {
130
+ font-family:"Instrument Serif", serif; font-style:italic;
131
+ font-size: 64px; line-height:1;
132
+ color: var(--lime);
133
+ }
134
+
135
+ /* ========== SLIDE 3: GRID OF VALUES ========== */
136
+ .s-grid { background: var(--pink); padding: 72px 64px 80px; }
137
+ .s-grid h2 {
138
+ margin:0 0 32px; font-size: 76px; line-height:1;
139
+ font-family:"Bricolage Grotesque", sans-serif; font-weight:700;
140
+ letter-spacing:-0.02em; color: var(--burgundy);
141
+ max-width: 1100px;
142
+ }
143
+ .s-grid h2 em { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; color: var(--navy); }
144
+ .s-grid .grid {
145
+ display:grid; grid-template-columns: repeat(4, 1fr);
146
+ gap: 24px;
147
+ }
148
+ .s-grid .card {
149
+ border-radius: 28px;
150
+ padding: 28px 28px 30px;
151
+ height: 340px;
152
+ display:flex; flex-direction:column; justify-content:space-between;
153
+ position:relative; overflow:hidden;
154
+ }
155
+ .s-grid .card .num {
156
+ font-family:"JetBrains Mono", monospace;
157
+ font-size: 24px; letter-spacing:0.15em;
158
+ opacity:0.7;
159
+ }
160
+ .s-grid .card h4 {
161
+ font-size: 40px; line-height:1; margin: 0;
162
+ font-weight:600; letter-spacing:-0.02em;
163
+ }
164
+ .s-grid .card p { font-size: 24px; line-height:1.4; margin:0; opacity:0.85; }
165
+ .s-grid .c1, .s-grid .c3, .s-grid .c5, .s-grid .c7 { background: var(--burgundy); color: var(--butter); }
166
+ .s-grid .c2, .s-grid .c4, .s-grid .c6, .s-grid .c8 { background: var(--butter); color: var(--burgundy); }
167
+
168
+ /* ========== SLIDE 4: BIG STAT / EDITORIAL ========== */
169
+ .s-stat { background: var(--burgundy); color: var(--cream); padding: 96px 64px; position:relative; }
170
+ .s-stat .toprow { display:flex; justify-content:space-between; align-items:flex-start; }
171
+ .s-stat .kicker { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.18em; text-transform:uppercase; color: var(--butter); }
172
+ .s-stat .swatches { display:flex; gap:10px; }
173
+ .s-stat .swatches i { width:36px; height:36px; border-radius:999px; display:block; }
174
+ .s-stat .figure {
175
+ margin-top: 20px;
176
+ font-family:"Bricolage Grotesque", sans-serif;
177
+ font-weight:700;
178
+ font-size: 540px;
179
+ line-height: 0.78;
180
+ letter-spacing: -0.06em;
181
+ color: var(--pink);
182
+ display:flex; align-items:flex-start;
183
+ }
184
+ .s-stat .figure .pct { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; font-size:220px; color: var(--lime); margin-top: 60px; margin-left: 20px; }
185
+ .s-stat .breakdown {
186
+ position:absolute; right:64px; bottom:80px;
187
+ width: 600px;
188
+ }
189
+ .s-stat .breakdown .row {
190
+ display:grid; grid-template-columns: 150px 1fr 90px;
191
+ gap: 16px; align-items:center; padding: 14px 0;
192
+ border-top: 1px solid rgba(246,237,220,0.25);
193
+ font-size: 24px;
194
+ }
195
+ .s-stat .breakdown .row:last-child { border-bottom: 1px solid rgba(246,237,220,0.25); }
196
+ .s-stat .breakdown .row .lbl { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.1em; text-transform:uppercase; opacity:0.7; }
197
+ .s-stat .breakdown .row .bar { height:10px; border-radius:999px; background: rgba(246,237,220,0.15); position:relative; overflow:hidden; }
198
+ .s-stat .breakdown .row .bar i { display:block; height:100%; border-radius:999px; }
199
+ .s-stat .breakdown .row .val { font-family:"JetBrains Mono", monospace; font-size:24px; text-align:right; }
200
+
201
+ /* ========== SLIDE 5: TIMELINE ========== */
202
+ .s-timeline { background: var(--butter); padding: 96px 80px; }
203
+ .s-timeline .head { display:flex; justify-content:space-between; align-items:flex-start; gap: 48px; margin-bottom: 48px; }
204
+ .s-timeline .head h2 {
205
+ margin:0; font-size: 76px; line-height:0.95;
206
+ font-weight:700; letter-spacing:-0.02em; color: var(--burgundy);
207
+ max-width: 1100px;
208
+ }
209
+ .s-timeline .head h2 em { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; color: var(--burgundy); }
210
+ .s-timeline .head .meta { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.15em; text-transform:uppercase; text-align:right; line-height:1.5; color: var(--burgundy); flex-shrink:0; }
211
+ .s-timeline .head .meta span { display:block; opacity:0.55; margin-top: 4px; }
212
+ .s-timeline .track {
213
+ position:relative;
214
+ padding: 60px 0 40px;
215
+ }
216
+ .s-timeline .axis {
217
+ position:absolute; left:0; right:0; top: 110px;
218
+ height: 4px; background: var(--ink); opacity:0.15;
219
+ }
220
+ .s-timeline .stops {
221
+ display:grid; grid-template-columns: repeat(5, 1fr);
222
+ gap: 24px; position:relative;
223
+ }
224
+ .s-timeline .stop { position:relative; padding-top: 90px; }
225
+ .s-timeline .stop .dot {
226
+ position:absolute; top: 90px; left: 0;
227
+ width: 28px; height: 28px; border-radius: 999px;
228
+ transform: translateY(-50%);
229
+ border: 4px solid var(--butter);
230
+ background: var(--burgundy);
231
+ display: none;
232
+ }
233
+ .s-timeline .stop .yr {
234
+ font-family:"Instrument Serif", serif; font-style:italic;
235
+ font-size: 56px; line-height:1; margin-bottom: 12px;
236
+ color: var(--burgundy);
237
+ }
238
+ .s-timeline .stop h5 {
239
+ margin:0 0 12px; font-size:28px; font-weight:600; letter-spacing:-0.01em; color: var(--burgundy);
240
+ }
241
+ .s-timeline .stop p { margin:0; font-size:24px; line-height:1.45; color: var(--burgundy); opacity:0.8; }
242
+
243
+ .s-timeline .ribbon {
244
+ margin-top: 56px;
245
+ background: var(--burgundy); color: var(--butter);
246
+ border-radius: 999px;
247
+ padding: 24px 44px;
248
+ display:flex; justify-content:space-between; align-items:center;
249
+ font-family:"JetBrains Mono", monospace; font-size: 24px; letter-spacing:0.15em; text-transform:uppercase;
250
+ }
251
+ .s-timeline .ribbon strong { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; font-size:30px; letter-spacing:0; text-transform:none; color: var(--pink); }
252
+
253
+ /* ========== SLIDE 6: CHART ========== */
254
+ .s-chart { background: var(--navy); color: var(--cream); padding: 88px 64px; display:grid; grid-template-columns: 1.1fr 1fr; gap:64px; }
255
+ .s-chart .l h2 {
256
+ margin:0 0 24px; font-size: 84px; line-height:0.95;
257
+ font-weight:700; letter-spacing:-0.02em;
258
+ }
259
+ .s-chart .l h2 em { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; color: var(--butter); }
260
+ .s-chart .l .lede { font-size: 24px; line-height:1.5; max-width: 640px; opacity:0.85; }
261
+ .s-chart .l .legend {
262
+ margin-top: 56px;
263
+ display:flex; flex-direction:column; gap: 16px;
264
+ }
265
+ .s-chart .l .legend .item { display:flex; align-items:center; gap: 14px; font-size:24px; }
266
+ .s-chart .l .legend .item i { width:14px; height:14px; border-radius:4px; display:block; }
267
+ .s-chart .l .legend .item .cat { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.1em; text-transform:uppercase; opacity:0.7; margin-left:auto; }
268
+ .s-chart .r {
269
+ background: var(--cream); color: var(--ink);
270
+ border-radius: 32px;
271
+ padding: 48px 48px 56px;
272
+ display:flex; flex-direction:column;
273
+ position:relative;
274
+ }
275
+ .s-chart .r .head { display:flex; justify-content:space-between; align-items:center; margin-bottom: 32px; }
276
+ .s-chart .r .head .ttl { font-family:"Instrument Serif", serif; font-style:italic; font-size: 40px; }
277
+ .s-chart .r .head .unit { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.1em; text-transform:uppercase; opacity:0.6; }
278
+ .s-chart svg.chart { width:100%; flex:0 0 auto; max-height: 480px; }
279
+ .s-chart .r .xax { display:grid; grid-template-columns: repeat(6, 1fr); margin-top: 12px; font-family:"JetBrains Mono", monospace; font-size:24px; opacity:0.6; letter-spacing:0.1em; }
280
+
281
+ /* ========== SLIDE 7: QUOTE / EDITORIAL SPLIT ========== */
282
+ .s-quote { background: var(--lime); color: var(--ink); padding: 0; display:grid; grid-template-columns: 0.95fr 1fr; }
283
+ .s-quote .l { padding: 80px 56px 80px 80px; display:flex; flex-direction:column; justify-content:space-between; gap: 24px; position:relative; }
284
+ .s-quote .l .top { display:flex; flex-direction:column; gap: 12px; }
285
+ .s-quote .l .mark { font-family:"Instrument Serif", serif; font-style:italic; font-size: 200px; line-height:0.6; color: var(--burgundy); margin: 80px 0 0 0; }
286
+ .s-quote .l blockquote {
287
+ margin: 0;
288
+ font-family:"Instrument Serif", serif; font-style:italic;
289
+ font-size: 64px; line-height:1.1;
290
+ color: var(--ink);
291
+ max-width: 760px;
292
+ }
293
+ .s-quote .l blockquote b { font-family:"Bricolage Grotesque", sans-serif; font-style:normal; font-weight:600; color: var(--burgundy); }
294
+ .s-quote .l .attribution { display:flex; align-items:center; gap:20px; }
295
+ .s-quote .l .avatar { width:72px; height:72px; border-radius:999px; background: var(--burgundy); border:3px solid var(--burgundy); }
296
+ .s-quote .l .who { font-size:26px; font-weight:600; }
297
+ .s-quote .l .who small { display:block; font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.1em; text-transform:uppercase; opacity:0.65; font-weight:400; margin-top:4px; }
298
+ .s-quote .r {
299
+ background: var(--burgundy); color: var(--butter);
300
+ padding: 96px 80px;
301
+ display:flex; flex-direction:column; gap: 28px;
302
+ position:relative;
303
+ }
304
+ .s-quote .r h3 { margin:0; font-size: 56px; font-weight:600; line-height:1; letter-spacing:-0.02em; }
305
+ .s-quote .r .endorsements { display:flex; flex-direction:column; gap: 20px; margin-top: 8px; }
306
+ .s-quote .r .endorsements .row {
307
+ display:grid; grid-template-columns: 80px 1fr;
308
+ gap: 20px; align-items:center;
309
+ padding: 20px 0; border-top: 1px solid rgba(246,237,220,0.3);
310
+ }
311
+ .s-quote .r .endorsements .row:last-child { border-bottom: 1px solid rgba(246,237,220,0.3); }
312
+ .s-quote .r .endorsements .num { font-family:"Instrument Serif", serif; font-style:italic; font-size: 56px; line-height:1; color: var(--pink); }
313
+ .s-quote .r .endorsements .txt { font-size: 26px; line-height:1.4; }
314
+ .s-quote .r .endorsements .txt strong { font-weight:600; display:block; margin-bottom: 4px; }
315
+
316
+ /* ========== SLIDE 8: CLOSER / INDEX ========== */
317
+ .s-closer { background: var(--ink); color: var(--cream); padding: 96px 64px; position:relative; }
318
+ .s-closer .top { display:flex; justify-content:space-between; align-items:flex-start; }
319
+ .s-closer .top .kicker { font-family:"JetBrains Mono", monospace; font-size:24px; letter-spacing:0.18em; text-transform:uppercase; color: var(--lime); }
320
+ .s-closer .big {
321
+ margin-top: 40px;
322
+ font-family:"Bricolage Grotesque", sans-serif;
323
+ font-weight:700;
324
+ font-size: 320px;
325
+ line-height: 0.82;
326
+ letter-spacing: -0.05em;
327
+ color: var(--pink);
328
+ max-width: 800px;
329
+ }
330
+ .s-closer .big em { display:inline-block; margin-left: -20px; }
331
+ .s-closer .big em { font-family:"Instrument Serif", serif; font-style:italic; font-weight:400; color: var(--butter); }
332
+ .s-closer .grid {
333
+ position:absolute; left:64px; right:64px; bottom: 120px;
334
+ display:grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
335
+ }
336
+ .s-closer .grid .col h6 {
337
+ margin: 0 0 16px;
338
+ font-family:"JetBrains Mono", monospace;
339
+ font-size:24px; letter-spacing:0.15em; text-transform:uppercase;
340
+ color: var(--lime); font-weight:500;
341
+ }
342
+ .s-closer .grid .col p { margin:0; font-size: 24px; line-height:1.45; }
343
+ .s-closer .grid .col p + p { margin-top: 8px; }
344
+ .s-closer .corner-pills {
345
+ position:absolute; right:64px; top: 200px;
346
+ display:flex; flex-direction:column; gap: 12px; align-items:flex-end;
347
+ }
348
+ .s-closer .corner-pills .pill { font-size:22px; padding: 10px 24px; }
349
+ </style>
350
+ </head>
351
+ <body>
352
+ <deck-stage>
353
+
354
+ <!-- ============ SLIDE 1: COVER ============ -->
355
+ <section class="s-cover" data-screen-label="01 Cover">
356
+ <div class="meta">
357
+ <span>Vol. 04 &mdash; Editorial Brief</span>
358
+ <span>Spring / Summer Edition</span>
359
+ <span>FW · 2026</span>
360
+ </div>
361
+
362
+ <div class="pill-cluster">
363
+ <span class="pill" style="background:var(--burgundy); color:var(--pink)">focus</span>
364
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">tech-equipped</span>
365
+ <span class="pill" style="background:var(--burgundy); color:var(--butter)">creativity</span>
366
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">coffee</span>
367
+ <span class="pill" style="background:var(--burgundy); color:var(--pink)">community</span>
368
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">coworking</span>
369
+ <span class="pill" style="background:var(--burgundy); color:var(--butter)">productivity</span>
370
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">inspiration</span>
371
+ <span class="pill" style="background:var(--burgundy); color:var(--pink)">flexible</span>
372
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">workshops</span>
373
+ <span class="pill" style="background:var(--burgundy); color:var(--butter)">collaboration</span>
374
+ <span class="pill" style="background:var(--butter); color:var(--burgundy)">studio</span>
375
+ </div>
376
+
377
+ <div class="wordmark">
378
+ <span>Studio</span>
379
+ <span class="amp" style="color:var(--butter); margin: 0 24px 24px;">&amp;</span>
380
+ <span>Salon</span>
381
+ </div>
382
+ </section>
383
+
384
+ <!-- ============ SLIDE 2: MANIFESTO ============ -->
385
+ <section class="s-manifesto" data-screen-label="02 Manifesto">
386
+ <div class="left">
387
+ <div>
388
+ <div class="label" style="margin-bottom:32px; color: var(--burgundy);">Chapter One · Manifesto</div>
389
+ <div class="chapter">01<sup></sup></div>
390
+ </div>
391
+ <div class="lede">
392
+ Placeholder lede sets the tone for the whole document. A short, declarative sentence followed by an <em>aside in italic</em> that carries the warmth.
393
+ </div>
394
+ <div class="mono" style="font-size:24px; letter-spacing:0.12em; opacity:0.6; text-transform:uppercase;">Page 002 / 016 &nbsp;·&nbsp; Read Time 04:30</div>
395
+ </div>
396
+ <div class="right">
397
+ <div>
398
+ <h3>An opening note</h3>
399
+ <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed posuere consectetur est at lobortis. Cras justo odio, dapibus ac facilisis in, egestas eget quam.</p>
400
+ <p>Maecenas faucibus mollis interdum. Nullam quis risus eget urna mollis ornare vel eu leo. Donec ullamcorper nulla non metus auctor fringilla.</p>
401
+ <p>Vestibulum id ligula porta felis euismod semper. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.</p>
402
+ </div>
403
+ <div>
404
+ <div class="signature">— with warmth,</div>
405
+ <div style="font-family:'JetBrains Mono', monospace; font-size:24px; letter-spacing:0.18em; text-transform:uppercase; margin-top: 12px; color: var(--butter);">The Editorial Desk</div>
406
+ </div>
407
+ </div>
408
+ </section>
409
+
410
+ <!-- ============ SLIDE 3: VALUES GRID ============ -->
411
+ <section class="s-grid" data-screen-label="03 Principles">
412
+ <div style="display:flex; justify-content:space-between; align-items:flex-end; margin-bottom: 24px;">
413
+ <h2>Eight principles, <em>loosely held.</em></h2>
414
+ <div class="mono" style="font-size:24px; letter-spacing:0.15em; text-transform:uppercase; color: var(--burgundy);">§ 03 — Principles</div>
415
+ </div>
416
+ <div class="grid">
417
+ <div class="card c1">
418
+ <div class="num">/ 01</div>
419
+ <h4>Slow looking</h4>
420
+ <p>A short paragraph describing the principle in plain language. Two sentences is plenty.</p>
421
+ </div>
422
+ <div class="card c2">
423
+ <div class="num">/ 02</div>
424
+ <h4>Open kitchen</h4>
425
+ <p>Process in public. Show the seams, the sketches, the half-formed thoughts before they harden.</p>
426
+ </div>
427
+ <div class="card c3">
428
+ <div class="num">/ 03</div>
429
+ <h4>Borrowed light</h4>
430
+ <p>Cite generously. The best ideas always belong to a lineage; name the room you walked into.</p>
431
+ </div>
432
+ <div class="card c4">
433
+ <div class="num">/ 04</div>
434
+ <h4>Quiet defaults</h4>
435
+ <p>Restraint as a posture. Loud only when the moment earns it; otherwise, a soft shoulder.</p>
436
+ </div>
437
+ <div class="card c5">
438
+ <div class="num">/ 05</div>
439
+ <h4>Fewer, finer</h4>
440
+ <p>Pare back the pile. Three considered objects beat thirty hurried ones, every single time.</p>
441
+ </div>
442
+ <div class="card c6">
443
+ <div class="num">/ 06</div>
444
+ <h4>Generous edges</h4>
445
+ <p>Margins are mercy. Leave white space for the reader to breathe and bring their own.</p>
446
+ </div>
447
+ <div class="card c7">
448
+ <div class="num">/ 07</div>
449
+ <h4>Hand in it</h4>
450
+ <p>A trace of the maker, on purpose. Polish should never quite hide the fingerprints.</p>
451
+ </div>
452
+ <div class="card c8">
453
+ <div class="num">/ 08</div>
454
+ <h4>To be added</h4>
455
+ <p>A placeholder principle, awaiting the next conversation. The list is not yet finished.</p>
456
+ </div>
457
+ </div>
458
+ </section>
459
+
460
+ <!-- ============ SLIDE 4: BIG STAT ============ -->
461
+ <section class="s-stat" data-screen-label="04 Headline figure">
462
+ <div class="toprow">
463
+ <div>
464
+ <div class="kicker">§ 04 — Headline Figure</div>
465
+ <div class="serif" style="font-size: 48px; margin-top: 16px; color: var(--pink);">A portrait, in numbers.</div>
466
+ </div>
467
+ <div class="swatches">
468
+ <i style="background:var(--pink)"></i>
469
+ <i style="background:var(--lime)"></i>
470
+ <i style="background:var(--butter)"></i>
471
+ <i style="background:var(--terracotta)"></i>
472
+ <i style="background:var(--sky)"></i>
473
+ </div>
474
+ </div>
475
+
476
+ <div class="figure" style="margin-left:0px; max-width: 900px;">
477
+ <span>72</span><span class="pct">%</span>
478
+ </div>
479
+ <div style="position:absolute; left:64px; bottom:80px; max-width: 900px;">
480
+ <div class="kicker" style="color:var(--butter);">What this measures</div>
481
+ <p style="font-size:24px; line-height:1.45; margin-top:18px; opacity:0.9;">Placeholder annotation. A short, candid sentence about what the figure means and, more importantly, what it doesn't. Survey of n=842, fielded in placeholder month, weighted to placeholder population.</p>
482
+ </div>
483
+
484
+ <div class="breakdown">
485
+ <div class="kicker" style="margin-bottom:12px;">Composition</div>
486
+ <div class="row">
487
+ <span class="lbl">Segment A</span>
488
+ <span class="bar"><i style="width:82%; background:var(--lime)"></i></span>
489
+ <span class="val">82.4</span>
490
+ </div>
491
+ <div class="row">
492
+ <span class="lbl">Segment B</span>
493
+ <span class="bar"><i style="width:64%; background:var(--butter)"></i></span>
494
+ <span class="val">63.9</span>
495
+ </div>
496
+ <div class="row">
497
+ <span class="lbl">Segment C</span>
498
+ <span class="bar"><i style="width:48%; background:var(--terracotta)"></i></span>
499
+ <span class="val">48.1</span>
500
+ </div>
501
+ <div class="row">
502
+ <span class="lbl">Segment D</span>
503
+ <span class="bar"><i style="width:31%; background:var(--sky)"></i></span>
504
+ <span class="val">31.0</span>
505
+ </div>
506
+ </div>
507
+ </section>
508
+
509
+ <!-- ============ SLIDE 5: TIMELINE ============ -->
510
+ <section class="s-timeline" data-screen-label="05 Trajectory">
511
+ <div class="head">
512
+ <h2>A short trajectory, <em>told in five stops.</em></h2>
513
+ <div class="meta">
514
+ § 05 — Trajectory<br/>
515
+ <span style="opacity:0.5;">2019 → present</span>
516
+ </div>
517
+ </div>
518
+
519
+ <div class="track">
520
+ <div class="axis"></div>
521
+ <div class="stops">
522
+ <div class="stop">
523
+ <span class="dot"></span>
524
+ <div class="yr">'19</div>
525
+ <h5>The first prototype</h5>
526
+ <p>A short caption per milestone, written in plain prose. One observation, one consequence.</p>
527
+ </div>
528
+ <div class="stop">
529
+ <span class="dot"></span>
530
+ <div class="yr">'21</div>
531
+ <h5>Quiet expansion</h5>
532
+ <p>Placeholder copy describing a turning point. Keep the writing concrete, never abstract.</p>
533
+ </div>
534
+ <div class="stop">
535
+ <span class="dot"></span>
536
+ <div class="yr">'23</div>
537
+ <h5>A new house style</h5>
538
+ <p>Type, color, voice — re-cast around a single editorial premise; everything else followed.</p>
539
+ </div>
540
+ <div class="stop">
541
+ <span class="dot"></span>
542
+ <div class="yr">'25</div>
543
+ <h5>The salon, formalized</h5>
544
+ <p>Monthly gatherings became a fixture, then a discipline, then the work's center of gravity.</p>
545
+ </div>
546
+ <div class="stop">
547
+ <span class="dot"></span>
548
+ <div class="yr">'26</div>
549
+ <h5>Where we sit now</h5>
550
+ <p>Present tense. A brief, honest description of the shape of the practice today, in two breaths.</p>
551
+ </div>
552
+ </div>
553
+ </div>
554
+
555
+ <div class="ribbon">
556
+ <span>Next chapter loading</span>
557
+ <strong>— and the work continues, gently.</strong>
558
+ <span>Vol. 05 / Autumn</span>
559
+ </div>
560
+ </section>
561
+
562
+ <!-- ============ SLIDE 6: CHART ============ -->
563
+ <section class="s-chart" data-screen-label="06 Composition">
564
+ <div class="l">
565
+ <div class="label" style="color:var(--butter); margin-bottom: 20px;">§ 06 — Composition</div>
566
+ <h2>How the days <em>arrange themselves.</em></h2>
567
+ <p class="lede">A placeholder description for the chart on the right. Speak to the shape of the data — what rises, what plateaus — not the precise figures. Methodology and a one-line caveat live at the bottom.</p>
568
+ <div class="legend">
569
+ <div class="item"><i style="background:var(--pink); border:1px solid var(--burgundy);"></i> Studio hours, deep work <span class="cat">Series A</span></div>
570
+ <div class="item"><i style="background:var(--butter); border:2px solid var(--burgundy); border-radius:999px;"></i> Salon &amp; conversation <span class="cat">Series B</span></div>
571
+ <div class="item"><i style="background:var(--burgundy);"></i> Reading, drift, walking <span class="cat">Series C</span></div>
572
+ <div class="item"><i style="background:transparent; border-top: 3px dotted var(--butter); border-radius:0; height: 0;"></i> Correspondence, admin <span class="cat">Series D</span></div>
573
+ </div>
574
+ <div class="mono" style="margin-top: 40px; font-size:24px; letter-spacing:0.1em; text-transform:uppercase; opacity:0.5;">Source: internal logs · self-reported · n = 24 weeks</div>
575
+ </div>
576
+ <div class="r">
577
+ <div class="head">
578
+ <span class="ttl">Hours per week, by mode</span>
579
+ <span class="unit">Hrs / wk</span>
580
+ </div>
581
+ <svg class="chart" viewBox="0 0 720 380" preserveAspectRatio="none">
582
+ <!-- gridlines -->
583
+ <g stroke="#7A1F35" stroke-opacity="0.15" stroke-width="1">
584
+ <line x1="60" y1="40" x2="720" y2="40" />
585
+ <line x1="60" y1="125" x2="720" y2="125" />
586
+ <line x1="60" y1="210" x2="720" y2="210" />
587
+ <line x1="60" y1="295" x2="720" y2="295" />
588
+ <line x1="60" y1="380" x2="720" y2="380" />
589
+ </g>
590
+ <!-- y labels -->
591
+ <g font-family="JetBrains Mono, monospace" font-size="24" fill="#7A1F35" fill-opacity="0.6">
592
+ <text x="0" y="48">40</text>
593
+ <text x="0" y="133">30</text>
594
+ <text x="0" y="218">20</text>
595
+ <text x="0" y="303">10</text>
596
+ <text x="8" y="380">0</text>
597
+ </g>
598
+
599
+ <!-- Series A (pink area, burgundy stroke) -->
600
+ <path d="M 60 230 Q 120 200 180 180 T 300 145 T 420 120 T 540 100 T 660 80 L 660 380 L 60 380 Z"
601
+ fill="#F2B6C6" fill-opacity="0.85"/>
602
+ <path d="M 60 230 Q 120 200 180 180 T 300 145 T 420 120 T 540 100 T 660 80"
603
+ fill="none" stroke="#7A1F35" stroke-width="3"/>
604
+
605
+ <!-- Series C bars (burgundy, dark on yellow) -->
606
+ <g fill="#7A1F35">
607
+ <rect x="80" y="320" width="22" height="60" rx="4"/>
608
+ <rect x="190" y="300" width="22" height="80" rx="4"/>
609
+ <rect x="300" y="285" width="22" height="95" rx="4"/>
610
+ <rect x="410" y="275" width="22" height="105" rx="4"/>
611
+ <rect x="520" y="260" width="22" height="120" rx="4"/>
612
+ <rect x="630" y="245" width="22" height="135" rx="4"/>
613
+ </g>
614
+
615
+ <!-- Series B (yellow circles + burgundy line) -->
616
+ <path d="M 90 280 L 200 250 L 310 235 L 420 215 L 530 200 L 640 175"
617
+ fill="none" stroke="#7A1F35" stroke-width="3"/>
618
+ <g fill="#F2D86A" stroke="#7A1F35" stroke-width="3">
619
+ <circle cx="90" cy="280" r="8"/>
620
+ <circle cx="200" cy="250" r="8"/>
621
+ <circle cx="310" cy="235" r="8"/>
622
+ <circle cx="420" cy="215" r="8"/>
623
+ <circle cx="530" cy="200" r="8"/>
624
+ <circle cx="640" cy="175" r="8"/>
625
+ </g>
626
+
627
+ <!-- Series D (burgundy dotted) -->
628
+ <path d="M 90 350 L 200 345 L 310 348 L 420 338 L 530 340 L 640 332"
629
+ fill="none" stroke="#7A1F35" stroke-width="3" stroke-dasharray="2 10" stroke-linecap="round" stroke-opacity="0.6"/>
630
+ </svg>
631
+ <div class="xax">
632
+ <span>W·01</span><span>W·05</span><span>W·09</span><span>W·13</span><span>W·17</span><span>W·24</span>
633
+ </div>
634
+ </div>
635
+ </section>
636
+
637
+ <!-- ============ SLIDE 7: QUOTE / SPLIT ============ -->
638
+ <section class="s-quote" data-screen-label="07 In their words">
639
+ <div class="l">
640
+ <div class="top">
641
+ <div class="mono" style="font-size:24px; letter-spacing:0.18em; text-transform:uppercase; color: var(--burgundy);">§ 07 — In their words</div>
642
+ <div class="mark">&ldquo;</div>
643
+ </div>
644
+ <blockquote>
645
+ A placeholder pull-quote, set in italic with one phrase rendered as <b>bold sans</b> for emphasis, the way good editorial designers have always done it.
646
+ </blockquote>
647
+ <div class="attribution">
648
+ <div class="avatar"></div>
649
+ <div class="who">
650
+ A. Placeholder-Surname
651
+ <small>Editor-at-large · Sister Publication</small>
652
+ </div>
653
+ </div>
654
+ </div>
655
+ <div class="r">
656
+ <div class="label" style="color: var(--butter);">Three short reads</div>
657
+ <h3>Voices, lightly edited &mdash; from the readership.</h3>
658
+ <div class="endorsements">
659
+ <div class="row">
660
+ <span class="num">i.</span>
661
+ <div class="txt">
662
+ <strong>On the rhythm</strong>
663
+ A two-line testimonial that reads as if spoken aloud across a small kitchen table.
664
+ </div>
665
+ </div>
666
+ <div class="row">
667
+ <span class="num">ii.</span>
668
+ <div class="txt">
669
+ <strong>On the company</strong>
670
+ Another short note, three or four beats long, useful and specific without being precious about it.
671
+ </div>
672
+ </div>
673
+ <div class="row">
674
+ <span class="num">iii.</span>
675
+ <div class="txt">
676
+ <strong>On returning</strong>
677
+ A closing testimonial — the one that comes after the others have already convinced the reader.
678
+ </div>
679
+ </div>
680
+ </div>
681
+ </div>
682
+ </section>
683
+
684
+ <!-- ============ SLIDE 8: CLOSER / INDEX ============ -->
685
+ <section class="s-closer" data-screen-label="08 Colophon">
686
+ <div class="top">
687
+ <div>
688
+ <div class="kicker">§ 08 — Colophon &amp; Index</div>
689
+ <div class="serif" style="font-size:48px; color:var(--pink); margin-top:12px;">Until the next volume.</div>
690
+ </div>
691
+ <div class="mono" style="font-size:24px; letter-spacing:0.15em; text-transform:uppercase; opacity:0.7; text-align:right; line-height:1.4;">
692
+ End of issue<br/>
693
+ <span style="opacity:0.5;">No. 04 · 016 pp.</span>
694
+ </div>
695
+ </div>
696
+
697
+ <div class="big">
698
+ Fin<em>.</em>
699
+ </div>
700
+
701
+ <div class="corner-pills">
702
+ <span class="pill" style="background:var(--burgundy); color:var(--cream); font-size:24px; padding: 12px 28px;">issue 04</span>
703
+ <span class="pill" style="background:var(--lime); color:var(--ink); font-size:24px; padding: 12px 28px;">spring volume</span>
704
+ <span class="pill" style="background:var(--butter); color:var(--ink); font-size:24px; padding: 12px 28px;">colophon</span>
705
+ </div>
706
+
707
+ <div class="grid">
708
+ <div class="col">
709
+ <h6>Editorial</h6>
710
+ <p>A. Placeholder</p>
711
+ <p>B. Placeholder</p>
712
+ <p>C. Placeholder</p>
713
+ </div>
714
+ <div class="col">
715
+ <h6>Type</h6>
716
+ <p>Bricolage Grotesque</p>
717
+ <p>Instrument Serif</p>
718
+ <p>JetBrains Mono</p>
719
+ </div>
720
+ <div class="col">
721
+ <h6>Printed by</h6>
722
+ <p>Placeholder Press</p>
723
+ <p>City &amp; State</p>
724
+ <p>Recycled stock, 120gsm</p>
725
+ </div>
726
+ <div class="col">
727
+ <h6>Correspondence</h6>
728
+ <p>desk@placeholder.studio</p>
729
+ <p>P.O. Box 0000</p>
730
+ <p>Routing No. 04 / 26</p>
731
+ </div>
732
+ </div>
733
+ </section>
734
+
735
+ </deck-stage>
736
+ </body>
737
+ </html>