howone 0.1.20 → 0.1.22
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/package.json +1 -1
- package/templates/vite/.howone/skills/hallmark/LICENSE +21 -0
- package/templates/vite/.howone/skills/hallmark/README.md +147 -0
- package/templates/vite/.howone/skills/hallmark/ROADMAP.md +201 -0
- package/templates/vite/.howone/skills/hallmark/SKILL.md +551 -0
- package/templates/vite/.howone/skills/hallmark/docs/recipes.md +186 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-anya.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-bananastudio.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-hyperlane.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-najm.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-slow-pour.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-soroe.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-tally.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-wayfare.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/docs/study-examples.md +176 -0
- package/templates/vite/.howone/skills/hallmark/docs/talk-slides.md +364 -0
- package/templates/vite/.howone/skills/hallmark/package.json +36 -0
- package/templates/vite/.howone/skills/hallmark/references/anti-patterns.md +412 -0
- package/templates/vite/.howone/skills/hallmark/references/assets.md +399 -0
- package/templates/vite/.howone/skills/hallmark/references/color.md +95 -0
- package/templates/vite/.howone/skills/hallmark/references/component-cookbook.md +256 -0
- package/templates/vite/.howone/skills/hallmark/references/components/c1-outlined-chip.md +12 -0
- package/templates/vite/.howone/skills/hallmark/references/components/c2-inline-form-as-cta.md +16 -0
- package/templates/vite/.howone/skills/hallmark/references/components/c3-typographic-link.md +8 -0
- package/templates/vite/.howone/skills/hallmark/references/components/c4-sticky-bottom-bar.md +16 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f1-bento-grid.md +20 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f2-sticky-scroll-stack.md +20 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f3-tabular-spec-sheet.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f4-step-sequence.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f5-annotated-screenshot.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/f6-product-card-grid.md +41 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft1-mast-headed.md +13 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft2-inline-rule-single-line.md +10 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft3-index-style-category-list.md +12 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft4-dense-typographic.md +10 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft5-statement.md +21 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft6-letter-close.md +19 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft7-newsletter-first.md +27 -0
- package/templates/vite/.howone/skills/hallmark/references/components/ft8-marquee-scroll.md +25 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h1-marquee.md +15 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h2-split-diptych.md +15 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h3-quote-led.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h4-stat-led.md +14 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h5-letter-hero.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h6-photographic-fold.md +16 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h7-demo-video-clipped-by-viewport-edge.md +27 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h8-mockup-split-browser-framed.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/components/h9-custom-illustration-centerpiece.md +27 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n1-wordmark-2-links.md +12 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n10-floating-on-scroll-morph.md +19 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n2-floating-chip.md +14 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n3-side-rail.md +14 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n4-hidden-behind-k.md +9 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n5-floating-pill.md +28 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n6-newspaper-masthead.md +24 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n7-brutal-slab.md +22 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n8-terminal-command.md +21 -0
- package/templates/vite/.howone/skills/hallmark/references/components/n9-edge-aligned-minimal.md +17 -0
- package/templates/vite/.howone/skills/hallmark/references/components/s1-left-margin-numbered.md +15 -0
- package/templates/vite/.howone/skills/hallmark/references/components/s2-hanging.md +13 -0
- package/templates/vite/.howone/skills/hallmark/references/components/s3-sticky-pinned.md +19 -0
- package/templates/vite/.howone/skills/hallmark/references/components/s4-inline-no-break.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/s5-bottom-anchored.md +13 -0
- package/templates/vite/.howone/skills/hallmark/references/components/t1-pull-quote-with-marginalia.md +12 -0
- package/templates/vite/.howone/skills/hallmark/references/components/t2-logo-wall-hairline.md +19 -0
- package/templates/vite/.howone/skills/hallmark/references/components/t3-single-huge-quote.md +11 -0
- package/templates/vite/.howone/skills/hallmark/references/components/t4-numbered-stat-strip.md +14 -0
- package/templates/vite/.howone/skills/hallmark/references/contract.md +24 -0
- package/templates/vite/.howone/skills/hallmark/references/copy.md +182 -0
- package/templates/vite/.howone/skills/hallmark/references/custom-craft.md +626 -0
- package/templates/vite/.howone/skills/hallmark/references/custom-theme.md +329 -0
- package/templates/vite/.howone/skills/hallmark/references/design-md.md +116 -0
- package/templates/vite/.howone/skills/hallmark/references/export-formats.md +328 -0
- package/templates/vite/.howone/skills/hallmark/references/floating-nav.md +89 -0
- package/templates/vite/.howone/skills/hallmark/references/genres/atmospheric.md +65 -0
- package/templates/vite/.howone/skills/hallmark/references/genres/editorial.md +70 -0
- package/templates/vite/.howone/skills/hallmark/references/genres/modern-minimal.md +67 -0
- package/templates/vite/.howone/skills/hallmark/references/genres/playful.md +65 -0
- package/templates/vite/.howone/skills/hallmark/references/hero-enrichment.md +474 -0
- package/templates/vite/.howone/skills/hallmark/references/imagery-kit.md +170 -0
- package/templates/vite/.howone/skills/hallmark/references/interaction-and-states.md +207 -0
- package/templates/vite/.howone/skills/hallmark/references/layout-and-space.md +111 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/01-bento-grid.md +35 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/02-long-document.md +34 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/03-marquee-hero.md +31 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/04-stat-led.md +32 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/05-workbench.md +32 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/06-conversational-faq.md +33 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/07-manifesto.md +32 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/08-photographic.md +34 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/09-quote-led.md +32 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/10-specimen.md +32 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/11-catalogue.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/12-letter.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/13-index-first.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/14-narrative-workflow.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/15-split-studio.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/16-feature-stack.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/17-type-specimen.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/18-portfolio-grid.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/19-map-diagram.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/20-ecosystem-index.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures/21-component-playground.md +23 -0
- package/templates/vite/.howone/skills/hallmark/references/macrostructures.md +89 -0
- package/templates/vite/.howone/skills/hallmark/references/microinteractions.md +260 -0
- package/templates/vite/.howone/skills/hallmark/references/motion.md +109 -0
- package/templates/vite/.howone/skills/hallmark/references/preview-examples.md +49 -0
- package/templates/vite/.howone/skills/hallmark/references/responsive.md +138 -0
- package/templates/vite/.howone/skills/hallmark/references/slop-test.md +205 -0
- package/templates/vite/.howone/skills/hallmark/references/structure.md +164 -0
- package/templates/vite/.howone/skills/hallmark/references/study.md +486 -0
- package/templates/vite/.howone/skills/hallmark/references/typography.md +243 -0
- package/templates/vite/.howone/skills/hallmark/references/verbs/audit.md +25 -0
- package/templates/vite/.howone/skills/hallmark/references/verbs/redesign.md +269 -0
- package/templates/vite/.howone/skills/hallmark/site/OG-hallmark.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/brief.md +71 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/index.html +64 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/style.css +240 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/brief.md +65 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/index.html +105 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/style.css +250 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/brief.md +64 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/index.html +131 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/style.css +240 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/brief.md +67 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/index.html +86 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/style.css +262 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/brief.md +63 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/index.html +167 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/style.css +457 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/brief.md +65 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/index.html +159 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/style.css +288 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/brief.md +64 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/index.html +146 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/style.css +484 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/brief.md +64 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/index.html +116 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/style.css +354 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/09-slow-pour/index.html +638 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/10-owl-hours/index.html +515 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/11-soroe-ceramics/index.html +515 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/12-loafer/index.html +608 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/13-alma/index.html +587 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/README.md +157 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-example.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Podcast-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/after-quiet-hour.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/audit-example.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/before-quiet-hour.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/example-redesign-uractivation.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/study-example.png +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/uractivation-after-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-loop.mp4 +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-still.jpg +0 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/index.html +77 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/style.css +238 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/index.html +110 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/style.css +326 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/index.html +134 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/style.css +262 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/custom/README.md +30 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/README.md +17 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/audit-report.md +56 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/input.html +160 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/notes.md +29 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/input.html +63 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/notes.md +72 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/output.html +374 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/diagnosis.md +52 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/input-description.md +29 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/notes.md +61 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.css +193 -0
- package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.html +66 -0
- package/templates/vite/.howone/skills/hallmark/site/css/base.css +194 -0
- package/templates/vite/.howone/skills/hallmark/site/css/components.css +4886 -0
- package/templates/vite/.howone/skills/hallmark/site/css/sections.css +2072 -0
- package/templates/vite/.howone/skills/hallmark/site/css/tokens.css +1129 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/index.html +475 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/styles.css +1584 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/tokens.css +96 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/index.html +344 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/script.js +103 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/styles.css +1103 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/tokens.css +83 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/najm/index.html +368 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/najm/script.js +133 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/najm/styles.css +1062 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/najm/tokens.css +97 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/tally/app.js +84 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/tally/index.html +446 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/tally/styles.css +1087 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/tally/tokens.css +101 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/index.html +359 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/style.css +1168 -0
- package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/tokens.css +81 -0
- package/templates/vite/.howone/skills/hallmark/site/favicon-dark.svg +5 -0
- package/templates/vite/.howone/skills/hallmark/site/favicon-light.svg +5 -0
- package/templates/vite/.howone/skills/hallmark/site/index.html +1043 -0
- package/templates/vite/.howone/skills/hallmark/site/js/main.js +1175 -0
- package/templates/vite/.howone/skills/hallmark/vercel.json +6 -0
- package/templates/vite/.howone/skills/howone-sdk/01-architect/01-app-generation.md +101 -0
- package/templates/vite/.howone/skills/howone-sdk/02-database/01-schema-design.md +147 -0
- package/templates/vite/.howone/skills/howone-sdk/02-database/02-schema-operations.md +96 -0
- package/templates/vite/.howone/skills/howone-sdk/02-database/03-data-access-patterns.md +172 -0
- package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/01-client-setup.md +3 -3
- package/templates/vite/.howone/skills/howone-sdk/{references/04-auth.md → 03-sdk/03-auth.md} +120 -3
- package/templates/vite/.howone/skills/howone-sdk/04-ai/.gitkeep +1 -0
- package/templates/vite/.howone/skills/howone-sdk/SKILL.md +67 -93
- package/templates/vite/.howone/skills/howone-sdk/agents/openai.yaml +3 -3
- package/templates/vite/.howone/skills/impeccable/SKILL.md +168 -0
- package/templates/vite/.howone/skills/impeccable/agents/impeccable-asset-producer.md +101 -0
- package/templates/vite/.howone/skills/impeccable/reference/adapt.md +190 -0
- package/templates/vite/.howone/skills/impeccable/reference/animate.md +175 -0
- package/templates/vite/.howone/skills/impeccable/reference/audit.md +133 -0
- package/templates/vite/.howone/skills/impeccable/reference/bolder.md +113 -0
- package/templates/vite/.howone/skills/impeccable/reference/brand.md +118 -0
- package/templates/vite/.howone/skills/impeccable/reference/clarify.md +174 -0
- package/templates/vite/.howone/skills/impeccable/reference/codex.md +105 -0
- package/templates/vite/.howone/skills/impeccable/reference/cognitive-load.md +106 -0
- package/templates/vite/.howone/skills/impeccable/reference/color-and-contrast.md +105 -0
- package/templates/vite/.howone/skills/impeccable/reference/colorize.md +154 -0
- package/templates/vite/.howone/skills/impeccable/reference/craft.md +123 -0
- package/templates/vite/.howone/skills/impeccable/reference/critique.md +273 -0
- package/templates/vite/.howone/skills/impeccable/reference/delight.md +302 -0
- package/templates/vite/.howone/skills/impeccable/reference/distill.md +111 -0
- package/templates/vite/.howone/skills/impeccable/reference/document.md +427 -0
- package/templates/vite/.howone/skills/impeccable/reference/extract.md +69 -0
- package/templates/vite/.howone/skills/impeccable/reference/harden.md +347 -0
- package/templates/vite/.howone/skills/impeccable/reference/heuristics-scoring.md +234 -0
- package/templates/vite/.howone/skills/impeccable/reference/interaction-design.md +195 -0
- package/templates/vite/.howone/skills/impeccable/reference/layout.md +141 -0
- package/templates/vite/.howone/skills/impeccable/reference/live.md +622 -0
- package/templates/vite/.howone/skills/impeccable/reference/motion-design.md +109 -0
- package/templates/vite/.howone/skills/impeccable/reference/onboard.md +234 -0
- package/templates/vite/.howone/skills/impeccable/reference/optimize.md +258 -0
- package/templates/vite/.howone/skills/impeccable/reference/overdrive.md +130 -0
- package/templates/vite/.howone/skills/impeccable/reference/personas.md +179 -0
- package/templates/vite/.howone/skills/impeccable/reference/polish.md +242 -0
- package/templates/vite/.howone/skills/impeccable/reference/product.md +62 -0
- package/templates/vite/.howone/skills/impeccable/reference/quieter.md +99 -0
- package/templates/vite/.howone/skills/impeccable/reference/responsive-design.md +114 -0
- package/templates/vite/.howone/skills/impeccable/reference/shape.md +165 -0
- package/templates/vite/.howone/skills/impeccable/reference/spatial-design.md +100 -0
- package/templates/vite/.howone/skills/impeccable/reference/teach.md +156 -0
- package/templates/vite/.howone/skills/impeccable/reference/typeset.md +124 -0
- package/templates/vite/.howone/skills/impeccable/reference/typography.md +159 -0
- package/templates/vite/.howone/skills/impeccable/reference/ux-writing.md +107 -0
- package/templates/vite/.howone/skills/impeccable/scripts/cleanup-deprecated.mjs +284 -0
- package/templates/vite/.howone/skills/impeccable/scripts/command-metadata.json +94 -0
- package/templates/vite/.howone/skills/impeccable/scripts/critique-storage.mjs +242 -0
- package/templates/vite/.howone/skills/impeccable/scripts/design-parser.mjs +820 -0
- package/templates/vite/.howone/skills/impeccable/scripts/detect-csp.mjs +198 -0
- package/templates/vite/.howone/skills/impeccable/scripts/detect.mjs +21 -0
- package/templates/vite/.howone/skills/impeccable/scripts/impeccable-paths.mjs +110 -0
- package/templates/vite/.howone/skills/impeccable/scripts/is-generated.mjs +69 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-accept.mjs +595 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-browser-session.js +123 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-browser.js +4860 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-complete.mjs +75 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-completion.mjs +18 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-inject.mjs +446 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-poll.mjs +200 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-resume.mjs +48 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-server.mjs +838 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-session-store.mjs +254 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-status.mjs +47 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live-wrap.mjs +632 -0
- package/templates/vite/.howone/skills/impeccable/scripts/live.mjs +247 -0
- package/templates/vite/.howone/skills/impeccable/scripts/load-context.mjs +141 -0
- package/templates/vite/.howone/skills/impeccable/scripts/modern-screenshot.umd.js +14 -0
- package/templates/vite/.howone/skills/impeccable/scripts/pin.mjs +214 -0
- package/templates/vite/AGENTS.md +2 -12
- package/templates/vite/package.json +1 -1
- /package/templates/vite/.howone/skills/howone-sdk/{references/08-manifest-codegen.md → 01-architect/02-manifest-codegen.md} +0 -0
- /package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/02-entity-operations.md +0 -0
- /package/templates/vite/.howone/skills/howone-sdk/{references/06-react-integration.md → 03-sdk/04-react-integration.md} +0 -0
- /package/templates/vite/.howone/skills/howone-sdk/{references → 03-sdk}/05-file-upload.md +0 -0
- /package/templates/vite/.howone/skills/howone-sdk/{references/07-raw-http.md → 03-sdk/06-raw-http.md} +0 -0
- /package/templates/vite/.howone/skills/howone-sdk/{references/03-ai-actions.md → 03-sdk/07-ai-action-calls.md} +0 -0
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
# Genre — playful
|
|
2
|
+
|
|
3
|
+
For the consumer / friendly / onboarding-led page. Soft surfaces, mild colour, motion that responds to hover, friendlier voice. Closer to Notion's marketing or Figma's onboarding than to Stripe's API docs.
|
|
4
|
+
|
|
5
|
+
## When to pick it
|
|
6
|
+
|
|
7
|
+
Brief mentions any of: *fun, consumer, casual, family, kids, friendly, approachable, onboarding-heavy, community, social, tactile-but-soft, post-Linear-soft*. Pick playful sparingly — most consumer briefs still belong to editorial (warm-paper, hand-set) unless the user explicitly asks for *softer* and *friendlier*.
|
|
8
|
+
|
|
9
|
+
## Themes that belong
|
|
10
|
+
|
|
11
|
+
`Plume` (canonical). The genre is small intentionally — playful is easy to overdo.
|
|
12
|
+
|
|
13
|
+
## Voice
|
|
14
|
+
|
|
15
|
+
- **Display** — Geist Sans 600 with tighter tracking (`-0.025em`), or a bricolage-style display weighted at 700. Friendly, not childish.
|
|
16
|
+
- **Body** — Geist Sans 400 in a slightly muted ink (not pure black).
|
|
17
|
+
- **Accent** — soft indigo, warm coral, or muted rose at low chroma. Always low — never the saturated consumer-app pop.
|
|
18
|
+
- **Layout** — slightly rounded surfaces, soft drop shadows, friendlier card edges (12 px radius is the upper bound).
|
|
19
|
+
- **Motion** — responsive on hover (cards lift slightly). One small bounce-free reveal per section. No spring physics on UI state.
|
|
20
|
+
- **Copy tone** — warm, direct, specific. Avoid quirk for quirk's sake. *"Made for teams who write together."* over *"For the squad ✨"*.
|
|
21
|
+
|
|
22
|
+
## What this genre allows
|
|
23
|
+
|
|
24
|
+
- **Soft drop shadows** on cards (`0 8px 24px -10px <accent at low chroma>`). Restrained.
|
|
25
|
+
- **12 px radius** on cards, 8 px on inputs, 999 px on pills.
|
|
26
|
+
- **Hover-lift animations** on cards (`translateY(-2px)` + shadow expansion).
|
|
27
|
+
- **Mild tinted backgrounds** on alternating sections (paper-2 vs paper, with a tinted band).
|
|
28
|
+
- **Soft accent colours** — `oklch(50% 0.13 282)` (indigo) and similar, never above 0.16 chroma.
|
|
29
|
+
|
|
30
|
+
## What this genre disallows
|
|
31
|
+
|
|
32
|
+
- **Saturated consumer-app pinks / purples** — colour stays low chroma even if friendly.
|
|
33
|
+
- **Emoji-as-decoration** — emoji can appear in copy ("we built X 🌱") but never as visual ornament replacing iconography.
|
|
34
|
+
- **Comic Sans, Comic Neue, anything that signals "we're zany"** — playful stays sophisticated.
|
|
35
|
+
- **Bouncy / overshoot easings** — gate 13 universal. Even playful uses smooth easings.
|
|
36
|
+
- **Glassmorphism** — banned across all genres.
|
|
37
|
+
- **Gradient text** — gate 5 universal. Stays banned.
|
|
38
|
+
|
|
39
|
+
## Voice fixtures
|
|
40
|
+
|
|
41
|
+
- *"Made for teams who write together."*
|
|
42
|
+
- *"Soft, but exact."*
|
|
43
|
+
- *"Software can be soft and exact at once. That's the trick."*
|
|
44
|
+
- *"For the people who keep things tidy."*
|
|
45
|
+
- *"A small tool, gently opinionated."*
|
|
46
|
+
|
|
47
|
+
## Nav and footer voice
|
|
48
|
+
|
|
49
|
+
- **Default nav:** N7 Brutal slab — heavy uppercase wordmark + tracked uppercase links + 2 px border-bottom. The voice is loud but composed.
|
|
50
|
+
- **Acceptable also:** N1 Wordmark + 2 links (when destinations are minimal); N3 Side-rail (when the page is long-scroll and section-numbered, e.g. Studio).
|
|
51
|
+
- **Default footer:** Ft8 Marquee scroll — horizontal repeating tagline + dot separator. Honours `prefers-reduced-motion: reduce`.
|
|
52
|
+
- **Acceptable also:** Ft5 Statement; Ft3 Index columns (only when the page is a hub).
|
|
53
|
+
- **Banned for playful:** N5 Floating pill (modern-minimal vocabulary, fights the loud register); N6 Newspaper masthead (editorial); Ft6 Letter close (warm-quiet voice; wrong genre).
|
|
54
|
+
|
|
55
|
+
See [`component-cookbook.md`](../component-cookbook.md) § Navigation and § Footers for the full archetypes + code.
|
|
56
|
+
|
|
57
|
+
## Stamp signature
|
|
58
|
+
|
|
59
|
+
```css
|
|
60
|
+
/* Hallmark · genre: playful · macrostructure: <name> · theme: <name> · enrichment: <tier> · nav: <N#> · footer: <Ft#> */
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Reference register
|
|
64
|
+
|
|
65
|
+
The aesthetic to match: soft surfaces, low-chroma colour, friendly-but-restrained type, hover-responsive motion. The post-Linear soft school. Never childish, never quirk-for-quirk.
|
|
@@ -0,0 +1,474 @@
|
|
|
1
|
+
# Hero enrichment — when, what, and how much
|
|
2
|
+
|
|
3
|
+
This file is loaded after the macrostructure pick (Step 3 in the design flow), when you reach Step 4: "Decide on hero enrichment." It tells you whether to enrich the hero with media at all, and if so, which archetype and how to build it.
|
|
4
|
+
|
|
5
|
+
**The promise.** Enrichment is an option, not a default. A typographic-only hero is *always* an acceptable answer. Visual enrichment — demo video, illustration, mockup, animated loop, abstract background, photography — has to *earn its place*. If the hero can be deleted of its enrichment and still works, the enrichment earned its place. If the hero collapses without the enrichment, you propped weak typography on a crutch.
|
|
6
|
+
|
|
7
|
+
**The bar.** Better nothing than bad something. A page that ships a quiet, well-set typographic hero is always better than a page that ships a stock illustration, a Lottie checkmark, an aurora-blob background, or a generic centred demo video block.
|
|
8
|
+
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
## Image-need detection — does this brief need imagery at all?
|
|
12
|
+
|
|
13
|
+
Before picking an enrichment tier, decide whether the brief actually wants imagery. The default is **typography-only**. Match the brief against this table; act on the *first* row that fires:
|
|
14
|
+
|
|
15
|
+
| Brief signal (any of these words / intents) | Image strategy |
|
|
16
|
+
| --- | --- |
|
|
17
|
+
| e-commerce, shop, store, product catalogue, brand, fashion, lookbook | Real product photos required — placeholder until user provides |
|
|
18
|
+
| photography, portfolio, gallery, artist | Imagery *is* the page — placeholder until user provides |
|
|
19
|
+
| food, restaurant, menu, dish, coffee, wine, recipe | Hero photo + product crops — placeholder until user provides |
|
|
20
|
+
| team, staff, "about us", portraits, hiring, careers | Portrait crops — placeholder until user provides |
|
|
21
|
+
| travel, hotel, destination, real estate, listing, property | Cover photo + tile photos — placeholder until user provides |
|
|
22
|
+
| news, blog, magazine, journal, publication | Feature image per post — placeholder until user provides |
|
|
23
|
+
| SaaS landing, manifesto, agency, studio, atmospheric, slow-and-editorial | **Kit-led.** Use Hallmark imagery kit (washes, transparent abstracts, ornaments) — see [`assets.md` § Placeholder strategy](assets.md) and [`imagery-kit.md`](imagery-kit.md). |
|
|
24
|
+
| API, docs, changelog, CLI, library, dev-tool, SDK, package | **No imagery.** Typography-only. Code blocks if needed. |
|
|
25
|
+
| editorial, essay, letter, foundry, type-specimen, broadside | **No imagery.** Display typography is the design. |
|
|
26
|
+
| (all other / vague / unspecified) | **Default: typography-only.** When in doubt, no images. |
|
|
27
|
+
|
|
28
|
+
Rules:
|
|
29
|
+
|
|
30
|
+
- When the user has attached an image asset (or `.hallmark/preflight.json` cached one), use it. Never overwrite with a placeholder.
|
|
31
|
+
- When the brief is genuinely ambiguous between a "needs photos" row and a "no imagery" row, ask one short question: *"Will you have product photos, or should I leave swappable placeholders?"*
|
|
32
|
+
- A placeholder must look like a placeholder, not like a confident decision. The skill refuses to invent stock photos as if they were the final design.
|
|
33
|
+
- Imagery rows above don't override genre overlays. Modern-minimal genre still suppresses decorative kit imagery (gate in `imagery-kit.md` anti-patterns).
|
|
34
|
+
|
|
35
|
+
The hierarchy below picks the tier *after* this gate decides imagery is needed at all. Skipping this gate is what produces "blob illustration on every page" outputs — exactly the AI-default Hallmark refuses.
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## The enrichment hierarchy
|
|
40
|
+
|
|
41
|
+
Reach for the highest tier the brief lets you ship in the time you have. Skipping tiers is the new tell.
|
|
42
|
+
|
|
43
|
+
| Tier | What | When |
|
|
44
|
+
| --- | --- | --- |
|
|
45
|
+
| **0 · Typography only** | No enrichment. Display, lede, optional CTA. | Always acceptable. The strongest fail-state. |
|
|
46
|
+
| **A · Custom-built CSS art** | Pure-CSS shapes, gradients, clip-paths, no asset, zero dependency. | Geometric shapes, gradient compositions, glyph-style decoration. |
|
|
47
|
+
| **B · Hand-built SVG** | Designed in Figma, optimised, animated declaratively. | Illustrations more complex than CSS handles cleanly — a loaf, a mascot, a workflow diagram. |
|
|
48
|
+
| **C · Generated illustration** | Nanobanana / Recraft V4 / Midjourney, with provenance + post-processing. | Characters or specific scenes that hand-build can't economically reach. Always post-processed. |
|
|
49
|
+
| **D · Library illustration** | Storyset / Humaaans / unDraw, customised with brand colours. | When budget and timeline force a shortcut — and even then, never unmodified. |
|
|
50
|
+
| **E · Lottie animation** | LAST RESORT. Only when complex character motion can't be hand-built. | Articulated figures, multi-frame mascot loops. Never for "spinning logo" or "checkmark draw" — those are CSS. |
|
|
51
|
+
|
|
52
|
+
**The discipline.** If you can do it in tier A, do it in tier A. If A can't reach it, try B. Only drop to C when characters demand it. Only D when the brief is explicit about "fast and cheap". Only E when E is genuinely the only option. Reaching for E because it's familiar — and many AI tools do — is the signature of a templated page.
|
|
53
|
+
|
|
54
|
+
See [`custom-craft.md`](custom-craft.md) for *how* to build at tiers A and B. See [`assets.md`](assets.md) for the catalogue of sources at tiers C, D, and E.
|
|
55
|
+
|
|
56
|
+
---
|
|
57
|
+
|
|
58
|
+
## Eyeball or ask — the decision protocol
|
|
59
|
+
|
|
60
|
+
Two paths to picking enrichment:
|
|
61
|
+
|
|
62
|
+
```
|
|
63
|
+
If the brief contains explicit visual cues, pick from this map:
|
|
64
|
+
|
|
65
|
+
• "demo", "show how it works", "product tour" → E1 / E2 demo video
|
|
66
|
+
• "platform", "tool", "infra", "dashboard", "developer" → E3 / E4 mockup
|
|
67
|
+
• "shop", "store", "menu", "products", "items" → E8 photography (or F6 product grid)
|
|
68
|
+
• "bakery", "kitchen", "café", "atelier" + craft brief → E5 custom illustration (Tier B SVG)
|
|
69
|
+
• "agency", "studio", "portfolio" → E8 photography or no enrichment
|
|
70
|
+
• "manifesto", "essay", "book", "letter" → no enrichment (typography only)
|
|
71
|
+
• Quiet theme picked → no enrichment (the theme IS restraint)
|
|
72
|
+
|
|
73
|
+
Else if the brief is genuinely ambiguous, ask one question:
|
|
74
|
+
"Want me to add a demo video, an illustration, or keep it
|
|
75
|
+
typography-only? I default to typography-only because it's
|
|
76
|
+
the strongest fail-state."
|
|
77
|
+
|
|
78
|
+
Else default to no enrichment. State the inference in one sentence
|
|
79
|
+
in your reply, alongside the macrostructure inference.
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
When in doubt: don't enrich. The hero will be fine. Most great landing pages are typographic.
|
|
83
|
+
|
|
84
|
+
---
|
|
85
|
+
|
|
86
|
+
## Eight enrichment archetypes
|
|
87
|
+
|
|
88
|
+
Each archetype has a one-line definition, "use when", "avoid when", a short code sketch, and 2–3 within-archetype variation knobs (consistent with [`component-cookbook.md`](component-cookbook.md)).
|
|
89
|
+
|
|
90
|
+
### E1 · Demo Video — Clipped-by-viewport-edge
|
|
91
|
+
|
|
92
|
+
A display headline left, a demo video right, and the rightmost ~10–20 % of the video extending past the viewport so it's intentionally cut off. The clip *is* the design — it implies "there's more product than fits on this screen". Pioneered by Linear; refined by Vercel, Resend, Cursor.
|
|
93
|
+
|
|
94
|
+
*Use when:* the brief is a SaaS / dev tool / dashboard / platform and you have real footage of the product.
|
|
95
|
+
*Avoid when:* you don't have real footage. A clipped-edge video of a stock-footage city skyline reads as filler.
|
|
96
|
+
|
|
97
|
+
**Knobs:**
|
|
98
|
+
- Clip side (right · left · both)
|
|
99
|
+
- Aspect ratio (16/10 · 16/9 · 4/3)
|
|
100
|
+
- Frame treatment (hairline 1 px frame · browser chrome · none)
|
|
101
|
+
|
|
102
|
+
**Example.** Tracejam (SaaS observability — see [`site/_tests/05-tracejam-saas/`](../../site/_tests/05-tracejam-saas/)). Display headline left ("Distributed tracing that explains itself."); hand-built CSS-art trace waterfall right, tilted -0.4°, extending 12 vw past the viewport's right edge. Aspect 16/10. Hairline frame. **Not a real video** — the mockup is custom-built CSS at Tier A (rectangles on a percentage grid simulating a flame chart). Mobile (< 60 rem): drop the clip, stack vertically.
|
|
103
|
+
|
|
104
|
+
```html
|
|
105
|
+
<section class="hero hero--clipped">
|
|
106
|
+
<div class="hero__copy">
|
|
107
|
+
<h1>Plan, build, ship.</h1>
|
|
108
|
+
<p>The project tracker your engineering team won't ignore.</p>
|
|
109
|
+
<a class="btn" href="/signup">Try it free</a>
|
|
110
|
+
</div>
|
|
111
|
+
<figure class="hero__media">
|
|
112
|
+
<video autoplay muted loop playsinline preload="metadata"
|
|
113
|
+
poster="/hero-poster.webp" fetchpriority="high"
|
|
114
|
+
aria-label="Tour of the dashboard interface">
|
|
115
|
+
<source src="/hero.av1.mp4" type='video/mp4; codecs="av01.0.05M.08"'>
|
|
116
|
+
<source src="/hero.vp9.webm" type="video/webm">
|
|
117
|
+
<source src="/hero.h264.mp4" type="video/mp4">
|
|
118
|
+
</video>
|
|
119
|
+
</figure>
|
|
120
|
+
</section>
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
```css
|
|
124
|
+
.hero--clipped {
|
|
125
|
+
display: grid;
|
|
126
|
+
grid-template-columns: minmax(20rem, 1fr) 1.4fr;
|
|
127
|
+
gap: var(--space-2xl);
|
|
128
|
+
align-items: center;
|
|
129
|
+
overflow: visible; /* let the media spill past the page edge */
|
|
130
|
+
}
|
|
131
|
+
.hero__media {
|
|
132
|
+
width: calc(100% + 12vw); /* the 12 % of viewport that sits beyond the right edge */
|
|
133
|
+
aspect-ratio: 16 / 10;
|
|
134
|
+
border-radius: 12px;
|
|
135
|
+
border: var(--rule-hair) solid var(--color-rule);
|
|
136
|
+
overflow: hidden;
|
|
137
|
+
}
|
|
138
|
+
.hero__media video { width: 100%; height: 100%; object-fit: cover; }
|
|
139
|
+
|
|
140
|
+
@media (max-width: 60rem) {
|
|
141
|
+
.hero--clipped { grid-template-columns: 1fr; }
|
|
142
|
+
.hero__media { width: 100%; } /* don't try to clip on mobile — reads as broken */
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
@media (prefers-reduced-motion: reduce) {
|
|
146
|
+
.hero__media video { display: none; }
|
|
147
|
+
.hero__media { background: url('/hero-poster.webp') center/cover; }
|
|
148
|
+
}
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
**Critical:** never `loading="lazy"` on the hero video — that kills LCP. Use `preload="metadata"` and `fetchpriority="high"`. Always include a `poster=""` and a `<track kind="captions">` for accessibility.
|
|
152
|
+
|
|
153
|
+
### E2 · Demo Video — Full-bleed muted loop with ghost overlay
|
|
154
|
+
|
|
155
|
+
Video fills the fold, ghost-tinted via `mix-blend-mode: multiply` over a paper-coloured overlay so the type stays readable. The video is wallpaper, not subject.
|
|
156
|
+
|
|
157
|
+
*Use when:* the product's *feel* is the message (mood, tactility, atmosphere).
|
|
158
|
+
*Avoid when:* the product needs to be *seen* clearly — use E1 or E3 instead.
|
|
159
|
+
|
|
160
|
+
**Knobs:**
|
|
161
|
+
- Ghost opacity (0.3 / 0.5 / 0.7)
|
|
162
|
+
- Text alignment (left-bias / centred)
|
|
163
|
+
- Pause behaviour (always-loop · pause-on-hover · pause-when-out-of-viewport)
|
|
164
|
+
|
|
165
|
+
**Example.** A small fashion brand's spring lookbook. 8-second muted loop of fabric draping in a studio. `mix-blend-mode: multiply` over a 0.5-opacity warm-cream overlay so the italic display headline ("Spring · 2026 · Lookbook 04") reads cleanly over the moving footage. Pauses on hover so the user can read the lede without distraction. Caption track (VTT) describes the footage for accessibility.
|
|
166
|
+
|
|
167
|
+
### E3 · Mock App Screenshot — Browser-framed split
|
|
168
|
+
|
|
169
|
+
Display headline left, a browser-frame mockup right, the mockup window slightly tilted (1–3°) for life. Frames are from [Browserframe](https://browserframe.com) or hand-built (a 1-px hairline + three macOS dots).
|
|
170
|
+
|
|
171
|
+
*Use when:* you're selling a web app and you have a clean, well-lit screenshot.
|
|
172
|
+
*Avoid when:* the screenshot is busy or blurry — the frame draws attention to the mess.
|
|
173
|
+
|
|
174
|
+
**Knobs:**
|
|
175
|
+
- Frame style (browser chrome · macOS toolbar · minimal hairline · none)
|
|
176
|
+
- Tilt angle (0° · 1.5° · 3°)
|
|
177
|
+
- Screenshot count (1 · stack-of-3 · orbit-of-3)
|
|
178
|
+
|
|
179
|
+
**Example.** A Linear-style SaaS landing for a project tracker. Headline left ("Plan, build, ship."), browser-frame screenshot of the kanban view right, tilted 1.5° clockwise. Three numbered annotations (1 · assigns automatically · 2 · real-time presence · 3 · keyboard-first), each with a small numbered pin and a margin-aligned caption — never arrows-and-labels. Single screenshot, not a stack — fewer assets to load, sharper read.
|
|
180
|
+
|
|
181
|
+
### E4 · Mock App Screenshot — Floating no-frame
|
|
182
|
+
|
|
183
|
+
Same composition as E3 but without browser chrome — the screenshot floats with a soft shadow and 12 px corner radius. Cleaner; demands a higher-quality screenshot since the chrome isn't there to forgive.
|
|
184
|
+
|
|
185
|
+
*Use when:* the screenshot itself is beautiful enough to stand naked.
|
|
186
|
+
*Avoid when:* the product needs the "this is a real web app" cue from the chrome.
|
|
187
|
+
|
|
188
|
+
**Knobs:**
|
|
189
|
+
- Shadow depth (subtle / medium / dramatic)
|
|
190
|
+
- Corner radius (0 · 8 px · 16 px)
|
|
191
|
+
- Background reveal (gradient / solid / none)
|
|
192
|
+
|
|
193
|
+
**Example.** A code-formatting CLI marketing page. Headline left ("Format anything, in eight lines."), a single floating screenshot right showing `before` / `after` code side by side. 12 px corner radius, a soft 24 px shadow at -10 px offset, sitting on a barely-tinted gradient surface. **No browser chrome** — the screenshot itself is composed and beautiful enough to stand naked. Use this when the screenshot is unusually high-quality; otherwise switch to E3 (the chrome forgives messier captures).
|
|
194
|
+
|
|
195
|
+
### E5 · Custom Illustration Centerpiece
|
|
196
|
+
|
|
197
|
+
A hand-built SVG (the default, Tier B) or a generated raster (Tier C, when characters demand it) sitting on the hero as a single illustrative element — the bakery loaf, the studio's mascot, the diagram of how the workflow flows.
|
|
198
|
+
|
|
199
|
+
*Use when:* the brand has a story or a thing-it-makes that benefits from being drawn.
|
|
200
|
+
*Avoid when:* the brand is "modern professional team" generic — illustrating that is the new template.
|
|
201
|
+
|
|
202
|
+
**Knobs:**
|
|
203
|
+
- Build method (Tier A pure-CSS / Tier B hand-SVG / Tier C generated / Tier D library)
|
|
204
|
+
- Animation (none · loop · scroll-linked)
|
|
205
|
+
- Scale (small accent · dominant)
|
|
206
|
+
|
|
207
|
+
**Example.** Maple Street Bread (bakery — see [`site/_tests/03-maple-bakery/`](../../site/_tests/03-maple-bakery/)). Letter-style hero copy left ("Saturday, 6:14 a.m. The dough went in at midnight."), 60-line hand-built SVG loaf right, 3 paths (body, shade, score-marks). Animated with `@property --rise` for a subtle 4 px breathing-loop over 6 s, alternating; the score-marks draw themselves on first paint via `stroke-dasharray`. Tier B, dominant scale, animation: loop. Reduced-motion fallback is a static keyframe.
|
|
208
|
+
|
|
209
|
+
For *how* to build a hand-drawn loaf in 60 lines of SVG and animate its breath with `@property`, see [`custom-craft.md`](custom-craft.md) — there's a full bakery worked example, plus four more recipes (workflow diagram, mascot, architectural diagram, botanical accent).
|
|
210
|
+
|
|
211
|
+
### E6 · Animated Loop — pure CSS / SVG / Motion
|
|
212
|
+
|
|
213
|
+
A small custom-built loop — an orbiting dot, a breathing rectangle, an animated gradient stop, a type-mask reveal. The point is *small*, custom, and looped *only when reduced-motion is off*.
|
|
214
|
+
|
|
215
|
+
*Use when:* the page is otherwise still and one small animated element gives it life.
|
|
216
|
+
*Avoid when:* the page already has movement — adding more reads as anxious.
|
|
217
|
+
|
|
218
|
+
**Knobs:**
|
|
219
|
+
- Medium (CSS keyframes · SVG SMIL/CSS · Motion)
|
|
220
|
+
- Placement (margin · inline-with-headline · corner-accent)
|
|
221
|
+
- Loop duration (≤ 4s — anything longer drags)
|
|
222
|
+
|
|
223
|
+
**Example.** A collaborative whiteboard app. A 2-second pure-CSS loop next to the headline: a single dot orbiting a slow ellipse, suggesting "real-time collaboration" without a Lottie. Built with `@property --angle` interpolating 0deg → 360deg on a `transform: rotate()`. Margin-placed, ~64 × 64 px, accent colour at low chroma. **Not a Lottie** — pure CSS keeps the bundle at zero bytes and respects reduced-motion gracefully (animation: none on the media query).
|
|
224
|
+
|
|
225
|
+
### E7 · Abstract Background — subtle gradient + grain
|
|
226
|
+
|
|
227
|
+
A two-colour CSS gradient at low chroma, overlaid with SVG `<feTurbulence>` grain at < 0.1 opacity. *Not* aurora; *not* purple-to-cyan mesh; *not* floating orbs. The point is *texture you can barely see* — paper-quality, not decoration.
|
|
228
|
+
|
|
229
|
+
*Use when:* the page would feel synthetic with a flat surface.
|
|
230
|
+
*Avoid when:* the theme already has a paper feel (Specimen, Linen, Riso). Doubling the grain is muddy.
|
|
231
|
+
|
|
232
|
+
**Knobs:**
|
|
233
|
+
- Gradient direction (45° / 135° / radial)
|
|
234
|
+
- Grain amount (off · subtle · textured)
|
|
235
|
+
- Animation (none · slow drift · scroll-linked parallax)
|
|
236
|
+
|
|
237
|
+
**Example.** A small podcast site (when the host wants more visual heat than Tide's typography-only quote). Two-stop CSS gradient at 135° (warm-cream → barely-orange, both at < 0.04 chroma) over the *hero only* — never page-wide. SVG `<feTurbulence>` grain overlay at 0.06 opacity, `mix-blend-mode: multiply`. No animation. Resists every aurora-blob temptation.
|
|
238
|
+
|
|
239
|
+
```html
|
|
240
|
+
<section class="hero hero--bg">
|
|
241
|
+
<div class="hero__bg" aria-hidden="true">
|
|
242
|
+
<svg width="0" height="0" style="position: absolute;">
|
|
243
|
+
<filter id="grain"><feTurbulence baseFrequency="0.9" numOctaves="2"/></filter>
|
|
244
|
+
</svg>
|
|
245
|
+
</div>
|
|
246
|
+
<div class="hero__copy"> ... </div>
|
|
247
|
+
</section>
|
|
248
|
+
```
|
|
249
|
+
```css
|
|
250
|
+
.hero { position: relative; isolation: isolate; }
|
|
251
|
+
.hero__bg {
|
|
252
|
+
position: absolute; inset: 0; z-index: -1;
|
|
253
|
+
background:
|
|
254
|
+
linear-gradient(135deg,
|
|
255
|
+
color-mix(in oklch, var(--color-paper) 100%, var(--color-accent) 4%),
|
|
256
|
+
color-mix(in oklch, var(--color-paper) 100%, var(--color-paper-2) 50%));
|
|
257
|
+
}
|
|
258
|
+
.hero__bg::after {
|
|
259
|
+
content: ""; position: absolute; inset: 0;
|
|
260
|
+
filter: url(#grain);
|
|
261
|
+
opacity: 0.06;
|
|
262
|
+
mix-blend-mode: multiply;
|
|
263
|
+
pointer-events: none;
|
|
264
|
+
}
|
|
265
|
+
```
|
|
266
|
+
|
|
267
|
+
### E8 · Hero Photography — single tightly-cropped image
|
|
268
|
+
|
|
269
|
+
Existing H6 archetype in the cookbook. Cross-referenced here for completeness. See [`component-cookbook.md`](component-cookbook.md) for variation knobs.
|
|
270
|
+
|
|
271
|
+
**Example.** A small Lisbon café. One tightly-cropped photograph of the espresso machine at dawn, 4/3 ratio, no full-bleed. Caption sits margin-aligned at lower-left in mono small-caps ("Plate 04 · 6:42 a.m."). The photograph is desaturated 8 % from the source to harmonise with the page's warm-paper tone. Always pair photography with a tone-matched typography pairing (see [`typography.md`](typography.md)) — a luxury-tone photo on a brutalist page jars.
|
|
272
|
+
|
|
273
|
+
---
|
|
274
|
+
|
|
275
|
+
## Hero shape polish — patterns beyond enrichment
|
|
276
|
+
|
|
277
|
+
The eight enrichment archetypes above (E1–E8) decide *what sits next to the headline*. The four polish patterns below decide *how the headline itself sits* — they affect layout, type, motion, not decoration on top. They are admissible on top of any hero macrostructure (Marquee Hero, Stat-Led, Quote-Led, Letter, Photographic, Clipped). Pick one polish pattern when the hero feels shape-flat — colour-only, symmetric, predictable.
|
|
278
|
+
|
|
279
|
+
You can ship a hero with one polish pattern *and* one enrichment archetype, but never two polish patterns at once. The hero is a high-stakes surface; one structural choice carries it.
|
|
280
|
+
|
|
281
|
+
### HP1 · Vertical-rail title
|
|
282
|
+
|
|
283
|
+
The wordmark or a pull-label runs *vertically* alongside the centred body. CSS: `writing-mode: vertical-rl; text-orientation: mixed;` on the rail; the body sits in normal flow beside it. Reads as studio · atelier · editorial — Japanese-print rhythm, hand-set page furniture.
|
|
284
|
+
|
|
285
|
+
*Use when:* the hero is otherwise centred or marquee-shaped and the page wants a structural anchor that isn't a rule or a numeral.
|
|
286
|
+
*Avoid when:* the body title is itself big and centred — vertical rail beside huge horizontal display reads as competing axes; pick one direction.
|
|
287
|
+
|
|
288
|
+
```html
|
|
289
|
+
<header class="hero hero--rail">
|
|
290
|
+
<p class="hero__rail" aria-hidden="true">STUDIO · 2026 · WORK · LETTERS</p>
|
|
291
|
+
<div class="hero__body">
|
|
292
|
+
<h1 class="hero__display">A working archive.</h1>
|
|
293
|
+
<p class="hero__lede">Twelve years. Selected projects, in their own time.</p>
|
|
294
|
+
</div>
|
|
295
|
+
</header>
|
|
296
|
+
```
|
|
297
|
+
```css
|
|
298
|
+
.hero--rail { display: grid; grid-template-columns: auto 1fr; gap: var(--space-2xl); padding: var(--space-2xl) var(--page-gutter); align-items: end; }
|
|
299
|
+
.hero__rail { writing-mode: vertical-rl; text-orientation: mixed; font-family: var(--font-display); font-size: var(--text-sm); letter-spacing: 0.18em; color: var(--color-ink-2); margin: 0; }
|
|
300
|
+
@media (max-width: 60rem) { .hero--rail { grid-template-columns: 1fr; } .hero__rail { writing-mode: horizontal-tb; font-size: var(--text-xs); } }
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
*Anti-pattern:* vertical text *and* horizontal display title competing at the same scale. Pick one direction; the rail is supporting voice.
|
|
304
|
+
|
|
305
|
+
### HP2 · Marquee-overflow
|
|
306
|
+
|
|
307
|
+
The H1 is intentionally larger than the viewport — `overflow-x: clip` on the hero container; the title bleeds past the right edge. Reads as manifesto · brutal · sport — the headline is loud enough that the page can't contain it.
|
|
308
|
+
|
|
309
|
+
*Use when:* the genre is playful (Brutal, Manifesto, Sport) and the title is *short* (≤ 6 words). Long titles + overflow = noise.
|
|
310
|
+
*Avoid when:* the title carries legal information that must be readable in full (privacy notice, terms page).
|
|
311
|
+
|
|
312
|
+
```html
|
|
313
|
+
<header class="hero hero--overflow">
|
|
314
|
+
<h1 class="hero__display hero__display--xxl">STOP MAKING UI THAT LOOKS LIKE EVERYONE ELSE'S UI.</h1>
|
|
315
|
+
<p class="hero__lede">Hallmark. A design skill that refuses defaults.</p>
|
|
316
|
+
</header>
|
|
317
|
+
```
|
|
318
|
+
```css
|
|
319
|
+
.hero--overflow { overflow-x: clip; padding: var(--space-2xl) var(--page-gutter); }
|
|
320
|
+
.hero__display--xxl { font-family: var(--font-display); font-weight: 800; font-size: clamp(4rem, 14vw, 14rem); line-height: 0.92; letter-spacing: -0.04em; margin: 0; white-space: nowrap; }
|
|
321
|
+
@media (max-width: 60rem) { .hero__display--xxl { white-space: normal; font-size: clamp(2.5rem, 10vw, 5rem); } }
|
|
322
|
+
```
|
|
323
|
+
|
|
324
|
+
*Anti-pattern:* `overflow-x: hidden` on `<html>` or `<body>` at the same time as this hero — the clip breaks horizontal scroll behaviour for descendants. Use `overflow-x: clip` only, scoped to the hero container.
|
|
325
|
+
|
|
326
|
+
### HP3 · Cursor-spotlight
|
|
327
|
+
|
|
328
|
+
A radial-gradient background that tracks `mousemove`, scoped to the hero only. Reads as atmospheric · modern-minimal SaaS — Linear, Tailwind Labs, Raycast.
|
|
329
|
+
|
|
330
|
+
*Use when:* the page is atmospheric / dark-paper / SaaS marketing, the hero has empty surface to play under, and the brand voice can carry "tactile, alive".
|
|
331
|
+
*Avoid when:* the cursor would track over content (text, buttons) — pulls focus from reading. Scope the spotlight to a backdrop layer beneath text, never over it.
|
|
332
|
+
|
|
333
|
+
```html
|
|
334
|
+
<header class="hero hero--spotlight">
|
|
335
|
+
<div class="hero__spotlight" aria-hidden="true"></div>
|
|
336
|
+
<div class="hero__body">
|
|
337
|
+
<h1 class="hero__display">Distributed tracing that explains itself.</h1>
|
|
338
|
+
<p class="hero__lede">Open one trace. See the whole story.</p>
|
|
339
|
+
</div>
|
|
340
|
+
</header>
|
|
341
|
+
```
|
|
342
|
+
```css
|
|
343
|
+
.hero--spotlight { position: relative; isolation: isolate; padding: var(--space-2xl) var(--page-gutter); overflow: hidden; }
|
|
344
|
+
.hero__spotlight { position: absolute; inset: 0; z-index: -1; background: radial-gradient(600px circle at var(--mx, 50%) var(--my, 30%), color-mix(in oklch, var(--color-accent) 22%, transparent), transparent 60%); transition: background 200ms var(--ease-out); }
|
|
345
|
+
@media (prefers-reduced-motion: reduce) { .hero__spotlight { transition: none; --mx: 50%; --my: 30%; } }
|
|
346
|
+
```
|
|
347
|
+
```js
|
|
348
|
+
// Scope to hero only — never page-wide.
|
|
349
|
+
const hero = document.querySelector('.hero--spotlight');
|
|
350
|
+
hero?.addEventListener('pointermove', (e) => {
|
|
351
|
+
const r = hero.getBoundingClientRect();
|
|
352
|
+
hero.style.setProperty('--mx', `${e.clientX - r.left}px`);
|
|
353
|
+
hero.style.setProperty('--my', `${e.clientY - r.top}px`);
|
|
354
|
+
});
|
|
355
|
+
```
|
|
356
|
+
|
|
357
|
+
*Anti-pattern:* tracking the cursor across the *whole page* — nausea-inducing, focus-stealing. Scope to hero only. The reduced-motion fallback must pin the gradient to a sensible static position (50% / 30%), not just disable the effect (which would leave a flat surface).
|
|
358
|
+
|
|
359
|
+
### HP4 · Decorative-numeral
|
|
360
|
+
|
|
361
|
+
A huge edition number / year / chapter glyph set in display-italic in a hero corner. The numeral *means something* — issue 22, year 2026, chapter 03, version 0.8. Reads as editorial · salon · newsprint · almanac.
|
|
362
|
+
|
|
363
|
+
*Use when:* the page genuinely has an edition / issue / chapter / version semantic — magazines, journals, archived work, dated essays.
|
|
364
|
+
*Avoid when:* the numeral has no semantic anchor. A random "42" in the corner reads as decoration, which is slop (see slop-test gate 55).
|
|
365
|
+
|
|
366
|
+
```html
|
|
367
|
+
<header class="hero hero--num">
|
|
368
|
+
<p class="hero__eyebrow">Studio · Spring 2026</p>
|
|
369
|
+
<h1 class="hero__display">A working archive.</h1>
|
|
370
|
+
<p class="hero__lede">Twelve years. Selected projects, in their own time.</p>
|
|
371
|
+
<span class="hero__num" aria-hidden="true">22</span>
|
|
372
|
+
</header>
|
|
373
|
+
```
|
|
374
|
+
```css
|
|
375
|
+
.hero--num { position: relative; padding: var(--space-2xl) var(--page-gutter) var(--space-3xl); overflow: hidden; }
|
|
376
|
+
.hero__num { position: absolute; right: var(--page-gutter); bottom: -0.15em; font-family: var(--font-display); font-style: italic; font-weight: 600; font-size: clamp(8rem, 22vw, 18rem); line-height: 1; color: color-mix(in oklch, var(--color-ink) 8%, transparent); pointer-events: none; user-select: none; }
|
|
377
|
+
@media (max-width: 60rem) { .hero__num { font-size: clamp(5rem, 26vw, 9rem); right: -0.1em; } }
|
|
378
|
+
```
|
|
379
|
+
|
|
380
|
+
*Anti-pattern:* numerals that mean nothing. The numeral must carry information — issue, year, version, chapter, plate. If you can't name what the number *is*, drop it.
|
|
381
|
+
|
|
382
|
+
---
|
|
383
|
+
|
|
384
|
+
## Hero space discipline
|
|
385
|
+
|
|
386
|
+
Every hero — enriched or not, polished or not — obeys these rules.
|
|
387
|
+
|
|
388
|
+
- **Footprint.** The hero takes 70–90 % of the first viewport's height — no more, no less. `min-height: 100vh / 100dvh` is the AI fingerprint (gate 7); a hero that's only 20 % of the viewport feels like a header. Aim for `min-height: clamp(60vh, 75dvh, 88dvh)` and let content settle inside.
|
|
389
|
+
- **Asymmetric padding.** `padding-block-end` ≥ 1.3× `padding-block-start`. The hero sits *into* the page; symmetric padding floats. Slop-test gate 54 enforces this.
|
|
390
|
+
- **Never centre everything.** Eyebrow + title + lede + CTA all stacked centred is the AI fingerprint. Pick at most *two* centred elements; break alignment for the others. Gate 53 enforces this. Centred-narrow heroes are admissible only when the genre is editorial / salon / atelier *and* the eyebrow or CTA breaks alignment.
|
|
391
|
+
- **Entrance animation.** Pick one of {fade, sweep, none} per element — never both fade *and* sweep on the same element. Duration ≤ 220 ms. Disable on `prefers-reduced-motion: reduce`. Cross-reference the "One orchestrated reveal per page" rule below.
|
|
392
|
+
- **Headline typography.** Prefer one display weight + tight tracking (-0.02em to -0.04em) over default 0; line-height 0.95–1.05 for display, never 1.2 (which inherits the body line-height and reads as un-set type). Avoid two display weights on the same headline (a `<strong>` in a different weight inside the title is AI's idea of "emphasis"; pick one weight, let the words carry).
|
|
393
|
+
- **One polish pattern, max.** HP1–HP4 are mutually exclusive on a single hero. A vertical rail *and* a marquee-overflow *and* a cursor spotlight *and* a decorative numeral on one hero is a panic attack. Pick one.
|
|
394
|
+
|
|
395
|
+
The decision sequence:
|
|
396
|
+
|
|
397
|
+
1. Pick the hero macrostructure (Marquee Hero, Stat-Led, Quote-Led, Letter, Photographic, Clipped) — see [`macrostructures.md`](macrostructures.md).
|
|
398
|
+
2. Pick zero-or-one **enrichment archetype** (E1–E8 above).
|
|
399
|
+
3. Pick zero-or-one **polish pattern** (HP1–HP4 above).
|
|
400
|
+
4. Apply the space discipline rules.
|
|
401
|
+
5. Stamp the choices into the macrostructure stamp.
|
|
402
|
+
|
|
403
|
+
---
|
|
404
|
+
|
|
405
|
+
## Animation discipline (hero specifically)
|
|
406
|
+
|
|
407
|
+
Cross-references [`motion.md`](motion.md), [`microinteractions.md`](microinteractions.md), and [`custom-craft.md`](custom-craft.md). The hero is the highest-stakes animation surface on the page; the rules are tighter here than elsewhere.
|
|
408
|
+
|
|
409
|
+
**One orchestrated reveal per page.** Not eight. Not "everything fades in on scroll". One: the hero settles in 0.4–0.8 s with a single coordinated motion, then stops.
|
|
410
|
+
|
|
411
|
+
**Banned for hero entrances:**
|
|
412
|
+
- Bouncy elastic easing (`cubic-bezier(0.34, 1.56, ...)`) — reads as 2016 Framer demo
|
|
413
|
+
- Scroll-fade-everything (every section fades in when it enters the viewport)
|
|
414
|
+
- Mouse-follow gradients on SaaS landing pages (allowed only on portfolio / creative / agency work)
|
|
415
|
+
- Parallax-on-mouse (motion sickness, gimmicky)
|
|
416
|
+
- Particle / starfield backgrounds (2010s nostalgia, distracting)
|
|
417
|
+
- Auto-rotating hero carousels (WCAG 2.2.2 fail unless paused-on-hover-and-focus is implemented)
|
|
418
|
+
|
|
419
|
+
**Allowed:**
|
|
420
|
+
- A single image-fade-in-late after the headline lands (~0.6 s after, ~0.4 s duration)
|
|
421
|
+
- Type-unmask on the headline (`clip-path` opening over text)
|
|
422
|
+
- View Transitions API for state changes (theme switch, route change)
|
|
423
|
+
- Number-tick on a stat-led hero (counter from 0 to final, ≤ 1.2 s)
|
|
424
|
+
- A single subtle Lottie / CSS loop ≤ 4 s, with `prefers-reduced-motion` fallback
|
|
425
|
+
|
|
426
|
+
**Reduced-motion is the default in 2026.** Every animation gets a `@media (prefers-reduced-motion: reduce)` block that either disables the motion or replaces it with a static keyframe. This is non-negotiable; the slop test will catch you.
|
|
427
|
+
|
|
428
|
+
---
|
|
429
|
+
|
|
430
|
+
## Quality bar — eight pre-flight questions
|
|
431
|
+
|
|
432
|
+
Every question must answer *yes* before the enrichment ships. If any answer is *no*, ship the typographic-only hero instead.
|
|
433
|
+
|
|
434
|
+
1. Does the enrichment **communicate** something the typography can't?
|
|
435
|
+
2. Is it under **2 MB** total (video poster + first segment, illustration + animation JSON, image + grain)?
|
|
436
|
+
3. Does it have a **`prefers-reduced-motion` fallback**?
|
|
437
|
+
4. If video: muted, looped, `playsinline`, with a poster + `fetchpriority="high"` + caption track?
|
|
438
|
+
5. If illustration: built or generated with intent? **Not picked from a Lottie library as a shortcut?**
|
|
439
|
+
6. If background: under one accent colour at < 5 % footprint? (Aurora and mesh-gradients fail this.)
|
|
440
|
+
7. Does it survive being deleted? (If the hero still works without it, it earned its place. If the hero collapses without it, you propped weak typography on a crutch.)
|
|
441
|
+
8. Does its tone match the page's tone? (Risograph illustration on a Brutal page = wrong. Hand-drawn doodle on a Workbench developer-tool page = wrong. Three.js bloom on a Quiet page = wrong.)
|
|
442
|
+
|
|
443
|
+
The slop test ([`SKILL.md`](../SKILL.md) §5) carries four binary gates that mirror these questions; the audit verb runs them.
|
|
444
|
+
|
|
445
|
+
---
|
|
446
|
+
|
|
447
|
+
## Output stamp
|
|
448
|
+
|
|
449
|
+
When you ship enrichment, the macrostructure stamp records the choice:
|
|
450
|
+
|
|
451
|
+
```css
|
|
452
|
+
/* Hallmark · macrostructure: Marquee Hero · H1 hero knobs: size=xxl, alignment=left-bias
|
|
453
|
+
* enrichment: E1 Clipped-Edge Video · clip=right, aspect=16/10, frame=hairline
|
|
454
|
+
* polish: HP3 Cursor-spotlight (scoped to hero, reduced-motion fallback pinned at 50%/30%)
|
|
455
|
+
* nav: N5 Floating pill · footer: Ft5 Statement
|
|
456
|
+
* craft: tier-A CSS art (no real video — pure custom-built mockup)
|
|
457
|
+
* theme: Linen · accent: steel-blue ~3% · studied: no
|
|
458
|
+
*/
|
|
459
|
+
```
|
|
460
|
+
|
|
461
|
+
If no polish pattern is used, omit the `polish:` line — don't fake it. Same for enrichment.
|
|
462
|
+
|
|
463
|
+
This signals to future Hallmark runs (and to the audit verb) what was chosen and how. It also lets the user see the inferences in one place and redirect if anything's off.
|
|
464
|
+
|
|
465
|
+
---
|
|
466
|
+
|
|
467
|
+
## Common mistakes — and the fixes
|
|
468
|
+
|
|
469
|
+
- **Defaulting to E5 illustration on every brief.** Most heroes don't want an illustration. Reach for E0 (typography only) first; reach for E1–E4 when there's a *thing* to show; reach for E5 only when illustration genuinely matches the tone.
|
|
470
|
+
- **Using a stock Lottie checkmark as the hero animation.** That's tier E used to skip tiers A–D. Build the checkmark in pure CSS (`stroke-dasharray` animated to draw the tick); it's 8 lines.
|
|
471
|
+
- **Adding a grain background everywhere.** Grain is a treatment, not a default. Half the existing themes already carry texture (Riso, Linen, Specimen). Don't double up.
|
|
472
|
+
- **Treating the abstract background as the hero.** It isn't. The headline is. The background is paper.
|
|
473
|
+
- **Shipping the unmodified Storyset SVG.** That's tier D ungrounded — the library look. Customise the colour to your anchor hue at minimum; recompose if you can.
|
|
474
|
+
- **A clipped-edge video on mobile.** The clip reads as broken on a 375-px viewport. Always collapse to stacked at < 60 rem.
|