@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,1205 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="utf-8" />
5
+ <title>Cobalt Grid — Slide 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=Newsreader:ital,wght@0,400;0,500;1,300;1,400;1,500&family=Hanken+Grotesk:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap" rel="stylesheet" />
10
+ <style>
11
+ :root {
12
+ --paper: #F0EBDE; /* warm cream / ivory paper canvas */
13
+ --paper-2: #E6E0CE;
14
+ --ink: #1F2BE0; /* electric cobalt / royal blue */
15
+ --ink-soft: #5560E5; /* lighter cobalt for secondary marks */
16
+ --grid: rgba(31, 43, 224, 0.10); /* very faint blue grid */
17
+ --rule: #1F2BE0;
18
+ }
19
+ * { box-sizing: border-box; }
20
+ html, body { margin: 0; padding: 0; height: 100%; background: #0a0a0a; }
21
+ body {
22
+ font-family: 'Hanken Grotesk', 'Helvetica Neue', sans-serif;
23
+ color: var(--ink);
24
+ overflow: hidden;
25
+ }
26
+
27
+ /* Deck wrapper — fills the viewport */
28
+ .deck { position: fixed; inset: 0; display: grid; place-items: center; }
29
+ .stage {
30
+ position: relative;
31
+ width: 100vw; height: 100vh;
32
+ overflow: hidden;
33
+ background: var(--paper);
34
+ }
35
+
36
+ /* Graph-paper grid behind every slide */
37
+ .stage::before {
38
+ content: '';
39
+ position: absolute; inset: 0;
40
+ background-image:
41
+ linear-gradient(to right, var(--grid) 1px, transparent 1px),
42
+ linear-gradient(to bottom, var(--grid) 1px, transparent 1px);
43
+ background-size: clamp(28px, 2.2vw, 44px) clamp(28px, 2.2vw, 44px);
44
+ pointer-events: none;
45
+ z-index: 1;
46
+ }
47
+
48
+ .slide {
49
+ position: absolute; inset: 0;
50
+ opacity: 0; pointer-events: none;
51
+ transition: opacity 280ms ease;
52
+ z-index: 2;
53
+ }
54
+ .slide.active { opacity: 1; pointer-events: auto; }
55
+
56
+ /* ─── TYPE SYSTEM ──────────────────────────────────────────── */
57
+ .disp {
58
+ font-family: 'Newsreader', Georgia, serif;
59
+ font-style: italic;
60
+ font-weight: 400;
61
+ line-height: 0.92;
62
+ letter-spacing: -0.005em;
63
+ color: var(--ink);
64
+ }
65
+ .body-tx {
66
+ font-family: 'Hanken Grotesk', sans-serif;
67
+ font-weight: 400;
68
+ line-height: 1.5;
69
+ color: var(--ink);
70
+ }
71
+ .micro {
72
+ font-family: 'Hanken Grotesk', sans-serif;
73
+ font-weight: 600;
74
+ text-transform: uppercase;
75
+ letter-spacing: 0.16em;
76
+ color: var(--ink);
77
+ }
78
+ .mono {
79
+ font-family: 'DM Mono', ui-monospace, monospace;
80
+ font-weight: 400;
81
+ color: var(--ink);
82
+ }
83
+
84
+ /* Single page-number marker, shared across slides.
85
+ Sits ABOVE the bottom hairline rule, with deliberate space between the
86
+ two so the chrome elements don't collide on any slide. */
87
+ .pagenum {
88
+ position: absolute;
89
+ right: clamp(28px, 2.4vw, 48px);
90
+ bottom: clamp(48px, 4.8vh, 76px);
91
+ font-family: 'DM Mono', ui-monospace, monospace;
92
+ font-size: clamp(11px, 0.82vw, 13px);
93
+ color: var(--ink);
94
+ letter-spacing: 0.06em;
95
+ z-index: 9;
96
+ }
97
+
98
+ /* Top + bottom slim hairlines that frame each slide.
99
+ Echo of the reference's thin rule above and below the composition. The
100
+ bottom rule is pinned at the slide's lower edge so the page number,
101
+ which sits above it, has clear space and never overlaps. */
102
+ .hairlines::before,
103
+ .hairlines::after {
104
+ content: '';
105
+ position: absolute;
106
+ left: clamp(36px, 3.6vw, 80px);
107
+ right: clamp(36px, 3.6vw, 80px);
108
+ height: 1.5px;
109
+ background: var(--ink);
110
+ z-index: 4;
111
+ pointer-events: none;
112
+ }
113
+ .hairlines::before { top: clamp(28px, 2.6vh, 48px); }
114
+ .hairlines::after { bottom: clamp(20px, 2vh, 32px); }
115
+
116
+ /* Fixed nav hint — sits above the bottom hairline, same vertical level
117
+ as the page number on the opposite side, so neither overlaps the rule. */
118
+ .nav-hint {
119
+ position: fixed;
120
+ left: clamp(36px, 3.6vw, 80px);
121
+ bottom: clamp(48px, 4.8vh, 76px);
122
+ font-family: 'DM Mono', ui-monospace, monospace;
123
+ font-size: clamp(10px, 0.75vw, 12px);
124
+ color: var(--ink);
125
+ letter-spacing: 0.08em;
126
+ opacity: 0.4;
127
+ z-index: 12;
128
+ pointer-events: none;
129
+ }
130
+
131
+ /* ─── DECORATIVE: pixel-glitch stair (reusable SVG) ─────────── */
132
+ /* The SVG below renders a column of stair-stepped rectangles, each
133
+ filled with vertical scanlines — a direct echo of the reference's
134
+ "pixelated" shape on the right side. Decorative only, pointer-events
135
+ disabled, sits behind content. */
136
+ .pixel-glitch {
137
+ position: absolute;
138
+ pointer-events: none;
139
+ z-index: 3;
140
+ }
141
+ .pixel-glitch svg { display: block; width: 100%; height: 100%; }
142
+
143
+ /* ─── DECORATIVE: small QR-style block ───────────────────────── */
144
+ /* The QR is paper-backgrounded so it reads as a discrete patch when it
145
+ overlaps the pixel-glitch column behind it — without the paper fill,
146
+ the empty grid cells let the glitch's vertical scanlines bleed
147
+ through and the QR loses its shape. */
148
+ .qr-block {
149
+ position: absolute;
150
+ pointer-events: none;
151
+ z-index: 5;
152
+ display: grid;
153
+ grid-template-columns: repeat(8, 1fr);
154
+ grid-template-rows: repeat(8, 1fr);
155
+ gap: 1.5px;
156
+ background: var(--paper);
157
+ padding: 4px;
158
+ box-shadow: 0 0 0 1.5px var(--paper);
159
+ }
160
+ .qr-block .px { background: var(--paper); }
161
+ .qr-block .px.on { background: var(--ink); }
162
+
163
+ /* ──────────────────────────────────────────────────────────────
164
+ SLIDE 1 — COVER
165
+ ────────────────────────────────────────────────────────────── */
166
+ .s-cover { background: var(--paper); }
167
+
168
+ .s-cover .titlewrap {
169
+ position: absolute;
170
+ left: clamp(36px, 3.6vw, 80px);
171
+ top: clamp(80px, 9vh, 160px);
172
+ z-index: 5;
173
+ max-width: 60%;
174
+ }
175
+ .s-cover .title {
176
+ font-family: 'Newsreader', Georgia, serif;
177
+ font-style: italic;
178
+ font-weight: 400;
179
+ font-size: clamp(100px, min(11vw, 18vh), 200px);
180
+ line-height: 0.92;
181
+ letter-spacing: -0.008em;
182
+ color: var(--ink);
183
+ }
184
+ .s-cover .subkicker {
185
+ margin-top: clamp(20px, 2.2vh, 36px);
186
+ display: flex; flex-direction: column; gap: 6px;
187
+ }
188
+ .s-cover .subkicker .l {
189
+ font-family: 'Hanken Grotesk', sans-serif;
190
+ font-weight: 600;
191
+ text-transform: uppercase;
192
+ letter-spacing: 0.18em;
193
+ font-size: clamp(13px, 1vw, 16px);
194
+ color: var(--ink);
195
+ }
196
+ .s-cover .subkicker .ed {
197
+ font-family: 'Newsreader', Georgia, serif;
198
+ font-style: italic;
199
+ font-size: clamp(28px, min(2.8vw, 4.6vh), 50px);
200
+ line-height: 1.1;
201
+ color: var(--ink);
202
+ }
203
+
204
+ /* Pixel-glitch column on the right side of the cover */
205
+ .s-cover .pixel-glitch {
206
+ top: clamp(60px, 6vh, 120px);
207
+ right: clamp(36px, 3.6vw, 80px);
208
+ width: clamp(280px, 32vw, 560px);
209
+ bottom: clamp(110px, 12vh, 200px);
210
+ }
211
+
212
+ /* QR block top-right */
213
+ .s-cover .qr-block {
214
+ top: clamp(60px, 6vh, 120px);
215
+ right: clamp(120px, 8vw, 200px);
216
+ width: clamp(58px, 4.2vw, 84px);
217
+ height: clamp(58px, 4.2vw, 84px);
218
+ }
219
+
220
+ /* Vertical right-side label column (reads as a stack of micro-text,
221
+ replacing the Korean column in the reference). */
222
+ .s-cover .vstack {
223
+ position: absolute;
224
+ right: clamp(36px, 3.6vw, 60px);
225
+ top: 50%;
226
+ transform: translateY(-50%);
227
+ z-index: 5;
228
+ display: flex; flex-direction: column;
229
+ gap: clamp(10px, 1.2vh, 18px);
230
+ align-items: end;
231
+ }
232
+ .s-cover .vstack .v-row {
233
+ font-family: 'DM Mono', ui-monospace, monospace;
234
+ font-size: clamp(12px, 0.9vw, 15px);
235
+ line-height: 1;
236
+ color: var(--ink);
237
+ letter-spacing: 0.04em;
238
+ writing-mode: vertical-rl;
239
+ text-orientation: mixed;
240
+ }
241
+
242
+ /* Footer row */
243
+ .s-cover .cfooter {
244
+ /* Constrained to the left half so it never runs under the right-side
245
+ pixel-glitch column on any viewport. */
246
+ position: absolute;
247
+ left: clamp(36px, 3.6vw, 80px);
248
+ right: clamp(680px, 40vw, 880px);
249
+ bottom: clamp(82px, 8vh, 120px);
250
+ display: flex; justify-content: flex-start; align-items: end;
251
+ z-index: 5;
252
+ gap: clamp(28px, 3vw, 56px);
253
+ }
254
+ .s-cover .cfooter .colf {
255
+ font-family: 'Hanken Grotesk', sans-serif;
256
+ font-size: clamp(14px, 0.92vw, 15px);
257
+ line-height: 1.45;
258
+ color: var(--ink);
259
+ }
260
+ .s-cover .cfooter .colf .ftag {
261
+ font-family: 'Hanken Grotesk', sans-serif;
262
+ font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em;
263
+ font-size: clamp(11px, 0.78vw, 13px);
264
+ margin-bottom: 4px;
265
+ color: var(--ink);
266
+ }
267
+
268
+ /* ──────────────────────────────────────────────────────────────
269
+ SLIDE 2 — MANIFESTO
270
+ ────────────────────────────────────────────────────────────── */
271
+ .s-manifesto { background: var(--paper); }
272
+ .s-manifesto .stmt-wrap {
273
+ position: absolute;
274
+ left: clamp(60px, 8vw, 160px);
275
+ right: clamp(60px, 8vw, 160px);
276
+ top: 50%;
277
+ transform: translateY(-50%);
278
+ z-index: 5;
279
+ text-align: left;
280
+ }
281
+ .s-manifesto .stmt {
282
+ font-family: 'Newsreader', Georgia, serif;
283
+ font-style: italic;
284
+ font-weight: 400;
285
+ font-size: clamp(56px, min(6.4vw, 11vh), 120px);
286
+ line-height: 1.05;
287
+ letter-spacing: -0.005em;
288
+ color: var(--ink);
289
+ }
290
+ .s-manifesto .stmt .roman {
291
+ font-style: normal;
292
+ font-weight: 500;
293
+ }
294
+ .s-manifesto .attr {
295
+ margin-top: clamp(28px, 3vh, 50px);
296
+ display: flex; gap: clamp(14px, 1.4vw, 24px); align-items: center;
297
+ border-top: 1px solid var(--ink);
298
+ padding-top: clamp(10px, 1.2vh, 18px);
299
+ }
300
+ .s-manifesto .attr .who {
301
+ font-family: 'Hanken Grotesk', sans-serif;
302
+ font-weight: 600;
303
+ text-transform: uppercase;
304
+ letter-spacing: 0.16em;
305
+ font-size: clamp(12px, 0.85vw, 14px);
306
+ color: var(--ink);
307
+ }
308
+ .s-manifesto .attr .meta-tag {
309
+ font-family: 'DM Mono', ui-monospace, monospace;
310
+ font-size: clamp(12px, 0.82vw, 14px);
311
+ color: var(--ink);
312
+ letter-spacing: 0.04em;
313
+ opacity: 0.78;
314
+ }
315
+
316
+ /* ──────────────────────────────────────────────────────────────
317
+ SLIDE 3 — INDEX (numbered list of trends)
318
+ ────────────────────────────────────────────────────────────── */
319
+ .s-index { background: var(--paper); }
320
+ .s-index .frame {
321
+ position: absolute;
322
+ inset: clamp(76px, 8vh, 130px) clamp(36px, 3.6vw, 80px) clamp(100px, 10vh, 150px);
323
+ display: grid;
324
+ grid-template-columns: 1fr;
325
+ grid-template-rows: auto 1fr;
326
+ gap: clamp(20px, 2.2vh, 36px);
327
+ z-index: 5;
328
+ }
329
+ .s-index .topbar {
330
+ display: flex; align-items: end; justify-content: space-between;
331
+ border-bottom: 1.5px solid var(--ink);
332
+ padding-bottom: clamp(12px, 1.4vh, 22px);
333
+ gap: 30px;
334
+ }
335
+ .s-index .topbar .h {
336
+ font-family: 'Newsreader', Georgia, serif;
337
+ font-style: italic;
338
+ font-size: clamp(48px, min(5vw, 8.5vh), 100px);
339
+ line-height: 0.95;
340
+ color: var(--ink);
341
+ }
342
+ .s-index .topbar .lab-tag {
343
+ font-family: 'Hanken Grotesk', sans-serif;
344
+ font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em;
345
+ font-size: clamp(12px, 0.9vw, 14px);
346
+ color: var(--ink); text-align: right;
347
+ }
348
+ .s-index .list {
349
+ display: grid;
350
+ grid-template-columns: 1fr 1fr;
351
+ grid-template-rows: 1fr 1fr 1fr;
352
+ gap: clamp(14px, 2vh, 28px) clamp(28px, 3vw, 56px);
353
+ }
354
+ .s-index .row { align-self: stretch; }
355
+ .s-index .row {
356
+ display: grid;
357
+ grid-template-columns: 56px 1fr;
358
+ gap: clamp(12px, 1.4vw, 22px);
359
+ border-bottom: 1px solid rgba(31, 43, 224, 0.18);
360
+ padding-bottom: clamp(12px, 1.4vh, 20px);
361
+ }
362
+ .s-index .row .num-tag {
363
+ font-family: 'DM Mono', ui-monospace, monospace;
364
+ font-size: clamp(13px, 0.9vw, 15px);
365
+ color: var(--ink);
366
+ letter-spacing: 0.04em;
367
+ padding-top: 6px;
368
+ }
369
+ .s-index .row h3 {
370
+ margin: 0 0 6px 0;
371
+ font-family: 'Newsreader', Georgia, serif;
372
+ font-style: italic;
373
+ font-weight: 400;
374
+ font-size: clamp(26px, 2vw, 40px);
375
+ line-height: 1.05;
376
+ color: var(--ink);
377
+ }
378
+ .s-index .row p {
379
+ margin: 0;
380
+ font-family: 'Hanken Grotesk', sans-serif;
381
+ font-size: clamp(14px, 0.95vw, 15px);
382
+ line-height: 1.5;
383
+ color: var(--ink);
384
+ max-width: 92%;
385
+ }
386
+
387
+ /* ──────────────────────────────────────────────────────────────
388
+ SLIDE 4 — CHAPTER (display + intro on glitch background)
389
+ ────────────────────────────────────────────────────────────── */
390
+ .s-chapter { background: var(--paper); }
391
+ .s-chapter .pixel-glitch {
392
+ top: clamp(60px, 6vh, 120px);
393
+ right: clamp(0px, 0vw, 0px);
394
+ width: clamp(220px, 26vw, 460px);
395
+ bottom: clamp(110px, 12vh, 200px);
396
+ opacity: 0.75;
397
+ }
398
+ .s-chapter .frame {
399
+ position: absolute;
400
+ left: clamp(36px, 3.6vw, 80px);
401
+ right: clamp(280px, 30vw, 540px);
402
+ top: clamp(80px, 9vh, 140px);
403
+ bottom: clamp(110px, 11vh, 170px);
404
+ display: flex; flex-direction: column;
405
+ justify-content: center;
406
+ z-index: 5;
407
+ gap: clamp(18px, 2vh, 32px);
408
+ }
409
+ .s-chapter .nm-tag {
410
+ font-family: 'DM Mono', ui-monospace, monospace;
411
+ font-size: clamp(13px, 0.92vw, 15px);
412
+ color: var(--ink);
413
+ letter-spacing: 0.06em;
414
+ }
415
+ .s-chapter .ttl {
416
+ font-family: 'Newsreader', Georgia, serif;
417
+ font-style: italic;
418
+ font-weight: 400;
419
+ font-size: clamp(56px, min(6vw, 10vh), 130px);
420
+ line-height: 1.0;
421
+ color: var(--ink);
422
+ letter-spacing: -0.005em;
423
+ }
424
+ .s-chapter .lede {
425
+ font-family: 'Hanken Grotesk', sans-serif;
426
+ font-weight: 400;
427
+ font-size: clamp(15px, 1vw, 18px);
428
+ line-height: 1.5;
429
+ color: var(--ink);
430
+ max-width: 56ch;
431
+ }
432
+
433
+ /* ──────────────────────────────────────────────────────────────
434
+ SLIDE 5 — DATA (vertical pixel-stack bar chart)
435
+ ────────────────────────────────────────────────────────────── */
436
+ .s-data { background: var(--paper); }
437
+ .s-data .frame {
438
+ position: absolute;
439
+ inset: clamp(76px, 8vh, 130px) clamp(36px, 3.6vw, 80px) clamp(100px, 10vh, 150px);
440
+ display: grid;
441
+ grid-template-rows: auto 1fr;
442
+ gap: clamp(20px, 2vh, 36px);
443
+ z-index: 5;
444
+ }
445
+ .s-data .topbar {
446
+ display: flex; align-items: end; justify-content: space-between;
447
+ border-bottom: 1.5px solid var(--ink);
448
+ padding-bottom: clamp(12px, 1.4vh, 22px);
449
+ gap: 30px;
450
+ }
451
+ .s-data .topbar .h {
452
+ font-family: 'Newsreader', Georgia, serif;
453
+ font-style: italic;
454
+ font-size: clamp(46px, min(4.8vw, 8.2vh), 92px);
455
+ line-height: 0.95;
456
+ color: var(--ink);
457
+ }
458
+ .s-data .topbar .lab-tag {
459
+ font-family: 'Hanken Grotesk', sans-serif;
460
+ font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em;
461
+ font-size: clamp(12px, 0.9vw, 14px);
462
+ color: var(--ink); text-align: right;
463
+ }
464
+ .s-data .body {
465
+ display: grid;
466
+ grid-template-columns: 0.8fr 1.6fr;
467
+ gap: clamp(28px, 3vw, 56px);
468
+ }
469
+ .s-data .col-a {
470
+ display: flex; flex-direction: column; justify-content: center;
471
+ gap: clamp(20px, 2.4vh, 36px);
472
+ }
473
+ .s-data .stat .vbig {
474
+ font-family: 'Newsreader', Georgia, serif;
475
+ font-style: italic;
476
+ font-weight: 400;
477
+ font-size: clamp(110px, min(11vw, 18vh), 240px);
478
+ line-height: 0.92;
479
+ color: var(--ink);
480
+ letter-spacing: -0.015em;
481
+ }
482
+ .s-data .stat .lab2 {
483
+ font-family: 'Hanken Grotesk', sans-serif;
484
+ font-weight: 600;
485
+ text-transform: uppercase;
486
+ letter-spacing: 0.16em;
487
+ font-size: clamp(13px, 0.95vw, 15px);
488
+ color: var(--ink);
489
+ margin-top: 6px;
490
+ }
491
+ .s-data .stat .desc {
492
+ font-family: 'Hanken Grotesk', sans-serif;
493
+ font-size: clamp(15px, 1vw, 17px);
494
+ line-height: 1.5;
495
+ color: var(--ink);
496
+ max-width: 30ch;
497
+ margin-top: 6px;
498
+ }
499
+
500
+ /* The chart itself: a row of vertical "pixel stacks" — each track is
501
+ a column of small filled cells, with cell count proportional to the
502
+ value. Visually echoes the reference's pixel-glitch decoration. */
503
+ .s-data .chart {
504
+ display: flex; flex-direction: column; justify-content: end;
505
+ gap: clamp(10px, 1.2vh, 18px);
506
+ }
507
+ .s-data .chart .bars {
508
+ display: grid;
509
+ grid-template-columns: repeat(8, 1fr);
510
+ gap: clamp(10px, 1vw, 18px);
511
+ align-items: end;
512
+ height: 100%;
513
+ min-height: clamp(280px, 38vh, 540px);
514
+ }
515
+ .s-data .chart .stack {
516
+ display: flex; flex-direction: column-reverse; gap: 3px;
517
+ height: 100%;
518
+ }
519
+ .s-data .chart .stack .cell {
520
+ flex: 1 1 0;
521
+ min-height: 6px;
522
+ background: rgba(31, 43, 224, 0.10);
523
+ }
524
+ .s-data .chart .stack .cell.on { background: var(--ink); }
525
+ .s-data .chart .ticks {
526
+ display: grid;
527
+ grid-template-columns: repeat(8, 1fr);
528
+ gap: clamp(10px, 1vw, 18px);
529
+ border-top: 1.5px solid var(--ink);
530
+ padding-top: clamp(8px, 1vh, 14px);
531
+ }
532
+ .s-data .chart .ticks .ticklab {
533
+ font-family: 'DM Mono', ui-monospace, monospace;
534
+ font-size: clamp(12px, 0.85vw, 14px);
535
+ color: var(--ink);
536
+ letter-spacing: 0.04em;
537
+ text-align: center;
538
+ }
539
+
540
+ /* ──────────────────────────────────────────────────────────────
541
+ SLIDE 6 — QUOTE
542
+ ────────────────────────────────────────────────────────────── */
543
+ .s-quote { background: var(--paper); }
544
+ .s-quote .pixel-glitch {
545
+ top: clamp(40px, 4vh, 80px);
546
+ right: clamp(36px, 3.6vw, 80px);
547
+ width: clamp(160px, 16vw, 280px);
548
+ bottom: clamp(40px, 4vh, 80px);
549
+ opacity: 0.6;
550
+ }
551
+ .s-quote .qframe {
552
+ position: absolute;
553
+ left: clamp(36px, 3.6vw, 80px);
554
+ right: clamp(220px, 22vw, 380px);
555
+ top: 50%;
556
+ transform: translateY(-50%);
557
+ z-index: 5;
558
+ }
559
+ .s-quote .qkicker {
560
+ font-family: 'Hanken Grotesk', sans-serif;
561
+ font-weight: 600;
562
+ text-transform: uppercase;
563
+ letter-spacing: 0.2em;
564
+ font-size: clamp(12px, 0.9vw, 14px);
565
+ color: var(--ink);
566
+ margin-bottom: clamp(16px, 1.8vh, 28px);
567
+ }
568
+ .s-quote .qbody {
569
+ font-family: 'Newsreader', Georgia, serif;
570
+ font-style: italic;
571
+ font-weight: 400;
572
+ font-size: clamp(50px, min(5.6vw, 9vh), 110px);
573
+ line-height: 1.05;
574
+ color: var(--ink);
575
+ letter-spacing: -0.005em;
576
+ max-width: 92%;
577
+ }
578
+ .s-quote .qattr {
579
+ margin-top: clamp(24px, 2.6vh, 40px);
580
+ display: grid; grid-template-columns: auto 1fr;
581
+ gap: clamp(14px, 1.4vw, 24px);
582
+ align-items: end;
583
+ border-top: 1px solid var(--ink);
584
+ padding-top: clamp(10px, 1.2vh, 18px);
585
+ }
586
+ .s-quote .qattr .who-tag {
587
+ font-family: 'Hanken Grotesk', sans-serif;
588
+ font-weight: 600;
589
+ text-transform: uppercase;
590
+ letter-spacing: 0.16em;
591
+ font-size: clamp(13px, 0.92vw, 15px);
592
+ color: var(--ink);
593
+ }
594
+ .s-quote .qattr .role-meta {
595
+ font-family: 'DM Mono', ui-monospace, monospace;
596
+ font-size: clamp(12px, 0.85vw, 14px);
597
+ color: var(--ink);
598
+ letter-spacing: 0.04em;
599
+ opacity: 0.78;
600
+ }
601
+
602
+ /* ──────────────────────────────────────────────────────────────
603
+ SLIDE 7 — TREND TABLE (dense ledger)
604
+ ────────────────────────────────────────────────────────────── */
605
+ .s-table { background: var(--paper); }
606
+ .s-table .frame {
607
+ position: absolute;
608
+ inset: clamp(76px, 8vh, 130px) clamp(36px, 3.6vw, 80px) clamp(100px, 10vh, 150px);
609
+ display: flex; flex-direction: column;
610
+ z-index: 5;
611
+ }
612
+ .s-table .topbar {
613
+ display: flex; align-items: end; justify-content: space-between;
614
+ border-bottom: 1.5px solid var(--ink);
615
+ padding-bottom: clamp(12px, 1.4vh, 22px);
616
+ margin-bottom: clamp(14px, 1.6vh, 24px);
617
+ gap: 30px;
618
+ }
619
+ .s-table .topbar .h {
620
+ font-family: 'Newsreader', Georgia, serif;
621
+ font-style: italic;
622
+ font-size: clamp(46px, min(4.8vw, 8.2vh), 92px);
623
+ line-height: 0.95;
624
+ color: var(--ink);
625
+ }
626
+ .s-table .topbar .lab-tag {
627
+ font-family: 'Hanken Grotesk', sans-serif;
628
+ font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em;
629
+ font-size: clamp(12px, 0.9vw, 14px);
630
+ color: var(--ink); text-align: right;
631
+ }
632
+ .s-table .ledger {
633
+ flex: 1;
634
+ display: flex;
635
+ flex-direction: column;
636
+ gap: 0;
637
+ /* Distribute the rows so they fill the available height.
638
+ The header row stays at the top, body rows space evenly below. */
639
+ justify-content: stretch;
640
+ }
641
+ .s-table .row {
642
+ display: grid;
643
+ grid-template-columns: 76px 0.6fr 1.4fr 0.7fr 0.5fr;
644
+ gap: clamp(14px, 1.4vw, 28px);
645
+ align-items: center;
646
+ padding: 0;
647
+ flex: 1 1 0;
648
+ min-height: clamp(46px, 6vh, 80px);
649
+ border-bottom: 1px solid rgba(31, 43, 224, 0.18);
650
+ }
651
+ .s-table .row.headrow {
652
+ border-bottom: 1.5px solid var(--ink);
653
+ flex: 0 0 auto;
654
+ min-height: 0;
655
+ padding: 8px 0;
656
+ }
657
+ .s-table .row.headrow > div {
658
+ font-family: 'Hanken Grotesk', sans-serif;
659
+ font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em;
660
+ font-size: clamp(11px, 0.75vw, 12px);
661
+ color: var(--ink);
662
+ }
663
+ .s-table .num-tag {
664
+ font-family: 'DM Mono', ui-monospace, monospace;
665
+ font-size: clamp(13px, 0.95vw, 15px);
666
+ color: var(--ink);
667
+ letter-spacing: 0.04em;
668
+ }
669
+ .s-table .nm {
670
+ font-family: 'Newsreader', Georgia, serif;
671
+ font-style: italic;
672
+ font-size: clamp(20px, 1.6vw, 28px);
673
+ line-height: 1.15;
674
+ color: var(--ink);
675
+ }
676
+ .s-table .desc {
677
+ font-family: 'Hanken Grotesk', sans-serif;
678
+ font-size: clamp(14px, 0.95vw, 15px);
679
+ line-height: 1.4;
680
+ color: var(--ink);
681
+ }
682
+ .s-table .mood-tag {
683
+ font-family: 'Hanken Grotesk', sans-serif;
684
+ font-weight: 600;
685
+ font-size: clamp(13px, 0.92vw, 15px);
686
+ color: var(--ink);
687
+ }
688
+ .s-table .delta-tag {
689
+ font-family: 'DM Mono', ui-monospace, monospace;
690
+ font-size: clamp(13px, 0.92vw, 15px);
691
+ text-align: right;
692
+ color: var(--ink);
693
+ letter-spacing: 0.04em;
694
+ }
695
+ .s-table .delta-tag.up::before { content: '↑ '; }
696
+ .s-table .delta-tag.down::before { content: '↓ '; opacity: 0.6; }
697
+ .s-table .delta-tag.flat::before { content: '— '; opacity: 0.6; }
698
+
699
+ /* ──────────────────────────────────────────────────────────────
700
+ SLIDE 8 — COLOPHON / CLOSING
701
+ ────────────────────────────────────────────────────────────── */
702
+ .s-colophon { background: var(--paper); }
703
+ .s-colophon .pixel-glitch {
704
+ top: clamp(80px, 9vh, 160px);
705
+ left: clamp(36px, 3.6vw, 80px);
706
+ width: clamp(220px, 26vw, 460px);
707
+ bottom: clamp(220px, 22vh, 360px);
708
+ opacity: 0.75;
709
+ }
710
+ .s-colophon .qr-block {
711
+ top: clamp(80px, 9vh, 160px);
712
+ right: clamp(36px, 3.6vw, 80px);
713
+ width: clamp(72px, 5vw, 100px);
714
+ height: clamp(72px, 5vw, 100px);
715
+ }
716
+ .s-colophon .titlewrap {
717
+ position: absolute;
718
+ right: clamp(36px, 3.6vw, 80px);
719
+ top: 28%;
720
+ z-index: 5;
721
+ max-width: 56%;
722
+ text-align: right;
723
+ }
724
+ .s-colophon .ktag {
725
+ font-family: 'Hanken Grotesk', sans-serif;
726
+ font-weight: 600;
727
+ text-transform: uppercase;
728
+ letter-spacing: 0.22em;
729
+ font-size: clamp(12px, 0.9vw, 14px);
730
+ color: var(--ink);
731
+ margin-bottom: clamp(14px, 1.6vh, 24px);
732
+ }
733
+ .s-colophon .ttl {
734
+ font-family: 'Newsreader', Georgia, serif;
735
+ font-style: italic;
736
+ font-weight: 400;
737
+ font-size: clamp(72px, min(8.4vw, 14vh), 180px);
738
+ line-height: 0.96;
739
+ color: var(--ink);
740
+ letter-spacing: -0.005em;
741
+ }
742
+ .s-colophon .col-footer {
743
+ position: absolute;
744
+ left: clamp(36px, 3.6vw, 80px);
745
+ right: clamp(36px, 3.6vw, 80px);
746
+ bottom: clamp(106px, 10.4vh, 160px);
747
+ display: grid;
748
+ grid-template-columns: 1fr 1fr 1fr 1.2fr;
749
+ gap: clamp(20px, 2.4vw, 44px);
750
+ z-index: 5;
751
+ }
752
+ .s-colophon .col-footer > div {
753
+ border-top: 1.5px solid var(--ink);
754
+ padding-top: clamp(10px, 1.2vh, 16px);
755
+ }
756
+ .s-colophon .col-footer .ftag {
757
+ font-family: 'Hanken Grotesk', sans-serif;
758
+ font-weight: 600;
759
+ text-transform: uppercase;
760
+ letter-spacing: 0.18em;
761
+ font-size: clamp(11px, 0.78vw, 13px);
762
+ margin-bottom: 6px;
763
+ color: var(--ink);
764
+ }
765
+ .s-colophon .col-footer .ftxt {
766
+ font-family: 'Hanken Grotesk', sans-serif;
767
+ font-size: clamp(14px, 0.95vw, 15px);
768
+ line-height: 1.5;
769
+ color: var(--ink);
770
+ }
771
+ </style>
772
+ </head>
773
+ <body>
774
+
775
+ <!-- Reusable SVG that draws the staircase of vertical-scanline blocks.
776
+ Used on cover, chapter divider, quote, and colophon. -->
777
+ <svg style="display:none" aria-hidden="true">
778
+ <defs>
779
+ <pattern id="vstripes" width="3" height="100" patternUnits="userSpaceOnUse">
780
+ <line x1="0.5" y1="0" x2="0.5" y2="100" stroke="#1F2BE0" stroke-width="1.2" />
781
+ </pattern>
782
+ </defs>
783
+ </svg>
784
+
785
+ <div class="deck">
786
+ <div class="stage">
787
+
788
+ <!-- 1. COVER ──────────────────────────────────────────────── -->
789
+ <section class="slide s-cover hairlines active">
790
+ <div class="titlewrap">
791
+ <h1 class="title">Index<br/>2026</h1>
792
+ <div class="subkicker">
793
+ <div class="l caption">Field Office Quarterly · Volume IV</div>
794
+ <div class="ed">A field report on the state of things.</div>
795
+ </div>
796
+ </div>
797
+
798
+ <!-- Pixel-glitch staircase decoration -->
799
+ <div class="pixel-glitch" aria-hidden="true">
800
+ <svg viewBox="0 0 100 100" preserveAspectRatio="none">
801
+ <defs>
802
+ <pattern id="vs1" width="2.4" height="100" patternUnits="userSpaceOnUse">
803
+ <line x1="0.5" y1="0" x2="0.5" y2="100" stroke="#1F2BE0" stroke-width="1.0" />
804
+ </pattern>
805
+ </defs>
806
+ <rect x="36" y="0" width="38" height="14" fill="url(#vs1)"/>
807
+ <rect x="22" y="14" width="50" height="12" fill="url(#vs1)"/>
808
+ <rect x="34" y="26" width="46" height="11" fill="url(#vs1)"/>
809
+ <rect x="16" y="37" width="60" height="13" fill="url(#vs1)"/>
810
+ <rect x="28" y="50" width="48" height="11" fill="url(#vs1)"/>
811
+ <rect x="18" y="61" width="62" height="14" fill="url(#vs1)"/>
812
+ <rect x="34" y="75" width="44" height="12" fill="url(#vs1)"/>
813
+ <rect x="22" y="87" width="50" height="13" fill="url(#vs1)"/>
814
+ </svg>
815
+ </div>
816
+
817
+ <!-- Vertical stack of micro-text on far right (replaces Korean) -->
818
+ <div class="vstack">
819
+ <div class="v-row caption">issue.04</div>
820
+ <div class="v-row caption">spring 2026</div>
821
+ <div class="v-row caption">field-office.co</div>
822
+ </div>
823
+
824
+ <!-- Footer row — two columns, sized to clear the right-side pixel-glitch -->
825
+ <div class="cfooter">
826
+ <div class="colf">
827
+ <div class="ftag caption">Edited by</div>
828
+ <div>Field Office Editorial · Lin Ito &amp; Anya Mehrotra</div>
829
+ </div>
830
+ <div class="colf">
831
+ <div class="ftag caption">Distributed</div>
832
+ <div>To subscribers &amp; the open web · twice a year</div>
833
+ </div>
834
+ </div>
835
+
836
+ <div class="pagenum">01 / 08</div>
837
+ </section>
838
+
839
+ <!-- 2. MANIFESTO ───────────────────────────────────────────── -->
840
+ <section class="slide s-manifesto hairlines">
841
+ <div class="stmt-wrap">
842
+ <p class="stmt">A trend is a quiet question that several rooms started asking <span class="roman">at roughly the same time.</span></p>
843
+ <div class="attr">
844
+ <div class="who caption">From the editor's note</div>
845
+ <div class="meta-tag caption">Index 2026 · opening pages</div>
846
+ </div>
847
+ </div>
848
+ <div class="pagenum">02 / 08</div>
849
+ </section>
850
+
851
+ <!-- 3. INDEX OF TRENDS ─────────────────────────────────────── -->
852
+ <section class="slide s-index hairlines">
853
+ <div class="frame">
854
+ <div class="topbar">
855
+ <div class="h">The index, in six entries.</div>
856
+ <div class="lab-tag caption">Spring 2026 · selected trends</div>
857
+ </div>
858
+ <div class="list">
859
+ <div class="row">
860
+ <div class="num-tag caption">01.</div>
861
+ <div>
862
+ <h3>Slow software</h3>
863
+ <p>Tools that opt out of the urgency contest and instead promise to be quiet, considered, and on by default.</p>
864
+ </div>
865
+ </div>
866
+ <div class="row">
867
+ <div class="num-tag caption">02.</div>
868
+ <div>
869
+ <h3>Domestic interfaces</h3>
870
+ <p>Screens designed to live in living rooms — softer typography, warmer colour, and a willingness to be ignored.</p>
871
+ </div>
872
+ </div>
873
+ <div class="row">
874
+ <div class="num-tag caption">03.</div>
875
+ <div>
876
+ <h3>Hand-set print again</h3>
877
+ <p>A return to letterpress, risograph, and small-edition print, often paired with the most digital-feeling clients.</p>
878
+ </div>
879
+ </div>
880
+ <div class="row">
881
+ <div class="num-tag caption">04.</div>
882
+ <div>
883
+ <h3>Quietly weird type</h3>
884
+ <p>Display type with one slightly off detail — a tilted ear, a long tail — that keeps a reader looking twice.</p>
885
+ </div>
886
+ </div>
887
+ <div class="row">
888
+ <div class="num-tag caption">05.</div>
889
+ <div>
890
+ <h3>Receipts and ledgers</h3>
891
+ <p>Information designed to be filed, not consumed. Tabular layouts, dotted leaders, the page returning the favour.</p>
892
+ </div>
893
+ </div>
894
+ <div class="row">
895
+ <div class="num-tag caption">06.</div>
896
+ <div>
897
+ <h3>Public weather</h3>
898
+ <p>Brand and product writing that includes the actual weather of the day, the mood of the team, the unfinished thought.</p>
899
+ </div>
900
+ </div>
901
+ </div>
902
+ </div>
903
+ <div class="pagenum">03 / 08</div>
904
+ </section>
905
+
906
+ <!-- 4. CHAPTER DIVIDER ─────────────────────────────────────── -->
907
+ <section class="slide s-chapter hairlines">
908
+ <div class="pixel-glitch" aria-hidden="true">
909
+ <svg viewBox="0 0 100 100" preserveAspectRatio="none">
910
+ <defs>
911
+ <pattern id="vs4" width="2.4" height="100" patternUnits="userSpaceOnUse">
912
+ <line x1="0.5" y1="0" x2="0.5" y2="100" stroke="#1F2BE0" stroke-width="1.0" />
913
+ </pattern>
914
+ </defs>
915
+ <rect x="40" y="0" width="40" height="14" fill="url(#vs4)"/>
916
+ <rect x="20" y="14" width="56" height="12" fill="url(#vs4)"/>
917
+ <rect x="32" y="26" width="48" height="11" fill="url(#vs4)"/>
918
+ <rect x="14" y="37" width="64" height="13" fill="url(#vs4)"/>
919
+ <rect x="26" y="50" width="50" height="11" fill="url(#vs4)"/>
920
+ <rect x="16" y="61" width="62" height="14" fill="url(#vs4)"/>
921
+ <rect x="32" y="75" width="46" height="12" fill="url(#vs4)"/>
922
+ <rect x="20" y="87" width="54" height="13" fill="url(#vs4)"/>
923
+ </svg>
924
+ </div>
925
+
926
+ <div class="frame">
927
+ <div class="nm-tag caption">Chapter one — the case for slow software</div>
928
+ <h2 class="ttl">Software is a room, and rooms are designed to be lived in slowly.</h2>
929
+ <p class="lede">In its first chapter the Index follows the studios, products, and quiet middleware projects that are walking back the urgency the last decade trained us into. Less push. More return. The tools that do not page you, on principle, are the ones we have chosen to read first.</p>
930
+ </div>
931
+
932
+ <div class="pagenum">04 / 08</div>
933
+ </section>
934
+
935
+ <!-- 5. DATA / PIXEL-STACK CHART ───────────────────────────── -->
936
+ <section class="slide s-data hairlines">
937
+ <div class="frame">
938
+ <div class="topbar">
939
+ <div class="h">Reader response, by quarter.</div>
940
+ <div class="lab-tag caption">Newsletter opens · 2024 Q1 — 2026 Q1</div>
941
+ </div>
942
+ <div class="body">
943
+ <div class="col-a">
944
+ <div class="stat">
945
+ <div class="vbig">82%</div>
946
+ <div class="lab2 caption">Open rate · Q1 2026</div>
947
+ <div class="desc">A 2.1× lift on the inaugural issue, driven mostly by long-form chapters being read on Sunday mornings.</div>
948
+ </div>
949
+ <div class="stat">
950
+ <div class="vbig" style="font-size: clamp(72px, min(7vw, 11vh), 150px);">11k</div>
951
+ <div class="lab2 caption">Active subscribers</div>
952
+ <div class="desc">Quiet, mostly-not-on-social, paying readers; we do not run a referral programme.</div>
953
+ </div>
954
+ </div>
955
+ <div class="chart">
956
+ <!-- Each .stack is a quarter; with column-reverse, the first .cell
957
+ in source order sits at the BOTTOM of the column, so .on cells
958
+ stack up from baseline like a real pixel-bar chart. -->
959
+ <div class="bars">
960
+ <div class="stack"><!-- Q1 2024: 4 -->
961
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
962
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div>
963
+ </div>
964
+ <div class="stack"><!-- Q2 2024: 5 -->
965
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
966
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div>
967
+ </div>
968
+ <div class="stack"><!-- Q3 2024: 5 -->
969
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
970
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div>
971
+ </div>
972
+ <div class="stack"><!-- Q4 2024: 6 -->
973
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
974
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div><div class="cell"></div>
975
+ </div>
976
+ <div class="stack"><!-- Q1 2025: 7 -->
977
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
978
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div>
979
+ </div>
980
+ <div class="stack"><!-- Q2 2025: 7 -->
981
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
982
+ <div class="cell"></div><div class="cell"></div><div class="cell"></div>
983
+ </div>
984
+ <div class="stack"><!-- Q4 2025: 8 -->
985
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
986
+ <div class="cell"></div><div class="cell"></div>
987
+ </div>
988
+ <div class="stack"><!-- Q1 2026: 9 -->
989
+ <div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div><div class="cell on"></div>
990
+ <div class="cell"></div>
991
+ </div>
992
+ </div>
993
+ <div class="ticks">
994
+ <div class="ticklab caption">Q1 24</div>
995
+ <div class="ticklab caption">Q2 24</div>
996
+ <div class="ticklab caption">Q3 24</div>
997
+ <div class="ticklab caption">Q4 24</div>
998
+ <div class="ticklab caption">Q1 25</div>
999
+ <div class="ticklab caption">Q2 25</div>
1000
+ <div class="ticklab caption">Q4 25</div>
1001
+ <div class="ticklab caption">Q1 26</div>
1002
+ </div>
1003
+ </div>
1004
+ </div>
1005
+ </div>
1006
+ <div class="pagenum">05 / 08</div>
1007
+ </section>
1008
+
1009
+ <!-- 6. QUOTE ──────────────────────────────────────────────── -->
1010
+ <section class="slide s-quote hairlines">
1011
+ <div class="pixel-glitch" aria-hidden="true">
1012
+ <svg viewBox="0 0 100 100" preserveAspectRatio="none">
1013
+ <defs>
1014
+ <pattern id="vs6" width="2.4" height="100" patternUnits="userSpaceOnUse">
1015
+ <line x1="0.5" y1="0" x2="0.5" y2="100" stroke="#1F2BE0" stroke-width="1.0" />
1016
+ </pattern>
1017
+ </defs>
1018
+ <rect x="20" y="0" width="50" height="14" fill="url(#vs6)"/>
1019
+ <rect x="34" y="14" width="46" height="13" fill="url(#vs6)"/>
1020
+ <rect x="14" y="27" width="62" height="14" fill="url(#vs6)"/>
1021
+ <rect x="26" y="41" width="50" height="13" fill="url(#vs6)"/>
1022
+ <rect x="22" y="54" width="56" height="14" fill="url(#vs6)"/>
1023
+ <rect x="36" y="68" width="44" height="13" fill="url(#vs6)"/>
1024
+ <rect x="20" y="81" width="60" height="14" fill="url(#vs6)"/>
1025
+ </svg>
1026
+ </div>
1027
+ <div class="qframe">
1028
+ <div class="qkicker caption">A note from the studio</div>
1029
+ <p class="qbody">"We started the bulletin because the loudest readings of design were eating the ones we found ourselves rereading."</p>
1030
+ <div class="qattr">
1031
+ <div class="who-tag caption">Lin Ito</div>
1032
+ <div class="role-meta caption">Editor · Field Office Quarterly · letter to subscribers, March 2025</div>
1033
+ </div>
1034
+ </div>
1035
+ <div class="pagenum">06 / 08</div>
1036
+ </section>
1037
+
1038
+ <!-- 7. TREND TABLE ─────────────────────────────────────────── -->
1039
+ <section class="slide s-table hairlines">
1040
+ <div class="frame">
1041
+ <div class="topbar">
1042
+ <div class="h">Trend ledger, in long.</div>
1043
+ <div class="lab-tag caption">All ten · with our reading on each</div>
1044
+ </div>
1045
+ <div class="ledger">
1046
+ <div class="row headrow">
1047
+ <div class="caption">No.</div>
1048
+ <div class="caption">Trend</div>
1049
+ <div class="caption">Reading</div>
1050
+ <div class="caption">Mood</div>
1051
+ <div class="caption">YoY</div>
1052
+ </div>
1053
+ <div class="row">
1054
+ <div class="num-tag caption">01.</div>
1055
+ <div class="nm">Slow software</div>
1056
+ <div class="desc">Tools that opt out of urgency by default.</div>
1057
+ <div class="mood-tag">Quiet · welcomed</div>
1058
+ <div class="delta-tag up caption">14 pts</div>
1059
+ </div>
1060
+ <div class="row">
1061
+ <div class="num-tag caption">02.</div>
1062
+ <div class="nm">Domestic interfaces</div>
1063
+ <div class="desc">Screens designed to live in living rooms.</div>
1064
+ <div class="mood-tag">Warm · ambient</div>
1065
+ <div class="delta-tag up caption">9 pts</div>
1066
+ </div>
1067
+ <div class="row">
1068
+ <div class="num-tag caption">03.</div>
1069
+ <div class="nm">Hand-set print</div>
1070
+ <div class="desc">Letterpress and risograph paired with digital briefs.</div>
1071
+ <div class="mood-tag">Tactile · careful</div>
1072
+ <div class="delta-tag up caption">7 pts</div>
1073
+ </div>
1074
+ <div class="row">
1075
+ <div class="num-tag caption">04.</div>
1076
+ <div class="nm">Quietly weird type</div>
1077
+ <div class="desc">Display faces with one slightly off detail.</div>
1078
+ <div class="mood-tag">Curious · alert</div>
1079
+ <div class="delta-tag flat caption">flat</div>
1080
+ </div>
1081
+ <div class="row">
1082
+ <div class="num-tag caption">05.</div>
1083
+ <div class="nm">Receipts &amp; ledgers</div>
1084
+ <div class="desc">Information designed to be filed, not consumed.</div>
1085
+ <div class="mood-tag">Plain · honest</div>
1086
+ <div class="delta-tag up caption">5 pts</div>
1087
+ </div>
1088
+ <div class="row">
1089
+ <div class="num-tag caption">06.</div>
1090
+ <div class="nm">Public weather</div>
1091
+ <div class="desc">Brand voice that admits the day's actual mood.</div>
1092
+ <div class="mood-tag">Open · tender</div>
1093
+ <div class="delta-tag up caption">11 pts</div>
1094
+ </div>
1095
+ <div class="row">
1096
+ <div class="num-tag caption">07.</div>
1097
+ <div class="nm">Long-form receipts</div>
1098
+ <div class="desc">Newsletters that read like printed pamphlets.</div>
1099
+ <div class="mood-tag">Slow · sourced</div>
1100
+ <div class="delta-tag up caption">3 pts</div>
1101
+ </div>
1102
+ <div class="row">
1103
+ <div class="num-tag caption">08.</div>
1104
+ <div class="nm">Pre-loved objects</div>
1105
+ <div class="desc">Resale and repair as the front of the brand.</div>
1106
+ <div class="mood-tag">Worn · cared</div>
1107
+ <div class="delta-tag down caption">2 pts</div>
1108
+ </div>
1109
+ </div>
1110
+ </div>
1111
+ <div class="pagenum">07 / 08</div>
1112
+ </section>
1113
+
1114
+ <!-- 8. COLOPHON / CLOSING ─────────────────────────────────── -->
1115
+ <section class="slide s-colophon hairlines">
1116
+ <div class="pixel-glitch" aria-hidden="true">
1117
+ <svg viewBox="0 0 100 100" preserveAspectRatio="none">
1118
+ <defs>
1119
+ <pattern id="vs8" width="2.4" height="100" patternUnits="userSpaceOnUse">
1120
+ <line x1="0.5" y1="0" x2="0.5" y2="100" stroke="#1F2BE0" stroke-width="1.0" />
1121
+ </pattern>
1122
+ </defs>
1123
+ <rect x="0" y="0" width="48" height="13" fill="url(#vs8)"/>
1124
+ <rect x="14" y="13" width="56" height="12" fill="url(#vs8)"/>
1125
+ <rect x="0" y="25" width="64" height="14" fill="url(#vs8)"/>
1126
+ <rect x="20" y="39" width="50" height="13" fill="url(#vs8)"/>
1127
+ <rect x="6" y="52" width="60" height="14" fill="url(#vs8)"/>
1128
+ <rect x="18" y="66" width="48" height="13" fill="url(#vs8)"/>
1129
+ <rect x="0" y="79" width="56" height="14" fill="url(#vs8)"/>
1130
+ <rect x="20" y="93" width="44" height="7" fill="url(#vs8)"/>
1131
+ </svg>
1132
+ </div>
1133
+
1134
+ <div class="qr-block" aria-hidden="true">
1135
+ <span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px"></span><span class="px on"></span>
1136
+ <span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px"></span>
1137
+ <span class="px on"></span><span class="px"></span><span class="px"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px on"></span>
1138
+ <span class="px on"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span>
1139
+ <span class="px"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px"></span><span class="px"></span><span class="px on"></span><span class="px"></span>
1140
+ <span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span>
1141
+ <span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span>
1142
+ <span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px"></span><span class="px on"></span><span class="px on"></span><span class="px"></span>
1143
+ </div>
1144
+
1145
+ <div class="titlewrap">
1146
+ <div class="ktag caption">Colophon · Index 2026</div>
1147
+ <h2 class="ttl">See you in the<br/>autumn issue.</h2>
1148
+ </div>
1149
+
1150
+ <div class="col-footer">
1151
+ <div>
1152
+ <div class="ftag caption">Editors</div>
1153
+ <div class="ftxt">Lin Ito &amp; Anya Mehrotra<br/>with the field-office collective</div>
1154
+ </div>
1155
+ <div>
1156
+ <div class="ftag caption">Designed</div>
1157
+ <div class="ftxt">In Newsreader, Hanken Grotesk<br/>&amp; DM Mono · cobalt on cream</div>
1158
+ </div>
1159
+ <div>
1160
+ <div class="ftag caption">Subscribed</div>
1161
+ <div class="ftxt">field-office.co · twice a year<br/>quiet, paid, and read slowly</div>
1162
+ </div>
1163
+ <div>
1164
+ <div class="ftag caption">Until autumn</div>
1165
+ <div class="ftxt">The next issue ships October 2026. Look for the cobalt envelope on a Monday morning.</div>
1166
+ </div>
1167
+ </div>
1168
+
1169
+ <div class="pagenum">08 / 08</div>
1170
+ </section>
1171
+
1172
+ </div>
1173
+ </div>
1174
+
1175
+ <div class="caption nav-hint">← / → · space</div>
1176
+
1177
+ <script>
1178
+ // Plain vanilla navigation: arrows, space, home/end, swipe.
1179
+ const slides = Array.from(document.querySelectorAll('.slide'));
1180
+ let current = 0;
1181
+ function show(i) {
1182
+ if (i < 0) i = 0;
1183
+ if (i > slides.length - 1) i = slides.length - 1;
1184
+ slides[current].classList.remove('active');
1185
+ slides[i].classList.add('active');
1186
+ current = i;
1187
+ }
1188
+ document.addEventListener('keydown', (e) => {
1189
+ if (e.key === 'ArrowRight' || e.key === 'PageDown' || e.key === ' ') { e.preventDefault(); show(current + 1); }
1190
+ else if (e.key === 'ArrowLeft' || e.key === 'PageUp') { e.preventDefault(); show(current - 1); }
1191
+ else if (e.key === 'Home') { e.preventDefault(); show(0); }
1192
+ else if (e.key === 'End') { e.preventDefault(); show(slides.length - 1); }
1193
+ });
1194
+ let tx = null;
1195
+ document.addEventListener('touchstart', (e) => { tx = e.touches[0].clientX; }, { passive: true });
1196
+ document.addEventListener('touchend', (e) => {
1197
+ if (tx == null) return;
1198
+ const dx = e.changedTouches[0].clientX - tx;
1199
+ if (Math.abs(dx) > 40) show(current + (dx < 0 ? 1 : -1));
1200
+ tx = null;
1201
+ });
1202
+ </script>
1203
+
1204
+ </body>
1205
+ </html>