bsmnt 0.0.2 → 0.1.0

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 (430) hide show
  1. package/.github/workflows/release.yml +2 -0
  2. package/CHANGELOG.md +21 -0
  3. package/CLAUDE.md +42 -23
  4. package/README.md +33 -11
  5. package/biome.json +1 -0
  6. package/bun.lock +1 -1
  7. package/docs/architecture.drawio +266 -0
  8. package/docs/architecture.mermaid +91 -0
  9. package/package.json +1 -1
  10. package/{bin → packages/cli/bin}/index.js +28 -27
  11. package/packages/cli/package.json +16 -0
  12. package/{src → packages/cli/src}/commands/add-integration.js +23 -25
  13. package/{src → packages/cli/src}/commands/create.js +104 -133
  14. package/packages/create-basement-app/integrations/basehub/config.js +21 -0
  15. package/packages/create-basement-app/integrations/sanity/config.js +46 -0
  16. package/{src → packages/create-basement-app/integrations/sanity}/mergers/check-integration-merger.js +1 -1
  17. package/{src → packages/create-basement-app/integrations/sanity}/mergers/layout-merger.js +1 -1
  18. package/{src → packages/create-basement-app/integrations/sanity}/mergers/sitemap-merger.js +1 -1
  19. package/packages/create-basement-app/package.json +10 -0
  20. package/packages/create-basement-app/src/configs/animations.js +28 -0
  21. package/packages/create-basement-app/src/index.js +15 -0
  22. package/packages/create-basement-app/src/mergers/check-integration-merger.js +105 -0
  23. package/{src → packages/create-basement-app/src}/mergers/config.js +1 -7
  24. package/{src → packages/create-basement-app/src}/mergers/index.js +87 -93
  25. package/packages/create-basement-app/src/mergers/layout-merger.js +223 -0
  26. package/packages/create-basement-app/src/mergers/sitemap-merger.js +121 -0
  27. package/packages/create-basement-app/template-hooks/config.js +38 -0
  28. package/packages/create-basement-app/templates/default/.biome/plugins/README.md +21 -0
  29. package/packages/create-basement-app/templates/default/.biome/plugins/no-anchor-element.grit +12 -0
  30. package/packages/create-basement-app/templates/default/.biome/plugins/no-relative-parent-imports.grit +10 -0
  31. package/packages/create-basement-app/templates/default/.biome/plugins/no-unnecessary-forwardref.grit +9 -0
  32. package/packages/create-basement-app/templates/default/.cursor/rules/README.md +184 -0
  33. package/packages/create-basement-app/templates/default/.cursor/rules/architecture.mdc +437 -0
  34. package/packages/create-basement-app/templates/default/.cursor/rules/components.mdc +436 -0
  35. package/packages/create-basement-app/templates/default/.cursor/rules/integrations.mdc +447 -0
  36. package/packages/create-basement-app/templates/default/.cursor/rules/main.mdc +278 -0
  37. package/packages/create-basement-app/templates/default/.cursor/rules/styling.mdc +433 -0
  38. package/packages/create-basement-app/templates/default/.editorconfig +40 -0
  39. package/packages/create-basement-app/templates/default/.env.example +81 -0
  40. package/packages/create-basement-app/templates/default/.gitattributes +19 -0
  41. package/packages/create-basement-app/templates/default/.github/PULL_REQUEST_TEMPLATE.md +14 -0
  42. package/packages/create-basement-app/templates/default/.github/workflows/lighthouse-to-slack.yml +136 -0
  43. package/packages/create-basement-app/templates/default/.vscode/extensions.json +20 -0
  44. package/packages/create-basement-app/templates/default/.vscode/settings.json +105 -0
  45. package/packages/create-basement-app/templates/default/README.md +221 -0
  46. package/packages/create-basement-app/templates/default/_gitignore +67 -0
  47. package/packages/create-basement-app/templates/default/app/favicon.ico +0 -0
  48. package/packages/create-basement-app/templates/default/app/layout.tsx +104 -0
  49. package/packages/create-basement-app/templates/default/app/page.tsx +275 -0
  50. package/packages/create-basement-app/templates/default/app/robots.ts +15 -0
  51. package/packages/create-basement-app/templates/default/app/sitemap.ts +16 -0
  52. package/packages/create-basement-app/templates/default/biome.json +250 -0
  53. package/packages/create-basement-app/templates/default/components/basement.svg +1 -0
  54. package/packages/create-basement-app/templates/default/components/layout/footer/index.tsx +27 -0
  55. package/packages/create-basement-app/templates/default/components/layout/header/index.tsx +11 -0
  56. package/packages/create-basement-app/templates/default/components/layout/theme/index.tsx +66 -0
  57. package/packages/create-basement-app/templates/default/components/layout/wrapper/index.tsx +65 -0
  58. package/packages/create-basement-app/templates/default/components/ui/README.md +77 -0
  59. package/packages/create-basement-app/templates/default/components/ui/image/README.md +37 -0
  60. package/packages/create-basement-app/templates/default/components/ui/image/index.tsx +224 -0
  61. package/packages/create-basement-app/templates/default/components/ui/link/index.tsx +146 -0
  62. package/packages/create-basement-app/templates/default/lib/README.md +33 -0
  63. package/packages/create-basement-app/templates/default/lib/hooks/index.ts +12 -0
  64. package/packages/create-basement-app/templates/default/lib/hooks/use-device-detection.ts +81 -0
  65. package/packages/create-basement-app/templates/default/lib/hooks/use-media-breakpoint.ts +15 -0
  66. package/packages/create-basement-app/templates/default/lib/hooks/use-prefetch.ts +74 -0
  67. package/packages/create-basement-app/templates/default/lib/scripts/dev.ts +52 -0
  68. package/packages/create-basement-app/templates/default/lib/scripts/generate-component.ts +322 -0
  69. package/packages/create-basement-app/templates/default/lib/scripts/generate-page.ts +193 -0
  70. package/packages/create-basement-app/templates/default/lib/scripts/generate.ts +79 -0
  71. package/packages/create-basement-app/templates/default/lib/scripts/utils.ts +246 -0
  72. package/packages/create-basement-app/templates/default/lib/store/app.ts +11 -0
  73. package/packages/create-basement-app/templates/default/lib/store/index.ts +11 -0
  74. package/packages/create-basement-app/templates/default/lib/styles/README.md +64 -0
  75. package/packages/create-basement-app/templates/default/lib/styles/cn.ts +7 -0
  76. package/packages/create-basement-app/templates/default/lib/styles/colors.ts +63 -0
  77. package/packages/create-basement-app/templates/default/lib/styles/config.ts +34 -0
  78. package/packages/create-basement-app/templates/default/lib/styles/css/global.css +85 -0
  79. package/packages/create-basement-app/templates/default/lib/styles/css/index.css +6 -0
  80. package/packages/create-basement-app/templates/default/lib/styles/css/reset.css +166 -0
  81. package/packages/create-basement-app/templates/default/lib/styles/css/root.css +68 -0
  82. package/packages/create-basement-app/templates/default/lib/styles/css/tailwind.css +132 -0
  83. package/packages/create-basement-app/templates/default/lib/styles/easings.ts +21 -0
  84. package/packages/create-basement-app/templates/default/lib/styles/fonts.ts +28 -0
  85. package/packages/create-basement-app/templates/default/lib/styles/index.ts +12 -0
  86. package/packages/create-basement-app/templates/default/lib/styles/layout.mjs +27 -0
  87. package/packages/create-basement-app/templates/default/lib/styles/scripts/README.md +29 -0
  88. package/packages/create-basement-app/templates/default/lib/styles/scripts/generate-root.ts +57 -0
  89. package/packages/create-basement-app/templates/default/lib/styles/scripts/generate-tailwind.ts +162 -0
  90. package/packages/create-basement-app/templates/default/lib/styles/scripts/postcss-functions.mjs +168 -0
  91. package/packages/create-basement-app/templates/default/lib/styles/scripts/setup-styles.ts +24 -0
  92. package/packages/create-basement-app/templates/default/lib/styles/scripts/utils.ts +20 -0
  93. package/packages/create-basement-app/templates/default/lib/styles/typography.ts +36 -0
  94. package/packages/create-basement-app/templates/default/lib/utils/README.md +40 -0
  95. package/packages/create-basement-app/templates/default/lib/utils/css.d.ts +21 -0
  96. package/packages/create-basement-app/templates/default/lib/utils/easings.ts +240 -0
  97. package/packages/create-basement-app/templates/default/lib/utils/fetch.ts +84 -0
  98. package/packages/create-basement-app/templates/default/lib/utils/math.test.ts +221 -0
  99. package/packages/create-basement-app/templates/default/lib/utils/math.ts +236 -0
  100. package/packages/create-basement-app/templates/default/lib/utils/metadata.ts +126 -0
  101. package/packages/create-basement-app/templates/default/lib/utils/strings.test.ts +166 -0
  102. package/packages/create-basement-app/templates/default/lib/utils/strings.ts +246 -0
  103. package/packages/create-basement-app/templates/default/lib/utils/types.d.ts +15 -0
  104. package/packages/create-basement-app/templates/default/lib/utils/viewport.test.ts +256 -0
  105. package/packages/create-basement-app/templates/default/lib/utils/viewport.ts +193 -0
  106. package/packages/create-basement-app/templates/default/next.config.ts +142 -0
  107. package/packages/create-basement-app/templates/default/package.json +62 -0
  108. package/packages/create-basement-app/templates/default/postcss.config.mjs +42 -0
  109. package/packages/create-basement-app/templates/default/public/fonts/geist/Geist-Mono.woff2 +0 -0
  110. package/packages/create-basement-app/templates/default/tsconfig.json +43 -0
  111. package/packages/create-basement-app/templates/experiment/.biome/plugins/README.md +21 -0
  112. package/packages/create-basement-app/templates/experiment/.biome/plugins/no-anchor-element.grit +12 -0
  113. package/packages/create-basement-app/templates/experiment/.biome/plugins/no-relative-parent-imports.grit +10 -0
  114. package/packages/create-basement-app/templates/experiment/.biome/plugins/no-unnecessary-forwardref.grit +9 -0
  115. package/packages/create-basement-app/templates/experiment/.cursor/rules/README.md +184 -0
  116. package/packages/create-basement-app/templates/experiment/.cursor/rules/architecture.mdc +437 -0
  117. package/packages/create-basement-app/templates/experiment/.cursor/rules/components.mdc +436 -0
  118. package/packages/create-basement-app/templates/experiment/.cursor/rules/integrations.mdc +447 -0
  119. package/packages/create-basement-app/templates/experiment/.cursor/rules/main.mdc +278 -0
  120. package/packages/create-basement-app/templates/experiment/.cursor/rules/styling.mdc +433 -0
  121. package/packages/create-basement-app/templates/experiment/.editorconfig +40 -0
  122. package/packages/create-basement-app/templates/experiment/.env.example +81 -0
  123. package/packages/create-basement-app/templates/experiment/.gitattributes +19 -0
  124. package/packages/create-basement-app/templates/experiment/.github/PULL_REQUEST_TEMPLATE.md +14 -0
  125. package/packages/create-basement-app/templates/experiment/.github/workflows/lighthouse-to-slack.yml +136 -0
  126. package/packages/create-basement-app/templates/experiment/.vscode/extensions.json +20 -0
  127. package/packages/create-basement-app/templates/experiment/.vscode/settings.json +105 -0
  128. package/packages/create-basement-app/templates/experiment/README.md +221 -0
  129. package/packages/create-basement-app/templates/experiment/_gitignore +67 -0
  130. package/packages/create-basement-app/templates/experiment/app/favicon.ico +0 -0
  131. package/packages/create-basement-app/templates/experiment/app/layout.tsx +104 -0
  132. package/packages/create-basement-app/templates/experiment/app/page.tsx +275 -0
  133. package/packages/create-basement-app/templates/experiment/app/robots.ts +15 -0
  134. package/packages/create-basement-app/templates/experiment/app/sitemap.ts +16 -0
  135. package/packages/create-basement-app/templates/experiment/biome.json +250 -0
  136. package/packages/create-basement-app/templates/experiment/components/basement.svg +1 -0
  137. package/packages/create-basement-app/templates/experiment/components/layout/footer/index.tsx +27 -0
  138. package/packages/create-basement-app/templates/experiment/components/layout/header/index.tsx +58 -0
  139. package/packages/create-basement-app/templates/experiment/components/layout/navigation-menu.tsx +127 -0
  140. package/packages/create-basement-app/templates/experiment/components/layout/theme/index.tsx +66 -0
  141. package/packages/create-basement-app/templates/experiment/components/layout/wrapper/index.tsx +65 -0
  142. package/packages/create-basement-app/templates/experiment/components/ui/README.md +77 -0
  143. package/packages/create-basement-app/templates/experiment/components/ui/image/README.md +37 -0
  144. package/packages/create-basement-app/templates/experiment/components/ui/image/index.tsx +224 -0
  145. package/packages/create-basement-app/templates/experiment/components/ui/link/index.tsx +146 -0
  146. package/packages/create-basement-app/templates/experiment/lib/README.md +33 -0
  147. package/packages/create-basement-app/templates/experiment/lib/constants.ts +12 -0
  148. package/packages/create-basement-app/templates/experiment/lib/hooks/index.ts +12 -0
  149. package/packages/create-basement-app/templates/experiment/lib/hooks/use-device-detection.ts +81 -0
  150. package/packages/create-basement-app/templates/experiment/lib/hooks/use-media-breakpoint.ts +15 -0
  151. package/packages/create-basement-app/templates/experiment/lib/hooks/use-prefetch.ts +74 -0
  152. package/packages/create-basement-app/templates/experiment/lib/integrations/.gitkeep +0 -0
  153. package/packages/create-basement-app/templates/experiment/lib/scripts/dev.ts +52 -0
  154. package/packages/create-basement-app/templates/experiment/lib/scripts/generate-component.ts +322 -0
  155. package/packages/create-basement-app/templates/experiment/lib/scripts/generate-page.ts +193 -0
  156. package/packages/create-basement-app/templates/experiment/lib/scripts/generate.ts +79 -0
  157. package/packages/create-basement-app/templates/experiment/lib/scripts/utils.ts +246 -0
  158. package/packages/create-basement-app/templates/experiment/lib/store/app.ts +11 -0
  159. package/packages/create-basement-app/templates/experiment/lib/store/index.ts +11 -0
  160. package/packages/create-basement-app/templates/experiment/lib/styles/README.md +64 -0
  161. package/packages/create-basement-app/templates/experiment/lib/styles/cn.ts +7 -0
  162. package/packages/create-basement-app/templates/experiment/lib/styles/colors.ts +63 -0
  163. package/packages/create-basement-app/templates/experiment/lib/styles/config.ts +34 -0
  164. package/packages/create-basement-app/templates/experiment/lib/styles/css/global.css +85 -0
  165. package/packages/create-basement-app/templates/experiment/lib/styles/css/index.css +6 -0
  166. package/packages/create-basement-app/templates/experiment/lib/styles/css/reset.css +166 -0
  167. package/packages/create-basement-app/templates/experiment/lib/styles/css/root.css +68 -0
  168. package/packages/create-basement-app/templates/experiment/lib/styles/css/tailwind.css +132 -0
  169. package/packages/create-basement-app/templates/experiment/lib/styles/easings.ts +21 -0
  170. package/packages/create-basement-app/templates/experiment/lib/styles/fonts.ts +28 -0
  171. package/packages/create-basement-app/templates/experiment/lib/styles/index.ts +12 -0
  172. package/packages/create-basement-app/templates/experiment/lib/styles/layout.mjs +27 -0
  173. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/README.md +29 -0
  174. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/generate-root.ts +57 -0
  175. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/generate-tailwind.ts +162 -0
  176. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/postcss-functions.mjs +168 -0
  177. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/setup-styles.ts +24 -0
  178. package/packages/create-basement-app/templates/experiment/lib/styles/scripts/utils.ts +20 -0
  179. package/packages/create-basement-app/templates/experiment/lib/styles/typography.ts +36 -0
  180. package/packages/create-basement-app/templates/experiment/lib/utils/README.md +40 -0
  181. package/packages/create-basement-app/templates/experiment/lib/utils/css.d.ts +21 -0
  182. package/packages/create-basement-app/templates/experiment/lib/utils/easings.ts +240 -0
  183. package/packages/create-basement-app/templates/experiment/lib/utils/fetch.ts +84 -0
  184. package/packages/create-basement-app/templates/experiment/lib/utils/math.test.ts +221 -0
  185. package/packages/create-basement-app/templates/experiment/lib/utils/math.ts +236 -0
  186. package/packages/create-basement-app/templates/experiment/lib/utils/metadata.ts +126 -0
  187. package/packages/create-basement-app/templates/experiment/lib/utils/strings.test.ts +166 -0
  188. package/packages/create-basement-app/templates/experiment/lib/utils/strings.ts +246 -0
  189. package/packages/create-basement-app/templates/experiment/lib/utils/types.d.ts +15 -0
  190. package/packages/create-basement-app/templates/experiment/lib/utils/viewport.test.ts +256 -0
  191. package/packages/create-basement-app/templates/experiment/lib/utils/viewport.ts +193 -0
  192. package/packages/create-basement-app/templates/experiment/next.config.ts +142 -0
  193. package/packages/create-basement-app/templates/experiment/package.json +69 -0
  194. package/packages/create-basement-app/templates/experiment/postcss.config.mjs +42 -0
  195. package/packages/create-basement-app/templates/experiment/public/fonts/geist/Geist-Mono.woff2 +0 -0
  196. package/packages/create-basement-app/templates/experiment/tsconfig.json +43 -0
  197. package/packages/create-basement-app/templates/webgl/.biome/plugins/README.md +21 -0
  198. package/packages/create-basement-app/templates/webgl/.biome/plugins/no-anchor-element.grit +12 -0
  199. package/packages/create-basement-app/templates/webgl/.biome/plugins/no-relative-parent-imports.grit +10 -0
  200. package/packages/create-basement-app/templates/webgl/.biome/plugins/no-unnecessary-forwardref.grit +9 -0
  201. package/packages/create-basement-app/templates/webgl/.cursor/rules/README.md +184 -0
  202. package/packages/create-basement-app/templates/webgl/.cursor/rules/architecture.mdc +437 -0
  203. package/packages/create-basement-app/templates/webgl/.cursor/rules/components.mdc +436 -0
  204. package/packages/create-basement-app/templates/webgl/.cursor/rules/integrations.mdc +447 -0
  205. package/packages/create-basement-app/templates/webgl/.cursor/rules/main.mdc +278 -0
  206. package/packages/create-basement-app/templates/webgl/.cursor/rules/styling.mdc +433 -0
  207. package/packages/create-basement-app/templates/webgl/.editorconfig +40 -0
  208. package/packages/create-basement-app/templates/webgl/.env.example +81 -0
  209. package/packages/create-basement-app/templates/webgl/.gitattributes +19 -0
  210. package/packages/create-basement-app/templates/webgl/.github/PULL_REQUEST_TEMPLATE.md +14 -0
  211. package/packages/create-basement-app/templates/webgl/.github/workflows/lighthouse-to-slack.yml +136 -0
  212. package/packages/create-basement-app/templates/webgl/.vscode/extensions.json +20 -0
  213. package/packages/create-basement-app/templates/webgl/.vscode/settings.json +105 -0
  214. package/packages/create-basement-app/templates/webgl/README.md +221 -0
  215. package/packages/create-basement-app/templates/webgl/_gitignore +67 -0
  216. package/packages/create-basement-app/templates/webgl/app/favicon.ico +0 -0
  217. package/packages/create-basement-app/templates/webgl/app/layout.tsx +104 -0
  218. package/packages/create-basement-app/templates/webgl/app/page.tsx +10 -0
  219. package/packages/create-basement-app/templates/webgl/app/robots.ts +15 -0
  220. package/packages/create-basement-app/templates/webgl/app/sitemap.ts +16 -0
  221. package/packages/create-basement-app/templates/webgl/biome.json +250 -0
  222. package/packages/create-basement-app/templates/webgl/components/basement.svg +1 -0
  223. package/packages/create-basement-app/templates/webgl/components/layout/footer/index.tsx +27 -0
  224. package/packages/create-basement-app/templates/webgl/components/layout/header/index.tsx +11 -0
  225. package/packages/create-basement-app/templates/webgl/components/layout/theme/index.tsx +66 -0
  226. package/packages/create-basement-app/templates/webgl/components/layout/wrapper/index.tsx +65 -0
  227. package/packages/create-basement-app/templates/webgl/components/ui/README.md +77 -0
  228. package/packages/create-basement-app/templates/webgl/components/ui/image/README.md +37 -0
  229. package/packages/create-basement-app/templates/webgl/components/ui/image/index.tsx +224 -0
  230. package/packages/create-basement-app/templates/webgl/components/ui/link/index.tsx +146 -0
  231. package/packages/create-basement-app/templates/webgl/components/webgl/canvas/dynamic.tsx +34 -0
  232. package/packages/create-basement-app/templates/webgl/components/webgl/canvas/index.tsx +43 -0
  233. package/packages/create-basement-app/templates/webgl/components/webgl/components/scene/index.tsx +21 -0
  234. package/packages/create-basement-app/templates/webgl/lib/README.md +33 -0
  235. package/packages/create-basement-app/templates/webgl/lib/hooks/index.ts +12 -0
  236. package/packages/create-basement-app/templates/webgl/lib/hooks/use-device-detection.ts +81 -0
  237. package/packages/create-basement-app/templates/webgl/lib/hooks/use-media-breakpoint.ts +15 -0
  238. package/packages/create-basement-app/templates/webgl/lib/hooks/use-prefetch.ts +74 -0
  239. package/packages/create-basement-app/templates/webgl/lib/integrations/.gitkeep +0 -0
  240. package/packages/create-basement-app/templates/webgl/lib/scripts/dev.ts +52 -0
  241. package/packages/create-basement-app/templates/webgl/lib/scripts/generate-component.ts +322 -0
  242. package/packages/create-basement-app/templates/webgl/lib/scripts/generate-page.ts +193 -0
  243. package/packages/create-basement-app/templates/webgl/lib/scripts/generate.ts +79 -0
  244. package/packages/create-basement-app/templates/webgl/lib/scripts/utils.ts +246 -0
  245. package/packages/create-basement-app/templates/webgl/lib/store/app.ts +11 -0
  246. package/packages/create-basement-app/templates/webgl/lib/store/index.ts +11 -0
  247. package/packages/create-basement-app/templates/webgl/lib/styles/README.md +64 -0
  248. package/packages/create-basement-app/templates/webgl/lib/styles/cn.ts +7 -0
  249. package/packages/create-basement-app/templates/webgl/lib/styles/colors.ts +63 -0
  250. package/packages/create-basement-app/templates/webgl/lib/styles/config.ts +34 -0
  251. package/packages/create-basement-app/templates/webgl/lib/styles/css/global.css +85 -0
  252. package/packages/create-basement-app/templates/webgl/lib/styles/css/index.css +6 -0
  253. package/packages/create-basement-app/templates/webgl/lib/styles/css/reset.css +166 -0
  254. package/packages/create-basement-app/templates/webgl/lib/styles/css/root.css +68 -0
  255. package/packages/create-basement-app/templates/webgl/lib/styles/css/tailwind.css +132 -0
  256. package/packages/create-basement-app/templates/webgl/lib/styles/easings.ts +21 -0
  257. package/packages/create-basement-app/templates/webgl/lib/styles/fonts.ts +28 -0
  258. package/packages/create-basement-app/templates/webgl/lib/styles/index.ts +12 -0
  259. package/packages/create-basement-app/templates/webgl/lib/styles/layout.mjs +27 -0
  260. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/README.md +29 -0
  261. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/generate-root.ts +57 -0
  262. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/generate-tailwind.ts +162 -0
  263. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/postcss-functions.mjs +168 -0
  264. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/setup-styles.ts +24 -0
  265. package/packages/create-basement-app/templates/webgl/lib/styles/scripts/utils.ts +20 -0
  266. package/packages/create-basement-app/templates/webgl/lib/styles/typography.ts +36 -0
  267. package/packages/create-basement-app/templates/webgl/lib/utils/README.md +40 -0
  268. package/packages/create-basement-app/templates/webgl/lib/utils/css.d.ts +21 -0
  269. package/packages/create-basement-app/templates/webgl/lib/utils/easings.ts +240 -0
  270. package/packages/create-basement-app/templates/webgl/lib/utils/fetch.ts +84 -0
  271. package/packages/create-basement-app/templates/webgl/lib/utils/math.test.ts +221 -0
  272. package/packages/create-basement-app/templates/webgl/lib/utils/math.ts +236 -0
  273. package/packages/create-basement-app/templates/webgl/lib/utils/metadata.ts +126 -0
  274. package/packages/create-basement-app/templates/webgl/lib/utils/strings.test.ts +166 -0
  275. package/packages/create-basement-app/templates/webgl/lib/utils/strings.ts +246 -0
  276. package/packages/create-basement-app/templates/webgl/lib/utils/types.d.ts +15 -0
  277. package/packages/create-basement-app/templates/webgl/lib/utils/viewport.test.ts +256 -0
  278. package/packages/create-basement-app/templates/webgl/lib/utils/viewport.ts +193 -0
  279. package/packages/create-basement-app/templates/webgl/next.config.ts +142 -0
  280. package/packages/create-basement-app/templates/webgl/package.json +68 -0
  281. package/packages/create-basement-app/templates/webgl/postcss.config.mjs +42 -0
  282. package/packages/create-basement-app/templates/webgl/public/fonts/geist/Geist-Mono.woff2 +0 -0
  283. package/packages/create-basement-app/templates/webgl/tsconfig.json +43 -0
  284. package/packages/create-basement-app/templates/webgpu/.biome/plugins/README.md +21 -0
  285. package/packages/create-basement-app/templates/webgpu/.biome/plugins/no-anchor-element.grit +12 -0
  286. package/packages/create-basement-app/templates/webgpu/.biome/plugins/no-relative-parent-imports.grit +10 -0
  287. package/packages/create-basement-app/templates/webgpu/.biome/plugins/no-unnecessary-forwardref.grit +9 -0
  288. package/packages/create-basement-app/templates/webgpu/.cursor/rules/README.md +184 -0
  289. package/packages/create-basement-app/templates/webgpu/.cursor/rules/architecture.mdc +437 -0
  290. package/packages/create-basement-app/templates/webgpu/.cursor/rules/components.mdc +436 -0
  291. package/packages/create-basement-app/templates/webgpu/.cursor/rules/integrations.mdc +447 -0
  292. package/packages/create-basement-app/templates/webgpu/.cursor/rules/main.mdc +278 -0
  293. package/packages/create-basement-app/templates/webgpu/.cursor/rules/styling.mdc +433 -0
  294. package/packages/create-basement-app/templates/webgpu/.editorconfig +40 -0
  295. package/packages/create-basement-app/templates/webgpu/.env.example +81 -0
  296. package/packages/create-basement-app/templates/webgpu/.gitattributes +19 -0
  297. package/packages/create-basement-app/templates/webgpu/.github/PULL_REQUEST_TEMPLATE.md +14 -0
  298. package/packages/create-basement-app/templates/webgpu/.github/workflows/lighthouse-to-slack.yml +136 -0
  299. package/packages/create-basement-app/templates/webgpu/.vscode/extensions.json +20 -0
  300. package/packages/create-basement-app/templates/webgpu/.vscode/settings.json +105 -0
  301. package/packages/create-basement-app/templates/webgpu/README.md +221 -0
  302. package/packages/create-basement-app/templates/webgpu/_gitignore +67 -0
  303. package/packages/create-basement-app/templates/webgpu/app/favicon.ico +0 -0
  304. package/packages/create-basement-app/templates/webgpu/app/layout.tsx +104 -0
  305. package/packages/create-basement-app/templates/webgpu/app/page.tsx +275 -0
  306. package/packages/create-basement-app/templates/webgpu/app/robots.ts +15 -0
  307. package/packages/create-basement-app/templates/webgpu/app/sitemap.ts +16 -0
  308. package/packages/create-basement-app/templates/webgpu/biome.json +250 -0
  309. package/packages/create-basement-app/templates/webgpu/components/basement.svg +1 -0
  310. package/packages/create-basement-app/templates/webgpu/components/layout/footer/index.tsx +27 -0
  311. package/packages/create-basement-app/templates/webgpu/components/layout/header/index.tsx +11 -0
  312. package/packages/create-basement-app/templates/webgpu/components/layout/theme/index.tsx +66 -0
  313. package/packages/create-basement-app/templates/webgpu/components/layout/wrapper/index.tsx +65 -0
  314. package/packages/create-basement-app/templates/webgpu/components/ui/README.md +77 -0
  315. package/packages/create-basement-app/templates/webgpu/components/ui/image/README.md +37 -0
  316. package/packages/create-basement-app/templates/webgpu/components/ui/image/index.tsx +224 -0
  317. package/packages/create-basement-app/templates/webgpu/components/ui/link/index.tsx +146 -0
  318. package/packages/create-basement-app/templates/webgpu/lib/README.md +33 -0
  319. package/packages/create-basement-app/templates/webgpu/lib/hooks/index.ts +12 -0
  320. package/packages/create-basement-app/templates/webgpu/lib/hooks/use-device-detection.ts +81 -0
  321. package/packages/create-basement-app/templates/webgpu/lib/hooks/use-media-breakpoint.ts +15 -0
  322. package/packages/create-basement-app/templates/webgpu/lib/hooks/use-prefetch.ts +74 -0
  323. package/packages/create-basement-app/templates/webgpu/lib/integrations/.gitkeep +0 -0
  324. package/packages/create-basement-app/templates/webgpu/lib/scripts/dev.ts +52 -0
  325. package/packages/create-basement-app/templates/webgpu/lib/scripts/generate-component.ts +322 -0
  326. package/packages/create-basement-app/templates/webgpu/lib/scripts/generate-page.ts +193 -0
  327. package/packages/create-basement-app/templates/webgpu/lib/scripts/generate.ts +79 -0
  328. package/packages/create-basement-app/templates/webgpu/lib/scripts/utils.ts +246 -0
  329. package/packages/create-basement-app/templates/webgpu/lib/store/app.ts +11 -0
  330. package/packages/create-basement-app/templates/webgpu/lib/store/index.ts +11 -0
  331. package/packages/create-basement-app/templates/webgpu/lib/styles/README.md +64 -0
  332. package/packages/create-basement-app/templates/webgpu/lib/styles/cn.ts +7 -0
  333. package/packages/create-basement-app/templates/webgpu/lib/styles/colors.ts +63 -0
  334. package/packages/create-basement-app/templates/webgpu/lib/styles/config.ts +34 -0
  335. package/packages/create-basement-app/templates/webgpu/lib/styles/css/global.css +85 -0
  336. package/packages/create-basement-app/templates/webgpu/lib/styles/css/index.css +6 -0
  337. package/packages/create-basement-app/templates/webgpu/lib/styles/css/reset.css +166 -0
  338. package/packages/create-basement-app/templates/webgpu/lib/styles/css/root.css +68 -0
  339. package/packages/create-basement-app/templates/webgpu/lib/styles/css/tailwind.css +132 -0
  340. package/packages/create-basement-app/templates/webgpu/lib/styles/easings.ts +21 -0
  341. package/packages/create-basement-app/templates/webgpu/lib/styles/fonts.ts +28 -0
  342. package/packages/create-basement-app/templates/webgpu/lib/styles/index.ts +12 -0
  343. package/packages/create-basement-app/templates/webgpu/lib/styles/layout.mjs +27 -0
  344. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/README.md +29 -0
  345. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/generate-root.ts +57 -0
  346. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/generate-tailwind.ts +162 -0
  347. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/postcss-functions.mjs +168 -0
  348. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/setup-styles.ts +24 -0
  349. package/packages/create-basement-app/templates/webgpu/lib/styles/scripts/utils.ts +20 -0
  350. package/packages/create-basement-app/templates/webgpu/lib/styles/typography.ts +36 -0
  351. package/packages/create-basement-app/templates/webgpu/lib/utils/README.md +40 -0
  352. package/packages/create-basement-app/templates/webgpu/lib/utils/css.d.ts +21 -0
  353. package/packages/create-basement-app/templates/webgpu/lib/utils/easings.ts +240 -0
  354. package/packages/create-basement-app/templates/webgpu/lib/utils/fetch.ts +84 -0
  355. package/packages/create-basement-app/templates/webgpu/lib/utils/math.test.ts +221 -0
  356. package/packages/create-basement-app/templates/webgpu/lib/utils/math.ts +236 -0
  357. package/packages/create-basement-app/templates/webgpu/lib/utils/metadata.ts +126 -0
  358. package/packages/create-basement-app/templates/webgpu/lib/utils/strings.test.ts +166 -0
  359. package/packages/create-basement-app/templates/webgpu/lib/utils/strings.ts +246 -0
  360. package/packages/create-basement-app/templates/webgpu/lib/utils/types.d.ts +15 -0
  361. package/packages/create-basement-app/templates/webgpu/lib/utils/viewport.test.ts +256 -0
  362. package/packages/create-basement-app/templates/webgpu/lib/utils/viewport.ts +193 -0
  363. package/packages/create-basement-app/templates/webgpu/next.config.ts +142 -0
  364. package/packages/create-basement-app/templates/webgpu/package.json +69 -0
  365. package/packages/create-basement-app/templates/webgpu/postcss.config.mjs +42 -0
  366. package/packages/create-basement-app/templates/webgpu/public/fonts/geist/Geist-Mono.woff2 +0 -0
  367. package/packages/create-basement-app/templates/webgpu/tsconfig.json +43 -0
  368. package/tasks/.last-branch +1 -0
  369. package/tasks/CLAUDE.md +104 -0
  370. package/tasks/archive/2026-02-09-next-starter-dynamic-layers/prd.json +153 -0
  371. package/tasks/archive/2026-02-09-next-starter-dynamic-layers/progress.txt +115 -0
  372. package/tasks/prd-project-restructure.md +375 -0
  373. package/tasks/prd.json +227 -91
  374. package/tasks/progress.txt +281 -87
  375. package/tasks/ralph.sh +113 -0
  376. package/layers/experiment/components/layout/header/index.tsx +0 -58
  377. package/layers/experiment/components/layout/navigation-menu.tsx +0 -127
  378. package/layers/experiment/lib/constants.ts +0 -12
  379. package/layers/webgl/app/page.tsx +0 -10
  380. package/layers/webgl/components/webgl/canvas/dynamic.tsx +0 -34
  381. package/layers/webgl/components/webgl/canvas/index.tsx +0 -43
  382. package/layers/webgl/components/webgl/components/scene/index.tsx +0 -21
  383. package/src/mergers/next-config-merger.js +0 -63
  384. /package/{src → packages/cli/src}/commands/setup-sanity.js +0 -0
  385. /package/{src → packages/cli/src}/commands/worktree.js +0 -0
  386. /package/{integrations/basehub → packages/create-basement-app/integrations/basehub/files}/README.md +0 -0
  387. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/api/draft-mode/disable/route.ts +0 -0
  388. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/api/draft-mode/enable/route.ts +0 -0
  389. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/api/revalidate/route.ts +0 -0
  390. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/layout.tsx +0 -0
  391. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/sitemap.ts +0 -0
  392. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/studio/[[...tool]]/page.tsx +0 -0
  393. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/app/studio/layout.tsx +0 -0
  394. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/components/ui/sanity-image/index.tsx +0 -0
  395. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/README.md +0 -0
  396. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/check-integration.ts +0 -0
  397. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/README.md +0 -0
  398. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/client.ts +0 -0
  399. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/components/disable-draft-mode.tsx +0 -0
  400. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/components/rich-text.tsx +0 -0
  401. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/env.ts +0 -0
  402. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/live/index.tsx +0 -0
  403. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/queries.ts +0 -0
  404. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/sanity.cli.ts +0 -0
  405. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/sanity.config.ts +0 -0
  406. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/sanity.types.ts +0 -0
  407. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schema.json +0 -0
  408. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/article.ts +0 -0
  409. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/example.ts +0 -0
  410. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/index.ts +0 -0
  411. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/link.ts +0 -0
  412. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/metadata.ts +0 -0
  413. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/navigation.ts +0 -0
  414. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/page.ts +0 -0
  415. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/schemas/richText.ts +0 -0
  416. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/structure.ts +0 -0
  417. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/utils/image.ts +0 -0
  418. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/integrations/sanity/utils/link.ts +0 -0
  419. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/scripts/copy-sanity-mcp.ts +0 -0
  420. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/scripts/generate-page.ts +0 -0
  421. /package/{integrations/sanity → packages/create-basement-app/integrations/sanity/files}/lib/utils/metadata.ts +0 -0
  422. /package/{plugins → packages/create-basement-app/plugins}/README.md +0 -0
  423. /package/{plugins → packages/create-basement-app/plugins}/no-anchor-element.grit +0 -0
  424. /package/{plugins → packages/create-basement-app/plugins}/no-relative-parent-imports.grit +0 -0
  425. /package/{plugins → packages/create-basement-app/plugins}/no-unnecessary-forwardref.grit +0 -0
  426. /package/{template-hooks → packages/create-basement-app/template-hooks}/use-battery.ts +0 -0
  427. /package/{template-hooks → packages/create-basement-app/template-hooks}/use-device-perf.ts +0 -0
  428. /package/{template-hooks → packages/create-basement-app/template-hooks}/use-intersection-observer.ts +0 -0
  429. /package/{template-hooks → packages/create-basement-app/template-hooks}/use-media.ts +0 -0
  430. /package/{layers/webgpu → packages/create-basement-app/templates/default/lib/integrations}/.gitkeep +0 -0
