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