howone 0.1.29 → 0.1.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (219) hide show
  1. package/package.json +1 -1
  2. package/templates/vite/.howone/skills/hallmark/SKILL.md +48 -42
  3. package/templates/vite/.howone/skills/hallmark/references/anti-patterns.md +12 -6
  4. package/templates/vite/.howone/skills/hallmark/references/assets.md +7 -0
  5. package/templates/vite/.howone/skills/hallmark/references/component-cookbook.md +19 -10
  6. package/templates/vite/.howone/skills/hallmark/references/components/f2-sticky-scroll-stack.md +1 -1
  7. package/templates/vite/.howone/skills/hallmark/references/components/ft6-letter-close.md +1 -1
  8. package/templates/vite/.howone/skills/hallmark/references/components/h7-demo-video-clipped-by-viewport-edge.md +1 -1
  9. package/templates/vite/.howone/skills/hallmark/references/components/h9-custom-illustration-centerpiece.md +1 -1
  10. package/templates/vite/.howone/skills/hallmark/references/components/n10-floating-on-scroll-morph.md +1 -1
  11. package/templates/vite/.howone/skills/hallmark/references/components/n11-mega-menu.md +40 -0
  12. package/templates/vite/.howone/skills/hallmark/references/components/n12-banner-retract.md +34 -0
  13. package/templates/vite/.howone/skills/hallmark/references/components/n13-inline-cmdk-pill.md +39 -0
  14. package/templates/vite/.howone/skills/hallmark/references/components/n1b-saas-three-section.md +35 -0
  15. package/templates/vite/.howone/skills/hallmark/references/components/n9-edge-aligned-minimal.md +1 -1
  16. package/templates/vite/.howone/skills/hallmark/references/components/s3-sticky-pinned.md +2 -2
  17. package/templates/vite/.howone/skills/hallmark/references/copy.md +8 -8
  18. package/templates/vite/.howone/skills/hallmark/references/custom-craft.md +2 -2
  19. package/templates/vite/.howone/skills/hallmark/references/custom-theme.md +50 -12
  20. package/templates/vite/.howone/skills/hallmark/references/export-formats.md +1 -1
  21. package/templates/vite/.howone/skills/hallmark/references/genres/atmospheric.md +11 -7
  22. package/templates/vite/.howone/skills/hallmark/references/genres/editorial.md +6 -4
  23. package/templates/vite/.howone/skills/hallmark/references/genres/modern-minimal.md +10 -6
  24. package/templates/vite/.howone/skills/hallmark/references/genres/playful.md +15 -10
  25. package/templates/vite/.howone/skills/hallmark/references/hero-enrichment.md +13 -12
  26. package/templates/vite/.howone/skills/hallmark/references/interaction-and-states.md +2 -1
  27. package/templates/vite/.howone/skills/hallmark/references/layout-and-space.md +4 -3
  28. package/templates/vite/.howone/skills/hallmark/references/macrostructures/04-stat-led.md +3 -1
  29. package/templates/vite/.howone/skills/hallmark/references/macrostructures/12-letter.md +1 -1
  30. package/templates/vite/.howone/skills/hallmark/references/macrostructures.md +1 -1
  31. package/templates/vite/.howone/skills/hallmark/references/microinteractions.md +1 -3
  32. package/templates/vite/.howone/skills/hallmark/references/preview-examples.md +12 -12
  33. package/templates/vite/.howone/skills/hallmark/references/responsive.md +8 -8
  34. package/templates/vite/.howone/skills/hallmark/references/slop-test.md +72 -85
  35. package/templates/vite/.howone/skills/hallmark/references/structure.md +9 -13
  36. package/templates/vite/.howone/skills/hallmark/references/study.md +40 -17
  37. package/templates/vite/.howone/skills/hallmark/references/themes/carnival.md +301 -0
  38. package/templates/vite/.howone/skills/hallmark/references/themes/cobalt.md +146 -0
  39. package/templates/vite/.howone/skills/hallmark/references/themes/hum.md +403 -0
  40. package/templates/vite/.howone/skills/hallmark/references/themes/lumen.md +478 -0
  41. package/templates/vite/.howone/skills/hallmark/references/typography.md +3 -3
  42. package/templates/vite/.howone/skills/hallmark/references/verbs/redesign.md +1 -1
  43. package/templates/vite/.howone/skills/hallmark/LICENSE +0 -21
  44. package/templates/vite/.howone/skills/hallmark/README.md +0 -147
  45. package/templates/vite/.howone/skills/hallmark/ROADMAP.md +0 -201
  46. package/templates/vite/.howone/skills/hallmark/docs/recipes.md +0 -186
  47. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-anya.jpg +0 -0
  48. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-bananastudio.jpg +0 -0
  49. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-hyperlane.jpg +0 -0
  50. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-najm.jpg +0 -0
  51. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-slow-pour.jpg +0 -0
  52. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-soroe.jpg +0 -0
  53. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-tally.jpg +0 -0
  54. package/templates/vite/.howone/skills/hallmark/docs/screenshots/hero-wayfare.jpg +0 -0
  55. package/templates/vite/.howone/skills/hallmark/docs/study-examples.md +0 -176
  56. package/templates/vite/.howone/skills/hallmark/docs/talk-slides.md +0 -364
  57. package/templates/vite/.howone/skills/hallmark/package.json +0 -36
  58. package/templates/vite/.howone/skills/hallmark/site/OG-hallmark.png +0 -0
  59. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/brief.md +0 -71
  60. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/index.html +0 -64
  61. package/templates/vite/.howone/skills/hallmark/site/_tests/01-tide-podcast/style.css +0 -240
  62. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/brief.md +0 -65
  63. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/index.html +0 -105
  64. package/templates/vite/.howone/skills/hallmark/site/_tests/02-streampipe-cli/style.css +0 -250
  65. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/brief.md +0 -64
  66. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/index.html +0 -131
  67. package/templates/vite/.howone/skills/hallmark/site/_tests/03-maple-bakery/style.css +0 -240
  68. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/brief.md +0 -67
  69. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/index.html +0 -86
  70. package/templates/vite/.howone/skills/hallmark/site/_tests/04-meridian-manifesto/style.css +0 -262
  71. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/brief.md +0 -63
  72. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/index.html +0 -167
  73. package/templates/vite/.howone/skills/hallmark/site/_tests/05-tracejam-saas/style.css +0 -457
  74. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/brief.md +0 -65
  75. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/index.html +0 -159
  76. package/templates/vite/.howone/skills/hallmark/site/_tests/06-anya-portfolio/style.css +0 -288
  77. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/brief.md +0 -64
  78. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/index.html +0 -146
  79. package/templates/vite/.howone/skills/hallmark/site/_tests/07-foundry-compliance/style.css +0 -484
  80. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/brief.md +0 -64
  81. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/index.html +0 -116
  82. package/templates/vite/.howone/skills/hallmark/site/_tests/08-cohort-courses/style.css +0 -354
  83. package/templates/vite/.howone/skills/hallmark/site/_tests/09-slow-pour/index.html +0 -638
  84. package/templates/vite/.howone/skills/hallmark/site/_tests/10-owl-hours/index.html +0 -515
  85. package/templates/vite/.howone/skills/hallmark/site/_tests/11-soroe-ceramics/index.html +0 -515
  86. package/templates/vite/.howone/skills/hallmark/site/_tests/12-loafer/index.html +0 -608
  87. package/templates/vite/.howone/skills/hallmark/site/_tests/13-alma/index.html +0 -587
  88. package/templates/vite/.howone/skills/hallmark/site/_tests/README.md +0 -157
  89. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-loop.mp4 +0 -0
  90. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/BananaStudio-still.jpg +0 -0
  91. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-example.mp4 +0 -0
  92. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Hyperlane-still.jpg +0 -0
  93. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-loop.mp4 +0 -0
  94. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Najm-still.jpg +0 -0
  95. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Podcast-loop.mp4 +0 -0
  96. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-loop.mp4 +0 -0
  97. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/SaaS-still.jpg +0 -0
  98. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-loop.mp4 +0 -0
  99. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/Soroe-still.jpg +0 -0
  100. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/after-quiet-hour.png +0 -0
  101. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-loop.mp4 +0 -0
  102. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/anya-still.jpg +0 -0
  103. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/audit-example.png +0 -0
  104. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/before-quiet-hour.png +0 -0
  105. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/example-redesign-uractivation.png +0 -0
  106. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-loop.mp4 +0 -0
  107. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/slow-pour-still.jpg +0 -0
  108. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/study-example.png +0 -0
  109. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/uractivation-after-loop.mp4 +0 -0
  110. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-loop.mp4 +0 -0
  111. package/templates/vite/.howone/skills/hallmark/site/_tests/_thumbs/wayfare-still.jpg +0 -0
  112. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/index.html +0 -77
  113. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/01-coffeebox/style.css +0 -238
  114. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/index.html +0 -110
  115. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/02-loop/style.css +0 -326
  116. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/index.html +0 -134
  117. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/03-mossroot/style.css +0 -262
  118. package/templates/vite/.howone/skills/hallmark/site/_tests/custom/README.md +0 -30
  119. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/README.md +0 -17
  120. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/audit-report.md +0 -56
  121. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/input.html +0 -160
  122. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/audit/notes.md +0 -29
  123. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/input.html +0 -63
  124. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/notes.md +0 -72
  125. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/redesign/output.html +0 -374
  126. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/diagnosis.md +0 -52
  127. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/input-description.md +0 -29
  128. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/notes.md +0 -61
  129. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.css +0 -193
  130. package/templates/vite/.howone/skills/hallmark/site/_tests/verbs/study/output.html +0 -66
  131. package/templates/vite/.howone/skills/hallmark/site/css/base.css +0 -194
  132. package/templates/vite/.howone/skills/hallmark/site/css/components.css +0 -4886
  133. package/templates/vite/.howone/skills/hallmark/site/css/sections.css +0 -2072
  134. package/templates/vite/.howone/skills/hallmark/site/css/tokens.css +0 -1129
  135. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/index.html +0 -475
  136. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/styles.css +0 -1584
  137. package/templates/vite/.howone/skills/hallmark/site/examples/bananastudio/tokens.css +0 -96
  138. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/index.html +0 -344
  139. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/script.js +0 -103
  140. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/styles.css +0 -1103
  141. package/templates/vite/.howone/skills/hallmark/site/examples/hyperlane/tokens.css +0 -83
  142. package/templates/vite/.howone/skills/hallmark/site/examples/najm/index.html +0 -368
  143. package/templates/vite/.howone/skills/hallmark/site/examples/najm/script.js +0 -133
  144. package/templates/vite/.howone/skills/hallmark/site/examples/najm/styles.css +0 -1062
  145. package/templates/vite/.howone/skills/hallmark/site/examples/najm/tokens.css +0 -97
  146. package/templates/vite/.howone/skills/hallmark/site/examples/tally/app.js +0 -84
  147. package/templates/vite/.howone/skills/hallmark/site/examples/tally/index.html +0 -446
  148. package/templates/vite/.howone/skills/hallmark/site/examples/tally/styles.css +0 -1087
  149. package/templates/vite/.howone/skills/hallmark/site/examples/tally/tokens.css +0 -101
  150. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/index.html +0 -359
  151. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/style.css +0 -1168
  152. package/templates/vite/.howone/skills/hallmark/site/examples/wayfare/tokens.css +0 -81
  153. package/templates/vite/.howone/skills/hallmark/site/favicon-dark.svg +0 -5
  154. package/templates/vite/.howone/skills/hallmark/site/favicon-light.svg +0 -5
  155. package/templates/vite/.howone/skills/hallmark/site/index.html +0 -1043
  156. package/templates/vite/.howone/skills/hallmark/site/js/main.js +0 -1175
  157. package/templates/vite/.howone/skills/hallmark/vercel.json +0 -6
  158. package/templates/vite/.howone/skills/impeccable/SKILL.md +0 -168
  159. package/templates/vite/.howone/skills/impeccable/agents/impeccable-asset-producer.md +0 -101
  160. package/templates/vite/.howone/skills/impeccable/reference/adapt.md +0 -190
  161. package/templates/vite/.howone/skills/impeccable/reference/animate.md +0 -175
  162. package/templates/vite/.howone/skills/impeccable/reference/audit.md +0 -133
  163. package/templates/vite/.howone/skills/impeccable/reference/bolder.md +0 -113
  164. package/templates/vite/.howone/skills/impeccable/reference/brand.md +0 -118
  165. package/templates/vite/.howone/skills/impeccable/reference/clarify.md +0 -174
  166. package/templates/vite/.howone/skills/impeccable/reference/codex.md +0 -105
  167. package/templates/vite/.howone/skills/impeccable/reference/cognitive-load.md +0 -106
  168. package/templates/vite/.howone/skills/impeccable/reference/color-and-contrast.md +0 -105
  169. package/templates/vite/.howone/skills/impeccable/reference/colorize.md +0 -154
  170. package/templates/vite/.howone/skills/impeccable/reference/craft.md +0 -123
  171. package/templates/vite/.howone/skills/impeccable/reference/critique.md +0 -273
  172. package/templates/vite/.howone/skills/impeccable/reference/delight.md +0 -302
  173. package/templates/vite/.howone/skills/impeccable/reference/distill.md +0 -111
  174. package/templates/vite/.howone/skills/impeccable/reference/document.md +0 -427
  175. package/templates/vite/.howone/skills/impeccable/reference/extract.md +0 -69
  176. package/templates/vite/.howone/skills/impeccable/reference/harden.md +0 -347
  177. package/templates/vite/.howone/skills/impeccable/reference/heuristics-scoring.md +0 -234
  178. package/templates/vite/.howone/skills/impeccable/reference/interaction-design.md +0 -195
  179. package/templates/vite/.howone/skills/impeccable/reference/layout.md +0 -141
  180. package/templates/vite/.howone/skills/impeccable/reference/live.md +0 -622
  181. package/templates/vite/.howone/skills/impeccable/reference/motion-design.md +0 -109
  182. package/templates/vite/.howone/skills/impeccable/reference/onboard.md +0 -234
  183. package/templates/vite/.howone/skills/impeccable/reference/optimize.md +0 -258
  184. package/templates/vite/.howone/skills/impeccable/reference/overdrive.md +0 -130
  185. package/templates/vite/.howone/skills/impeccable/reference/personas.md +0 -179
  186. package/templates/vite/.howone/skills/impeccable/reference/polish.md +0 -242
  187. package/templates/vite/.howone/skills/impeccable/reference/product.md +0 -62
  188. package/templates/vite/.howone/skills/impeccable/reference/quieter.md +0 -99
  189. package/templates/vite/.howone/skills/impeccable/reference/responsive-design.md +0 -114
  190. package/templates/vite/.howone/skills/impeccable/reference/shape.md +0 -165
  191. package/templates/vite/.howone/skills/impeccable/reference/spatial-design.md +0 -100
  192. package/templates/vite/.howone/skills/impeccable/reference/teach.md +0 -156
  193. package/templates/vite/.howone/skills/impeccable/reference/typeset.md +0 -124
  194. package/templates/vite/.howone/skills/impeccable/reference/typography.md +0 -159
  195. package/templates/vite/.howone/skills/impeccable/reference/ux-writing.md +0 -107
  196. package/templates/vite/.howone/skills/impeccable/scripts/cleanup-deprecated.mjs +0 -284
  197. package/templates/vite/.howone/skills/impeccable/scripts/command-metadata.json +0 -94
  198. package/templates/vite/.howone/skills/impeccable/scripts/critique-storage.mjs +0 -242
  199. package/templates/vite/.howone/skills/impeccable/scripts/design-parser.mjs +0 -820
  200. package/templates/vite/.howone/skills/impeccable/scripts/detect-csp.mjs +0 -198
  201. package/templates/vite/.howone/skills/impeccable/scripts/detect.mjs +0 -21
  202. package/templates/vite/.howone/skills/impeccable/scripts/impeccable-paths.mjs +0 -110
  203. package/templates/vite/.howone/skills/impeccable/scripts/is-generated.mjs +0 -69
  204. package/templates/vite/.howone/skills/impeccable/scripts/live-accept.mjs +0 -595
  205. package/templates/vite/.howone/skills/impeccable/scripts/live-browser-session.js +0 -123
  206. package/templates/vite/.howone/skills/impeccable/scripts/live-browser.js +0 -4860
  207. package/templates/vite/.howone/skills/impeccable/scripts/live-complete.mjs +0 -75
  208. package/templates/vite/.howone/skills/impeccable/scripts/live-completion.mjs +0 -18
  209. package/templates/vite/.howone/skills/impeccable/scripts/live-inject.mjs +0 -446
  210. package/templates/vite/.howone/skills/impeccable/scripts/live-poll.mjs +0 -200
  211. package/templates/vite/.howone/skills/impeccable/scripts/live-resume.mjs +0 -48
  212. package/templates/vite/.howone/skills/impeccable/scripts/live-server.mjs +0 -838
  213. package/templates/vite/.howone/skills/impeccable/scripts/live-session-store.mjs +0 -254
  214. package/templates/vite/.howone/skills/impeccable/scripts/live-status.mjs +0 -47
  215. package/templates/vite/.howone/skills/impeccable/scripts/live-wrap.mjs +0 -632
  216. package/templates/vite/.howone/skills/impeccable/scripts/live.mjs +0 -247
  217. package/templates/vite/.howone/skills/impeccable/scripts/load-context.mjs +0 -141
  218. package/templates/vite/.howone/skills/impeccable/scripts/modern-screenshot.umd.js +0 -14
  219. package/templates/vite/.howone/skills/impeccable/scripts/pin.mjs +0 -214
