lsd-pi 1.2.0 → 1.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (520) hide show
  1. package/dist/cli.js +7 -1
  2. package/dist/onboarding.js +3 -3
  3. package/dist/resources/agents/scout.md +6 -0
  4. package/dist/resources/extensions/slash-commands/plan.js +7 -1
  5. package/dist/resources/extensions/subagent/index.js +10 -2
  6. package/dist/resources/extensions/usage/index.js +87 -36
  7. package/package.json +1 -1
  8. package/packages/pi-agent-core/dist/agent.d.ts.map +1 -1
  9. package/packages/pi-agent-core/dist/agent.js +8 -2
  10. package/packages/pi-agent-core/dist/agent.js.map +1 -1
  11. package/packages/pi-agent-core/src/agent.ts +8 -2
  12. package/packages/pi-ai/dist/models.generated.d.ts +222 -1
  13. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  14. package/packages/pi-ai/dist/models.generated.js +227 -6
  15. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  16. package/packages/pi-ai/dist/models.test.js +28 -0
  17. package/packages/pi-ai/dist/models.test.js.map +1 -1
  18. package/packages/pi-ai/scripts/generate-models.ts +10 -100
  19. package/packages/pi-ai/src/models.generated.ts +227 -6
  20. package/packages/pi-ai/src/models.test.ts +30 -0
  21. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  22. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  23. package/packages/pi-coding-agent/dist/core/agent-session.js +28 -0
  24. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  25. package/packages/pi-coding-agent/dist/core/settings-manager.js +1 -1
  26. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  27. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
  28. package/packages/pi-coding-agent/dist/core/system-prompt.js +10 -0
  29. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  30. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  31. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  32. package/packages/pi-coding-agent/dist/index.js +1 -1
  33. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  34. package/packages/pi-coding-agent/dist/tests/path-display.test.js +13 -0
  35. package/packages/pi-coding-agent/dist/tests/path-display.test.js.map +1 -1
  36. package/packages/pi-coding-agent/dist/tests/settings-manager-scout-policy.test.d.ts +2 -0
  37. package/packages/pi-coding-agent/dist/tests/settings-manager-scout-policy.test.d.ts.map +1 -0
  38. package/packages/pi-coding-agent/dist/tests/settings-manager-scout-policy.test.js +15 -0
  39. package/packages/pi-coding-agent/dist/tests/settings-manager-scout-policy.test.js.map +1 -0
  40. package/packages/pi-coding-agent/package.json +1 -1
  41. package/packages/pi-coding-agent/src/core/agent-session.ts +35 -0
  42. package/packages/pi-coding-agent/src/core/settings-manager.ts +1 -1
  43. package/packages/pi-coding-agent/src/core/system-prompt.ts +26 -0
  44. package/packages/pi-coding-agent/src/index.ts +1 -0
  45. package/packages/pi-coding-agent/src/tests/path-display.test.ts +14 -0
  46. package/pkg/package.json +1 -1
  47. package/src/resources/agents/scout.md +6 -0
  48. package/src/resources/extensions/slash-commands/plan.ts +11 -1
  49. package/src/resources/extensions/subagent/index.ts +10 -2
  50. package/src/resources/extensions/usage/index.ts +92 -38
  51. package/dist/resources/agents/javascript-pro.md +0 -280
  52. package/dist/resources/agents/researcher.md +0 -29
  53. package/dist/resources/agents/teams-builder.md +0 -74
  54. package/dist/resources/agents/teams-reviewer.md +0 -113
  55. package/dist/resources/agents/typescript-pro.md +0 -255
  56. package/dist/resources/skills/accessibility/SKILL.md +0 -522
  57. package/dist/resources/skills/accessibility/references/WCAG.md +0 -162
  58. package/dist/resources/skills/core-web-vitals/SKILL.md +0 -441
  59. package/dist/resources/skills/core-web-vitals/references/LCP.md +0 -208
  60. package/dist/resources/skills/frontend-design/SKILL.md +0 -45
  61. package/dist/resources/skills/make-interfaces-feel-better/SKILL.md +0 -122
  62. package/dist/resources/skills/make-interfaces-feel-better/animations.md +0 -379
  63. package/dist/resources/skills/make-interfaces-feel-better/performance.md +0 -88
  64. package/dist/resources/skills/make-interfaces-feel-better/surfaces.md +0 -247
  65. package/dist/resources/skills/make-interfaces-feel-better/typography.md +0 -123
  66. package/dist/resources/skills/react-best-practices/README.md +0 -123
  67. package/dist/resources/skills/react-best-practices/SKILL.md +0 -136
  68. package/dist/resources/skills/react-best-practices/metadata.json +0 -15
  69. package/dist/resources/skills/react-best-practices/rules/_sections.md +0 -46
  70. package/dist/resources/skills/react-best-practices/rules/_template.md +0 -28
  71. package/dist/resources/skills/react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  72. package/dist/resources/skills/react-best-practices/rules/advanced-init-once.md +0 -42
  73. package/dist/resources/skills/react-best-practices/rules/advanced-use-latest.md +0 -39
  74. package/dist/resources/skills/react-best-practices/rules/async-api-routes.md +0 -38
  75. package/dist/resources/skills/react-best-practices/rules/async-defer-await.md +0 -80
  76. package/dist/resources/skills/react-best-practices/rules/async-dependencies.md +0 -51
  77. package/dist/resources/skills/react-best-practices/rules/async-parallel.md +0 -28
  78. package/dist/resources/skills/react-best-practices/rules/async-suspense-boundaries.md +0 -99
  79. package/dist/resources/skills/react-best-practices/rules/bundle-barrel-imports.md +0 -59
  80. package/dist/resources/skills/react-best-practices/rules/bundle-conditional.md +0 -31
  81. package/dist/resources/skills/react-best-practices/rules/bundle-defer-third-party.md +0 -49
  82. package/dist/resources/skills/react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  83. package/dist/resources/skills/react-best-practices/rules/bundle-preload.md +0 -50
  84. package/dist/resources/skills/react-best-practices/rules/client-event-listeners.md +0 -74
  85. package/dist/resources/skills/react-best-practices/rules/client-localstorage-schema.md +0 -71
  86. package/dist/resources/skills/react-best-practices/rules/client-passive-event-listeners.md +0 -48
  87. package/dist/resources/skills/react-best-practices/rules/client-swr-dedup.md +0 -56
  88. package/dist/resources/skills/react-best-practices/rules/js-batch-dom-css.md +0 -107
  89. package/dist/resources/skills/react-best-practices/rules/js-cache-function-results.md +0 -80
  90. package/dist/resources/skills/react-best-practices/rules/js-cache-property-access.md +0 -28
  91. package/dist/resources/skills/react-best-practices/rules/js-cache-storage.md +0 -70
  92. package/dist/resources/skills/react-best-practices/rules/js-combine-iterations.md +0 -32
  93. package/dist/resources/skills/react-best-practices/rules/js-early-exit.md +0 -50
  94. package/dist/resources/skills/react-best-practices/rules/js-hoist-regexp.md +0 -45
  95. package/dist/resources/skills/react-best-practices/rules/js-index-maps.md +0 -37
  96. package/dist/resources/skills/react-best-practices/rules/js-length-check-first.md +0 -49
  97. package/dist/resources/skills/react-best-practices/rules/js-min-max-loop.md +0 -82
  98. package/dist/resources/skills/react-best-practices/rules/js-set-map-lookups.md +0 -24
  99. package/dist/resources/skills/react-best-practices/rules/js-tosorted-immutable.md +0 -57
  100. package/dist/resources/skills/react-best-practices/rules/rendering-activity.md +0 -26
  101. package/dist/resources/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  102. package/dist/resources/skills/react-best-practices/rules/rendering-conditional-render.md +0 -40
  103. package/dist/resources/skills/react-best-practices/rules/rendering-content-visibility.md +0 -38
  104. package/dist/resources/skills/react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  105. package/dist/resources/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  106. package/dist/resources/skills/react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  107. package/dist/resources/skills/react-best-practices/rules/rendering-svg-precision.md +0 -28
  108. package/dist/resources/skills/react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  109. package/dist/resources/skills/react-best-practices/rules/rerender-defer-reads.md +0 -39
  110. package/dist/resources/skills/react-best-practices/rules/rerender-dependencies.md +0 -45
  111. package/dist/resources/skills/react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  112. package/dist/resources/skills/react-best-practices/rules/rerender-derived-state.md +0 -29
  113. package/dist/resources/skills/react-best-practices/rules/rerender-functional-setstate.md +0 -74
  114. package/dist/resources/skills/react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  115. package/dist/resources/skills/react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  116. package/dist/resources/skills/react-best-practices/rules/rerender-memo.md +0 -44
  117. package/dist/resources/skills/react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  118. package/dist/resources/skills/react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  119. package/dist/resources/skills/react-best-practices/rules/rerender-transitions.md +0 -40
  120. package/dist/resources/skills/react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  121. package/dist/resources/skills/react-best-practices/rules/server-after-nonblocking.md +0 -73
  122. package/dist/resources/skills/react-best-practices/rules/server-auth-actions.md +0 -96
  123. package/dist/resources/skills/react-best-practices/rules/server-cache-lru.md +0 -41
  124. package/dist/resources/skills/react-best-practices/rules/server-cache-react.md +0 -76
  125. package/dist/resources/skills/react-best-practices/rules/server-dedup-props.md +0 -65
  126. package/dist/resources/skills/react-best-practices/rules/server-parallel-fetching.md +0 -83
  127. package/dist/resources/skills/react-best-practices/rules/server-serialization.md +0 -38
  128. package/dist/resources/skills/userinterface-wiki/SKILL.md +0 -253
  129. package/dist/resources/skills/userinterface-wiki/rules/_sections.md +0 -66
  130. package/dist/resources/skills/userinterface-wiki/rules/_template.md +0 -24
  131. package/dist/resources/skills/userinterface-wiki/rules/a11y-reduced-motion-check.md +0 -30
  132. package/dist/resources/skills/userinterface-wiki/rules/a11y-toggle-setting.md +0 -30
  133. package/dist/resources/skills/userinterface-wiki/rules/a11y-visual-equivalent.md +0 -36
  134. package/dist/resources/skills/userinterface-wiki/rules/a11y-volume-control.md +0 -28
  135. package/dist/resources/skills/userinterface-wiki/rules/appropriate-confirmations-only.md +0 -19
  136. package/dist/resources/skills/userinterface-wiki/rules/appropriate-errors-warnings.md +0 -18
  137. package/dist/resources/skills/userinterface-wiki/rules/appropriate-no-decorative.md +0 -21
  138. package/dist/resources/skills/userinterface-wiki/rules/appropriate-no-high-frequency.md +0 -28
  139. package/dist/resources/skills/userinterface-wiki/rules/appropriate-no-punishing.md +0 -27
  140. package/dist/resources/skills/userinterface-wiki/rules/container-callback-ref.md +0 -31
  141. package/dist/resources/skills/userinterface-wiki/rules/container-guard-initial-zero.md +0 -25
  142. package/dist/resources/skills/userinterface-wiki/rules/container-no-excessive-use.md +0 -13
  143. package/dist/resources/skills/userinterface-wiki/rules/container-overflow-hidden.md +0 -25
  144. package/dist/resources/skills/userinterface-wiki/rules/container-transition-delay.md +0 -21
  145. package/dist/resources/skills/userinterface-wiki/rules/container-two-div-pattern.md +0 -35
  146. package/dist/resources/skills/userinterface-wiki/rules/container-use-resize-observer.md +0 -48
  147. package/dist/resources/skills/userinterface-wiki/rules/context-cleanup-nodes.md +0 -25
  148. package/dist/resources/skills/userinterface-wiki/rules/context-resume-suspended.md +0 -28
  149. package/dist/resources/skills/userinterface-wiki/rules/context-reuse-single.md +0 -30
  150. package/dist/resources/skills/userinterface-wiki/rules/design-filter-for-character.md +0 -25
  151. package/dist/resources/skills/userinterface-wiki/rules/design-noise-for-percussion.md +0 -26
  152. package/dist/resources/skills/userinterface-wiki/rules/design-oscillator-for-tonal.md +0 -22
  153. package/dist/resources/skills/userinterface-wiki/rules/duration-max-300ms.md +0 -21
  154. package/dist/resources/skills/userinterface-wiki/rules/duration-press-hover.md +0 -21
  155. package/dist/resources/skills/userinterface-wiki/rules/duration-shorten-before-curve.md +0 -21
  156. package/dist/resources/skills/userinterface-wiki/rules/duration-small-state.md +0 -15
  157. package/dist/resources/skills/userinterface-wiki/rules/easing-entrance-ease-out.md +0 -21
  158. package/dist/resources/skills/userinterface-wiki/rules/easing-exit-ease-in.md +0 -21
  159. package/dist/resources/skills/userinterface-wiki/rules/easing-for-state-change.md +0 -27
  160. package/dist/resources/skills/userinterface-wiki/rules/easing-linear-only-progress.md +0 -21
  161. package/dist/resources/skills/userinterface-wiki/rules/easing-natural-decay.md +0 -22
  162. package/dist/resources/skills/userinterface-wiki/rules/easing-no-linear-motion.md +0 -22
  163. package/dist/resources/skills/userinterface-wiki/rules/easing-transition-ease-in-out.md +0 -15
  164. package/dist/resources/skills/userinterface-wiki/rules/envelope-exponential-decay.md +0 -21
  165. package/dist/resources/skills/userinterface-wiki/rules/envelope-no-zero-target.md +0 -21
  166. package/dist/resources/skills/userinterface-wiki/rules/envelope-set-initial-value.md +0 -22
  167. package/dist/resources/skills/userinterface-wiki/rules/exit-key-required.md +0 -29
  168. package/dist/resources/skills/userinterface-wiki/rules/exit-matches-initial.md +0 -29
  169. package/dist/resources/skills/userinterface-wiki/rules/exit-prop-required.md +0 -33
  170. package/dist/resources/skills/userinterface-wiki/rules/exit-requires-wrapper.md +0 -27
  171. package/dist/resources/skills/userinterface-wiki/rules/impl-default-subtle.md +0 -21
  172. package/dist/resources/skills/userinterface-wiki/rules/impl-preload-audio.md +0 -34
  173. package/dist/resources/skills/userinterface-wiki/rules/impl-reset-current-time.md +0 -26
  174. package/dist/resources/skills/userinterface-wiki/rules/mode-pop-layout-for-lists.md +0 -25
  175. package/dist/resources/skills/userinterface-wiki/rules/mode-sync-layout-conflict.md +0 -29
  176. package/dist/resources/skills/userinterface-wiki/rules/mode-wait-doubles-duration.md +0 -25
  177. package/dist/resources/skills/userinterface-wiki/rules/morphing-aria-hidden.md +0 -21
  178. package/dist/resources/skills/userinterface-wiki/rules/morphing-consistent-viewbox.md +0 -23
  179. package/dist/resources/skills/userinterface-wiki/rules/morphing-group-variants.md +0 -33
  180. package/dist/resources/skills/userinterface-wiki/rules/morphing-jump-non-grouped.md +0 -29
  181. package/dist/resources/skills/userinterface-wiki/rules/morphing-reduced-motion.md +0 -28
  182. package/dist/resources/skills/userinterface-wiki/rules/morphing-spring-rotation.md +0 -23
  183. package/dist/resources/skills/userinterface-wiki/rules/morphing-strokelinecap-round.md +0 -21
  184. package/dist/resources/skills/userinterface-wiki/rules/morphing-three-lines.md +0 -32
  185. package/dist/resources/skills/userinterface-wiki/rules/morphing-use-collapsed.md +0 -33
  186. package/dist/resources/skills/userinterface-wiki/rules/native-backdrop-styling.md +0 -27
  187. package/dist/resources/skills/userinterface-wiki/rules/native-placeholder-styling.md +0 -27
  188. package/dist/resources/skills/userinterface-wiki/rules/native-selection-styling.md +0 -18
  189. package/dist/resources/skills/userinterface-wiki/rules/nested-consistent-timing.md +0 -25
  190. package/dist/resources/skills/userinterface-wiki/rules/nested-propagate-required.md +0 -41
  191. package/dist/resources/skills/userinterface-wiki/rules/none-context-menu-entrance.md +0 -25
  192. package/dist/resources/skills/userinterface-wiki/rules/none-high-frequency.md +0 -29
  193. package/dist/resources/skills/userinterface-wiki/rules/none-keyboard-navigation.md +0 -32
  194. package/dist/resources/skills/userinterface-wiki/rules/param-click-duration.md +0 -21
  195. package/dist/resources/skills/userinterface-wiki/rules/param-filter-frequency-range.md +0 -21
  196. package/dist/resources/skills/userinterface-wiki/rules/param-q-value-range.md +0 -21
  197. package/dist/resources/skills/userinterface-wiki/rules/param-reasonable-gain.md +0 -21
  198. package/dist/resources/skills/userinterface-wiki/rules/physics-active-state.md +0 -23
  199. package/dist/resources/skills/userinterface-wiki/rules/physics-no-excessive-stagger.md +0 -22
  200. package/dist/resources/skills/userinterface-wiki/rules/physics-spring-for-overshoot.md +0 -23
  201. package/dist/resources/skills/userinterface-wiki/rules/physics-subtle-deformation.md +0 -22
  202. package/dist/resources/skills/userinterface-wiki/rules/prefetch-hit-slop.md +0 -27
  203. package/dist/resources/skills/userinterface-wiki/rules/prefetch-keyboard-tab.md +0 -19
  204. package/dist/resources/skills/userinterface-wiki/rules/prefetch-not-everything.md +0 -22
  205. package/dist/resources/skills/userinterface-wiki/rules/prefetch-touch-fallback.md +0 -34
  206. package/dist/resources/skills/userinterface-wiki/rules/prefetch-trajectory-over-hover.md +0 -32
  207. package/dist/resources/skills/userinterface-wiki/rules/prefetch-use-selectively.md +0 -13
  208. package/dist/resources/skills/userinterface-wiki/rules/presence-disable-interactions.md +0 -31
  209. package/dist/resources/skills/userinterface-wiki/rules/presence-hook-in-child.md +0 -31
  210. package/dist/resources/skills/userinterface-wiki/rules/presence-safe-to-remove.md +0 -37
  211. package/dist/resources/skills/userinterface-wiki/rules/pseudo-content-required.md +0 -28
  212. package/dist/resources/skills/userinterface-wiki/rules/pseudo-first-line-styling.md +0 -27
  213. package/dist/resources/skills/userinterface-wiki/rules/pseudo-hit-target-expansion.md +0 -31
  214. package/dist/resources/skills/userinterface-wiki/rules/pseudo-marker-styling.md +0 -28
  215. package/dist/resources/skills/userinterface-wiki/rules/pseudo-over-dom-node.md +0 -32
  216. package/dist/resources/skills/userinterface-wiki/rules/pseudo-position-relative-parent.md +0 -33
  217. package/dist/resources/skills/userinterface-wiki/rules/pseudo-z-index-layering.md +0 -37
  218. package/dist/resources/skills/userinterface-wiki/rules/spring-for-gestures.md +0 -27
  219. package/dist/resources/skills/userinterface-wiki/rules/spring-for-interruptible.md +0 -27
  220. package/dist/resources/skills/userinterface-wiki/rules/spring-params-balanced.md +0 -29
  221. package/dist/resources/skills/userinterface-wiki/rules/spring-preserves-velocity.md +0 -28
  222. package/dist/resources/skills/userinterface-wiki/rules/staging-dim-background.md +0 -22
  223. package/dist/resources/skills/userinterface-wiki/rules/staging-one-focal-point.md +0 -24
  224. package/dist/resources/skills/userinterface-wiki/rules/staging-z-index-hierarchy.md +0 -22
  225. package/dist/resources/skills/userinterface-wiki/rules/timing-consistent.md +0 -24
  226. package/dist/resources/skills/userinterface-wiki/rules/timing-no-entrance-context-menu.md +0 -22
  227. package/dist/resources/skills/userinterface-wiki/rules/timing-under-300ms.md +0 -22
  228. package/dist/resources/skills/userinterface-wiki/rules/transition-name-cleanup.md +0 -28
  229. package/dist/resources/skills/userinterface-wiki/rules/transition-name-required.md +0 -27
  230. package/dist/resources/skills/userinterface-wiki/rules/transition-name-unique.md +0 -24
  231. package/dist/resources/skills/userinterface-wiki/rules/transition-over-js-library.md +0 -32
  232. package/dist/resources/skills/userinterface-wiki/rules/transition-style-pseudo-elements.md +0 -24
  233. package/dist/resources/skills/userinterface-wiki/rules/type-antialiased-on-retina.md +0 -18
  234. package/dist/resources/skills/userinterface-wiki/rules/type-disambiguation-stylistic-set.md +0 -15
  235. package/dist/resources/skills/userinterface-wiki/rules/type-font-display-swap.md +0 -28
  236. package/dist/resources/skills/userinterface-wiki/rules/type-justify-with-hyphens.md +0 -24
  237. package/dist/resources/skills/userinterface-wiki/rules/type-letter-spacing-uppercase.md +0 -28
  238. package/dist/resources/skills/userinterface-wiki/rules/type-no-font-synthesis.md +0 -18
  239. package/dist/resources/skills/userinterface-wiki/rules/type-oldstyle-nums-for-prose.md +0 -21
  240. package/dist/resources/skills/userinterface-wiki/rules/type-opentype-contextual-alternates.md +0 -15
  241. package/dist/resources/skills/userinterface-wiki/rules/type-optical-sizing-auto.md +0 -25
  242. package/dist/resources/skills/userinterface-wiki/rules/type-proper-fractions.md +0 -15
  243. package/dist/resources/skills/userinterface-wiki/rules/type-slashed-zero.md +0 -17
  244. package/dist/resources/skills/userinterface-wiki/rules/type-tabular-nums-for-data.md +0 -21
  245. package/dist/resources/skills/userinterface-wiki/rules/type-text-wrap-balance-headings.md +0 -21
  246. package/dist/resources/skills/userinterface-wiki/rules/type-text-wrap-pretty.md +0 -16
  247. package/dist/resources/skills/userinterface-wiki/rules/type-underline-offset.md +0 -25
  248. package/dist/resources/skills/userinterface-wiki/rules/type-variable-weight-continuous.md +0 -23
  249. package/dist/resources/skills/userinterface-wiki/rules/ux-aesthetic-usability.md +0 -32
  250. package/dist/resources/skills/userinterface-wiki/rules/ux-cognitive-load-reduce.md +0 -49
  251. package/dist/resources/skills/userinterface-wiki/rules/ux-common-region-boundaries.md +0 -50
  252. package/dist/resources/skills/userinterface-wiki/rules/ux-doherty-perceived-speed.md +0 -29
  253. package/dist/resources/skills/userinterface-wiki/rules/ux-doherty-under-400ms.md +0 -30
  254. package/dist/resources/skills/userinterface-wiki/rules/ux-fitts-hit-area.md +0 -32
  255. package/dist/resources/skills/userinterface-wiki/rules/ux-fitts-target-size.md +0 -31
  256. package/dist/resources/skills/userinterface-wiki/rules/ux-goal-gradient-progress.md +0 -33
  257. package/dist/resources/skills/userinterface-wiki/rules/ux-hicks-minimize-choices.md +0 -45
  258. package/dist/resources/skills/userinterface-wiki/rules/ux-jakobs-familiar-patterns.md +0 -37
  259. package/dist/resources/skills/userinterface-wiki/rules/ux-millers-chunking.md +0 -23
  260. package/dist/resources/skills/userinterface-wiki/rules/ux-pareto-prioritize-features.md +0 -36
  261. package/dist/resources/skills/userinterface-wiki/rules/ux-peak-end-finish-strong.md +0 -35
  262. package/dist/resources/skills/userinterface-wiki/rules/ux-postels-accept-messy-input.md +0 -45
  263. package/dist/resources/skills/userinterface-wiki/rules/ux-pragnanz-simplify.md +0 -33
  264. package/dist/resources/skills/userinterface-wiki/rules/ux-progressive-disclosure.md +0 -41
  265. package/dist/resources/skills/userinterface-wiki/rules/ux-proximity-grouping.md +0 -38
  266. package/dist/resources/skills/userinterface-wiki/rules/ux-serial-position.md +0 -31
  267. package/dist/resources/skills/userinterface-wiki/rules/ux-similarity-consistency.md +0 -35
  268. package/dist/resources/skills/userinterface-wiki/rules/ux-teslers-complexity.md +0 -28
  269. package/dist/resources/skills/userinterface-wiki/rules/ux-uniform-connectedness.md +0 -43
  270. package/dist/resources/skills/userinterface-wiki/rules/ux-von-restorff-emphasis.md +0 -29
  271. package/dist/resources/skills/userinterface-wiki/rules/ux-zeigarnik-show-incomplete.md +0 -36
  272. package/dist/resources/skills/userinterface-wiki/rules/visual-animate-shadow-pseudo.md +0 -49
  273. package/dist/resources/skills/userinterface-wiki/rules/visual-border-alpha-colors.md +0 -25
  274. package/dist/resources/skills/userinterface-wiki/rules/visual-button-shadow-anatomy.md +0 -49
  275. package/dist/resources/skills/userinterface-wiki/rules/visual-concentric-radius.md +0 -40
  276. package/dist/resources/skills/userinterface-wiki/rules/visual-consistent-spacing-scale.md +0 -35
  277. package/dist/resources/skills/userinterface-wiki/rules/visual-layered-shadows.md +0 -30
  278. package/dist/resources/skills/userinterface-wiki/rules/visual-no-pure-black-shadow.md +0 -25
  279. package/dist/resources/skills/userinterface-wiki/rules/visual-shadow-direction.md +0 -25
  280. package/dist/resources/skills/userinterface-wiki/rules/visual-shadow-matches-elevation.md +0 -23
  281. package/dist/resources/skills/userinterface-wiki/rules/weight-duration-matches-action.md +0 -29
  282. package/dist/resources/skills/userinterface-wiki/rules/weight-match-action.md +0 -32
  283. package/dist/resources/skills/web-design-guidelines/SKILL.md +0 -39
  284. package/dist/resources/skills/web-quality-audit/SKILL.md +0 -168
  285. package/dist/resources/skills/web-quality-audit/scripts/analyze.sh +0 -91
  286. package/src/resources/agents/javascript-pro.md +0 -280
  287. package/src/resources/agents/researcher.md +0 -29
  288. package/src/resources/agents/teams-builder.md +0 -74
  289. package/src/resources/agents/teams-reviewer.md +0 -113
  290. package/src/resources/agents/typescript-pro.md +0 -255
  291. package/src/resources/skills/accessibility/SKILL.md +0 -522
  292. package/src/resources/skills/accessibility/references/WCAG.md +0 -162
  293. package/src/resources/skills/core-web-vitals/SKILL.md +0 -441
  294. package/src/resources/skills/core-web-vitals/references/LCP.md +0 -208
  295. package/src/resources/skills/frontend-design/SKILL.md +0 -45
  296. package/src/resources/skills/make-interfaces-feel-better/SKILL.md +0 -122
  297. package/src/resources/skills/make-interfaces-feel-better/animations.md +0 -379
  298. package/src/resources/skills/make-interfaces-feel-better/performance.md +0 -88
  299. package/src/resources/skills/make-interfaces-feel-better/surfaces.md +0 -247
  300. package/src/resources/skills/make-interfaces-feel-better/typography.md +0 -123
  301. package/src/resources/skills/react-best-practices/README.md +0 -123
  302. package/src/resources/skills/react-best-practices/SKILL.md +0 -136
  303. package/src/resources/skills/react-best-practices/metadata.json +0 -15
  304. package/src/resources/skills/react-best-practices/rules/_sections.md +0 -46
  305. package/src/resources/skills/react-best-practices/rules/_template.md +0 -28
  306. package/src/resources/skills/react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  307. package/src/resources/skills/react-best-practices/rules/advanced-init-once.md +0 -42
  308. package/src/resources/skills/react-best-practices/rules/advanced-use-latest.md +0 -39
  309. package/src/resources/skills/react-best-practices/rules/async-api-routes.md +0 -38
  310. package/src/resources/skills/react-best-practices/rules/async-defer-await.md +0 -80
  311. package/src/resources/skills/react-best-practices/rules/async-dependencies.md +0 -51
  312. package/src/resources/skills/react-best-practices/rules/async-parallel.md +0 -28
  313. package/src/resources/skills/react-best-practices/rules/async-suspense-boundaries.md +0 -99
  314. package/src/resources/skills/react-best-practices/rules/bundle-barrel-imports.md +0 -59
  315. package/src/resources/skills/react-best-practices/rules/bundle-conditional.md +0 -31
  316. package/src/resources/skills/react-best-practices/rules/bundle-defer-third-party.md +0 -49
  317. package/src/resources/skills/react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  318. package/src/resources/skills/react-best-practices/rules/bundle-preload.md +0 -50
  319. package/src/resources/skills/react-best-practices/rules/client-event-listeners.md +0 -74
  320. package/src/resources/skills/react-best-practices/rules/client-localstorage-schema.md +0 -71
  321. package/src/resources/skills/react-best-practices/rules/client-passive-event-listeners.md +0 -48
  322. package/src/resources/skills/react-best-practices/rules/client-swr-dedup.md +0 -56
  323. package/src/resources/skills/react-best-practices/rules/js-batch-dom-css.md +0 -107
  324. package/src/resources/skills/react-best-practices/rules/js-cache-function-results.md +0 -80
  325. package/src/resources/skills/react-best-practices/rules/js-cache-property-access.md +0 -28
  326. package/src/resources/skills/react-best-practices/rules/js-cache-storage.md +0 -70
  327. package/src/resources/skills/react-best-practices/rules/js-combine-iterations.md +0 -32
  328. package/src/resources/skills/react-best-practices/rules/js-early-exit.md +0 -50
  329. package/src/resources/skills/react-best-practices/rules/js-hoist-regexp.md +0 -45
  330. package/src/resources/skills/react-best-practices/rules/js-index-maps.md +0 -37
  331. package/src/resources/skills/react-best-practices/rules/js-length-check-first.md +0 -49
  332. package/src/resources/skills/react-best-practices/rules/js-min-max-loop.md +0 -82
  333. package/src/resources/skills/react-best-practices/rules/js-set-map-lookups.md +0 -24
  334. package/src/resources/skills/react-best-practices/rules/js-tosorted-immutable.md +0 -57
  335. package/src/resources/skills/react-best-practices/rules/rendering-activity.md +0 -26
  336. package/src/resources/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  337. package/src/resources/skills/react-best-practices/rules/rendering-conditional-render.md +0 -40
  338. package/src/resources/skills/react-best-practices/rules/rendering-content-visibility.md +0 -38
  339. package/src/resources/skills/react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  340. package/src/resources/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  341. package/src/resources/skills/react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  342. package/src/resources/skills/react-best-practices/rules/rendering-svg-precision.md +0 -28
  343. package/src/resources/skills/react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  344. package/src/resources/skills/react-best-practices/rules/rerender-defer-reads.md +0 -39
  345. package/src/resources/skills/react-best-practices/rules/rerender-dependencies.md +0 -45
  346. package/src/resources/skills/react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  347. package/src/resources/skills/react-best-practices/rules/rerender-derived-state.md +0 -29
  348. package/src/resources/skills/react-best-practices/rules/rerender-functional-setstate.md +0 -74
  349. package/src/resources/skills/react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  350. package/src/resources/skills/react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  351. package/src/resources/skills/react-best-practices/rules/rerender-memo.md +0 -44
  352. package/src/resources/skills/react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  353. package/src/resources/skills/react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  354. package/src/resources/skills/react-best-practices/rules/rerender-transitions.md +0 -40
  355. package/src/resources/skills/react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  356. package/src/resources/skills/react-best-practices/rules/server-after-nonblocking.md +0 -73
  357. package/src/resources/skills/react-best-practices/rules/server-auth-actions.md +0 -96
  358. package/src/resources/skills/react-best-practices/rules/server-cache-lru.md +0 -41
  359. package/src/resources/skills/react-best-practices/rules/server-cache-react.md +0 -76
  360. package/src/resources/skills/react-best-practices/rules/server-dedup-props.md +0 -65
  361. package/src/resources/skills/react-best-practices/rules/server-parallel-fetching.md +0 -83
  362. package/src/resources/skills/react-best-practices/rules/server-serialization.md +0 -38
  363. package/src/resources/skills/userinterface-wiki/SKILL.md +0 -253
  364. package/src/resources/skills/userinterface-wiki/rules/_sections.md +0 -66
  365. package/src/resources/skills/userinterface-wiki/rules/_template.md +0 -24
  366. package/src/resources/skills/userinterface-wiki/rules/a11y-reduced-motion-check.md +0 -30
  367. package/src/resources/skills/userinterface-wiki/rules/a11y-toggle-setting.md +0 -30
  368. package/src/resources/skills/userinterface-wiki/rules/a11y-visual-equivalent.md +0 -36
  369. package/src/resources/skills/userinterface-wiki/rules/a11y-volume-control.md +0 -28
  370. package/src/resources/skills/userinterface-wiki/rules/appropriate-confirmations-only.md +0 -19
  371. package/src/resources/skills/userinterface-wiki/rules/appropriate-errors-warnings.md +0 -18
  372. package/src/resources/skills/userinterface-wiki/rules/appropriate-no-decorative.md +0 -21
  373. package/src/resources/skills/userinterface-wiki/rules/appropriate-no-high-frequency.md +0 -28
  374. package/src/resources/skills/userinterface-wiki/rules/appropriate-no-punishing.md +0 -27
  375. package/src/resources/skills/userinterface-wiki/rules/container-callback-ref.md +0 -31
  376. package/src/resources/skills/userinterface-wiki/rules/container-guard-initial-zero.md +0 -25
  377. package/src/resources/skills/userinterface-wiki/rules/container-no-excessive-use.md +0 -13
  378. package/src/resources/skills/userinterface-wiki/rules/container-overflow-hidden.md +0 -25
  379. package/src/resources/skills/userinterface-wiki/rules/container-transition-delay.md +0 -21
  380. package/src/resources/skills/userinterface-wiki/rules/container-two-div-pattern.md +0 -35
  381. package/src/resources/skills/userinterface-wiki/rules/container-use-resize-observer.md +0 -48
  382. package/src/resources/skills/userinterface-wiki/rules/context-cleanup-nodes.md +0 -25
  383. package/src/resources/skills/userinterface-wiki/rules/context-resume-suspended.md +0 -28
  384. package/src/resources/skills/userinterface-wiki/rules/context-reuse-single.md +0 -30
  385. package/src/resources/skills/userinterface-wiki/rules/design-filter-for-character.md +0 -25
  386. package/src/resources/skills/userinterface-wiki/rules/design-noise-for-percussion.md +0 -26
  387. package/src/resources/skills/userinterface-wiki/rules/design-oscillator-for-tonal.md +0 -22
  388. package/src/resources/skills/userinterface-wiki/rules/duration-max-300ms.md +0 -21
  389. package/src/resources/skills/userinterface-wiki/rules/duration-press-hover.md +0 -21
  390. package/src/resources/skills/userinterface-wiki/rules/duration-shorten-before-curve.md +0 -21
  391. package/src/resources/skills/userinterface-wiki/rules/duration-small-state.md +0 -15
  392. package/src/resources/skills/userinterface-wiki/rules/easing-entrance-ease-out.md +0 -21
  393. package/src/resources/skills/userinterface-wiki/rules/easing-exit-ease-in.md +0 -21
  394. package/src/resources/skills/userinterface-wiki/rules/easing-for-state-change.md +0 -27
  395. package/src/resources/skills/userinterface-wiki/rules/easing-linear-only-progress.md +0 -21
  396. package/src/resources/skills/userinterface-wiki/rules/easing-natural-decay.md +0 -22
  397. package/src/resources/skills/userinterface-wiki/rules/easing-no-linear-motion.md +0 -22
  398. package/src/resources/skills/userinterface-wiki/rules/easing-transition-ease-in-out.md +0 -15
  399. package/src/resources/skills/userinterface-wiki/rules/envelope-exponential-decay.md +0 -21
  400. package/src/resources/skills/userinterface-wiki/rules/envelope-no-zero-target.md +0 -21
  401. package/src/resources/skills/userinterface-wiki/rules/envelope-set-initial-value.md +0 -22
  402. package/src/resources/skills/userinterface-wiki/rules/exit-key-required.md +0 -29
  403. package/src/resources/skills/userinterface-wiki/rules/exit-matches-initial.md +0 -29
  404. package/src/resources/skills/userinterface-wiki/rules/exit-prop-required.md +0 -33
  405. package/src/resources/skills/userinterface-wiki/rules/exit-requires-wrapper.md +0 -27
  406. package/src/resources/skills/userinterface-wiki/rules/impl-default-subtle.md +0 -21
  407. package/src/resources/skills/userinterface-wiki/rules/impl-preload-audio.md +0 -34
  408. package/src/resources/skills/userinterface-wiki/rules/impl-reset-current-time.md +0 -26
  409. package/src/resources/skills/userinterface-wiki/rules/mode-pop-layout-for-lists.md +0 -25
  410. package/src/resources/skills/userinterface-wiki/rules/mode-sync-layout-conflict.md +0 -29
  411. package/src/resources/skills/userinterface-wiki/rules/mode-wait-doubles-duration.md +0 -25
  412. package/src/resources/skills/userinterface-wiki/rules/morphing-aria-hidden.md +0 -21
  413. package/src/resources/skills/userinterface-wiki/rules/morphing-consistent-viewbox.md +0 -23
  414. package/src/resources/skills/userinterface-wiki/rules/morphing-group-variants.md +0 -33
  415. package/src/resources/skills/userinterface-wiki/rules/morphing-jump-non-grouped.md +0 -29
  416. package/src/resources/skills/userinterface-wiki/rules/morphing-reduced-motion.md +0 -28
  417. package/src/resources/skills/userinterface-wiki/rules/morphing-spring-rotation.md +0 -23
  418. package/src/resources/skills/userinterface-wiki/rules/morphing-strokelinecap-round.md +0 -21
  419. package/src/resources/skills/userinterface-wiki/rules/morphing-three-lines.md +0 -32
  420. package/src/resources/skills/userinterface-wiki/rules/morphing-use-collapsed.md +0 -33
  421. package/src/resources/skills/userinterface-wiki/rules/native-backdrop-styling.md +0 -27
  422. package/src/resources/skills/userinterface-wiki/rules/native-placeholder-styling.md +0 -27
  423. package/src/resources/skills/userinterface-wiki/rules/native-selection-styling.md +0 -18
  424. package/src/resources/skills/userinterface-wiki/rules/nested-consistent-timing.md +0 -25
  425. package/src/resources/skills/userinterface-wiki/rules/nested-propagate-required.md +0 -41
  426. package/src/resources/skills/userinterface-wiki/rules/none-context-menu-entrance.md +0 -25
  427. package/src/resources/skills/userinterface-wiki/rules/none-high-frequency.md +0 -29
  428. package/src/resources/skills/userinterface-wiki/rules/none-keyboard-navigation.md +0 -32
  429. package/src/resources/skills/userinterface-wiki/rules/param-click-duration.md +0 -21
  430. package/src/resources/skills/userinterface-wiki/rules/param-filter-frequency-range.md +0 -21
  431. package/src/resources/skills/userinterface-wiki/rules/param-q-value-range.md +0 -21
  432. package/src/resources/skills/userinterface-wiki/rules/param-reasonable-gain.md +0 -21
  433. package/src/resources/skills/userinterface-wiki/rules/physics-active-state.md +0 -23
  434. package/src/resources/skills/userinterface-wiki/rules/physics-no-excessive-stagger.md +0 -22
  435. package/src/resources/skills/userinterface-wiki/rules/physics-spring-for-overshoot.md +0 -23
  436. package/src/resources/skills/userinterface-wiki/rules/physics-subtle-deformation.md +0 -22
  437. package/src/resources/skills/userinterface-wiki/rules/prefetch-hit-slop.md +0 -27
  438. package/src/resources/skills/userinterface-wiki/rules/prefetch-keyboard-tab.md +0 -19
  439. package/src/resources/skills/userinterface-wiki/rules/prefetch-not-everything.md +0 -22
  440. package/src/resources/skills/userinterface-wiki/rules/prefetch-touch-fallback.md +0 -34
  441. package/src/resources/skills/userinterface-wiki/rules/prefetch-trajectory-over-hover.md +0 -32
  442. package/src/resources/skills/userinterface-wiki/rules/prefetch-use-selectively.md +0 -13
  443. package/src/resources/skills/userinterface-wiki/rules/presence-disable-interactions.md +0 -31
  444. package/src/resources/skills/userinterface-wiki/rules/presence-hook-in-child.md +0 -31
  445. package/src/resources/skills/userinterface-wiki/rules/presence-safe-to-remove.md +0 -37
  446. package/src/resources/skills/userinterface-wiki/rules/pseudo-content-required.md +0 -28
  447. package/src/resources/skills/userinterface-wiki/rules/pseudo-first-line-styling.md +0 -27
  448. package/src/resources/skills/userinterface-wiki/rules/pseudo-hit-target-expansion.md +0 -31
  449. package/src/resources/skills/userinterface-wiki/rules/pseudo-marker-styling.md +0 -28
  450. package/src/resources/skills/userinterface-wiki/rules/pseudo-over-dom-node.md +0 -32
  451. package/src/resources/skills/userinterface-wiki/rules/pseudo-position-relative-parent.md +0 -33
  452. package/src/resources/skills/userinterface-wiki/rules/pseudo-z-index-layering.md +0 -37
  453. package/src/resources/skills/userinterface-wiki/rules/spring-for-gestures.md +0 -27
  454. package/src/resources/skills/userinterface-wiki/rules/spring-for-interruptible.md +0 -27
  455. package/src/resources/skills/userinterface-wiki/rules/spring-params-balanced.md +0 -29
  456. package/src/resources/skills/userinterface-wiki/rules/spring-preserves-velocity.md +0 -28
  457. package/src/resources/skills/userinterface-wiki/rules/staging-dim-background.md +0 -22
  458. package/src/resources/skills/userinterface-wiki/rules/staging-one-focal-point.md +0 -24
  459. package/src/resources/skills/userinterface-wiki/rules/staging-z-index-hierarchy.md +0 -22
  460. package/src/resources/skills/userinterface-wiki/rules/timing-consistent.md +0 -24
  461. package/src/resources/skills/userinterface-wiki/rules/timing-no-entrance-context-menu.md +0 -22
  462. package/src/resources/skills/userinterface-wiki/rules/timing-under-300ms.md +0 -22
  463. package/src/resources/skills/userinterface-wiki/rules/transition-name-cleanup.md +0 -28
  464. package/src/resources/skills/userinterface-wiki/rules/transition-name-required.md +0 -27
  465. package/src/resources/skills/userinterface-wiki/rules/transition-name-unique.md +0 -24
  466. package/src/resources/skills/userinterface-wiki/rules/transition-over-js-library.md +0 -32
  467. package/src/resources/skills/userinterface-wiki/rules/transition-style-pseudo-elements.md +0 -24
  468. package/src/resources/skills/userinterface-wiki/rules/type-antialiased-on-retina.md +0 -18
  469. package/src/resources/skills/userinterface-wiki/rules/type-disambiguation-stylistic-set.md +0 -15
  470. package/src/resources/skills/userinterface-wiki/rules/type-font-display-swap.md +0 -28
  471. package/src/resources/skills/userinterface-wiki/rules/type-justify-with-hyphens.md +0 -24
  472. package/src/resources/skills/userinterface-wiki/rules/type-letter-spacing-uppercase.md +0 -28
  473. package/src/resources/skills/userinterface-wiki/rules/type-no-font-synthesis.md +0 -18
  474. package/src/resources/skills/userinterface-wiki/rules/type-oldstyle-nums-for-prose.md +0 -21
  475. package/src/resources/skills/userinterface-wiki/rules/type-opentype-contextual-alternates.md +0 -15
  476. package/src/resources/skills/userinterface-wiki/rules/type-optical-sizing-auto.md +0 -25
  477. package/src/resources/skills/userinterface-wiki/rules/type-proper-fractions.md +0 -15
  478. package/src/resources/skills/userinterface-wiki/rules/type-slashed-zero.md +0 -17
  479. package/src/resources/skills/userinterface-wiki/rules/type-tabular-nums-for-data.md +0 -21
  480. package/src/resources/skills/userinterface-wiki/rules/type-text-wrap-balance-headings.md +0 -21
  481. package/src/resources/skills/userinterface-wiki/rules/type-text-wrap-pretty.md +0 -16
  482. package/src/resources/skills/userinterface-wiki/rules/type-underline-offset.md +0 -25
  483. package/src/resources/skills/userinterface-wiki/rules/type-variable-weight-continuous.md +0 -23
  484. package/src/resources/skills/userinterface-wiki/rules/ux-aesthetic-usability.md +0 -32
  485. package/src/resources/skills/userinterface-wiki/rules/ux-cognitive-load-reduce.md +0 -49
  486. package/src/resources/skills/userinterface-wiki/rules/ux-common-region-boundaries.md +0 -50
  487. package/src/resources/skills/userinterface-wiki/rules/ux-doherty-perceived-speed.md +0 -29
  488. package/src/resources/skills/userinterface-wiki/rules/ux-doherty-under-400ms.md +0 -30
  489. package/src/resources/skills/userinterface-wiki/rules/ux-fitts-hit-area.md +0 -32
  490. package/src/resources/skills/userinterface-wiki/rules/ux-fitts-target-size.md +0 -31
  491. package/src/resources/skills/userinterface-wiki/rules/ux-goal-gradient-progress.md +0 -33
  492. package/src/resources/skills/userinterface-wiki/rules/ux-hicks-minimize-choices.md +0 -45
  493. package/src/resources/skills/userinterface-wiki/rules/ux-jakobs-familiar-patterns.md +0 -37
  494. package/src/resources/skills/userinterface-wiki/rules/ux-millers-chunking.md +0 -23
  495. package/src/resources/skills/userinterface-wiki/rules/ux-pareto-prioritize-features.md +0 -36
  496. package/src/resources/skills/userinterface-wiki/rules/ux-peak-end-finish-strong.md +0 -35
  497. package/src/resources/skills/userinterface-wiki/rules/ux-postels-accept-messy-input.md +0 -45
  498. package/src/resources/skills/userinterface-wiki/rules/ux-pragnanz-simplify.md +0 -33
  499. package/src/resources/skills/userinterface-wiki/rules/ux-progressive-disclosure.md +0 -41
  500. package/src/resources/skills/userinterface-wiki/rules/ux-proximity-grouping.md +0 -38
  501. package/src/resources/skills/userinterface-wiki/rules/ux-serial-position.md +0 -31
  502. package/src/resources/skills/userinterface-wiki/rules/ux-similarity-consistency.md +0 -35
  503. package/src/resources/skills/userinterface-wiki/rules/ux-teslers-complexity.md +0 -28
  504. package/src/resources/skills/userinterface-wiki/rules/ux-uniform-connectedness.md +0 -43
  505. package/src/resources/skills/userinterface-wiki/rules/ux-von-restorff-emphasis.md +0 -29
  506. package/src/resources/skills/userinterface-wiki/rules/ux-zeigarnik-show-incomplete.md +0 -36
  507. package/src/resources/skills/userinterface-wiki/rules/visual-animate-shadow-pseudo.md +0 -49
  508. package/src/resources/skills/userinterface-wiki/rules/visual-border-alpha-colors.md +0 -25
  509. package/src/resources/skills/userinterface-wiki/rules/visual-button-shadow-anatomy.md +0 -49
  510. package/src/resources/skills/userinterface-wiki/rules/visual-concentric-radius.md +0 -40
  511. package/src/resources/skills/userinterface-wiki/rules/visual-consistent-spacing-scale.md +0 -35
  512. package/src/resources/skills/userinterface-wiki/rules/visual-layered-shadows.md +0 -30
  513. package/src/resources/skills/userinterface-wiki/rules/visual-no-pure-black-shadow.md +0 -25
  514. package/src/resources/skills/userinterface-wiki/rules/visual-shadow-direction.md +0 -25
  515. package/src/resources/skills/userinterface-wiki/rules/visual-shadow-matches-elevation.md +0 -23
  516. package/src/resources/skills/userinterface-wiki/rules/weight-duration-matches-action.md +0 -29
  517. package/src/resources/skills/userinterface-wiki/rules/weight-match-action.md +0 -32
  518. package/src/resources/skills/web-design-guidelines/SKILL.md +0 -39
  519. package/src/resources/skills/web-quality-audit/SKILL.md +0 -168
  520. package/src/resources/skills/web-quality-audit/scripts/analyze.sh +0 -91
