howone 0.1.20 → 0.1.23
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/nextjs/lib/sdk.ts +3 -0
- 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 +126 -0
- package/templates/vite/.howone/skills/howone-sdk/{references/08-manifest-codegen.md → 01-architect/02-manifest-codegen.md} +31 -19
- 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/{references/06-react-integration.md → 03-sdk/04-react-integration.md} +2 -4
- package/templates/vite/.howone/skills/howone-sdk/{references/03-ai-actions.md → 03-sdk/07-ai-action-calls.md} +31 -34
- package/templates/vite/.howone/skills/howone-sdk/04-ai/.gitkeep +1 -0
- package/templates/vite/.howone/skills/howone-sdk/04-ai/01-ai-capability-architecture.md +142 -0
- package/templates/vite/.howone/skills/howone-sdk/04-ai/02-workflow-contract-rules.md +169 -0
- package/templates/vite/.howone/skills/howone-sdk/04-ai/03-ai-sdk-handoff.md +80 -0
- package/templates/vite/.howone/skills/howone-sdk/SKILL.md +118 -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/src/lib/sdk.ts +3 -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 → 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
|
@@ -0,0 +1,1043 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html lang="en" data-theme="specimen">
|
|
3
|
+
|
|
4
|
+
<head>
|
|
5
|
+
<meta charset="utf-8" />
|
|
6
|
+
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
|
|
7
|
+
<meta name="color-scheme" content="light" />
|
|
8
|
+
<title>Hallmark — A design skill that refuses to look AI-generated</title>
|
|
9
|
+
<meta name="description"
|
|
10
|
+
content="Hallmark is a design skill for AI coding assistants. It encodes the anti-AI-slop consensus — typography, colour, layout, motion, interaction — into one holistic ruleset. Powered by Together AI." />
|
|
11
|
+
|
|
12
|
+
<meta property="og:title" content="Hallmark — A design skill that refuses to look AI-generated" />
|
|
13
|
+
<meta property="og:description"
|
|
14
|
+
content="A design skill for AI coding assistants. Encodes the anti-slop consensus into one ruleset. Powered by Together AI." />
|
|
15
|
+
<meta property="og:type" content="website" />
|
|
16
|
+
<meta property="og:url" content="https://www.usehallmark.com/" />
|
|
17
|
+
<meta property="og:site_name" content="Hallmark" />
|
|
18
|
+
<meta property="og:image" content="https://www.usehallmark.com/OG-hallmark.png" />
|
|
19
|
+
<meta property="og:image:secure_url" content="https://www.usehallmark.com/OG-hallmark.png" />
|
|
20
|
+
<meta property="og:image:type" content="image/png" />
|
|
21
|
+
<meta property="og:image:width" content="4800" />
|
|
22
|
+
<meta property="og:image:height" content="2520" />
|
|
23
|
+
<meta property="og:image:alt" content="Hallmark — A design skill that refuses to look AI-generated" />
|
|
24
|
+
<meta name="twitter:card" content="summary_large_image" />
|
|
25
|
+
<meta name="twitter:title" content="Hallmark — A design skill that refuses to look AI-generated" />
|
|
26
|
+
<meta name="twitter:description"
|
|
27
|
+
content="A design skill for AI coding assistants. Encodes the anti-slop consensus into one ruleset. Powered by Together AI." />
|
|
28
|
+
<meta name="twitter:image" content="https://www.usehallmark.com/OG-hallmark.png" />
|
|
29
|
+
<meta name="twitter:image:alt" content="Hallmark — A design skill that refuses to look AI-generated" />
|
|
30
|
+
|
|
31
|
+
<link rel="icon" type="image/svg+xml" href="favicon-light.svg" media="(prefers-color-scheme: light)" />
|
|
32
|
+
<link rel="icon" type="image/svg+xml" href="favicon-dark.svg" media="(prefers-color-scheme: dark)" />
|
|
33
|
+
<link rel="icon" type="image/svg+xml" href="favicon-light.svg" />
|
|
34
|
+
|
|
35
|
+
<!-- Entrance gate. Hides body until web fonts resolve so the page doesn't
|
|
36
|
+
flash system fonts then snap to the real faces. Fires once on first
|
|
37
|
+
load only — the matching script in the pre-paint block at the bottom
|
|
38
|
+
of <head> sets data-fonts-ready on <html> when document.fonts.ready
|
|
39
|
+
resolves (or after a 1200 ms safety timeout). Theme switches modify
|
|
40
|
+
[data-theme], not [data-fonts-ready], so the fade never re-runs. -->
|
|
41
|
+
<style>
|
|
42
|
+
html:not([data-fonts-ready]) body { opacity: 0; }
|
|
43
|
+
body {
|
|
44
|
+
opacity: 1;
|
|
45
|
+
transition: opacity 280ms cubic-bezier(0.22, 1, 0.36, 1);
|
|
46
|
+
}
|
|
47
|
+
@media (prefers-reduced-motion: reduce) {
|
|
48
|
+
html:not([data-fonts-ready]) body { opacity: 1; }
|
|
49
|
+
body { transition: none; }
|
|
50
|
+
}
|
|
51
|
+
</style>
|
|
52
|
+
|
|
53
|
+
<!-- Google Fonts — Anton, Albert Sans, Fraunces, Geist, Geist Mono, Hanken Grotesk, Inter, Inter Tight, Newsreader, Playfair Display, Public Sans. -->
|
|
54
|
+
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
|
55
|
+
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
|
|
56
|
+
<link rel="stylesheet"
|
|
57
|
+
href="https://fonts.googleapis.com/css2?family=Albert+Sans:wght@400;500;600;700;800&family=Anton&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,900;1,9..144,400;1,9..144,500&family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500&family=Hanken+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=Inter+Tight:ital,wght@0,500;0,600;0,700;0,800;1,500;1,600;1,700&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;1,6..72,400;1,6..72,500&family=Playfair+Display:ital,wght@1,400;1,500;1,600&family=Public+Sans:wght@400;500;600;700&display=swap" />
|
|
58
|
+
|
|
59
|
+
<link rel="stylesheet" href="css/tokens.css" />
|
|
60
|
+
<link rel="stylesheet" href="css/base.css" />
|
|
61
|
+
<link rel="stylesheet" href="css/components.css" />
|
|
62
|
+
<link rel="stylesheet" href="css/sections.css" />
|
|
63
|
+
|
|
64
|
+
<script>
|
|
65
|
+
// Load theme before paint to avoid flash. Order: ?theme= → localStorage → default.
|
|
66
|
+
try {
|
|
67
|
+
const url = new URL(window.location.href);
|
|
68
|
+
const q = url.searchParams.get("theme");
|
|
69
|
+
const t = q || localStorage.getItem("hallmark-theme");
|
|
70
|
+
if (t) document.documentElement.dataset.theme = t;
|
|
71
|
+
} catch (e) { }
|
|
72
|
+
|
|
73
|
+
// Mark fonts-ready when document.fonts resolves; safety timeout at 1200 ms.
|
|
74
|
+
// Pairs with the entrance-fade <style> above. Fires once on first load —
|
|
75
|
+
// theme switches don't reset the attribute, so the fade never re-runs.
|
|
76
|
+
(function () {
|
|
77
|
+
var html = document.documentElement;
|
|
78
|
+
var fired = false;
|
|
79
|
+
function ready() {
|
|
80
|
+
if (fired) return;
|
|
81
|
+
fired = true;
|
|
82
|
+
html.setAttribute("data-fonts-ready", "");
|
|
83
|
+
}
|
|
84
|
+
if (document.fonts && document.fonts.ready && typeof document.fonts.ready.then === "function") {
|
|
85
|
+
document.fonts.ready.then(ready);
|
|
86
|
+
} else {
|
|
87
|
+
ready();
|
|
88
|
+
}
|
|
89
|
+
setTimeout(ready, 1200);
|
|
90
|
+
})();
|
|
91
|
+
</script>
|
|
92
|
+
|
|
93
|
+
<!-- Privacy-friendly analytics by Plausible -->
|
|
94
|
+
<script async src="https://plausible.io/js/pa-C-D0j4RyxujH0xB9vHv0a.js"></script>
|
|
95
|
+
<script>
|
|
96
|
+
window.plausible=window.plausible||function(){(plausible.q=plausible.q||[]).push(arguments)},plausible.init=plausible.init||function(i){plausible.o=i||{}};
|
|
97
|
+
plausible.init()
|
|
98
|
+
</script>
|
|
99
|
+
</head>
|
|
100
|
+
|
|
101
|
+
<body>
|
|
102
|
+
|
|
103
|
+
<!-- BANNER — sticky top, thin, holds the theme picker -->
|
|
104
|
+
<header class="banner" role="banner">
|
|
105
|
+
<a class="banner__mark" href="#top" aria-label="Hallmark — top of page">
|
|
106
|
+
<span class="brand-mark" aria-hidden="true"><span class="brand-mark__slash">/</span><span class="brand-mark__name">hallmark</span></span>
|
|
107
|
+
<span class="banner__ver tnum">v1.0</span>
|
|
108
|
+
</a>
|
|
109
|
+
|
|
110
|
+
<a class="banner__install" href="#install" aria-label="Jump to install section">Install</a>
|
|
111
|
+
|
|
112
|
+
<a class="banner__star" href="https://github.com/nutlope/hallmark" target="_blank" rel="noopener"
|
|
113
|
+
aria-label="Star Hallmark on GitHub">
|
|
114
|
+
<svg class="banner__star-icon" viewBox="0 0 16 16" width="11" height="11" aria-hidden="true">
|
|
115
|
+
<path fill="currentColor"
|
|
116
|
+
d="M8 0.5l2.36 4.78 5.27.77-3.81 3.72.9 5.24L8 12.55 3.28 15.01l.9-5.24L.37 6.05l5.27-.77L8 .5z" />
|
|
117
|
+
</svg>
|
|
118
|
+
<span class="banner__star-count tnum" data-star-count>0</span>
|
|
119
|
+
</a>
|
|
120
|
+
|
|
121
|
+
<span class="banner__spacer" aria-hidden="true"></span>
|
|
122
|
+
|
|
123
|
+
<div class="banner__theme-wrap" data-theme-wrap>
|
|
124
|
+
<button class="banner__theme-indicator" type="button" aria-haspopup="listbox" aria-expanded="false"
|
|
125
|
+
aria-controls="theme-dropdown" data-theme-trigger>
|
|
126
|
+
<span class="banner__ordinal tnum" data-theme-ordinal>01 / 23</span>
|
|
127
|
+
<span class="banner__indicator-sep" aria-hidden="true">—</span>
|
|
128
|
+
<span class="banner__theme" data-theme-current>Specimen</span>
|
|
129
|
+
<svg class="banner__caret" viewBox="0 0 12 12" width="10" height="10" aria-hidden="true">
|
|
130
|
+
<path d="M2 4l4 4 4-4" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"
|
|
131
|
+
stroke-linejoin="round" />
|
|
132
|
+
</svg>
|
|
133
|
+
</button>
|
|
134
|
+
|
|
135
|
+
<div class="theme-dropdown" id="theme-dropdown" role="listbox" aria-label="Theme picker" hidden>
|
|
136
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="specimen" aria-label="01 — Specimen"
|
|
137
|
+
style="--dot: oklch(96% 0.018 80); --dot-edge: oklch(70% 0.04 75);"><span
|
|
138
|
+
class="theme-dropdown__num">01</span></button>
|
|
139
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="midnight" aria-label="02 — Midnight"
|
|
140
|
+
style="--dot: oklch(15% 0.022 250); --dot-edge: oklch(72% 0.16 220);"><span
|
|
141
|
+
class="theme-dropdown__num">02</span></button>
|
|
142
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="brutal" aria-label="03 — Brutal"
|
|
143
|
+
style="--dot: oklch(98% 0.001 0); --dot-edge: oklch(60% 0.21 27);"><span
|
|
144
|
+
class="theme-dropdown__num">03</span></button>
|
|
145
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="garden" aria-label="04 — Garden"
|
|
146
|
+
style="--dot: oklch(95% 0.030 130); --dot-edge: oklch(54% 0.16 14);"><span
|
|
147
|
+
class="theme-dropdown__num">04</span></button>
|
|
148
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="atelier" aria-label="05 — Atelier"
|
|
149
|
+
style="--dot: oklch(94% 0.005 60); --dot-edge: oklch(45% 0.13 60);"><span
|
|
150
|
+
class="theme-dropdown__num">05</span></button>
|
|
151
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="newsprint" aria-label="06 — Newsprint"
|
|
152
|
+
style="--dot: oklch(92% 0.045 50); --dot-edge: oklch(32% 0.10 28);"><span
|
|
153
|
+
class="theme-dropdown__num">06</span></button>
|
|
154
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="terminal" aria-label="07 — Terminal"
|
|
155
|
+
style="--dot: oklch(11% 0.018 145); --dot-edge: oklch(78% 0.19 138);"><span
|
|
156
|
+
class="theme-dropdown__num">07</span></button>
|
|
157
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="manifesto" aria-label="08 — Manifesto"
|
|
158
|
+
style="--dot: oklch(10% 0.005 60); --dot-edge: oklch(60% 0.22 27);"><span
|
|
159
|
+
class="theme-dropdown__num">08</span></button>
|
|
160
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="salon" aria-label="09 — Salon"
|
|
161
|
+
style="--dot: oklch(94% 0.030 65); --dot-edge: oklch(40% 0.085 50);"><span
|
|
162
|
+
class="theme-dropdown__num">09</span></button>
|
|
163
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="linen" aria-label="10 — Linen"
|
|
164
|
+
style="--dot: oklch(89% 0.022 95); --dot-edge: oklch(46% 0.06 95);"><span
|
|
165
|
+
class="theme-dropdown__num">10</span></button>
|
|
166
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="almanac" aria-label="11 — Almanac"
|
|
167
|
+
style="--dot: oklch(94% 0.008 245); --dot-edge: oklch(38% 0.135 250);"><span
|
|
168
|
+
class="theme-dropdown__num">11</span></button>
|
|
169
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="sport" aria-label="12 — Sport"
|
|
170
|
+
style="--dot: oklch(98% 0.003 250); --dot-edge: oklch(58% 0.190 35);"><span
|
|
171
|
+
class="theme-dropdown__num">12</span></button>
|
|
172
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="studio" aria-label="13 — Studio"
|
|
173
|
+
style="--dot: oklch(96.5% 0.014 95); --dot-edge: oklch(46% 0.140 145);"><span
|
|
174
|
+
class="theme-dropdown__num">13</span></button>
|
|
175
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="riso" aria-label="14 — Riso"
|
|
176
|
+
style="--dot: oklch(91% 0.034 30); --dot-edge: oklch(58% 0.170 220);"><span
|
|
177
|
+
class="theme-dropdown__num">14</span></button>
|
|
178
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="quiet" aria-label="15 — Quiet"
|
|
179
|
+
style="--dot: oklch(100% 0 0); --dot-edge: oklch(15% 0 0);"><span
|
|
180
|
+
class="theme-dropdown__num">15</span></button>
|
|
181
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="bloom" aria-label="16 — Bloom"
|
|
182
|
+
style="--dot: oklch(96% 0.018 35); --dot-edge: oklch(64% 0.180 18);"><span
|
|
183
|
+
class="theme-dropdown__num">16</span></button>
|
|
184
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="coral" aria-label="17 — Coral"
|
|
185
|
+
style="--dot: oklch(96.5% 0.005 50); --dot-edge: oklch(64% 0.165 28);"><span
|
|
186
|
+
class="theme-dropdown__num">17</span></button>
|
|
187
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="violet" aria-label="18 — Violet"
|
|
188
|
+
style="--dot: oklch(99% 0.003 280); --dot-edge: oklch(58% 0.16 285);"><span
|
|
189
|
+
class="theme-dropdown__num">18</span></button>
|
|
190
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="aurora" aria-label="19 — Aurora"
|
|
191
|
+
style="--dot: oklch(11% 0.025 200); --dot-edge: oklch(72% 0.170 200);"><span
|
|
192
|
+
class="theme-dropdown__num">19</span></button>
|
|
193
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="halo" aria-label="20 — Halo"
|
|
194
|
+
style="--dot: oklch(13% 0.005 60); --dot-edge: oklch(74% 0.16 70);"><span
|
|
195
|
+
class="theme-dropdown__num">20</span></button>
|
|
196
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="plume" aria-label="21 — Plume"
|
|
197
|
+
style="--dot: oklch(96% 0.020 70); --dot-edge: oklch(68% 0.130 18);"><span
|
|
198
|
+
class="theme-dropdown__num">21</span></button>
|
|
199
|
+
<button class="theme-dropdown__dot" type="button" data-theme-btn="editorial" aria-label="22 — Editorial"
|
|
200
|
+
style="--dot: oklch(94% 0.020 75); --dot-edge: oklch(60% 0.160 35);"><span
|
|
201
|
+
class="theme-dropdown__num">22</span></button>
|
|
202
|
+
</div>
|
|
203
|
+
</div>
|
|
204
|
+
|
|
205
|
+
<button class="banner__shuffle" type="button" aria-label="Random theme · T cycles · R randomises"
|
|
206
|
+
title="Click → random · T cycles · R randomises">
|
|
207
|
+
<svg viewBox="0 0 24 24" width="14" height="14" fill="none" stroke="currentColor" stroke-width="2"
|
|
208
|
+
stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
|
209
|
+
<path d="M16 3h5v5" />
|
|
210
|
+
<path d="M4 20 21 3" />
|
|
211
|
+
<path d="M21 16v5h-5" />
|
|
212
|
+
<path d="m15 15 6 6" />
|
|
213
|
+
<path d="M4 4l5 5" />
|
|
214
|
+
</svg>
|
|
215
|
+
<span class="banner__shuffle-key">T</span>
|
|
216
|
+
</button>
|
|
217
|
+
|
|
218
|
+
<aside class="t-tooltip" data-t-tooltip hidden role="status" aria-live="polite">
|
|
219
|
+
<span class="t-tooltip__arrow" aria-hidden="true"></span>
|
|
220
|
+
<span class="t-tooltip__body">
|
|
221
|
+
Press <kbd>T</kbd> to see this page in <strong>22 shapes</strong>.
|
|
222
|
+
</span>
|
|
223
|
+
</aside>
|
|
224
|
+
</header>
|
|
225
|
+
|
|
226
|
+
<main class="page">
|
|
227
|
+
|
|
228
|
+
<!-- 01 · HERO SLOT — archetype swaps per theme -->
|
|
229
|
+
<section class="slot slot--hero reveal" data-slot="hero" id="top" style="--i:0" aria-label="Opening"></section>
|
|
230
|
+
|
|
231
|
+
<!-- 02 · EXAMPLES — full-bleed rail, the centerpiece -->
|
|
232
|
+
<section class="section section--bleed reveal" style="--i:1" id="examples" aria-labelledby="s2">
|
|
233
|
+
<header class="section__head">
|
|
234
|
+
<p class="section-label">
|
|
235
|
+
<span class="num">02</span><span class="divider">⁄</span><span>Examples</span>
|
|
236
|
+
</p>
|
|
237
|
+
<h2 class="section__title" id="s2">
|
|
238
|
+
Worked examples.
|
|
239
|
+
</h2>
|
|
240
|
+
</header>
|
|
241
|
+
|
|
242
|
+
<p class="examples__intro">One-shotted. No shared theme. No shared layout.</p>
|
|
243
|
+
|
|
244
|
+
<div class="examples-rail" role="list" aria-label="Example landing pages">
|
|
245
|
+
|
|
246
|
+
<a class="ex-card" role="listitem" href="examples/tally/" target="_blank" rel="noopener" aria-label="Open the Tally example — SaaS product page, modern-minimal — in a new tab">
|
|
247
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
248
|
+
<video data-hover-play src="_tests/_thumbs/SaaS-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
249
|
+
</div>
|
|
250
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a SaaS product page, modern-minimal</p>
|
|
251
|
+
</a>
|
|
252
|
+
|
|
253
|
+
<a class="ex-card" role="listitem" href="examples/wayfare/" target="_blank" rel="noopener" aria-label="Open the Wayfare example — travel booking site, atmospheric — in a new tab">
|
|
254
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
255
|
+
<video data-hover-play src="_tests/_thumbs/wayfare-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
256
|
+
</div>
|
|
257
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a travel booking site, atmospheric</p>
|
|
258
|
+
</a>
|
|
259
|
+
|
|
260
|
+
<a class="ex-card" role="listitem" href="_tests/09-slow-pour/" target="_blank" rel="noopener" aria-label="Open the Slow Pour example — small-batch coffee subscription — in a new tab">
|
|
261
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
262
|
+
<video data-hover-play src="_tests/_thumbs/slow-pour-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
263
|
+
</div>
|
|
264
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a small-batch coffee subscription page</p>
|
|
265
|
+
</a>
|
|
266
|
+
|
|
267
|
+
<a class="ex-card" role="listitem" href="examples/bananastudio/" target="_blank" rel="noopener" aria-label="Open the BananaStudio example — creative studio with playful motion — in a new tab">
|
|
268
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
269
|
+
<video data-hover-play src="_tests/_thumbs/BananaStudio-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
270
|
+
</div>
|
|
271
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a creative studio with playful motion</p>
|
|
272
|
+
</a>
|
|
273
|
+
|
|
274
|
+
<a class="ex-card" role="listitem" href="_tests/06-anya-portfolio/" target="_blank" rel="noopener" aria-label="Open the Anya Reis example — software architect personal site — in a new tab">
|
|
275
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
276
|
+
<video data-hover-play src="_tests/_thumbs/anya-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
277
|
+
</div>
|
|
278
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a software architect personal site</p>
|
|
279
|
+
</a>
|
|
280
|
+
|
|
281
|
+
<a class="ex-card" role="listitem" href="examples/najm/" target="_blank" rel="noopener" aria-label="Open the NAJM example — Moroccan fashion brand landing page — in a new tab">
|
|
282
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
283
|
+
<video data-hover-play src="_tests/_thumbs/Najm-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
284
|
+
</div>
|
|
285
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a Moroccan fashion brand landing page</p>
|
|
286
|
+
</a>
|
|
287
|
+
|
|
288
|
+
<a class="ex-card" role="listitem" href="_tests/11-soroe-ceramics/" target="_blank" rel="noopener" aria-label="Open the Soroe example — small ceramics studio site — in a new tab">
|
|
289
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
290
|
+
<video data-hover-play src="_tests/_thumbs/Soroe-loop.mp4" autoplay loop muted playsinline preload="metadata" width="1804" height="1080"></video>
|
|
291
|
+
</div>
|
|
292
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a small ceramics studio site</p>
|
|
293
|
+
</a>
|
|
294
|
+
|
|
295
|
+
<a class="ex-card" role="listitem" href="examples/hyperlane/" target="_blank" rel="noopener" aria-label="Open the Hyperlane example — developer infrastructure landing page — in a new tab">
|
|
296
|
+
<div class="ex-card__thumb ex-card__thumb--video" aria-hidden="true">
|
|
297
|
+
<video data-hover-play src="_tests/_thumbs/Hyperlane-example.mp4" autoplay loop muted playsinline preload="metadata" width="1784" height="1080"></video>
|
|
298
|
+
</div>
|
|
299
|
+
<p class="ex-card__prompt"><span class="ex-card__prompt-mark">$</span> /hallmark build a developer infrastructure landing page</p>
|
|
300
|
+
</a>
|
|
301
|
+
|
|
302
|
+
</div>
|
|
303
|
+
|
|
304
|
+
</section>
|
|
305
|
+
|
|
306
|
+
<!-- 03 · SKILLS — five things Hallmark does, one ruleset underneath -->
|
|
307
|
+
<section class="section reveal" style="--i:2" id="skills" aria-labelledby="s-skills">
|
|
308
|
+
<header class="section__head">
|
|
309
|
+
<p class="section-label">
|
|
310
|
+
<span class="num">03</span><span class="divider">⁄</span><span>Skills</span>
|
|
311
|
+
</p>
|
|
312
|
+
<h2 class="section__title" id="s-skills">
|
|
313
|
+
What it does.
|
|
314
|
+
</h2>
|
|
315
|
+
</header>
|
|
316
|
+
|
|
317
|
+
<p class="skills__intro">
|
|
318
|
+
Hallmark has one default behaviour and three explicit verbs. Each reads a different input and returns a
|
|
319
|
+
different shape — same opinions, different jobs.
|
|
320
|
+
</p>
|
|
321
|
+
|
|
322
|
+
<ol class="skills-list">
|
|
323
|
+
|
|
324
|
+
<!-- Row I — Build (default) -->
|
|
325
|
+
<li class="skill-row" data-verb="build">
|
|
326
|
+
<header class="skill-row__head">
|
|
327
|
+
<div class="skill-row__head-body">
|
|
328
|
+
<h3 class="skill-row__title">Build <span class="skill-row__title-meta">(default)</span></h3>
|
|
329
|
+
<p class="skill-row__lede">Ask for a page. Get a page that doesn't look generated. Hallmark picks a
|
|
330
|
+
macrostructure first, then dresses it — and refuses to repeat the same shape twice.</p>
|
|
331
|
+
</div>
|
|
332
|
+
</header>
|
|
333
|
+
|
|
334
|
+
<div class="skill-row__body">
|
|
335
|
+
<figure class="skill-row__demo skill-row__demo--build">
|
|
336
|
+
<span class="brief-pill" aria-label="Example brief">"Build me a landing page for an indie podcast
|
|
337
|
+
platform."</span>
|
|
338
|
+
<span class="brief-arrow" aria-hidden="true">↓</span>
|
|
339
|
+
<span class="fig-corners brief-output">
|
|
340
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
341
|
+
<video class="brief-output__media" src="_tests/_thumbs/Podcast-loop.mp4" autoplay loop muted playsinline
|
|
342
|
+
preload="metadata" width="1600" height="1022"
|
|
343
|
+
aria-label="Podcast platform — a Hallmark output looping through its scroll"></video>
|
|
344
|
+
</span>
|
|
345
|
+
</figure>
|
|
346
|
+
|
|
347
|
+
<ol class="skill-row__list">
|
|
348
|
+
<li class="dna__row"><span class="dna__k">Invocation</span><span class="dna__v">(default) — just
|
|
349
|
+
ask</span></li>
|
|
350
|
+
<li class="dna__row"><span class="dna__k">Reads</span><span class="dna__v">your brief, project tokens,
|
|
351
|
+
framework</span></li>
|
|
352
|
+
<li class="dna__row"><span class="dna__k">Picks</span><span class="dna__v">macrostructure → theme →
|
|
353
|
+
enrichment</span></li>
|
|
354
|
+
<li class="dna__row"><span class="dna__k">Returns</span><span class="dna__v">a working page, stamped,
|
|
355
|
+
slop-tested</span></li>
|
|
356
|
+
<li class="dna__row"><span class="dna__k">Refuses</span><span class="dna__v">repeating the last 3
|
|
357
|
+
macrostructures</span></li>
|
|
358
|
+
</ol>
|
|
359
|
+
</div>
|
|
360
|
+
</li>
|
|
361
|
+
|
|
362
|
+
<!-- Row II — Study (preserves the existing DNA cards as THE demo) -->
|
|
363
|
+
<li class="skill-row" data-verb="study">
|
|
364
|
+
<header class="skill-row__head">
|
|
365
|
+
<div class="skill-row__head-body">
|
|
366
|
+
<h3 class="skill-row__title">Study</h3>
|
|
367
|
+
<p class="skill-row__lede">Paste a design you admire — a screenshot <em>or</em> a URL. Hallmark reads its
|
|
368
|
+
structure, not its pixels, and returns a DNA card you can build against. Or say <code>lock the
|
|
369
|
+
DNA</code> to write a portable <code>design.md</code> you can hand to another AI tool. Never copies
|
|
370
|
+
pixels. Tighter refusal layer for the portable spec than for the diagnosis.</p>
|
|
371
|
+
</div>
|
|
372
|
+
</header>
|
|
373
|
+
|
|
374
|
+
<div class="skill-row__body">
|
|
375
|
+
<figure class="skill-row__demo skill-row__demo--build">
|
|
376
|
+
<span class="brief-pill" aria-label="Example brief">/hallmark study together.ai · or paste a screenshot</span>
|
|
377
|
+
<span class="brief-arrow" aria-hidden="true">↓</span>
|
|
378
|
+
<span class="fig-corners brief-output">
|
|
379
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
380
|
+
<img src="_tests/_thumbs/study-example.png"
|
|
381
|
+
alt="A scheduling-tool landing page — used as a study reference for Hallmark's DNA extractor"
|
|
382
|
+
loading="lazy" decoding="async" width="1680" height="1050" />
|
|
383
|
+
</span>
|
|
384
|
+
</figure>
|
|
385
|
+
|
|
386
|
+
<ol class="skill-row__list">
|
|
387
|
+
<li class="dna__row"><span class="dna__k">Invocation</span><span
|
|
388
|
+
class="dna__v"><code>hallmark study <screenshot | URL></code></span></li>
|
|
389
|
+
<li class="dna__row"><span class="dna__k">Macrostructure</span><span class="dna__v">Split Hero</span></li>
|
|
390
|
+
<li class="dna__row"><span class="dna__k">Hero archetype</span><span class="dna__v">H7 Clipped · copy-left
|
|
391
|
+
+ product-mock right</span></li>
|
|
392
|
+
<li class="dna__row"><span class="dna__k">Display role</span><span class="dna__v">heavy geometric
|
|
393
|
+
sans</span></li>
|
|
394
|
+
<li class="dna__row"><span class="dna__k">Body role</span><span class="dna__v">same family · regular
|
|
395
|
+
weight</span></li>
|
|
396
|
+
<li class="dna__row"><span class="dna__k">Label role</span><span class="dna__v">grotesque · sentence
|
|
397
|
+
case</span></li>
|
|
398
|
+
<li class="dna__row"><span class="dna__k">Paper band</span><span class="dna__v">light · pure white</span>
|
|
399
|
+
</li>
|
|
400
|
+
<li class="dna__row"><span class="dna__k">Accent hue</span><span class="dna__v">cool blue + magenta ·
|
|
401
|
+
organic gradient</span></li>
|
|
402
|
+
<li class="dna__row"><span class="dna__k">Rhythm</span><span class="dna__v">left-copy · right product card
|
|
403
|
+
· overlapping watercolor blobs</span></li>
|
|
404
|
+
<li class="dna__row"><span class="dna__k">Refuses</span><span class="dna__v">to ID fonts · to copy
|
|
405
|
+
pixels</span></li>
|
|
406
|
+
</ol>
|
|
407
|
+
</div>
|
|
408
|
+
</li>
|
|
409
|
+
|
|
410
|
+
<!-- Row III — Audit -->
|
|
411
|
+
<li class="skill-row" data-verb="audit">
|
|
412
|
+
<header class="skill-row__head">
|
|
413
|
+
<div class="skill-row__head-body">
|
|
414
|
+
<h3 class="skill-row__title">Audit</h3>
|
|
415
|
+
<p class="skill-row__lede">Point Hallmark at a page. Get a ranked punch list of what's wrong — scored
|
|
416
|
+
against the anti-pattern catalogue. <strong>No edits.</strong> Just the diagnosis.</p>
|
|
417
|
+
</div>
|
|
418
|
+
</header>
|
|
419
|
+
|
|
420
|
+
<div class="skill-row__body">
|
|
421
|
+
<figure class="skill-row__demo skill-row__demo--audit" aria-label="A Hallmark output for reference">
|
|
422
|
+
<span class="fig-corners brief-output">
|
|
423
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
424
|
+
<img src="_tests/_thumbs/audit-example.png"
|
|
425
|
+
alt="A Hallmark output — editorial display, real proof, hand-built illustration"
|
|
426
|
+
loading="lazy" decoding="async" width="1024" height="640" />
|
|
427
|
+
</span>
|
|
428
|
+
</figure>
|
|
429
|
+
|
|
430
|
+
<ol class="audit-check">
|
|
431
|
+
<li class="audit-check__row">
|
|
432
|
+
<span class="audit-check__cross" aria-hidden="true">✗</span>
|
|
433
|
+
<span class="audit-check__problem">Purple-to-pink gradient hero</span>
|
|
434
|
+
<span class="audit-check__arrow" aria-hidden="true">→</span>
|
|
435
|
+
<span class="audit-check__fix">Solid surface, single accent</span>
|
|
436
|
+
</li>
|
|
437
|
+
<li class="audit-check__row">
|
|
438
|
+
<span class="audit-check__cross" aria-hidden="true">✗</span>
|
|
439
|
+
<span class="audit-check__problem">Inter as display + body</span>
|
|
440
|
+
<span class="audit-check__arrow" aria-hidden="true">→</span>
|
|
441
|
+
<span class="audit-check__fix">Pair distinctive display + body</span>
|
|
442
|
+
</li>
|
|
443
|
+
<li class="audit-check__row">
|
|
444
|
+
<span class="audit-check__cross" aria-hidden="true">✗</span>
|
|
445
|
+
<span class="audit-check__problem">Centered everything</span>
|
|
446
|
+
<span class="audit-check__arrow" aria-hidden="true">→</span>
|
|
447
|
+
<span class="audit-check__fix">Bias the layout, break symmetry</span>
|
|
448
|
+
</li>
|
|
449
|
+
<li class="audit-check__row">
|
|
450
|
+
<span class="audit-check__cross" aria-hidden="true">✗</span>
|
|
451
|
+
<span class="audit-check__problem">Sparkle ✨ emoji as badge</span>
|
|
452
|
+
<span class="audit-check__arrow" aria-hidden="true">→</span>
|
|
453
|
+
<span class="audit-check__fix">Pick an icon library, or drop it</span>
|
|
454
|
+
</li>
|
|
455
|
+
<li class="audit-check__row">
|
|
456
|
+
<span class="audit-check__cross" aria-hidden="true">✗</span>
|
|
457
|
+
<span class="audit-check__problem">Gradient pill CTA</span>
|
|
458
|
+
<span class="audit-check__arrow" aria-hidden="true">→</span>
|
|
459
|
+
<span class="audit-check__fix">Solid fill or outline, single hue</span>
|
|
460
|
+
</li>
|
|
461
|
+
</ol>
|
|
462
|
+
</div>
|
|
463
|
+
</li>
|
|
464
|
+
|
|
465
|
+
<!-- Row IV — Redesign -->
|
|
466
|
+
<li class="skill-row" data-verb="redesign">
|
|
467
|
+
<header class="skill-row__head">
|
|
468
|
+
<div class="skill-row__head-body">
|
|
469
|
+
<h3 class="skill-row__title">Redesign</h3>
|
|
470
|
+
<p class="skill-row__lede">Same content. Same brand. Different bones. Hallmark throws out the structural
|
|
471
|
+
fingerprint and rebuilds with a deliberately different one — new section rhythm, new heading placement,
|
|
472
|
+
new component voice.</p>
|
|
473
|
+
</div>
|
|
474
|
+
</header>
|
|
475
|
+
|
|
476
|
+
<div class="skill-row__body skill-row__body--full">
|
|
477
|
+
<figure class="skill-row__demo skill-row__demo--diptych">
|
|
478
|
+
<figure class="diptych__half" data-state="before">
|
|
479
|
+
<span class="fig-corners">
|
|
480
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
481
|
+
<img src="_tests/_thumbs/example-redesign-uractivation.png"
|
|
482
|
+
alt="The original page — generic SaaS chrome before the redesign" loading="lazy" decoding="async"
|
|
483
|
+
width="1784" height="1080" />
|
|
484
|
+
</span>
|
|
485
|
+
<figcaption class="diptych__cap">Before</figcaption>
|
|
486
|
+
</figure>
|
|
487
|
+
<figure class="diptych__half" data-state="after">
|
|
488
|
+
<span class="fig-corners">
|
|
489
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
490
|
+
<video src="_tests/_thumbs/uractivation-after-loop.mp4" autoplay loop muted
|
|
491
|
+
playsinline preload="metadata" width="1784" height="1080"
|
|
492
|
+
aria-label="Same content, redesigned by Hallmark — different macrostructure, different fingerprint"></video>
|
|
493
|
+
</span>
|
|
494
|
+
<figcaption class="diptych__cap">After Hallmark redesign</figcaption>
|
|
495
|
+
</figure>
|
|
496
|
+
</figure>
|
|
497
|
+
</div>
|
|
498
|
+
</li>
|
|
499
|
+
|
|
500
|
+
</ol>
|
|
501
|
+
|
|
502
|
+
</section>
|
|
503
|
+
|
|
504
|
+
<!-- INTERLUDE — full-bleed typographic moment between III and IV.
|
|
505
|
+
Mid-scroll punctuation: a single declarative phrase set in
|
|
506
|
+
the active theme's display face, on a contrasting paper band.
|
|
507
|
+
Reprise of the marketing pitch in oversized type. -->
|
|
508
|
+
<aside class="interlude reveal" style="--i:3" aria-hidden="true">
|
|
509
|
+
<p class="interlude__phrase"><em>The page</em> is the demo.</p>
|
|
510
|
+
</aside>
|
|
511
|
+
|
|
512
|
+
<!-- 04 · ANTI-PATTERNS — Slop, by name. Five named AI-UI tells, each
|
|
513
|
+
with the Hallmark fix beside it. Replaces the original Without/
|
|
514
|
+
With section (preserved as a <template> below). -->
|
|
515
|
+
<section class="section reveal" style="--i:3" id="anti-patterns" aria-labelledby="s-anti">
|
|
516
|
+
<header class="section__head">
|
|
517
|
+
<p class="section-label">
|
|
518
|
+
<span class="num">04</span><span class="divider">⁄</span><span>Anti-patterns</span>
|
|
519
|
+
</p>
|
|
520
|
+
<h2 class="section__title" id="s-anti">
|
|
521
|
+
Slop, by name.
|
|
522
|
+
</h2>
|
|
523
|
+
</header>
|
|
524
|
+
|
|
525
|
+
<p class="anti__intro">
|
|
526
|
+
Five tells the LLM reaches for by default. The Hallmark fix beside each. <code>hallmark audit</code> flags every
|
|
527
|
+
one of these on existing code.
|
|
528
|
+
</p>
|
|
529
|
+
|
|
530
|
+
<ol class="anti-list">
|
|
531
|
+
|
|
532
|
+
<li class="anti-row">
|
|
533
|
+
<p class="anti-row__num tnum">01</p>
|
|
534
|
+
<div class="anti-row__slop">
|
|
535
|
+
<h3 class="anti-row__name">The purple-gradient hero.</h3>
|
|
536
|
+
<p class="anti-row__desc">A hero with a background gradient from purple to blue or purple to pink, white
|
|
537
|
+
centred text. The single most-recognised AI aesthetic.</p>
|
|
538
|
+
</div>
|
|
539
|
+
<div class="anti-row__fix">
|
|
540
|
+
<p class="anti-row__fix-label">Hallmark</p>
|
|
541
|
+
<p class="anti-row__fix-body">Pick a single anchor hue. One accent. No gradient backgrounds on heroes. If
|
|
542
|
+
you want warmth, tint the neutrals.</p>
|
|
543
|
+
</div>
|
|
544
|
+
</li>
|
|
545
|
+
|
|
546
|
+
<li class="anti-row">
|
|
547
|
+
<p class="anti-row__num tnum">02</p>
|
|
548
|
+
<div class="anti-row__slop">
|
|
549
|
+
<h3 class="anti-row__name">Inter as display.</h3>
|
|
550
|
+
<p class="anti-row__desc">Inter (or Roboto, or Open Sans) used as both display and body, no pairing face. A
|
|
551
|
+
one-font page is a template page.</p>
|
|
552
|
+
</div>
|
|
553
|
+
<div class="anti-row__fix">
|
|
554
|
+
<p class="anti-row__fix-label">Hallmark</p>
|
|
555
|
+
<p class="anti-row__fix-body">Pair a distinctive display face with a refined body. Two faces minimum, never
|
|
556
|
+
the same family doing both jobs.</p>
|
|
557
|
+
</div>
|
|
558
|
+
</li>
|
|
559
|
+
|
|
560
|
+
<li class="anti-row">
|
|
561
|
+
<p class="anti-row__num tnum">03</p>
|
|
562
|
+
<div class="anti-row__slop">
|
|
563
|
+
<h3 class="anti-row__name">Centred everything.</h3>
|
|
564
|
+
<p class="anti-row__desc">Headline centred, body centred, button centred, section after section of centred
|
|
565
|
+
columns. Symmetry as default.</p>
|
|
566
|
+
</div>
|
|
567
|
+
<div class="anti-row__fix">
|
|
568
|
+
<p class="anti-row__fix-label">Hallmark</p>
|
|
569
|
+
<p class="anti-row__fix-body">Bias the layout. Wide left margin, narrow right — or the reverse. Breaking
|
|
570
|
+
symmetry once is enough to register intent.</p>
|
|
571
|
+
</div>
|
|
572
|
+
</li>
|
|
573
|
+
|
|
574
|
+
<li class="anti-row">
|
|
575
|
+
<p class="anti-row__num tnum">04</p>
|
|
576
|
+
<div class="anti-row__slop">
|
|
577
|
+
<h3 class="anti-row__name">The icon-tile feature card.</h3>
|
|
578
|
+
<p class="anti-row__desc">Rounded rectangle, icon in a coloured square top-left, two-line heading,
|
|
579
|
+
three-line copy, optional "Learn more →". The universal template.</p>
|
|
580
|
+
</div>
|
|
581
|
+
<div class="anti-row__fix">
|
|
582
|
+
<p class="anti-row__fix-label">Hallmark</p>
|
|
583
|
+
<p class="anti-row__fix-body">If you need feature cards, let them be asymmetric — vary sizes, vary
|
|
584
|
+
alignments, pull the icon inline. Or drop the icon and lead with type.</p>
|
|
585
|
+
</div>
|
|
586
|
+
</li>
|
|
587
|
+
|
|
588
|
+
<li class="anti-row">
|
|
589
|
+
<p class="anti-row__num tnum">05</p>
|
|
590
|
+
<div class="anti-row__slop">
|
|
591
|
+
<h3 class="anti-row__name">The AI nav.</h3>
|
|
592
|
+
<p class="anti-row__desc">Wordmark hard-left, four inline links centred, CTA button hard-right, sticky on
|
|
593
|
+
scroll, hairline border-bottom. The shape every LLM ships.</p>
|
|
594
|
+
</div>
|
|
595
|
+
<div class="anti-row__fix">
|
|
596
|
+
<p class="anti-row__fix-label">Hallmark</p>
|
|
597
|
+
<p class="anti-row__fix-body">Pick a nav archetype that matches the page's genre — newspaper masthead,
|
|
598
|
+
terminal command bar, edge-aligned minimal. The nav should tell you what kind of site you're on.</p>
|
|
599
|
+
</div>
|
|
600
|
+
</li>
|
|
601
|
+
|
|
602
|
+
</ol>
|
|
603
|
+
|
|
604
|
+
</section>
|
|
605
|
+
|
|
606
|
+
|
|
607
|
+
<!-- 05 · FOUNDATIONS — eight compact cards in a 4×2 grid. Each
|
|
608
|
+
card holds a hand-drawn SVG icon, one-word title, and a single
|
|
609
|
+
line of description. Replaces the radio-tab Foundations panel
|
|
610
|
+
(preserved in <template id="section-05-archive-foundations-tabs">
|
|
611
|
+
below). -->
|
|
612
|
+
<section class="section reveal" style="--i:4" id="foundations" aria-labelledby="s5-foundations">
|
|
613
|
+
<header class="section__head">
|
|
614
|
+
<p class="section-label">
|
|
615
|
+
<span class="num">05</span><span class="divider">⁄</span><span>Foundations</span>
|
|
616
|
+
</p>
|
|
617
|
+
<h2 class="section__title" id="s5-foundations">
|
|
618
|
+
Foundations.
|
|
619
|
+
</h2>
|
|
620
|
+
</header>
|
|
621
|
+
|
|
622
|
+
<p class="found__intro">Eight rules that hold across every theme. None of them are settings.</p>
|
|
623
|
+
|
|
624
|
+
<ul class="found-cards" role="list">
|
|
625
|
+
|
|
626
|
+
<li class="found-card">
|
|
627
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
628
|
+
<svg viewBox="0 0 48 48" fill="none" stroke-linecap="round" stroke-linejoin="round">
|
|
629
|
+
<text x="3" y="36" font-family="'Fraunces', 'Tiempos', serif" font-style="italic" font-size="34"
|
|
630
|
+
font-weight="500" fill="currentColor">A</text>
|
|
631
|
+
<text x="22" y="42" font-family="'Geist', 'Inter', sans-serif" font-size="22" font-weight="600"
|
|
632
|
+
fill="currentColor">a</text>
|
|
633
|
+
</svg>
|
|
634
|
+
</span>
|
|
635
|
+
<h3 class="found-card__name">Type</h3>
|
|
636
|
+
<p class="found-card__body">Pair a display face with a body face. Never one font doing both jobs.</p>
|
|
637
|
+
</li>
|
|
638
|
+
|
|
639
|
+
<li class="found-card">
|
|
640
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
641
|
+
<svg viewBox="0 0 48 48" fill="currentColor">
|
|
642
|
+
<circle cx="9" cy="24" r="4.5" />
|
|
643
|
+
<circle cx="20" cy="24" r="4.5" opacity="0.7" />
|
|
644
|
+
<circle cx="31" cy="24" r="4.5" opacity="0.4" />
|
|
645
|
+
<circle cx="42" cy="24" r="4.5" fill="none" stroke="currentColor" stroke-width="1.5" />
|
|
646
|
+
</svg>
|
|
647
|
+
</span>
|
|
648
|
+
<h3 class="found-card__name">Colour</h3>
|
|
649
|
+
<p class="found-card__body">OKLCH palettes. One anchor hue. The accent stays under five percent.</p>
|
|
650
|
+
</li>
|
|
651
|
+
|
|
652
|
+
<li class="found-card">
|
|
653
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
654
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round">
|
|
655
|
+
<line x1="4" y1="26" x2="44" y2="26" />
|
|
656
|
+
<line x1="8" y1="22" x2="8" y2="30" />
|
|
657
|
+
<line x1="16" y1="24" x2="16" y2="28" />
|
|
658
|
+
<line x1="24" y1="18" x2="24" y2="32" />
|
|
659
|
+
<line x1="32" y1="24" x2="32" y2="28" />
|
|
660
|
+
<line x1="40" y1="22" x2="40" y2="30" />
|
|
661
|
+
</svg>
|
|
662
|
+
</span>
|
|
663
|
+
<h3 class="found-card__name">Space</h3>
|
|
664
|
+
<p class="found-card__body">A named scale. Multiples of four. No arbitrary 17-pixel paddings.</p>
|
|
665
|
+
</li>
|
|
666
|
+
|
|
667
|
+
<li class="found-card">
|
|
668
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
669
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"
|
|
670
|
+
stroke-linejoin="round">
|
|
671
|
+
<path d="M 6 32 Q 18 32 24 24 T 40 14" />
|
|
672
|
+
<path d="M 34 14 L 40 14 L 40 20" />
|
|
673
|
+
</svg>
|
|
674
|
+
</span>
|
|
675
|
+
<h3 class="found-card__name">Motion</h3>
|
|
676
|
+
<p class="found-card__body">Exponential ease-out. Reduced-motion alternative for every animation.</p>
|
|
677
|
+
</li>
|
|
678
|
+
|
|
679
|
+
<li class="found-card">
|
|
680
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
681
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="2.4" stroke-linecap="round">
|
|
682
|
+
<path d="M 11 16 Q 7 19 7 24 Q 7 28 11 28" />
|
|
683
|
+
<path d="M 17 16 Q 13 19 13 24 Q 13 28 17 28" />
|
|
684
|
+
<path d="M 31 16 Q 27 19 27 24 Q 27 28 31 28" />
|
|
685
|
+
<path d="M 37 16 Q 33 19 33 24 Q 33 28 37 28" />
|
|
686
|
+
</svg>
|
|
687
|
+
</span>
|
|
688
|
+
<h3 class="found-card__name">Voice</h3>
|
|
689
|
+
<p class="found-card__body">Distinct register per theme. Never the SaaS-default neutral middle.</p>
|
|
690
|
+
</li>
|
|
691
|
+
|
|
692
|
+
<li class="found-card">
|
|
693
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
694
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5">
|
|
695
|
+
<rect x="6" y="12" width="14" height="26" />
|
|
696
|
+
<rect x="22" y="18" width="20" height="20" />
|
|
697
|
+
</svg>
|
|
698
|
+
</span>
|
|
699
|
+
<h3 class="found-card__name">Layout</h3>
|
|
700
|
+
<p class="found-card__body">Bias the page. Asymmetric is intentional. Centred everything is a tell.</p>
|
|
701
|
+
</li>
|
|
702
|
+
|
|
703
|
+
<li class="found-card">
|
|
704
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
705
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-linecap="round">
|
|
706
|
+
<line x1="6" y1="14" x2="42" y2="14" stroke-width="3.5" />
|
|
707
|
+
<line x1="6" y1="25" x2="32" y2="25" stroke-width="2" />
|
|
708
|
+
<line x1="6" y1="36" x2="22" y2="36" stroke-width="1.2" />
|
|
709
|
+
</svg>
|
|
710
|
+
</span>
|
|
711
|
+
<h3 class="found-card__name">Hierarchy</h3>
|
|
712
|
+
<p class="found-card__body">Display, body, label. A weight ladder you can read in two seconds.</p>
|
|
713
|
+
</li>
|
|
714
|
+
|
|
715
|
+
<li class="found-card">
|
|
716
|
+
<span class="found-card__icon" aria-hidden="true">
|
|
717
|
+
<svg viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5">
|
|
718
|
+
<rect x="6" y="6" width="36" height="36" />
|
|
719
|
+
<circle cx="24" cy="24" r="3" fill="currentColor" />
|
|
720
|
+
</svg>
|
|
721
|
+
</span>
|
|
722
|
+
<h3 class="found-card__name">Restraint</h3>
|
|
723
|
+
<p class="found-card__body">Better nothing than bad something. The strongest fail-state is silence.</p>
|
|
724
|
+
</li>
|
|
725
|
+
|
|
726
|
+
</ul>
|
|
727
|
+
|
|
728
|
+
</section>
|
|
729
|
+
|
|
730
|
+
<!-- DEPRECATED: original Section 05 (Foundations radio tabs) — replaced
|
|
731
|
+
by the 8-card grid above. Wrapped in <template> so the markup stays
|
|
732
|
+
in this file but doesn't render. To revert: change the opening
|
|
733
|
+
<template> to <section class="section reveal" style="--i:4"
|
|
734
|
+
aria-labelledby="s5-foundations"> and the closing </template> to
|
|
735
|
+
</section>, then remove the new 8-card section above. -->
|
|
736
|
+
|
|
737
|
+
<!-- 06 · WITH / WITHOUT HALLMARK — same prompt, two different outputs.
|
|
738
|
+
The "without" was generated by Sonnet 4.6 alone; the "with" by
|
|
739
|
+
Sonnet 4.6 with Hallmark loaded. Both are real outputs of the
|
|
740
|
+
same brief. -->
|
|
741
|
+
<section class="section reveal" style="--i:5" id="before-after" aria-labelledby="s-ba">
|
|
742
|
+
<header class="section__head">
|
|
743
|
+
<p class="section-label">
|
|
744
|
+
<span class="num">06</span><span class="divider">⁄</span><span>With / Without</span>
|
|
745
|
+
</p>
|
|
746
|
+
<h2 class="section__title" id="s-ba">
|
|
747
|
+
Same prompt. Two different outputs.
|
|
748
|
+
</h2>
|
|
749
|
+
</header>
|
|
750
|
+
|
|
751
|
+
<p class="ba__prompt" aria-label="The shared prompt"><span class="ba__prompt-mark">$</span> /hallmark build a landing page for a dev event launch.</p>
|
|
752
|
+
|
|
753
|
+
<div class="ba">
|
|
754
|
+
<figure class="ba__panel ba__panel--before">
|
|
755
|
+
<p class="ba__panel-label"><span class="ba__panel-tag">Sonnet 4.6, no Hallmark</span></p>
|
|
756
|
+
<span class="fig-corners ba__frame">
|
|
757
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
758
|
+
<img src="_tests/_thumbs/before-quiet-hour.png" alt="Generic AI-default landing page — purple-pink gradient hero, generic 'Discover natural wines' headline, ★★★★★ trust strip, 3-column feature cards" loading="lazy" decoding="async" width="1440" height="900" />
|
|
759
|
+
</span>
|
|
760
|
+
<figcaption class="ba__panel-cap">Default reach for the gradient. Generic stat strip, made-up Trustpilot rating, "10× faster" feature card.</figcaption>
|
|
761
|
+
</figure>
|
|
762
|
+
|
|
763
|
+
<figure class="ba__panel ba__panel--after">
|
|
764
|
+
<p class="ba__panel-label"><span class="ba__panel-tag ba__panel-tag--accent">Sonnet 4.6 + Hallmark</span></p>
|
|
765
|
+
<span class="fig-corners ba__frame">
|
|
766
|
+
<span class="fig-corners__bl"></span><span class="fig-corners__br"></span>
|
|
767
|
+
<img src="_tests/_thumbs/after-quiet-hour.png" alt="A Hallmark output — editorial Lisbon dispatch, italic Fraunces display, real bottle plate with grape + region + tasting notes, no fabricated proof" loading="lazy" decoding="async" width="1440" height="900" />
|
|
768
|
+
</span>
|
|
769
|
+
<figcaption class="ba__panel-cap">Marquee Hero · Atelier · italic Fraunces. Real bottle, real grape, real region. No fabricated stats.</figcaption>
|
|
770
|
+
</figure>
|
|
771
|
+
</div>
|
|
772
|
+
</section>
|
|
773
|
+
|
|
774
|
+
<!-- 07 · INSTALL — one command, every harness -->
|
|
775
|
+
<section class="section reveal" style="--i:6" id="install" aria-labelledby="s6">
|
|
776
|
+
<header class="section__head">
|
|
777
|
+
<p class="section-label">
|
|
778
|
+
<span class="num">07</span><span class="divider">⁄</span><span>Install</span>
|
|
779
|
+
</p>
|
|
780
|
+
<h2 class="section__title" id="s6">
|
|
781
|
+
Install.
|
|
782
|
+
</h2>
|
|
783
|
+
</header>
|
|
784
|
+
|
|
785
|
+
<div class="install-pane">
|
|
786
|
+
|
|
787
|
+
<div class="install-pane__row install-pane__row--cmd">
|
|
788
|
+
<p class="install-pane__label"><span class="install-pane__step">I</span> Run</p>
|
|
789
|
+
<div class="install-pane__cmd" data-copy-source>
|
|
790
|
+
<span class="install-pane__prompt" aria-hidden="true">$</span>
|
|
791
|
+
<span class="install-pane__cmd-text" data-copy-text>npx skills add nutlope/hallmark</span>
|
|
792
|
+
<button class="install-pane__copy" type="button" data-copy-btn aria-label="Copy install command">
|
|
793
|
+
<span class="install-pane__copy-default">Copy</span>
|
|
794
|
+
<span class="install-pane__copy-done">Copied</span>
|
|
795
|
+
</button>
|
|
796
|
+
</div>
|
|
797
|
+
</div>
|
|
798
|
+
|
|
799
|
+
<div class="install-pane__row">
|
|
800
|
+
<p class="install-pane__label"><span class="install-pane__step">II</span> In</p>
|
|
801
|
+
<ul class="install-pane__harnesses">
|
|
802
|
+
<li class="harness"> <span class="harness__name">Claude Code</span>
|
|
803
|
+
<code class="harness__path">~/.claude/skills/hallmark/</code>
|
|
804
|
+
<span class="harness__status harness__status--ok">auto-detected</span>
|
|
805
|
+
</li>
|
|
806
|
+
<li class="harness"> <span class="harness__name">Cursor</span>
|
|
807
|
+
<code class="harness__path">.cursor/rules/hallmark.mdc</code>
|
|
808
|
+
<span class="harness__status harness__status--ok">auto-detected</span>
|
|
809
|
+
</li>
|
|
810
|
+
<li class="harness"> <span class="harness__name">Codex</span>
|
|
811
|
+
<code class="harness__path">~/.codex/skills/hallmark/</code>
|
|
812
|
+
<span class="harness__status harness__status--ok">auto-detected</span>
|
|
813
|
+
</li>
|
|
814
|
+
</ul>
|
|
815
|
+
</div>
|
|
816
|
+
|
|
817
|
+
<div class="install-pane__row">
|
|
818
|
+
<p class="install-pane__label"><span class="install-pane__step">III</span> Then</p>
|
|
819
|
+
<p class="install-pane__next">Ask your agent for a UI. <code>hallmark</code> attaches itself.</p>
|
|
820
|
+
</div>
|
|
821
|
+
|
|
822
|
+
</div>
|
|
823
|
+
</section>
|
|
824
|
+
<!-- FOOTER SLOT — archetype swaps per theme -->
|
|
825
|
+
<footer class="slot slot--foot reveal" data-slot="footer" style="--i:6" role="contentinfo" aria-label="Colophon">
|
|
826
|
+
</footer>
|
|
827
|
+
|
|
828
|
+
</main>
|
|
829
|
+
|
|
830
|
+
<!-- ─── Easter egg ─── revealed when the user spams T —— -->
|
|
831
|
+
<aside class="easter" data-easter-egg hidden role="dialog" aria-modal="true" aria-label="A note from Hallmark">
|
|
832
|
+
<div class="easter__panel">
|
|
833
|
+
<ol class="easter__lines" aria-live="polite">
|
|
834
|
+
<li class="easter__line easter__line--cmd"><span class="easter__prompt">$</span> hallmark.observe()</li>
|
|
835
|
+
<li class="easter__line easter__line--punchline" data-easter-punchline>
|
|
836
|
+
<span class="easter__arrow">></span> <span data-easter-line>theme connoisseur.</span><span
|
|
837
|
+
class="easter__cursor" aria-hidden="true"></span>
|
|
838
|
+
</li>
|
|
839
|
+
</ol>
|
|
840
|
+
<p class="easter__hint">
|
|
841
|
+
<span>back in a moment</span>
|
|
842
|
+
</p>
|
|
843
|
+
</div>
|
|
844
|
+
</aside>
|
|
845
|
+
|
|
846
|
+
<!-- ─────────── HERO ARCHETYPES ─────────── -->
|
|
847
|
+
|
|
848
|
+
<template id="hero-marquee">
|
|
849
|
+
<div class="hero hero--marquee">
|
|
850
|
+
<div class="hero__main">
|
|
851
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
852
|
+
<h1 class="hero__display" data-text="{{title}}">{{title}}</h1>
|
|
853
|
+
<p class="hero__lede">{{lede}}</p>
|
|
854
|
+
<div class="hero__cta">
|
|
855
|
+
<p class="label">{{ctaLabel}}</p>
|
|
856
|
+
<pre class="code"
|
|
857
|
+
data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
|
|
858
|
+
</div>
|
|
859
|
+
</div>
|
|
860
|
+
<aside class="hero__moment" aria-hidden="true"></aside>
|
|
861
|
+
</div>
|
|
862
|
+
</template>
|
|
863
|
+
|
|
864
|
+
<template id="hero-split">
|
|
865
|
+
<div class="hero hero--split">
|
|
866
|
+
<div class="hero__col">
|
|
867
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
868
|
+
<h1 class="hero__display">{{title}}</h1>
|
|
869
|
+
<p class="hero__lede">{{lede}}</p>
|
|
870
|
+
</div>
|
|
871
|
+
<aside class="hero__proof">
|
|
872
|
+
<p class="label">{{proofLabel}}</p>
|
|
873
|
+
<p class="hero__proof-line">{{proofA}}</p>
|
|
874
|
+
<p class="hero__proof-line">{{proofB}}</p>
|
|
875
|
+
<p class="hero__proof-line">{{proofC}}</p>
|
|
876
|
+
<a href="#install" class="link">{{cta}} →</a>
|
|
877
|
+
</aside>
|
|
878
|
+
</div>
|
|
879
|
+
</template>
|
|
880
|
+
|
|
881
|
+
<template id="hero-stat-led">
|
|
882
|
+
<div class="hero hero--stat">
|
|
883
|
+
<div class="hero__main">
|
|
884
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
885
|
+
<span class="hero__stat tabular-nums">{{stat}}</span>
|
|
886
|
+
<p class="hero__qualifier">{{qualifier}}</p>
|
|
887
|
+
<p class="hero__lede">{{lede}}</p>
|
|
888
|
+
<a href="#install" class="link hero__link">{{cta}} →</a>
|
|
889
|
+
</div>
|
|
890
|
+
<aside class="hero__moment" aria-hidden="true"></aside>
|
|
891
|
+
</div>
|
|
892
|
+
</template>
|
|
893
|
+
|
|
894
|
+
<template id="hero-quote-led">
|
|
895
|
+
<div class="hero hero--quote">
|
|
896
|
+
<div class="hero__main">
|
|
897
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
898
|
+
<blockquote class="hero__quote">
|
|
899
|
+
<p>“{{quote}}”</p>
|
|
900
|
+
<footer class="hero__attrib">— {{attrib}}</footer>
|
|
901
|
+
</blockquote>
|
|
902
|
+
<p class="hero__lede">{{lede}}</p>
|
|
903
|
+
<a href="#install" class="link hero__link">{{cta}} →</a>
|
|
904
|
+
</div>
|
|
905
|
+
<aside class="hero__moment" aria-hidden="true"></aside>
|
|
906
|
+
</div>
|
|
907
|
+
</template>
|
|
908
|
+
|
|
909
|
+
<template id="hero-letter">
|
|
910
|
+
<div class="hero hero--letter">
|
|
911
|
+
<div class="hero__main">
|
|
912
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
913
|
+
<p class="hero__salutation">{{salutation}}</p>
|
|
914
|
+
<p class="hero__letter-body">{{letterBody}}</p>
|
|
915
|
+
<p class="hero__signoff">{{signoff}}<br><span class="hero__sign">— Hallmark</span></p>
|
|
916
|
+
</div>
|
|
917
|
+
<aside class="hero__moment" aria-hidden="true"></aside>
|
|
918
|
+
</div>
|
|
919
|
+
</template>
|
|
920
|
+
|
|
921
|
+
|
|
922
|
+
|
|
923
|
+
|
|
924
|
+
<!-- H9 — Bloom. Two-column hero with a layered watercolor + brushstroke
|
|
925
|
+
composition on the right: soft transparent SVG wash + oversized
|
|
926
|
+
italic wordmark + small geometric accents. Painterly, no chrome. -->
|
|
927
|
+
<template id="hero-bloom">
|
|
928
|
+
<div class="hero hero--bloom">
|
|
929
|
+
<div class="hero__copy">
|
|
930
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
931
|
+
<h1 class="hero__display hero__display--small">{{title}}</h1>
|
|
932
|
+
<p class="hero__lede">{{lede}}</p>
|
|
933
|
+
<div class="hero__cta">
|
|
934
|
+
<pre class="code"
|
|
935
|
+
data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
|
|
936
|
+
</div>
|
|
937
|
+
</div>
|
|
938
|
+
<figure class="hero__bloom-stage" aria-hidden="true">
|
|
939
|
+
<svg class="hero__bloom-wash" viewBox="0 0 400 500" preserveAspectRatio="xMidYMid meet">
|
|
940
|
+
<defs>
|
|
941
|
+
<radialGradient id="bloomGrad" cx="0.42" cy="0.36" r="0.72">
|
|
942
|
+
<stop offset="0%" stop-color="currentColor" stop-opacity="0.85" />
|
|
943
|
+
<stop offset="55%" stop-color="currentColor" stop-opacity="0.45" />
|
|
944
|
+
<stop offset="100%" stop-color="currentColor" stop-opacity="0" />
|
|
945
|
+
</radialGradient>
|
|
946
|
+
</defs>
|
|
947
|
+
<path
|
|
948
|
+
d="M 80 60 Q 60 140 90 220 Q 50 280 80 360 Q 110 410 200 420 Q 320 440 340 360 Q 380 280 340 220 Q 380 130 320 80 Q 240 30 180 60 Q 130 30 80 60 Z"
|
|
949
|
+
fill="url(#bloomGrad)" />
|
|
950
|
+
</svg>
|
|
951
|
+
<span class="hero__bloom-glyph"><em>Hallmark.</em></span>
|
|
952
|
+
<span class="hero__bloom-dot" aria-hidden="true"></span>
|
|
953
|
+
<span class="hero__bloom-line" aria-hidden="true"></span>
|
|
954
|
+
<span class="hero__bloom-circle" aria-hidden="true"></span>
|
|
955
|
+
</figure>
|
|
956
|
+
</div>
|
|
957
|
+
</template>
|
|
958
|
+
|
|
959
|
+
<!-- H10 — Orbit. Two-column hero with concentric rings + a glowing
|
|
960
|
+
center dot. Slow rotation gives the page life without noise.
|
|
961
|
+
Reserved for atmospheric warm-glow themes (Halo). -->
|
|
962
|
+
<template id="hero-orbit">
|
|
963
|
+
<div class="hero hero--orbit">
|
|
964
|
+
<div class="hero__copy">
|
|
965
|
+
<p class="hero__eyebrow"><span class="mark" aria-hidden="true"></span>{{eyebrow}}</p>
|
|
966
|
+
<h1 class="hero__display hero__display--small">{{title}}</h1>
|
|
967
|
+
<p class="hero__lede">{{lede}}</p>
|
|
968
|
+
<div class="hero__cta">
|
|
969
|
+
<pre class="code"
|
|
970
|
+
data-copy-source><span class="prompt">$</span><span data-copy-text>npx skills add nutlope/hallmark</span><button class="code__copy" type="button" data-copy-btn aria-label="Copy install command"><span class="code__copy-default">Copy</span><span class="code__copy-done">Copied</span></button></pre>
|
|
971
|
+
</div>
|
|
972
|
+
</div>
|
|
973
|
+
<figure class="hero__orbit-stage" aria-hidden="true">
|
|
974
|
+
<div class="hero__orbit-rings">
|
|
975
|
+
<svg viewBox="0 0 400 400" preserveAspectRatio="xMidYMid meet">
|
|
976
|
+
<g fill="none" stroke="currentColor" stroke-linecap="round">
|
|
977
|
+
<circle cx="200" cy="200" r="190" stroke-width="0.6" opacity="0.35" />
|
|
978
|
+
<circle cx="200" cy="200" r="155" stroke-width="0.8" opacity="0.5" />
|
|
979
|
+
<circle cx="200" cy="200" r="118" stroke-width="1" opacity="0.7" />
|
|
980
|
+
<circle cx="200" cy="200" r="82" stroke-width="1.4" opacity="0.85" />
|
|
981
|
+
<circle cx="200" cy="200" r="48" stroke-width="1.8" opacity="1" />
|
|
982
|
+
<line x1="200" y1="10" x2="200" y2="22" stroke-width="1.2" stroke="var(--color-accent)" />
|
|
983
|
+
</g>
|
|
984
|
+
</svg>
|
|
985
|
+
</div>
|
|
986
|
+
<span class="hero__orbit-dot pulse" aria-hidden="true"></span>
|
|
987
|
+
<div class="hero__orbit-rule"></div>
|
|
988
|
+
<p class="hero__orbit-spec">{{captionA}} · {{captionB}}</p>
|
|
989
|
+
</figure>
|
|
990
|
+
</div>
|
|
991
|
+
</template>
|
|
992
|
+
|
|
993
|
+
<!-- ─────────── FOOTER ARCHETYPES ─────────── -->
|
|
994
|
+
|
|
995
|
+
<!-- The COLOPHON — a single editorial footer for every theme. The
|
|
996
|
+
publisher's signature page traditionally doesn't change across
|
|
997
|
+
volumes; the structural variety lives in the body, not here.
|
|
998
|
+
Per-theme typography still re-renders this block. -->
|
|
999
|
+
<template id="footer-colophon">
|
|
1000
|
+
<div class="foot foot--colophon">
|
|
1001
|
+
|
|
1002
|
+
<div class="foot__masthead">
|
|
1003
|
+
<span class="foot__wordmark" aria-label="Hallmark"><span class="brand-mark brand-mark--lg" aria-hidden="true"><span class="brand-mark__slash">/</span><span class="brand-mark__name">hallmark</span></span></span>
|
|
1004
|
+
<span class="foot__version tnum">v1.0 · MMXXVI</span>
|
|
1005
|
+
</div>
|
|
1006
|
+
|
|
1007
|
+
<div class="foot__grid">
|
|
1008
|
+
<section class="foot__block">
|
|
1009
|
+
<p class="foot__label">Currently in</p>
|
|
1010
|
+
<p class="foot__value"><strong data-theme-current-foot>Specimen</strong></p>
|
|
1011
|
+
<p class="foot__hint">Press <kbd class="kbd">T</kbd> to cycle · <kbd class="kbd">R</kbd> to randomise.</p>
|
|
1012
|
+
</section>
|
|
1013
|
+
|
|
1014
|
+
<section class="foot__block">
|
|
1015
|
+
<p class="foot__label">In the catalog</p>
|
|
1016
|
+
<ul class="foot__stats">
|
|
1017
|
+
<li><span class="foot__stat-num tnum">22</span><span class="foot__stat-key">themes</span></li>
|
|
1018
|
+
<li><span class="foot__stat-num tnum">21</span><span class="foot__stat-key">macrostructures</span></li>
|
|
1019
|
+
<li><span class="foot__stat-num tnum">65</span><span class="foot__stat-key">slop-test gates</span></li>
|
|
1020
|
+
</ul>
|
|
1021
|
+
</section>
|
|
1022
|
+
|
|
1023
|
+
<section class="foot__block">
|
|
1024
|
+
<p class="foot__label">Read or take a copy</p>
|
|
1025
|
+
<ul class="foot__nav">
|
|
1026
|
+
<li><a class="link" href="https://github.com/nutlope/hallmark">Source on GitHub →</a></li>
|
|
1027
|
+
<li><a class="link" href="#install">Install command</a></li>
|
|
1028
|
+
<li><a class="link" href="#top">Back to top</a></li>
|
|
1029
|
+
</ul>
|
|
1030
|
+
</section>
|
|
1031
|
+
</div>
|
|
1032
|
+
|
|
1033
|
+
<p class="foot__base">
|
|
1034
|
+
Made by <a class="foot__powered-mark" href="https://www.together.ai" target="_blank" rel="noopener">Together AI</a>. MIT licensed.
|
|
1035
|
+
</p>
|
|
1036
|
+
|
|
1037
|
+
</div>
|
|
1038
|
+
</template>
|
|
1039
|
+
|
|
1040
|
+
<script type="module" src="js/main.js"></script>
|
|
1041
|
+
</body>
|
|
1042
|
+
|
|
1043
|
+
</html>
|