@@ -0,0 +1,85 @@
1
+ /* GLOBAL CSS FILE - Contains global styles that shouldn't be reset */
2
+
3
+ html {
4
+ --scrollbar-gutter: 0px;
5
+ scrollbar-gutter: stable; /* This is needed to prevent the scrollbar from jumping */
6
+
7
+ &.lenis-stopped {
8
+ --scrollbar-gutter: var(--scrollbar-width);
9
+ }
10
+ }
11
+
12
+ html.overflow-hidden {
13
+ overflow: hidden;
14
+ touch-action: none;
15
+ }
16
+
17
+ body {
18
+ min-height: 100vh;
19
+ overscroll-behavior: none;
20
+ background-color: var(--color-primary);
21
+ color: var(--color-secondary);
22
+ display: flex;
23
+ flex-direction: column;
24
+ -webkit-font-smoothing: antialiased;
25
+ -moz-osx-font-smoothing: grayscale;
26
+ }
27
+
28
+ /* Selection styling */
29
+ *::selection {
30
+ background-color: var(--color-contrast);
31
+ color: var(--color-primary);
32
+ }
33
+
34
+ /* SVG icon colors */
35
+ svg.icon {
36
+ path[fill],
37
+ rect[fill],
38
+ circle[fill] {
39
+ fill: currentColor;
40
+ }
41
+ path[stroke],
42
+ rect[stroke],
43
+ circle[stroke] {
44
+ stroke: currentColor;
45
+ }
46
+ }
47
+
48
+ /* Hover states */
49
+ .link {
50
+ @media (--hover) {
51
+ &:hover {
52
+ text-decoration: underline;
53
+ }
54
+ }
55
+ }
56
+
57
+ /* Focus states */
58
+ *:focus-visible {
59
+ outline: 2px solid var(--color-contrast);
60
+ }
61
+
62
+ html.scrollbar-grabbing,
63
+ img {
64
+ -webkit-touch-callout: none;
65
+ -webkit-user-select: none;
66
+ -moz-user-select: none;
67
+ -ms-user-select: none;
68
+ -o-user-select: none;
69
+ user-select: none;
70
+ }
71
+
72
+ button {
73
+ cursor: pointer;
74
+ /* Fix vertical text centering by trimming font metric space */
75
+ text-box-trim: both;
76
+ text-box-edge: cap alphabetic;
77
+ user-select: none;
78
+ }
79
+
80
+ html.screenshot {
81
+ *:not(:has(canvas), canvas, :has(#orchestra), #orchestra, #orchestra *) {
82
+ /* biome-ignore lint: it's all good */
83
+ opacity: 0 !important;
84
+ }
85
+ }
@@ -0,0 +1,6 @@
1
+ /* INDEX CSS FILE - Barrel file for importing all the css files */
2
+ @import "./reset.css";
3
+ @import "tailwindcss/utilities.css";
4
+ @import "./tailwind.css";
5
+ @import "./root.css";
6
+ @import "./global.css";
@@ -0,0 +1,166 @@
1
+ /***
2
+ The new CSS reset - version 1.11.3 (last updated 25.08.2024)
3
+ GitHub page: https://github.com/elad2412/the-new-css-reset
4
+ ***/
5
+
6
+ /*
7
+ Remove all the styles of the "User-Agent-Stylesheet", except for the 'display' property
8
+ - The "symbol *" part is to solve Firefox SVG sprite bug
9
+ - The "html" element is excluded, otherwise a bug in Chrome breaks the CSS hyphens property (https://github.com/elad2412/the-new-css-reset/issues/36)
10
+ */
11
+ *:where(
12
+ :not(
13
+ html,
14
+ iframe,
15
+ canvas,
16
+ img,
17
+ svg,
18
+ video,
19
+ audio,
20
+ dialog,
21
+ vercel-live-feedback,
22
+ nextjs-portal,
23
+ :where(select, option)
24
+ ):not(svg *, symbol *)
25
+ ) {
26
+ all: unset;
27
+ display: revert;
28
+ }
29
+
30
+ /* Preferred box-sizing value */
31
+ *,
32
+ *::before,
33
+ *::after {
34
+ box-sizing: border-box;
35
+ }
36
+
37
+ /* Fix mobile Safari increase font-size on landscape mode */
38
+ html {
39
+ -moz-text-size-adjust: none;
40
+ -webkit-text-size-adjust: none;
41
+ text-size-adjust: none;
42
+ }
43
+
44
+ /* Reapply the pointer cursor for anchor tags */
45
+ a,
46
+ button {
47
+ cursor: revert;
48
+ }
49
+
50
+ /* Remove list styles (bullets/numbers) */
51
+ ol,
52
+ ul,
53
+ menu,
54
+ summary {
55
+ list-style: none;
56
+ }
57
+
58
+ /* Firefox: solve issue where nested ordered lists continue numbering from parent (https://bugzilla.mozilla.org/show_bug.cgi?id=1881517) */
59
+ ol {
60
+ counter-reset: revert;
61
+ }
62
+
63
+ /* For images to not be able to exceed their container */
64
+ img {
65
+ max-inline-size: 100%;
66
+ max-block-size: 100%;
67
+ }
68
+
69
+ /* removes spacing between cells in tables */
70
+ table {
71
+ border-collapse: collapse;
72
+ }
73
+
74
+ /* Safari - solving issue when using user-select:none on the <body> text input doesn't working */
75
+ input,
76
+ textarea {
77
+ -webkit-user-select: auto;
78
+ }
79
+
80
+ /* revert the 'white-space' property for textarea elements on Safari */
81
+ textarea {
82
+ white-space: revert;
83
+ }
84
+
85
+ /* minimum style to allow to style meter element */
86
+ meter {
87
+ -webkit-appearance: revert;
88
+ appearance: revert;
89
+ }
90
+
91
+ /* preformatted text - use only for this feature */
92
+ :where(pre) {
93
+ all: revert;
94
+ box-sizing: border-box;
95
+ }
96
+
97
+ /* reset default text opacity of input placeholder */
98
+ ::placeholder {
99
+ color: unset;
100
+ }
101
+
102
+ /* fix the feature of 'hidden' attribute.
103
+ display:revert; revert to element instead of attribute */
104
+ :where([hidden]) {
105
+ display: none;
106
+ }
107
+
108
+ /* revert for bug in Chromium browsers
109
+ - fix for the content editable attribute will work properly.
110
+ - webkit-user-select: auto; added for Safari in case of using user-select:none on wrapper element*/
111
+ :where([contenteditable]:not([contenteditable="false"])) {
112
+ -moz-user-modify: read-write;
113
+ -webkit-user-modify: read-write;
114
+ overflow-wrap: break-word;
115
+ -webkit-line-break: after-white-space;
116
+ -webkit-user-select: auto;
117
+ }
118
+
119
+ /* apply back the draggable feature - exist only in Chromium and Safari */
120
+ :where([draggable="true"]) {
121
+ -webkit-user-drag: element;
122
+ }
123
+
124
+ /* Revert Modal native behavior */
125
+ :where(dialog:modal) {
126
+ all: revert;
127
+ box-sizing: border-box;
128
+ }
129
+
130
+ /* Remove details summary webkit styles */
131
+ ::-webkit-details-marker {
132
+ display: none;
133
+ }
134
+
135
+ /* Add support for color-scheme */
136
+ :root {
137
+ color-scheme: light dark;
138
+ }
139
+
140
+ /* Add support for newer form controls */
141
+ :where(input[type="file"]) {
142
+ cursor: default;
143
+ -webkit-appearance: none;
144
+ appearance: none;
145
+ }
146
+
147
+ /* Improve text rendering */
148
+ html {
149
+ text-size-adjust: 100%;
150
+ -webkit-text-size-adjust: 100%;
151
+ -moz-text-size-adjust: 100%;
152
+ text-rendering: optimizeLegibility;
153
+ }
154
+
155
+ /* Remove tap highlight on iOS */
156
+ a,
157
+ button {
158
+ -webkit-tap-highlight-color: transparent;
159
+ }
160
+
161
+ /* Improve media defaults */
162
+ video,
163
+ audio {
164
+ max-inline-size: 100%;
165
+ max-block-size: 100%;
166
+ }
@@ -0,0 +1,68 @@
1
+ /*
2
+ * THIS FILE IS GENERATED BY setup-styles.ts
3
+ * DO NOT EDIT IT DIRECTLY.
4
+ */
5
+
6
+ @custom-media --hover (hover: hover);
7
+ @custom-media --reduced-motion (prefers-reduced-motion: reduce);
8
+ @custom-media --mobile (width <= 767.98px);
9
+ @custom-media --desktop-large (width >= 1920px);
10
+ @custom-media --desktop (width >= 1440px);
11
+ @custom-media --tablet-lg (width >= 1024px);
12
+ @custom-media --tablet (width >= 768px);
13
+ @custom-media --mobile (width >= 640px);
14
+
15
+ :root {
16
+ --device-width: 640;
17
+ --device-height: 650;
18
+
19
+ --columns: 4;
20
+ --gap: 16px;
21
+ --safe: 16px;
22
+
23
+ --header-height: 58px;
24
+
25
+ --layout-width: calc(100vw - (2 * var(--safe)));
26
+ --column-width: calc((var(--layout-width) - (var(--columns) - 1) * var(--gap)) / var(--columns));
27
+
28
+ --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
29
+ --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
30
+ --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
31
+ --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
32
+ --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
33
+ --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
34
+ --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
35
+ --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
36
+ --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
37
+ --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
38
+ --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
39
+ --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
40
+ --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
41
+ --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
42
+ --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
43
+ --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
44
+ --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
45
+ --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
46
+ --ease-gleasing: cubic-bezier(0.4, 0, 0, 1);
47
+
48
+ --color-black: #000000;
49
+ --color-white: #ffffff;
50
+ --color-orange: #FF4D00;
51
+ --color-blue: #487CFF;
52
+ --color-green: #00FF9B;
53
+ --color-violet: #F101A5;
54
+ --color-pink: #FF73A6;
55
+ --color-gray: #666666;
56
+
57
+ @variant desktop {
58
+ --device-width: 1440;
59
+ --device-height: 816;
60
+
61
+ --columns: 12;
62
+ --gap: 16px;
63
+ --safe: 16px;
64
+
65
+ --header-height: 98px;
66
+ }
67
+ }
68
+
@@ -0,0 +1,132 @@
1
+ /*
2
+ * THIS FILE IS GENERATED BY setup-styles.ts
3
+ * DO NOT EDIT IT DIRECTLY.
4
+ */
5
+
6
+ /** Custom theme **/
7
+ @theme {
8
+ --breakpoint-*: initial;
9
+ --breakpoint-desktop-large: 1920px;
10
+ --breakpoint-desktop: 1440px;
11
+ --breakpoint-tablet-lg: 1024px;
12
+ --breakpoint-tablet: 768px;
13
+ --breakpoint-mobile: 640px;
14
+
15
+ --color-*: initial;
16
+ --color-primary: #ffffff;
17
+ --color-secondary: #000000;
18
+ --color-contrast: #FF4D00;
19
+ --color-black: #000000;
20
+ --color-white: #ffffff;
21
+ --color-orange: #FF4D00;
22
+ --color-blue: #487CFF;
23
+ --color-green: #00FF9B;
24
+ --color-violet: #F101A5;
25
+ --color-pink: #FF73A6;
26
+ --color-gray: #666666;
27
+
28
+ /* gray */
29
+ --color-gray-50: #F5F5F5;
30
+ --color-gray-100: #E0E0E0;
31
+ --color-gray-200: #C2C2C2;
32
+ --color-gray-300: #A3A3A3;
33
+ --color-gray-400: #858585;
34
+ --color-gray-500: #666666;
35
+ --color-gray-600: #4D4D4D;
36
+ --color-gray-700: #333333;
37
+ --color-gray-800: #1A1A1A;
38
+
39
+ --spacing: 0.25rem;
40
+ --spacing-0: 0;
41
+ --spacing-safe: var(--safe);
42
+ --spacing-gap: var(--gap);
43
+ --spacing-header-height: var(--header-height);
44
+
45
+ --font-*: initial;
46
+ --font-mono: var(--geist-mono);
47
+
48
+ --ease-*: initial;
49
+ --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
50
+ --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
51
+ --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
52
+ --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
53
+ --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
54
+ --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
55
+ --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
56
+ --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
57
+ --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
58
+ --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
59
+ --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
60
+ --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
61
+ --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
62
+ --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
63
+ --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
64
+ --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
65
+ --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
66
+ --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
67
+ --ease-gleasing: cubic-bezier(0.4, 0, 0, 1);
68
+ }
69
+
70
+ /** Custom theme overwrites **/
71
+ [data-theme=light] {
72
+ --color-primary: #ffffff;
73
+ --color-secondary: #000000;
74
+ --color-contrast: #FF4D00;
75
+ }
76
+ [data-theme=dark] {
77
+ --color-primary: #000000;
78
+ --color-secondary: #ffffff;
79
+ --color-contrast: #FF4D00;
80
+ }
81
+
82
+
83
+ /** Custom static utilities **/
84
+ @utility test-mono {
85
+ font-family: var(--geist-mono);
86
+ font-style: normal;
87
+ font-weight: 400;
88
+ line-height: 90%;
89
+ letter-spacing: 0em;
90
+ font-size: 20px;
91
+ @variant desktop { font-size: 24px; }
92
+ }
93
+
94
+ @utility desktop-only {
95
+ @media (--mobile) {
96
+ display: none !important;
97
+ }
98
+ }
99
+
100
+ @utility mobile-only {
101
+ @media (--desktop) {
102
+ display: none !important;
103
+ }
104
+ }
105
+
106
+ @utility b-grid {
107
+ display: grid;
108
+ grid-template-columns: repeat(var(--columns), 1fr);
109
+ column-gap: var(--gap);
110
+ }
111
+
112
+ @utility b-layout-block {
113
+ margin-inline: auto;
114
+ width: calc(100% - 2 * var(--safe));
115
+ }
116
+
117
+ @utility b-layout-block-inner {
118
+ padding-inline: var(--safe);
119
+ width: 100%;
120
+ }
121
+
122
+ @utility b-layout-grid {
123
+ @apply b-layout-block b-grid;
124
+ }
125
+
126
+ @utility b-layout-grid-inner {
127
+ @apply b-layout-block-inner b-grid;
128
+ }
129
+
130
+ /** Custom variants **/
131
+ @custom-variant light (&:where([data-theme=light], [data-theme=light] *));
132
+ @custom-variant dark (&:where([data-theme=dark], [data-theme=dark] *));
@@ -0,0 +1,21 @@
1
+ export const easings = {
2
+ "in-quad": "cubic-bezier(0.55, 0.085, 0.68, 0.53)",
3
+ "in-cubic": "cubic-bezier(0.55, 0.055, 0.675, 0.19)",
4
+ "in-quart": "cubic-bezier(0.895, 0.03, 0.685, 0.22)",
5
+ "in-quint": "cubic-bezier(0.755, 0.05, 0.855, 0.06)",
6
+ "in-expo": "cubic-bezier(0.95, 0.05, 0.795, 0.035)",
7
+ "in-circ": "cubic-bezier(0.6, 0.04, 0.98, 0.335)",
8
+ "out-quad": "cubic-bezier(0.25, 0.46, 0.45, 0.94)",
9
+ "out-cubic": "cubic-bezier(0.215, 0.61, 0.355, 1)",
10
+ "out-quart": "cubic-bezier(0.165, 0.84, 0.44, 1)",
11
+ "out-quint": "cubic-bezier(0.23, 1, 0.32, 1)",
12
+ "out-expo": "cubic-bezier(0.19, 1, 0.22, 1)",
13
+ "out-circ": "cubic-bezier(0.075, 0.82, 0.165, 1)",
14
+ "in-out-quad": "cubic-bezier(0.455, 0.03, 0.515, 0.955)",
15
+ "in-out-cubic": "cubic-bezier(0.645, 0.045, 0.355, 1)",
16
+ "in-out-quart": "cubic-bezier(0.77, 0, 0.175, 1)",
17
+ "in-out-quint": "cubic-bezier(0.86, 0, 0.07, 1)",
18
+ "in-out-expo": "cubic-bezier(1, 0, 0, 1)",
19
+ "in-out-circ": "cubic-bezier(0.785, 0.135, 0.15, 0.86)",
20
+ gleasing: "cubic-bezier(0.4, 0, 0, 1)",
21
+ }
@@ -0,0 +1,28 @@
1
+ import localFont from "next/font/local"
2
+
3
+ const mono = localFont({
4
+ src: [
5
+ {
6
+ path: "../../public/fonts/geist/Geist-Mono.woff2",
7
+ weight: "400",
8
+ style: "normal",
9
+ },
10
+ ],
11
+ display: "swap",
12
+ variable: "--geist-mono",
13
+ preload: true,
14
+ adjustFontFallback: "Arial",
15
+ fallback: [
16
+ "ui-monospace",
17
+ "SFMono-Regular",
18
+ "Consolas",
19
+ "Liberation Mono",
20
+ "Menlo",
21
+ "monospace",
22
+ ],
23
+ })
24
+
25
+ const fonts = [mono]
26
+ const fontsVariable = fonts.map((font) => font.variable).join(" ")
27
+
28
+ export { fontsVariable }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Styling System
3
+ *
4
+ * Import from barrel:
5
+ * import { colors, themes, breakpoints } from '@/styles'
6
+ */
7
+
8
+ export { colors, type Themes, themeNames, themes } from "./colors"
9
+ export type { ThemeName } from "./config"
10
+ export { breakpoints, customSizes, layout, screens } from "./config"
11
+ export { easings } from "./easings"
12
+ export { fontsVariable } from "./fonts"
@@ -0,0 +1,27 @@
1
+ // THIS FILE HAS TO STAY .mjs AS ITS CONSUMED BY POSTCSS
2
+ // EDIT THIS AS NEEDED
3
+
4
+ const breakpoints = {
5
+ "desktop-large": 1920,
6
+ desktop: 1440,
7
+ "tablet-lg": 1024,
8
+ tablet: 768,
9
+ mobile: 640,
10
+ }
11
+
12
+ const screens = {
13
+ mobile: { width: breakpoints.mobile, height: 650 },
14
+ desktop: { width: breakpoints.desktop, height: 816 },
15
+ }
16
+
17
+ const layout = {
18
+ columns: { mobile: 4, desktop: 12 },
19
+ gap: { mobile: 16, desktop: 16 },
20
+ safe: { mobile: 16, desktop: 16 },
21
+ }
22
+
23
+ const customSizes = {
24
+ "header-height": { mobile: 58, desktop: 98 },
25
+ }
26
+
27
+ export { breakpoints, customSizes, layout, screens }
@@ -0,0 +1,29 @@
1
+ # Style Generation Scripts
2
+
3
+ Generate CSS from TypeScript config. Run with `bun setup:styles`.
4
+
5
+ ## Scripts
6
+
7
+ | Script | Output |
8
+ |--------|--------|
9
+ | `setup-styles.ts` | Orchestrates all generation |
10
+ | `generate-root.ts` | → `css/root.css` |
11
+ | `generate-tailwind.ts` | → `css/tailwind.css` |
12
+ | `generate-scale.ts` | Scale utilities |
13
+ | `postcss-functions.mjs` | `tovw()`, `torem()`, `toem()`, `columns()` |
14
+
15
+ ## Build Flow
16
+
17
+ ```
18
+ TypeScript Config → Generation Scripts → CSS Variables → PostCSS → Output
19
+ ```
20
+
21
+ 1. Edit `colors.ts`, `typography.ts`, etc.
22
+ 2. Run `bun setup:styles`
23
+ 3. Generated CSS is used by PostCSS
24
+
25
+ ## Best Practices
26
+
27
+ - Always run `bun setup:styles` after config changes
28
+ - Never edit `css/root.css` or `css/tailwind.css` directly
29
+ - Use `bun dev` for development (includes style watching)
@@ -0,0 +1,57 @@
1
+ import type { Config } from "../config"
2
+ import { formatObject } from "./utils"
3
+
4
+ export function generateRoot({
5
+ breakpoints,
6
+ colors,
7
+ customSizes,
8
+ easings,
9
+ layout,
10
+ screens,
11
+ }: Pick<
12
+ Config,
13
+ "breakpoints" | "colors" | "customSizes" | "easings" | "layout" | "screens"
14
+ >) {
15
+ return `@custom-media --hover (hover: hover);
16
+ @custom-media --reduced-motion (prefers-reduced-motion: reduce);
17
+ @custom-media --mobile (width <= ${breakpoints.tablet - 0.02}px);
18
+ ${formatObject(breakpoints, ([name, value]) => `@custom-media --${name} (width >= ${value}px);`, "\n")}
19
+
20
+ :root {
21
+ --device-width: ${screens.mobile.width};
22
+ --device-height: ${screens.mobile.height};
23
+
24
+ ${formatObject(layout, ([name, { mobile }]) => {
25
+ if (name === "columns") return `--columns: ${mobile};`
26
+
27
+ return `--${name}: ${mobile}px;`
28
+ })}
29
+
30
+ ${formatObject(customSizes, ([name, { mobile }]) => `--${name}: ${mobile}px;`)}
31
+
32
+ --layout-width: calc(100vw - (2 * var(--safe)));
33
+ --column-width: calc((var(--layout-width) - (var(--columns) - 1) * var(--gap)) / var(--columns));
34
+
35
+ ${formatObject(easings, ([name, value]) => `--ease-${name}: ${value};`)}
36
+
37
+ ${formatObject(colors, ([name, value]) => `--color-${name}: ${value};`)}
38
+
39
+ @variant desktop {
40
+ --device-width: ${screens.desktop.width};
41
+ --device-height: ${screens.desktop.height};
42
+
43
+ ${formatObject(
44
+ layout,
45
+ ([name, { desktop }]) => {
46
+ if (name === "columns") return `--columns: ${desktop};`
47
+
48
+ return `--${name}: ${desktop}px;`
49
+ },
50
+ "\n\t\t"
51
+ )}
52
+
53
+ ${formatObject(customSizes, ([name, { desktop }]) => `--${name}: ${desktop}px;`, "\n\t\t")}
54
+ }
55
+ }
56
+ `
57
+ }