@@ -1,1087 +0,0 @@
1
- @import url("./tokens.css");
2
-
3
- * { box-sizing: border-box; }
4
- html, body { margin: 0; padding: 0; }
5
-
6
- html {
7
- font-family: var(--font-body);
8
- color: var(--color-ink-0);
9
- background: var(--color-paper-0);
10
- -webkit-font-smoothing: antialiased;
11
- text-rendering: optimizeLegibility;
12
- }
13
-
14
- body {
15
- font-size: var(--text-base);
16
- line-height: 1.55;
17
- background:
18
- radial-gradient(1200px 600px at 12% -10%, color-mix(in oklch, var(--color-accent-tint) 70%, transparent), transparent 60%),
19
- radial-gradient(900px 500px at 88% 8%, color-mix(in oklch, var(--color-companion) 35%, transparent), transparent 55%),
20
- var(--color-paper-0);
21
- background-attachment: fixed;
22
- }
23
-
24
- ::selection { background: var(--color-accent); color: var(--color-paper-0); }
25
-
26
- a { color: inherit; text-decoration: none; }
27
-
28
- button, input, select { font: inherit; color: inherit; }
29
-
30
- :focus-visible {
31
- outline: 2px solid var(--color-focus);
32
- outline-offset: 3px;
33
- border-radius: var(--radius-sm);
34
- }
35
-
36
- /* ───────── shared layout ───────── */
37
- .container {
38
- width: 100%;
39
- max-width: 1240px;
40
- margin: 0 auto;
41
- padding-inline: var(--space-xl);
42
- }
43
-
44
- .eyebrow {
45
- font-family: var(--font-mono);
46
- font-size: var(--text-xs);
47
- letter-spacing: 0.08em;
48
- text-transform: uppercase;
49
- color: var(--color-ink-2);
50
- display: inline-flex;
51
- align-items: center;
52
- gap: var(--space-xs);
53
- }
54
-
55
- .italic-accent {
56
- font-family: var(--font-italic);
57
- font-style: italic;
58
- font-weight: 400;
59
- letter-spacing: -0.01em;
60
- }
61
-
62
- /* ───────── nav · N5 Floating pill ───────── */
63
- .nav {
64
- position: fixed;
65
- top: 18px;
66
- left: 50%;
67
- transform: translateX(-50%);
68
- z-index: 50;
69
- display: flex;
70
- align-items: center;
71
- gap: var(--space-md);
72
- padding: 6px 8px 6px 18px;
73
- background: color-mix(in oklch, var(--color-paper-0) 78%, transparent);
74
- -webkit-backdrop-filter: blur(20px);
75
- backdrop-filter: blur(20px);
76
- border: var(--rule-soft);
77
- border-radius: var(--radius-pill);
78
- box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset, 0 8px 30px -12px rgba(20, 30, 80, 0.18);
79
- font-size: var(--text-sm);
80
- }
81
-
82
- .nav__brand {
83
- font-weight: 600;
84
- letter-spacing: -0.01em;
85
- display: flex;
86
- align-items: center;
87
- gap: 8px;
88
- margin-right: var(--space-xs);
89
- }
90
-
91
- .nav__brand svg { display: block; }
92
-
93
- .nav__links {
94
- display: flex;
95
- gap: 4px;
96
- }
97
-
98
- .nav__link {
99
- padding: 8px 14px;
100
- border-radius: var(--radius-pill);
101
- color: var(--color-ink-1);
102
- transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
103
- }
104
-
105
- .nav__link:hover { background: var(--color-paper-2); color: var(--color-ink-0); }
106
- .nav__link.is-hover { background: var(--color-paper-2); color: var(--color-ink-0); }
107
-
108
- .nav__cta {
109
- padding: 8px 14px;
110
- border-radius: var(--radius-pill);
111
- background: var(--color-ink-0);
112
- color: var(--color-paper-0);
113
- font-weight: 500;
114
- border: 1px solid var(--color-ink-0);
115
- cursor: pointer;
116
- transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
117
- }
118
-
119
- .nav__cta:hover { background: var(--color-accent); border-color: var(--color-accent); transform: translateY(-1px); }
120
- .nav__cta:active { transform: translateY(0); }
121
-
122
- @media (max-width: 760px) {
123
- .nav__links { display: none; }
124
- .nav { padding: 6px 8px 6px 14px; }
125
- }
126
-
127
- /* ───────── hero · Marquee Hero ───────── */
128
- .hero {
129
- padding-top: 140px;
130
- padding-bottom: var(--space-3xl);
131
- position: relative;
132
- overflow: clip;
133
- }
134
-
135
- .hero::before {
136
- content: "";
137
- position: absolute;
138
- inset: 0;
139
- background-image:
140
- linear-gradient(to right, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 1px, transparent 1px),
141
- linear-gradient(to bottom, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 1px, transparent 1px);
142
- background-size: 64px 64px;
143
- mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, black 30%, transparent 70%);
144
- -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, black 30%, transparent 70%);
145
- pointer-events: none;
146
- }
147
-
148
- .hero__live {
149
- display: inline-flex;
150
- align-items: center;
151
- gap: 10px;
152
- padding: 6px 14px 6px 12px;
153
- border: var(--rule-soft);
154
- background: var(--color-paper-0);
155
- border-radius: var(--radius-pill);
156
- font-family: var(--font-mono);
157
- font-size: var(--text-xs);
158
- color: var(--color-ink-1);
159
- }
160
-
161
- .hero__live .dot {
162
- width: 8px;
163
- height: 8px;
164
- border-radius: 999px;
165
- background: var(--color-success);
166
- box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 60%, transparent);
167
- animation: pulse 1800ms var(--ease-in-out) infinite;
168
- }
169
-
170
- @keyframes pulse {
171
- 0% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 60%, transparent); }
172
- 70% { box-shadow: 0 0 0 10px color-mix(in oklch, var(--color-success) 0%, transparent); }
173
- 100% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--color-success) 0%, transparent); }
174
- }
175
-
176
- .hero__layout {
177
- display: grid;
178
- grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
179
- gap: var(--space-3xl);
180
- align-items: center;
181
- margin-top: var(--space-xl);
182
- }
183
-
184
- @media (max-width: 980px) {
185
- .hero__layout { grid-template-columns: 1fr; gap: var(--space-2xl); }
186
- }
187
-
188
- .hero__h1 {
189
- font-family: var(--font-display);
190
- font-weight: 600;
191
- font-size: var(--text-5xl);
192
- line-height: 0.96;
193
- letter-spacing: -0.03em;
194
- margin: 0.4em 0 0.2em;
195
- max-width: 13ch;
196
- }
197
-
198
- .hero__h1 .italic-accent {
199
- color: var(--color-accent);
200
- font-weight: 400;
201
- }
202
-
203
- .hero__sub {
204
- font-size: var(--text-md);
205
- color: var(--color-ink-1);
206
- max-width: 46ch;
207
- margin: 0 0 var(--space-xl);
208
- line-height: 1.5;
209
- }
210
-
211
- .hero__ctas {
212
- display: flex;
213
- gap: var(--space-sm);
214
- align-items: center;
215
- flex-wrap: wrap;
216
- }
217
-
218
- .btn {
219
- display: inline-flex;
220
- align-items: center;
221
- gap: 8px;
222
- padding: 14px 22px;
223
- border-radius: var(--radius-pill);
224
- font-weight: 500;
225
- font-size: var(--text-base);
226
- border: 1px solid transparent;
227
- cursor: pointer;
228
- transition: transform var(--dur-fast) var(--ease-out),
229
- background var(--dur-fast) var(--ease-out),
230
- border-color var(--dur-fast) var(--ease-out),
231
- box-shadow var(--dur-fast) var(--ease-out);
232
- position: relative;
233
- isolation: isolate;
234
- }
235
-
236
- .btn--primary {
237
- background: var(--color-ink-0);
238
- color: var(--color-paper-0);
239
- border-color: var(--color-ink-0);
240
- box-shadow: 0 1px 0 rgba(255, 255, 255, 0.16) inset, 0 8px 24px -10px rgba(0, 10, 60, 0.4);
241
- }
242
-
243
- .btn--primary:hover { background: var(--color-accent); border-color: var(--color-accent); transform: translateY(-1px); }
244
- .btn--primary:active { transform: translateY(0); }
245
-
246
- .btn--ghost {
247
- background: transparent;
248
- color: var(--color-ink-0);
249
- border-color: color-mix(in oklch, var(--color-ink-0) 16%, transparent);
250
- }
251
-
252
- .btn--ghost:hover { background: var(--color-paper-2); border-color: color-mix(in oklch, var(--color-ink-0) 22%, transparent); }
253
-
254
- .btn[disabled] { opacity: 0.5; cursor: not-allowed; transform: none; }
255
-
256
- .hero__fineprint {
257
- margin-top: var(--space-md);
258
- font-family: var(--font-mono);
259
- font-size: var(--text-xs);
260
- color: var(--color-ink-2);
261
- display: flex;
262
- gap: var(--space-md);
263
- flex-wrap: wrap;
264
- }
265
-
266
- .hero__fineprint span::before { content: "·"; margin-right: var(--space-md); color: var(--color-ink-3); }
267
- .hero__fineprint span:first-child::before { content: ""; margin: 0; }
268
-
269
- /* live invoice card · Tier-A pure-CSS art */
270
- .invoice {
271
- background: var(--color-paper-0);
272
- border: var(--rule-soft);
273
- border-radius: var(--radius-lg);
274
- padding: var(--space-lg);
275
- box-shadow:
276
- 0 1px 0 rgba(255, 255, 255, 0.7) inset,
277
- 0 24px 60px -28px rgba(20, 30, 80, 0.25),
278
- 0 4px 12px -4px rgba(20, 30, 80, 0.08);
279
- font-family: var(--font-mono);
280
- font-size: var(--text-sm);
281
- position: relative;
282
- transform: rotate(0.5deg);
283
- max-width: 420px;
284
- margin-left: auto;
285
- }
286
-
287
- .invoice::before {
288
- content: "";
289
- position: absolute;
290
- inset: -8px;
291
- border: 1px dashed color-mix(in oklch, var(--color-ink-0) 8%, transparent);
292
- border-radius: calc(var(--radius-lg) + 8px);
293
- pointer-events: none;
294
- }
295
-
296
- .invoice__head {
297
- display: flex;
298
- justify-content: space-between;
299
- align-items: center;
300
- padding-bottom: var(--space-sm);
301
- border-bottom: var(--rule-hair);
302
- }
303
-
304
- .invoice__title { font-weight: 600; color: var(--color-ink-0); }
305
-
306
- .invoice__tag {
307
- font-size: 10px;
308
- letter-spacing: 0.1em;
309
- text-transform: uppercase;
310
- color: var(--color-success);
311
- background: color-mix(in oklch, var(--color-success) 18%, transparent);
312
- padding: 3px 8px;
313
- border-radius: var(--radius-pill);
314
- }
315
-
316
- .invoice__rows {
317
- display: flex;
318
- flex-direction: column;
319
- gap: 8px;
320
- padding: var(--space-sm) 0;
321
- }
322
-
323
- .invoice__row {
324
- display: flex;
325
- justify-content: space-between;
326
- font-size: var(--text-xs);
327
- color: var(--color-ink-1);
328
- }
329
-
330
- .invoice__row strong { color: var(--color-ink-0); font-weight: 500; }
331
-
332
- .invoice__total {
333
- display: flex;
334
- justify-content: space-between;
335
- align-items: baseline;
336
- padding-top: var(--space-sm);
337
- border-top: var(--rule-hair);
338
- font-size: var(--text-sm);
339
- }
340
-
341
- .invoice__total .num {
342
- font-family: var(--font-display);
343
- font-size: var(--text-xl);
344
- font-weight: 600;
345
- color: var(--color-ink-0);
346
- letter-spacing: -0.01em;
347
- }
348
-
349
- .invoice__bar {
350
- height: 6px;
351
- background: var(--color-paper-3);
352
- border-radius: var(--radius-pill);
353
- margin-top: var(--space-md);
354
- overflow: hidden;
355
- }
356
-
357
- .invoice__bar > i {
358
- display: block;
359
- height: 100%;
360
- width: 64%;
361
- background: linear-gradient(90deg, var(--color-accent), var(--color-companion));
362
- border-radius: inherit;
363
- transition: width var(--dur-slow) var(--ease-out);
364
- }
365
-
366
- /* hero marquee strip */
367
- .hero__marquee {
368
- margin-top: var(--space-3xl);
369
- border-top: var(--rule-hair);
370
- border-bottom: var(--rule-hair);
371
- padding: var(--space-md) 0;
372
- overflow: hidden;
373
- position: relative;
374
- -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
375
- mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
376
- }
377
-
378
- .hero__marquee__track {
379
- display: flex;
380
- gap: var(--space-3xl);
381
- animation: marquee 38s linear infinite;
382
- width: max-content;
383
- font-family: var(--font-mono);
384
- font-size: var(--text-sm);
385
- color: var(--color-ink-2);
386
- text-transform: uppercase;
387
- letter-spacing: 0.18em;
388
- }
389
-
390
- .hero__marquee__track span { display: inline-flex; align-items: center; gap: var(--space-md); }
391
- .hero__marquee__track span::after { content: "✦"; color: var(--color-accent); }
392
-
393
- @keyframes marquee {
394
- to { transform: translateX(-50%); }
395
- }
396
-
397
- @media (prefers-reduced-motion: reduce) {
398
- .hero__marquee__track { animation: none; }
399
- }
400
-
401
- /* ───────── logos strip ───────── */
402
- .logos {
403
- padding: var(--space-2xl) 0;
404
- }
405
-
406
- .logos__label {
407
- text-align: center;
408
- font-family: var(--font-mono);
409
- font-size: var(--text-xs);
410
- text-transform: uppercase;
411
- letter-spacing: 0.16em;
412
- color: var(--color-ink-2);
413
- margin-bottom: var(--space-lg);
414
- }
415
-
416
- .logos__row {
417
- display: grid;
418
- grid-template-columns: repeat(6, 1fr);
419
- gap: var(--space-xl);
420
- align-items: center;
421
- opacity: 0.62;
422
- }
423
-
424
- .logos__row > div {
425
- font-family: var(--font-display);
426
- font-weight: 600;
427
- font-size: var(--text-md);
428
- letter-spacing: -0.02em;
429
- text-align: center;
430
- color: var(--color-ink-1);
431
- }
432
-
433
- .logos__row .l-1 { font-family: var(--font-italic); font-style: italic; font-weight: 400; }
434
- .logos__row .l-2 { font-family: var(--font-mono); font-weight: 500; text-transform: lowercase; letter-spacing: -0.02em; }
435
- .logos__row .l-3 { font-weight: 700; letter-spacing: -0.05em; }
436
- .logos__row .l-4 { font-weight: 300; letter-spacing: 0.3em; text-transform: uppercase; font-size: var(--text-sm); }
437
- .logos__row .l-5 { font-weight: 800; }
438
- .logos__row .l-6 { font-weight: 500; font-style: italic; }
439
-
440
- @media (max-width: 760px) {
441
- .logos__row { grid-template-columns: repeat(3, 1fr); row-gap: var(--space-lg); }
442
- }
443
-
444
- /* ───────── workbench / live demo ───────── */
445
- .workbench {
446
- padding: var(--space-4xl) 0 var(--space-3xl);
447
- }
448
-
449
- .section-head {
450
- display: grid;
451
- grid-template-columns: 1fr 1fr;
452
- gap: var(--space-2xl);
453
- align-items: end;
454
- margin-bottom: var(--space-2xl);
455
- }
456
-
457
- @media (max-width: 760px) {
458
- .section-head { grid-template-columns: 1fr; gap: var(--space-md); }
459
- }
460
-
461
- .section-head__title {
462
- font-family: var(--font-display);
463
- font-size: var(--text-3xl);
464
- font-weight: 600;
465
- letter-spacing: -0.025em;
466
- line-height: 1.05;
467
- margin: var(--space-sm) 0 0;
468
- }
469
-
470
- .section-head__title em { font-family: var(--font-italic); font-weight: 400; color: var(--color-accent); font-style: italic; }
471
-
472
- .section-head__desc {
473
- font-size: var(--text-md);
474
- color: var(--color-ink-1);
475
- max-width: 50ch;
476
- }
477
-
478
- .bench {
479
- display: grid;
480
- grid-template-columns: 280px 1fr;
481
- background: var(--color-paper-0);
482
- border: var(--rule-soft);
483
- border-radius: var(--radius-xl);
484
- overflow: hidden;
485
- box-shadow: 0 30px 80px -40px rgba(20, 30, 80, 0.2);
486
- }
487
-
488
- @media (max-width: 880px) {
489
- .bench { grid-template-columns: 1fr; }
490
- }
491
-
492
- .bench__rail {
493
- padding: var(--space-lg);
494
- border-right: var(--rule-hair);
495
- background: var(--color-paper-1);
496
- }
497
-
498
- @media (max-width: 880px) {
499
- .bench__rail { border-right: 0; border-bottom: var(--rule-hair); }
500
- }
501
-
502
- .bench__brand {
503
- display: flex;
504
- align-items: center;
505
- gap: 10px;
506
- font-weight: 600;
507
- margin-bottom: var(--space-lg);
508
- }
509
-
510
- .bench__nav { display: flex; flex-direction: column; gap: 2px; font-size: var(--text-sm); }
511
-
512
- .bench__navitem {
513
- padding: 8px 12px;
514
- border-radius: var(--radius-md);
515
- color: var(--color-ink-1);
516
- display: flex;
517
- align-items: center;
518
- gap: 10px;
519
- cursor: pointer;
520
- transition: background var(--dur-fast) var(--ease-out);
521
- }
522
-
523
- .bench__navitem:hover { background: var(--color-paper-2); }
524
- .bench__navitem[aria-current="page"] { background: var(--color-paper-2); color: var(--color-ink-0); font-weight: 500; }
525
-
526
- .bench__navitem .glyph { width: 14px; height: 14px; flex: none; opacity: 0.8; }
527
-
528
- .bench__main { padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-lg); }
529
-
530
- .bench__statrow { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
531
-
532
- @media (max-width: 580px) { .bench__statrow { grid-template-columns: 1fr; } }
533
-
534
- .bench__stat {
535
- background: var(--color-paper-1);
536
- padding: var(--space-md);
537
- border-radius: var(--radius-md);
538
- border: var(--rule-hair);
539
- }
540
-
541
- .bench__stat .label {
542
- font-family: var(--font-mono);
543
- font-size: 10px;
544
- letter-spacing: 0.12em;
545
- text-transform: uppercase;
546
- color: var(--color-ink-2);
547
- }
548
-
549
- .bench__stat .value {
550
- font-family: var(--font-display);
551
- font-size: var(--text-xl);
552
- font-weight: 600;
553
- letter-spacing: -0.02em;
554
- margin-top: 4px;
555
- display: flex;
556
- align-items: baseline;
557
- gap: 6px;
558
- }
559
-
560
- .bench__stat .delta {
561
- font-family: var(--font-mono);
562
- font-size: var(--text-xs);
563
- color: var(--color-success);
564
- background: color-mix(in oklch, var(--color-success) 14%, transparent);
565
- padding: 2px 6px;
566
- border-radius: var(--radius-pill);
567
- }
568
-
569
- .bench__chart {
570
- background: var(--color-paper-1);
571
- border-radius: var(--radius-md);
572
- border: var(--rule-hair);
573
- padding: var(--space-lg);
574
- position: relative;
575
- min-height: 240px;
576
- }
577
-
578
- .bench__chart h4 {
579
- margin: 0 0 var(--space-sm);
580
- font-size: var(--text-sm);
581
- font-weight: 500;
582
- color: var(--color-ink-1);
583
- display: flex;
584
- justify-content: space-between;
585
- }
586
-
587
- .bench__chart h4 .live {
588
- font-family: var(--font-mono);
589
- font-size: var(--text-xs);
590
- color: var(--color-success);
591
- display: inline-flex;
592
- align-items: center;
593
- gap: 6px;
594
- }
595
-
596
- .bench__chart h4 .live::before {
597
- content: "";
598
- width: 6px;
599
- height: 6px;
600
- border-radius: 999px;
601
- background: var(--color-success);
602
- }
603
-
604
- .bench__chart svg { width: 100%; height: auto; display: block; }
605
-
606
- .bench__chart .grid line { stroke: color-mix(in oklch, var(--color-ink-0) 6%, transparent); stroke-width: 1; }
607
- .bench__chart .area { fill: url(#area-grad); }
608
- .bench__chart .line { fill: none; stroke: var(--color-accent); stroke-width: 2.4; stroke-linejoin: round; stroke-linecap: round; }
609
- .bench__chart .dot {
610
- fill: var(--color-paper-0);
611
- stroke: var(--color-accent);
612
- stroke-width: 2;
613
- filter: drop-shadow(0 4px 10px rgba(60, 30, 220, 0.25));
614
- }
615
-
616
- /* ───────── stats triplet ───────── */
617
- .stats {
618
- padding: var(--space-3xl) 0;
619
- }
620
-
621
- .stats__grid {
622
- display: grid;
623
- grid-template-columns: repeat(3, 1fr);
624
- gap: var(--space-md);
625
- margin-top: var(--space-xl);
626
- }
627
-
628
- @media (max-width: 760px) { .stats__grid { grid-template-columns: 1fr; } }
629
-
630
- .stats__card {
631
- padding: var(--space-2xl) var(--space-xl);
632
- background: var(--color-paper-0);
633
- border: var(--rule-soft);
634
- border-radius: var(--radius-lg);
635
- position: relative;
636
- overflow: hidden;
637
- }
638
-
639
- .stats__card:nth-child(1) { background: linear-gradient(160deg, var(--color-accent-tint), var(--color-paper-0) 60%); }
640
- .stats__card:nth-child(2) { background: linear-gradient(160deg, color-mix(in oklch, var(--color-companion) 35%, var(--color-paper-0)), var(--color-paper-0) 60%); }
641
- .stats__card:nth-child(3) { background: linear-gradient(160deg, color-mix(in oklch, var(--color-warning) 25%, var(--color-paper-0)), var(--color-paper-0) 60%); }
642
-
643
- .stats__num {
644
- font-family: var(--font-display);
645
- font-size: clamp(2.8rem, 6vw, 4.5rem);
646
- font-weight: 600;
647
- letter-spacing: -0.04em;
648
- line-height: 1;
649
- display: inline-flex;
650
- align-items: baseline;
651
- }
652
-
653
- .stats__num small {
654
- font-size: 0.5em;
655
- font-weight: 500;
656
- color: var(--color-ink-1);
657
- margin-left: 4px;
658
- }
659
-
660
- .stats__label {
661
- font-family: var(--font-mono);
662
- text-transform: uppercase;
663
- letter-spacing: 0.12em;
664
- font-size: var(--text-xs);
665
- color: var(--color-ink-1);
666
- margin-top: var(--space-md);
667
- }
668
-
669
- .stats__note {
670
- margin-top: var(--space-sm);
671
- font-size: var(--text-sm);
672
- color: var(--color-ink-1);
673
- max-width: 28ch;
674
- }
675
-
676
- /* ───────── three feature cards ───────── */
677
- .features {
678
- padding: var(--space-4xl) 0 var(--space-3xl);
679
- }
680
-
681
- .features__grid {
682
- display: grid;
683
- grid-template-columns: repeat(3, 1fr);
684
- gap: var(--space-md);
685
- margin-top: var(--space-xl);
686
- }
687
-
688
- @media (max-width: 880px) { .features__grid { grid-template-columns: 1fr; } }
689
-
690
- .feature {
691
- background: var(--color-paper-0);
692
- border: var(--rule-soft);
693
- border-radius: var(--radius-lg);
694
- padding: var(--space-xl);
695
- display: flex;
696
- flex-direction: column;
697
- gap: var(--space-md);
698
- transition: transform var(--dur-mid) var(--ease-out), box-shadow var(--dur-mid) var(--ease-out);
699
- transform-style: preserve-3d;
700
- will-change: transform;
701
- }
702
-
703
- .feature:hover {
704
- box-shadow: 0 20px 60px -30px rgba(40, 30, 120, 0.28);
705
- }
706
-
707
- .feature__art {
708
- height: 180px;
709
- border-radius: var(--radius-md);
710
- background: var(--color-paper-1);
711
- border: var(--rule-hair);
712
- position: relative;
713
- overflow: hidden;
714
- }
715
-
716
- /* Feature 1 — meter / counter */
717
- .art-meter { background: linear-gradient(180deg, var(--color-paper-0), var(--color-paper-1)); }
718
- .art-meter::before {
719
- content: "";
720
- position: absolute;
721
- inset: 22px;
722
- border: var(--rule-soft);
723
- border-radius: var(--radius-md);
724
- background:
725
- repeating-linear-gradient(90deg, transparent 0 22px, color-mix(in oklch, var(--color-ink-0) 6%, transparent) 22px 23px);
726
- }
727
- .art-meter::after {
728
- content: "1,247 / sec";
729
- position: absolute;
730
- left: 50%;
731
- top: 50%;
732
- transform: translate(-50%, -50%);
733
- font-family: var(--font-mono);
734
- font-size: var(--text-md);
735
- font-weight: 600;
736
- letter-spacing: -0.02em;
737
- color: var(--color-accent);
738
- background: var(--color-paper-0);
739
- padding: 6px 12px;
740
- border-radius: var(--radius-pill);
741
- border: var(--rule-soft);
742
- }
743
-
744
- /* Feature 2 — pricing tiers visualisation */
745
- .art-tiers { padding: 22px; display: flex; align-items: end; gap: 10px; height: 180px; }
746
- .art-tiers > i {
747
- flex: 1;
748
- background: linear-gradient(180deg, var(--color-companion), color-mix(in oklch, var(--color-companion) 50%, var(--color-paper-1)));
749
- border-radius: var(--radius-sm);
750
- border: var(--rule-hair);
751
- }
752
- .art-tiers > i:nth-child(1) { height: 35%; }
753
- .art-tiers > i:nth-child(2) { height: 50%; }
754
- .art-tiers > i:nth-child(3) { height: 70%; background: linear-gradient(180deg, var(--color-accent), var(--color-accent-soft)); }
755
- .art-tiers > i:nth-child(4) { height: 90%; }
756
- .art-tiers > i:nth-child(5) { height: 60%; }
757
-
758
- /* Feature 3 — invoice stack */
759
- .art-invoice {
760
- padding: 22px;
761
- }
762
- .art-invoice .sheet {
763
- position: absolute;
764
- width: 70%;
765
- height: 60%;
766
- background: var(--color-paper-0);
767
- border: var(--rule-soft);
768
- border-radius: var(--radius-md);
769
- padding: 14px;
770
- font-family: var(--font-mono);
771
- font-size: 10px;
772
- color: var(--color-ink-2);
773
- box-shadow: 0 6px 16px -8px rgba(20, 30, 80, 0.2);
774
- }
775
- .art-invoice .sheet:nth-child(1) { top: 20%; left: 14%; transform: rotate(-4deg); z-index: 1; }
776
- .art-invoice .sheet:nth-child(2) { top: 16%; left: 22%; transform: rotate(2deg); z-index: 2; }
777
- .art-invoice .sheet:nth-child(3) { top: 12%; left: 30%; transform: rotate(-1deg); z-index: 3; background: var(--color-accent-tint); }
778
- .art-invoice .sheet b { display: block; color: var(--color-ink-0); font-size: 12px; margin-bottom: 6px; font-family: var(--font-display); font-weight: 600; }
779
- .art-invoice .sheet em { font-style: normal; color: var(--color-accent); font-weight: 600; font-size: 14px; }
780
-
781
- .feature__title {
782
- font-family: var(--font-display);
783
- font-size: var(--text-lg);
784
- font-weight: 600;
785
- letter-spacing: -0.02em;
786
- margin: 0;
787
- }
788
-
789
- .feature__desc {
790
- font-size: var(--text-sm);
791
- color: var(--color-ink-1);
792
- margin: 0;
793
- line-height: 1.55;
794
- }
795
-
796
- .feature__link {
797
- margin-top: auto;
798
- font-family: var(--font-mono);
799
- font-size: var(--text-xs);
800
- text-transform: uppercase;
801
- letter-spacing: 0.12em;
802
- color: var(--color-accent);
803
- display: inline-flex;
804
- align-items: center;
805
- gap: 6px;
806
- }
807
-
808
- .feature__link::after {
809
- content: "→";
810
- transition: transform var(--dur-fast) var(--ease-out);
811
- }
812
-
813
- .feature:hover .feature__link::after { transform: translateX(3px); }
814
-
815
- /* ───────── pricing ───────── */
816
- .pricing {
817
- padding: var(--space-4xl) 0 var(--space-3xl);
818
- }
819
-
820
- .pricing__head { text-align: center; margin-bottom: var(--space-xl); }
821
-
822
- .pricing__toggle {
823
- margin: var(--space-md) auto 0;
824
- display: inline-flex;
825
- padding: 4px;
826
- background: var(--color-paper-2);
827
- border: var(--rule-soft);
828
- border-radius: var(--radius-pill);
829
- }
830
-
831
- .pricing__toggle button {
832
- border: 0;
833
- background: transparent;
834
- padding: 8px 16px;
835
- border-radius: var(--radius-pill);
836
- font-size: var(--text-sm);
837
- cursor: pointer;
838
- color: var(--color-ink-1);
839
- transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
840
- }
841
-
842
- .pricing__toggle button[aria-pressed="true"] { background: var(--color-paper-0); color: var(--color-ink-0); font-weight: 500; box-shadow: 0 2px 6px -2px rgba(20, 30, 80, 0.14); }
843
-
844
- .pricing__toggle .save {
845
- font-family: var(--font-mono);
846
- font-size: 10px;
847
- text-transform: uppercase;
848
- letter-spacing: 0.1em;
849
- color: var(--color-success);
850
- margin-left: 6px;
851
- }
852
-
853
- .pricing__grid {
854
- display: grid;
855
- grid-template-columns: repeat(3, 1fr);
856
- gap: var(--space-md);
857
- margin-top: var(--space-xl);
858
- }
859
-
860
- @media (max-width: 980px) { .pricing__grid { grid-template-columns: 1fr; } }
861
-
862
- .tier {
863
- background: var(--color-paper-0);
864
- border: var(--rule-soft);
865
- border-radius: var(--radius-lg);
866
- padding: var(--space-xl);
867
- display: flex;
868
- flex-direction: column;
869
- gap: var(--space-md);
870
- position: relative;
871
- }
872
-
873
- .tier--featured {
874
- background: var(--color-ink-0);
875
- color: var(--color-paper-0);
876
- border-color: var(--color-ink-0);
877
- transform: scale(1.02);
878
- box-shadow: 0 24px 60px -30px rgba(0, 0, 60, 0.5);
879
- }
880
-
881
- .tier--featured .tier__price { color: var(--color-paper-0); }
882
- .tier--featured .tier__features li { color: color-mix(in oklch, var(--color-paper-0) 75%, transparent); }
883
- .tier--featured .tier__features li::before { color: var(--color-companion); }
884
- .tier--featured .btn--primary { background: var(--color-companion); color: var(--color-ink-0); border-color: var(--color-companion); }
885
- .tier--featured .btn--primary:hover { background: var(--color-paper-0); border-color: var(--color-paper-0); }
886
-
887
- .tier__badge {
888
- position: absolute;
889
- top: -12px;
890
- left: var(--space-xl);
891
- font-family: var(--font-mono);
892
- font-size: 10px;
893
- letter-spacing: 0.12em;
894
- text-transform: uppercase;
895
- background: var(--color-companion);
896
- color: var(--color-ink-0);
897
- padding: 4px 10px;
898
- border-radius: var(--radius-pill);
899
- }
900
-
901
- .tier__name {
902
- font-family: var(--font-mono);
903
- font-size: var(--text-xs);
904
- text-transform: uppercase;
905
- letter-spacing: 0.12em;
906
- }
907
-
908
- .tier__price {
909
- font-family: var(--font-display);
910
- font-size: var(--text-3xl);
911
- font-weight: 600;
912
- letter-spacing: -0.03em;
913
- display: flex;
914
- align-items: baseline;
915
- gap: 4px;
916
- }
917
-
918
- .tier__price small {
919
- font-size: 0.4em;
920
- font-weight: 400;
921
- color: var(--color-ink-2);
922
- }
923
-
924
- .tier--featured .tier__price small { color: color-mix(in oklch, var(--color-paper-0) 70%, transparent); }
925
-
926
- .tier__desc { font-size: var(--text-sm); color: var(--color-ink-1); margin-top: -4px; }
927
- .tier--featured .tier__desc { color: color-mix(in oklch, var(--color-paper-0) 75%, transparent); }
928
-
929
- .tier__features { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; font-size: var(--text-sm); }
930
-
931
- .tier__features li { padding-left: 22px; position: relative; color: var(--color-ink-1); }
932
- .tier__features li::before {
933
- content: "✓";
934
- position: absolute;
935
- left: 0;
936
- top: 0;
937
- color: var(--color-accent);
938
- font-weight: 700;
939
- }
940
-
941
- /* ───────── testimonial ───────── */
942
- .testimonial { padding: var(--space-3xl) 0; }
943
-
944
- .testimonial__quote {
945
- font-family: var(--font-italic);
946
- font-style: italic;
947
- font-weight: 400;
948
- font-size: clamp(1.6rem, 3.4vw, 2.6rem);
949
- line-height: 1.25;
950
- letter-spacing: -0.015em;
951
- max-width: 22ch;
952
- margin: 0 auto;
953
- text-align: center;
954
- }
955
-
956
- .testimonial__quote::before { content: "\201C"; color: var(--color-accent); margin-right: 4px; }
957
- .testimonial__quote::after { content: "\201D"; color: var(--color-accent); }
958
-
959
- .testimonial__byline {
960
- margin-top: var(--space-xl);
961
- display: flex;
962
- flex-direction: column;
963
- align-items: center;
964
- gap: 2px;
965
- font-size: var(--text-sm);
966
- color: var(--color-ink-1);
967
- }
968
-
969
- .testimonial__byline strong { color: var(--color-ink-0); font-weight: 500; }
970
- .testimonial__byline span { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-ink-2); text-transform: uppercase; letter-spacing: 0.1em; }
971
-
972
- /* ───────── CTA ───────── */
973
- .cta {
974
- padding: var(--space-3xl) 0 var(--space-4xl);
975
- }
976
-
977
- .cta__panel {
978
- position: relative;
979
- background: var(--color-ink-0);
980
- color: var(--color-paper-0);
981
- border-radius: var(--radius-xl);
982
- padding: var(--space-4xl) var(--space-2xl);
983
- text-align: center;
984
- overflow: hidden;
985
- isolation: isolate;
986
- }
987
-
988
- .cta__panel::before {
989
- content: "";
990
- position: absolute;
991
- inset: 0;
992
- background:
993
- radial-gradient(600px 200px at 20% 110%, color-mix(in oklch, var(--color-accent) 60%, transparent), transparent 70%),
994
- radial-gradient(500px 220px at 90% -10%, color-mix(in oklch, var(--color-companion) 50%, transparent), transparent 70%);
995
- z-index: -1;
996
- }
997
-
998
- .cta__panel::after {
999
- content: "";
1000
- position: absolute;
1001
- inset: 0;
1002
- background-image:
1003
- linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
1004
- linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
1005
- background-size: 48px 48px;
1006
- z-index: -1;
1007
- }
1008
-
1009
- .cta__title {
1010
- font-family: var(--font-display);
1011
- font-size: clamp(2.4rem, 6vw, 5rem);
1012
- font-weight: 600;
1013
- letter-spacing: -0.035em;
1014
- line-height: 1;
1015
- margin: 0 0 var(--space-md);
1016
- max-width: 16ch;
1017
- margin-inline: auto;
1018
- }
1019
-
1020
- .cta__title em { font-family: var(--font-italic); font-weight: 400; font-style: italic; color: var(--color-companion); }
1021
-
1022
- .cta__sub {
1023
- color: color-mix(in oklch, var(--color-paper-0) 75%, transparent);
1024
- max-width: 50ch;
1025
- margin: 0 auto var(--space-xl);
1026
- font-size: var(--text-md);
1027
- }
1028
-
1029
- .cta__panel .btn--primary { background: var(--color-paper-0); color: var(--color-ink-0); border-color: var(--color-paper-0); }
1030
- .cta__panel .btn--primary:hover { background: var(--color-companion); border-color: var(--color-companion); }
1031
- .cta__panel .btn--ghost { color: var(--color-paper-0); border-color: rgba(255, 255, 255, 0.18); }
1032
- .cta__panel .btn--ghost:hover { background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.3); }
1033
-
1034
- /* ───────── footer · Ft5 Statement ───────── */
1035
- .footer { padding: var(--space-3xl) 0 var(--space-2xl); border-top: var(--rule-hair); }
1036
-
1037
- .footer__statement {
1038
- font-family: var(--font-display);
1039
- font-size: clamp(1.8rem, 4.5vw, 3.2rem);
1040
- font-weight: 600;
1041
- letter-spacing: -0.03em;
1042
- line-height: 1.05;
1043
- max-width: 22ch;
1044
- margin: 0 0 var(--space-2xl);
1045
- }
1046
-
1047
- .footer__statement em { font-family: var(--font-italic); font-weight: 400; font-style: italic; color: var(--color-accent); }
1048
-
1049
- .footer__row {
1050
- display: grid;
1051
- grid-template-columns: 1.2fr 1fr 1fr 1fr;
1052
- gap: var(--space-xl);
1053
- border-top: var(--rule-hair);
1054
- padding-top: var(--space-xl);
1055
- }
1056
-
1057
- @media (max-width: 760px) { .footer__row { grid-template-columns: 1fr 1fr; } }
1058
-
1059
- .footer__col h5 {
1060
- font-family: var(--font-mono);
1061
- font-size: var(--text-xs);
1062
- font-weight: 500;
1063
- text-transform: uppercase;
1064
- letter-spacing: 0.12em;
1065
- color: var(--color-ink-2);
1066
- margin: 0 0 var(--space-sm);
1067
- }
1068
-
1069
- .footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: var(--text-sm); }
1070
- .footer__col a { color: var(--color-ink-1); transition: color var(--dur-fast) var(--ease-out); }
1071
- .footer__col a:hover { color: var(--color-ink-0); }
1072
-
1073
- .footer__legal {
1074
- margin-top: var(--space-2xl);
1075
- display: flex;
1076
- justify-content: space-between;
1077
- align-items: center;
1078
- font-family: var(--font-mono);
1079
- font-size: var(--text-xs);
1080
- color: var(--color-ink-2);
1081
- border-top: var(--rule-hair);
1082
- padding-top: var(--space-md);
1083
- }
1084
-
1085
- .footer__legal .wordmark { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; font-size: var(--text-base); color: var(--color-ink-0); }
1086
-
1087
- @media (max-width: 760px) { .footer__legal { flex-direction: column; gap: var(--space-sm); align-items: flex-start; } }