@@ -1,122 +0,0 @@
1
- ---
2
- name: make-interfaces-feel-better
3
- description: Design engineering principles for making interfaces feel polished. Use when building UI components, reviewing frontend code, implementing animations, hover states, shadows, borders, typography, micro-interactions, enter/exit animations, or any visual detail work. Triggers on UI polish, design details, "make it feel better", "feels off", stagger animations, border radius, optical alignment, font smoothing, tabular numbers, image outlines, box shadows.
4
- ---
5
-
6
- # Details that make interfaces feel better
7
-
8
- Great interfaces rarely come from a single thing. It's usually a collection of small details that compound into a great experience. Apply these principles when building or reviewing UI code.
9
-
10
- ## Quick Reference
11
-
12
- | Category | When to Use |
13
- | --- | --- |
14
- | [Typography](typography.md) | Text wrapping, font smoothing, tabular numbers |
15
- | [Surfaces](surfaces.md) | Border radius, optical alignment, shadows, image outlines, hit areas |
16
- | [Animations](animations.md) | Interruptible animations, enter/exit transitions, icon animations, scale on press |
17
- | [Performance](performance.md) | Transition specificity, `will-change` usage |
18
-
19
- ## Core Principles
20
-
21
- ### 1. Concentric Border Radius
22
-
23
- Outer radius = inner radius + padding. Mismatched radii on nested elements is the most common thing that makes interfaces feel off.
24
-
25
- ### 2. Optical Over Geometric Alignment
26
-
27
- When geometric centering looks off, align optically. Buttons with icons, play triangles, and asymmetric icons all need manual adjustment.
28
-
29
- ### 3. Shadows Over Borders
30
-
31
- Layer multiple transparent `box-shadow` values for natural depth. Shadows adapt to any background; solid borders don't.
32
-
33
- ### 4. Interruptible Animations
34
-
35
- Use CSS transitions for interactive state changes — they can be interrupted mid-animation. Reserve keyframes for staged sequences that run once.
36
-
37
- ### 5. Split and Stagger Enter Animations
38
-
39
- Don't animate a single container. Break content into semantic chunks and stagger each with ~100ms delay.
40
-
41
- ### 6. Subtle Exit Animations
42
-
43
- Use a small fixed `translateY` instead of full height. Exits should be softer than enters.
44
-
45
- ### 7. Contextual Icon Animations
46
-
47
- Animate icons with `opacity`, `scale`, and `blur` instead of toggling visibility. Use exactly these values: scale from `0.25` to `1`, opacity from `0` to `1`, blur from `4px` to `0px`. If the project has `motion` or `framer-motion` in `package.json`, use `transition: { type: "spring", duration: 0.3, bounce: 0 }` — bounce must always be `0`. If no motion library is installed, keep both icons in the DOM (one absolute-positioned) and cross-fade with CSS transitions using `cubic-bezier(0.2, 0, 0, 1)` — this gives both enter and exit animations without any dependency.
48
-
49
- ### 8. Font Smoothing
50
-
51
- Apply `-webkit-font-smoothing: antialiased` to the root layout on macOS for crisper text.
52
-
53
- ### 9. Tabular Numbers
54
-
55
- Use `font-variant-numeric: tabular-nums` for any dynamically updating numbers to prevent layout shift.
56
-
57
- ### 10. Text Wrapping
58
-
59
- Use `text-wrap: balance` on headings. Use `text-wrap: pretty` for body text to avoid orphans.
60
-
61
- ### 11. Image Outlines
62
-
63
- Add a subtle `1px` outline with low opacity to images for consistent depth.
64
-
65
- ### 12. Scale on Press
66
-
67
- A subtle `scale(0.96)` on click gives buttons tactile feedback. Always use `0.96`. Never use a value smaller than `0.95` — anything below feels exaggerated. Add a `static` prop to disable it when motion would be distracting.
68
-
69
- ### 13. Skip Animation on Page Load
70
-
71
- Use `initial={false}` on `AnimatePresence` to prevent enter animations on first render. Verify it doesn't break intentional entrance animations.
72
-
73
- ### 14. Never Use `transition: all`
74
-
75
- Always specify exact properties: `transition-property: scale, opacity`. Tailwind's `transition-transform` covers `transform, translate, scale, rotate`.
76
-
77
- ### 15. Use `will-change` Sparingly
78
-
79
- Only for `transform`, `opacity`, `filter` — properties the GPU can composite. Never use `will-change: all`. Only add when you notice first-frame stutter.
80
-
81
- ### 16. Minimum Hit Area
82
-
83
- Interactive elements need at least 40×40px hit area. Extend with a pseudo-element if the visible element is smaller. Never let hit areas of two elements overlap.
84
-
85
- ## Common Mistakes
86
-
87
- | Mistake | Fix |
88
- | --- | --- |
89
- | Same border radius on parent and child | Calculate `outerRadius = innerRadius + padding` |
90
- | Icons look off-center | Adjust optically with padding or fix SVG directly |
91
- | Hard borders between sections | Use layered `box-shadow` with transparency |
92
- | Jarring enter/exit animations | Split, stagger, and keep exits subtle |
93
- | Numbers cause layout shift | Apply `tabular-nums` |
94
- | Heavy text on macOS | Apply `antialiased` to root |
95
- | Animation plays on page load | Add `initial={false}` to `AnimatePresence` |
96
- | `transition: all` on elements | Specify exact properties |
97
- | First-frame animation stutter | Add `will-change: transform` (sparingly) |
98
- | Tiny hit areas on small controls | Extend with pseudo-element to 40×40px |
99
-
100
- ## Review Checklist
101
-
102
- - [ ] Nested rounded elements use concentric border radius
103
- - [ ] Icons are optically centered, not just geometrically
104
- - [ ] Shadows used instead of borders where appropriate
105
- - [ ] Enter animations are split and staggered
106
- - [ ] Exit animations are subtle
107
- - [ ] Dynamic numbers use tabular-nums
108
- - [ ] Font smoothing is applied
109
- - [ ] Headings use text-wrap: balance
110
- - [ ] Images have subtle outlines
111
- - [ ] Buttons use scale on press where appropriate
112
- - [ ] AnimatePresence uses `initial={false}` for default-state elements
113
- - [ ] No `transition: all` — only specific properties
114
- - [ ] `will-change` only on transform/opacity/filter, never `all`
115
- - [ ] Interactive elements have at least 40×40px hit area
116
-
117
- ## Reference Files
118
-
119
- - [typography.md](typography.md) — Text wrapping, font smoothing, tabular numbers
120
- - [surfaces.md](surfaces.md) — Border radius, optical alignment, shadows, image outlines
121
- - [animations.md](animations.md) — Interruptible animations, enter/exit transitions, icon animations, scale on press
122
- - [performance.md](performance.md) — Transition specificity, `will-change` usage
@@ -1,379 +0,0 @@
1
- # Animations
2
-
3
- Interruptible animations, enter/exit transitions, and contextual icon animations.
4
-
5
- ## Interruptible Animations
6
-
7
- Users change intent mid-interaction. If animations aren't interruptible, the interface feels broken.
8
-
9
- ### CSS Transitions vs. Keyframes
10
-
11
- | | CSS Transitions | CSS Keyframe Animations |
12
- | --- | --- | --- |
13
- | **Behavior** | Interpolate toward latest state | Run on a fixed timeline |
14
- | **Interruptible** | Yes — retargets mid-animation | No — restarts from beginning |
15
- | **Use for** | Interactive state changes (hover, toggle, open/close) | Staged sequences that run once (enter animations, loading) |
16
- | **Duration** | Adapts to remaining distance | Fixed regardless of state |
17
-
18
- ```css
19
- /* Good — interruptible transition for a toggle */
20
- .drawer {
21
- transform: translateX(-100%);
22
- transition: transform 200ms ease-out;
23
- }
24
- .drawer.open {
25
- transform: translateX(0);
26
- }
27
-
28
- /* Clicking again mid-animation smoothly reverses — no jank */
29
- ```
30
-
31
- ```css
32
- /* Bad — keyframe animation for interactive element */
33
- .drawer.open {
34
- animation: slideIn 200ms ease-out forwards;
35
- }
36
-
37
- /* Closing mid-animation snaps or restarts — feels broken */
38
- ```
39
-
40
- **Rule:** Always prefer CSS transitions for interactive elements. Reserve keyframes for one-shot sequences.
41
-
42
- ## Enter Animations: Split and Stagger
43
-
44
- Don't animate a single large container. Break content into semantic chunks and animate each individually.
45
-
46
- ### Step by Step
47
-
48
- 1. **Split** into logical groups (title, description, buttons)
49
- 2. **Stagger** with ~100ms delay between groups
50
- 3. **For titles**, consider splitting into individual words with ~80ms stagger
51
- 4. **Combine** `opacity`, `blur`, and `translateY` for the enter effect
52
-
53
- ### Code Example
54
-
55
- ```tsx
56
- // Motion (Framer Motion) — staggered enter
57
- function PageHeader() {
58
- return (
59
- <motion.div
60
- initial="hidden"
61
- animate="visible"
62
- variants={{
63
- visible: { transition: { staggerChildren: 0.1 } },
64
- }}
65
- >
66
- <motion.h1
67
- variants={{
68
- hidden: { opacity: 0, y: 12, filter: "blur(4px)" },
69
- visible: { opacity: 1, y: 0, filter: "blur(0px)" },
70
- }}
71
- >
72
- Welcome
73
- </motion.h1>
74
-
75
- <motion.p
76
- variants={{
77
- hidden: { opacity: 0, y: 12, filter: "blur(4px)" },
78
- visible: { opacity: 1, y: 0, filter: "blur(0px)" },
79
- }}
80
- >
81
- A description of the page.
82
- </motion.p>
83
-
84
- <motion.div
85
- variants={{
86
- hidden: { opacity: 0, y: 12, filter: "blur(4px)" },
87
- visible: { opacity: 1, y: 0, filter: "blur(0px)" },
88
- }}
89
- >
90
- <Button>Get started</Button>
91
- </motion.div>
92
- </motion.div>
93
- );
94
- }
95
- ```
96
-
97
- ### CSS-Only Stagger
98
-
99
- ```css
100
- .stagger-item {
101
- opacity: 0;
102
- transform: translateY(12px);
103
- filter: blur(4px);
104
- animation: fadeInUp 400ms ease-out forwards;
105
- }
106
-
107
- .stagger-item:nth-child(1) { animation-delay: 0ms; }
108
- .stagger-item:nth-child(2) { animation-delay: 100ms; }
109
- .stagger-item:nth-child(3) { animation-delay: 200ms; }
110
-
111
- @keyframes fadeInUp {
112
- to {
113
- opacity: 1;
114
- transform: translateY(0);
115
- filter: blur(0);
116
- }
117
- }
118
- ```
119
-
120
- ## Exit Animations
121
-
122
- Exit animations should be softer and less attention-grabbing than enter animations. The user's focus is moving to the next thing — don't fight for attention.
123
-
124
- ### Subtle Exit (Recommended)
125
-
126
- ```tsx
127
- // Small fixed translateY — indicates direction without drama
128
- <motion.div
129
- exit={{
130
- opacity: 0,
131
- y: -12,
132
- filter: "blur(4px)",
133
- transition: { duration: 0.15, ease: "easeIn" },
134
- }}
135
- >
136
- {content}
137
- </motion.div>
138
- ```
139
-
140
- ### Full Exit (When Context Matters)
141
-
142
- ```tsx
143
- // Slide fully out — use when spatial context is important
144
- // (e.g., a card returning to a list, a drawer closing)
145
- <motion.div
146
- exit={{
147
- opacity: 0,
148
- x: "-100%",
149
- transition: { duration: 0.2, ease: "easeIn" },
150
- }}
151
- >
152
- {content}
153
- </motion.div>
154
- ```
155
-
156
- ### Good vs. Bad
157
-
158
- ```css
159
- /* Good — subtle exit */
160
- .item-exit {
161
- opacity: 0;
162
- transform: translateY(-12px);
163
- transition: opacity 150ms ease-in, transform 150ms ease-in;
164
- }
165
-
166
- /* Bad — dramatic exit that steals focus */
167
- .item-exit {
168
- opacity: 0;
169
- transform: translateY(-100%) scale(0.5);
170
- transition: all 400ms ease-in;
171
- }
172
-
173
- /* Bad — no exit animation at all (element just vanishes) */
174
- .item-exit {
175
- display: none;
176
- }
177
- ```
178
-
179
- **Key points:**
180
- - Use a small fixed `translateY` (e.g., `-12px`) instead of the full container height
181
- - Keep some directional movement to indicate where the element went
182
- - Exit duration should be shorter than enter duration (150ms vs 300ms)
183
- - Don't remove exit animations entirely — subtle motion preserves context
184
-
185
- ## Contextual Icon Animations
186
-
187
- When icons appear or disappear contextually (on hover, on state change), animate them with `opacity`, `scale`, and `blur` rather than just toggling visibility.
188
-
189
- ### Motion Example
190
-
191
- ```tsx
192
- import { AnimatePresence, motion } from "motion/react";
193
-
194
- function IconButton({ isActive, icon: Icon }) {
195
- return (
196
- <button>
197
- <AnimatePresence mode="popLayout">
198
- <motion.span
199
- key={isActive ? "active" : "inactive"}
200
- initial={{ opacity: 0, scale: 0.25, filter: "blur(4px)" }}
201
- animate={{ opacity: 1, scale: 1, filter: "blur(0px)" }}
202
- exit={{ opacity: 0, scale: 0.25, filter: "blur(4px)" }}
203
- transition={{ type: "spring", duration: 0.3, bounce: 0 }}
204
- >
205
- <Icon />
206
- </motion.span>
207
- </AnimatePresence>
208
- </button>
209
- );
210
- }
211
- ```
212
-
213
- ### CSS Transition Approach (No Motion)
214
-
215
- If the project doesn't use Motion (Framer Motion), keep both icons in the DOM and cross-fade them with CSS transitions. Because neither icon unmounts, both enter and exit animate smoothly.
216
-
217
- The trick: one icon is absolutely positioned on top of the other. Toggling state cross-fades them — the entering icon scales up from `0.25` while the exiting icon scales down to `0.25`, both with opacity and blur.
218
-
219
- ```tsx
220
- function IconButton({ isActive, ActiveIcon, InactiveIcon }) {
221
- return (
222
- <button>
223
- <div className="relative">
224
- <div
225
- className={cn(
226
- "absolute inset-0 flex items-center justify-center",
227
- "transition-[opacity,filter,scale] duration-300",
228
- "cubic-bezier(0.2, 0, 0, 1)",
229
- isActive
230
- ? "scale-100 opacity-100 blur-0"
231
- : "scale-[0.25] opacity-0 blur-[4px]"
232
- )}
233
- >
234
- <ActiveIcon />
235
- </div>
236
- <div
237
- className={cn(
238
- "transition-[opacity,filter,scale] duration-300",
239
- "cubic-bezier(0.2, 0, 0, 1)",
240
- isActive
241
- ? "scale-[0.25] opacity-0 blur-[4px]"
242
- : "scale-100 opacity-100 blur-0"
243
- )}
244
- >
245
- <InactiveIcon />
246
- </div>
247
- </div>
248
- </button>
249
- );
250
- }
251
- ```
252
-
253
- The non-absolute icon (InactiveIcon) defines the layout size. The absolute icon (ActiveIcon) overlays it without affecting flow.
254
-
255
- ### Choosing Between Motion and CSS
256
-
257
- | | Motion (Framer Motion) | CSS transitions (both icons in DOM) |
258
- | --- | --- | --- |
259
- | **Enter animation** | Yes | Yes |
260
- | **Exit animation** | Yes (via `AnimatePresence`) | Yes (cross-fade — icon never unmounts) |
261
- | **Spring physics** | Yes | No — use `cubic-bezier(0.2, 0, 0, 1)` as approximation |
262
- | **When to use** | Project already uses `motion/react` | No motion dependency, or keeping bundle small |
263
-
264
- **Rule:** Check the project's `package.json` for `motion` or `framer-motion`. If present, use the Motion approach. If not, use the CSS cross-fade pattern — don't add a dependency just for icon transitions.
265
-
266
- ### When to Animate Icons
267
-
268
- | Animate | Don't animate |
269
- | --- | --- |
270
- | Icons that appear on hover (action buttons) | Static navigation icons |
271
- | State change icons (play → pause, like → liked) | Decorative icons |
272
- | Icons in contextual toolbars | Icons that are always visible |
273
- | Loading/success state indicators | Icon labels (text next to icon) |
274
-
275
- **Important:** Always use exactly these values for contextual icon animations — do not deviate:
276
- - `scale`: `0.25` → `1` (never use `0.5` or `0.6`)
277
- - `opacity`: `0` → `1`
278
- - `filter`: `"blur(4px)"` → `"blur(0px)"`
279
- - `transition`: `{ type: "spring", duration: 0.3, bounce: 0 }` — **bounce must always be `0`**, never `0.1` or any other value
280
-
281
- ## Scale on Press
282
-
283
- A subtle scale-down on click gives buttons tactile feedback. Always use `scale(0.96)`. Never use a value smaller than `0.95` — anything below feels exaggerated. Use CSS transitions for interruptibility — if the user releases mid-press, it should smoothly return.
284
-
285
- Not every button needs this. Add a `static` prop to your button component that disables the scale effect when the motion would be distracting.
286
-
287
- ### CSS Example
288
-
289
- ```css
290
- .button {
291
- transition-property: scale;
292
- transition-duration: 150ms;
293
- transition-timing-function: ease-out;
294
- }
295
-
296
- .button:active {
297
- scale: 0.96;
298
- }
299
- ```
300
-
301
- ### Tailwind Example
302
-
303
- ```tsx
304
- <button className="transition-transform duration-150 ease-out active:scale-[0.96]">
305
- Click me
306
- </button>
307
- ```
308
-
309
- ### Motion Example
310
-
311
- ```tsx
312
- <motion.button whileTap={{ scale: 0.96 }}>
313
- Click me
314
- </motion.button>
315
- ```
316
-
317
- ### Static Prop Pattern
318
-
319
- Extract the scale class into a variable and conditionally apply it based on a `static` prop:
320
-
321
- ```tsx
322
- const tapScale = "active:not-disabled:scale-[0.96]";
323
-
324
- function Button({ static: isStatic, className, children, ...props }) {
325
- return (
326
- <button
327
- className={cn(
328
- "transition-transform duration-150 ease-out",
329
- !isStatic && tapScale,
330
- className,
331
- )}
332
- {...props}
333
- >
334
- {children}
335
- </button>
336
- );
337
- }
338
-
339
- // Usage
340
- <Button>Click me</Button> {/* scales on press */}
341
- <Button static>Submit</Button> {/* no scale */}
342
- ```
343
-
344
- ## Skip Animation on Page Load
345
-
346
- Use `initial={false}` on `AnimatePresence` to prevent enter animations from firing on first render. Elements that are already in their default state shouldn't animate in on page load — only on subsequent state changes.
347
-
348
- ### When It Works
349
-
350
- ```tsx
351
- // Good — icon doesn't animate in on mount, only on state change
352
- <AnimatePresence initial={false} mode="popLayout">
353
- <motion.span
354
- key={isActive ? "active" : "inactive"}
355
- initial={{ opacity: 0, scale: 0.25, filter: "blur(4px)" }}
356
- animate={{ opacity: 1, scale: 1, filter: "blur(0px)" }}
357
- exit={{ opacity: 0, scale: 0.25, filter: "blur(4px)" }}
358
- >
359
- <Icon />
360
- </motion.span>
361
- </AnimatePresence>
362
- ```
363
-
364
- Works well for: icon swaps, toggles, tabs, segmented controls — anything that has a default state on page load.
365
-
366
- ### When It Breaks
367
-
368
- Don't use `initial={false}` when the component relies on its `initial` prop to set up a first-time enter animation, like a staggered page hero or a loading state. In those cases, removing the initial animation skips the entire entrance.
369
-
370
- ```tsx
371
- // Bad — initial={false} would skip the staggered page enter entirely
372
- <AnimatePresence initial={false}>
373
- <motion.div initial="hidden" animate="visible" variants={...}>
374
- ...
375
- </motion.div>
376
- </AnimatePresence>
377
- ```
378
-
379
- Verify the component still looks right on a full page refresh before applying this.
@@ -1,88 +0,0 @@
1
- # Performance
2
-
3
- Transition specificity and GPU compositing hints.
4
-
5
- ## Transition Only What Changes
6
-
7
- Never use `transition: all` or Tailwind's `transition` shorthand (which maps to `transition-property: all`). Always specify the exact properties that change.
8
-
9
- ### Why
10
-
11
- - `transition: all` forces the browser to watch every property for changes
12
- - Causes unexpected transitions on properties you didn't intend to animate (colors, padding, shadows)
13
- - Prevents browser optimizations
14
-
15
- ### CSS Example
16
-
17
- ```css
18
- /* Good — only transition what changes */
19
- .button {
20
- transition-property: scale, background-color;
21
- transition-duration: 150ms;
22
- transition-timing-function: ease-out;
23
- }
24
-
25
- /* Bad — transition everything */
26
- .button {
27
- transition: all 150ms ease-out;
28
- }
29
- ```
30
-
31
- ### Tailwind
32
-
33
- ```tsx
34
- // Good — explicit properties
35
- <button className="transition-[scale,background-color] duration-150 ease-out">
36
-
37
- // Bad — transition all
38
- <button className="transition duration-150 ease-out">
39
- ```
40
-
41
- ### Tailwind `transition-transform` Note
42
-
43
- `transition-transform` in Tailwind maps to `transition-property: transform, translate, scale, rotate` — it covers all transform-related properties, not just `transform`. Use this when you're only animating transforms. For multiple non-transform properties, use the bracket syntax: `transition-[scale,opacity,filter]`.
44
-
45
- ## Use `will-change` Sparingly
46
-
47
- `will-change` hints the browser to pre-promote an element to its own GPU compositing layer. Without it, the browser promotes the element only when the animation starts — that one-time layer promotion can cause a micro-stutter on the first frame.
48
-
49
- This particularly helps when an element is changing `scale`, `rotation`, or moving around with `transform`. For other properties, it doesn't help much — the browser can't composite them on the GPU anyway.
50
-
51
- ### Rules
52
-
53
- ```css
54
- /* Good — specific property that benefits from GPU compositing */
55
- .animated-card {
56
- will-change: transform;
57
- }
58
-
59
- /* Good — multiple compositor-friendly properties */
60
- .animated-card {
61
- will-change: transform, opacity;
62
- }
63
-
64
- /* Bad — never use will-change: all */
65
- .animated-card {
66
- will-change: all;
67
- }
68
-
69
- /* Bad — properties that can't be GPU-composited anyway */
70
- .animated-card {
71
- will-change: background-color, padding;
72
- }
73
- ```
74
-
75
- ### Useful Properties
76
-
77
- | Property | GPU-compositable | Worth using `will-change` |
78
- | --- | --- | --- |
79
- | `transform` | Yes | Yes |
80
- | `opacity` | Yes | Yes |
81
- | `filter` (blur, brightness) | Yes | Yes |
82
- | `clip-path` | Yes | Yes |
83
- | `top`, `left`, `width`, `height` | No | No |
84
- | `background`, `border`, `color` | No | No |
85
-
86
- ### When to Skip
87
-
88
- Modern browsers are already good at optimizing on their own. Only add `will-change` when you notice first-frame stutter — Safari in particular benefits from it. Don't add it preemptively to every animated element; each extra compositing layer costs memory.