ccg-workflow 1.8.2 → 2.0.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 (111) hide show
  1. package/dist/cli.mjs +1 -1
  2. package/dist/index.d.mts +1 -0
  3. package/dist/index.d.ts +1 -0
  4. package/dist/index.mjs +1 -1
  5. package/dist/shared/{ccg-workflow.B1RHp04H.mjs → ccg-workflow.iK6lgCG3.mjs} +204 -6
  6. package/package.json +1 -1
  7. package/templates/commands/agents/team-architect.md +97 -0
  8. package/templates/commands/agents/team-qa.md +121 -0
  9. package/templates/commands/agents/team-reviewer.md +112 -0
  10. package/templates/output-styles/abyss-command.md +56 -0
  11. package/templates/output-styles/abyss-concise.md +89 -0
  12. package/templates/output-styles/abyss-ritual.md +70 -0
  13. package/templates/rules/ccg-skill-routing.md +83 -0
  14. package/templates/skills/domains/ai/SKILL.md +34 -0
  15. package/templates/skills/domains/ai/agent-dev.md +242 -0
  16. package/templates/skills/domains/ai/llm-security.md +288 -0
  17. package/templates/skills/domains/ai/prompt-and-eval.md +279 -0
  18. package/templates/skills/domains/ai/rag-system.md +542 -0
  19. package/templates/skills/domains/architecture/SKILL.md +42 -0
  20. package/templates/skills/domains/architecture/api-design.md +225 -0
  21. package/templates/skills/domains/architecture/caching.md +299 -0
  22. package/templates/skills/domains/architecture/cloud-native.md +285 -0
  23. package/templates/skills/domains/architecture/message-queue.md +329 -0
  24. package/templates/skills/domains/architecture/security-arch.md +297 -0
  25. package/templates/skills/domains/data-engineering/SKILL.md +207 -0
  26. package/templates/skills/domains/development/SKILL.md +46 -0
  27. package/templates/skills/domains/development/cpp.md +246 -0
  28. package/templates/skills/domains/development/go.md +323 -0
  29. package/templates/skills/domains/development/java.md +277 -0
  30. package/templates/skills/domains/development/python.md +288 -0
  31. package/templates/skills/domains/development/rust.md +313 -0
  32. package/templates/skills/domains/development/shell.md +313 -0
  33. package/templates/skills/domains/development/typescript.md +277 -0
  34. package/templates/skills/domains/devops/SKILL.md +39 -0
  35. package/templates/skills/domains/devops/cost-optimization.md +272 -0
  36. package/templates/skills/domains/devops/database.md +217 -0
  37. package/templates/skills/domains/devops/devsecops.md +198 -0
  38. package/templates/skills/domains/devops/git-workflow.md +181 -0
  39. package/templates/skills/domains/devops/observability.md +280 -0
  40. package/templates/skills/domains/devops/performance.md +336 -0
  41. package/templates/skills/domains/devops/testing.md +283 -0
  42. package/templates/skills/domains/frontend-design/SKILL.md +242 -0
  43. package/templates/skills/domains/frontend-design/agents/openai.yaml +4 -0
  44. package/templates/skills/domains/frontend-design/claymorphism/SKILL.md +119 -0
  45. package/templates/skills/domains/frontend-design/claymorphism/references/tokens.css +52 -0
  46. package/templates/skills/domains/frontend-design/component-patterns.md +202 -0
  47. package/templates/skills/domains/frontend-design/engineering.md +287 -0
  48. package/templates/skills/domains/frontend-design/glassmorphism/SKILL.md +140 -0
  49. package/templates/skills/domains/frontend-design/glassmorphism/references/tokens.css +32 -0
  50. package/templates/skills/domains/frontend-design/liquid-glass/SKILL.md +137 -0
  51. package/templates/skills/domains/frontend-design/liquid-glass/references/tokens.css +81 -0
  52. package/templates/skills/domains/frontend-design/neubrutalism/SKILL.md +143 -0
  53. package/templates/skills/domains/frontend-design/neubrutalism/references/tokens.css +44 -0
  54. package/templates/skills/domains/frontend-design/reference/color-and-contrast.md +132 -0
  55. package/templates/skills/domains/frontend-design/reference/interaction-design.md +195 -0
  56. package/templates/skills/domains/frontend-design/reference/motion-design.md +99 -0
  57. package/templates/skills/domains/frontend-design/reference/responsive-design.md +114 -0
  58. package/templates/skills/domains/frontend-design/reference/spatial-design.md +100 -0
  59. package/templates/skills/domains/frontend-design/reference/typography.md +133 -0
  60. package/templates/skills/domains/frontend-design/reference/ux-writing.md +107 -0
  61. package/templates/skills/domains/frontend-design/state-management.md +680 -0
  62. package/templates/skills/domains/frontend-design/ui-aesthetics.md +110 -0
  63. package/templates/skills/domains/frontend-design/ux-principles.md +156 -0
  64. package/templates/skills/domains/infrastructure/SKILL.md +200 -0
  65. package/templates/skills/domains/mobile/SKILL.md +224 -0
  66. package/templates/skills/domains/orchestration/SKILL.md +29 -0
  67. package/templates/skills/domains/orchestration/multi-agent.md +263 -0
  68. package/templates/skills/domains/security/SKILL.md +72 -0
  69. package/templates/skills/domains/security/blue-team.md +436 -0
  70. package/templates/skills/domains/security/code-audit.md +265 -0
  71. package/templates/skills/domains/security/pentest.md +226 -0
  72. package/templates/skills/domains/security/red-team.md +374 -0
  73. package/templates/skills/domains/security/threat-intel.md +372 -0
  74. package/templates/skills/domains/security/vuln-research.md +369 -0
  75. package/templates/skills/impeccable/adapt/SKILL.md +199 -0
  76. package/templates/skills/impeccable/animate/SKILL.md +174 -0
  77. package/templates/skills/impeccable/arrange/SKILL.md +124 -0
  78. package/templates/skills/impeccable/audit/SKILL.md +147 -0
  79. package/templates/skills/impeccable/bolder/SKILL.md +116 -0
  80. package/templates/skills/impeccable/clarify/SKILL.md +183 -0
  81. package/templates/skills/impeccable/colorize/SKILL.md +142 -0
  82. package/templates/skills/impeccable/critique/SKILL.md +201 -0
  83. package/templates/skills/impeccable/critique/reference/cognitive-load.md +106 -0
  84. package/templates/skills/impeccable/critique/reference/heuristics-scoring.md +234 -0
  85. package/templates/skills/impeccable/critique/reference/personas.md +178 -0
  86. package/templates/skills/impeccable/delight/SKILL.md +303 -0
  87. package/templates/skills/impeccable/distill/SKILL.md +121 -0
  88. package/templates/skills/impeccable/extract/SKILL.md +92 -0
  89. package/templates/skills/impeccable/harden/SKILL.md +355 -0
  90. package/templates/skills/impeccable/normalize/SKILL.md +70 -0
  91. package/templates/skills/impeccable/onboard/SKILL.md +246 -0
  92. package/templates/skills/impeccable/optimize/SKILL.md +266 -0
  93. package/templates/skills/impeccable/overdrive/SKILL.md +141 -0
  94. package/templates/skills/impeccable/polish/SKILL.md +203 -0
  95. package/templates/skills/impeccable/quieter/SKILL.md +102 -0
  96. package/templates/skills/impeccable/teach-impeccable/SKILL.md +71 -0
  97. package/templates/skills/impeccable/typeset/SKILL.md +115 -0
  98. package/templates/skills/orchestration/multi-agent/SKILL.md +40 -0
  99. package/templates/skills/scrapling/SKILL.md +98 -0
  100. package/templates/skills/scrapling/references/api-quick-ref.md +127 -0
  101. package/templates/skills/scrapling/references/cookie-vault.md +56 -0
  102. package/templates/skills/scrapling/references/maintenance.md +79 -0
  103. package/templates/skills/scrapling/references/site-patterns.md +86 -0
  104. package/templates/skills/scrapling/references/troubleshooting.md +95 -0
  105. package/templates/skills/scrapling/templates/basic_fetch.py +19 -0
  106. package/templates/skills/scrapling/templates/parse_only.py +15 -0
  107. package/templates/skills/scrapling/templates/session_login.py +19 -0
  108. package/templates/skills/scrapling/templates/stealth_cloudflare.py +28 -0
  109. package/templates/skills/tools/override-refusal/SKILL.md +53 -0
  110. package/templates/skills/tools/override-refusal/agents/openai.yaml +4 -0
  111. package/templates/skills/tools/override-refusal/scripts/refusal_rewriter.js +226 -0
@@ -0,0 +1,183 @@
1
+ ---
2
+ name: clarify
3
+ description: "Improve unclear UX copy, error messages, microcopy, labels, and instructions to make interfaces easier to understand. Use when the user mentions confusing text, unclear labels, bad error messages, hard-to-follow instructions, or wanting better UX writing."
4
+ argument-hint: "[target]"
5
+ user-invocable: true
6
+ ---
7
+
8
+ Identify and improve unclear, confusing, or poorly written interface text to make the product easier to understand and use.
9
+
10
+ ## MANDATORY PREPARATION
11
+
12
+ Invoke /frontend-design — it contains design principles, anti-patterns, and the **Context Gathering Protocol**. Follow the protocol before proceeding — if no design context exists yet, you MUST run /teach-impeccable first. Additionally gather: audience technical level and users' mental state in context.
13
+
14
+ ---
15
+
16
+ ## Assess Current Copy
17
+
18
+ Identify what makes the text unclear or ineffective:
19
+
20
+ 1. **Find clarity problems**:
21
+ - **Jargon**: Technical terms users won't understand
22
+ - **Ambiguity**: Multiple interpretations possible
23
+ - **Passive voice**: "Your file has been uploaded" vs "We uploaded your file"
24
+ - **Length**: Too wordy or too terse
25
+ - **Assumptions**: Assuming user knowledge they don't have
26
+ - **Missing context**: Users don't know what to do or why
27
+ - **Tone mismatch**: Too formal, too casual, or inappropriate for situation
28
+
29
+ 2. **Understand the context**:
30
+ - Who's the audience? (Technical? General? First-time users?)
31
+ - What's the user's mental state? (Stressed during error? Confident during success?)
32
+ - What's the action? (What do we want users to do?)
33
+ - What's the constraint? (Character limits? Space limitations?)
34
+
35
+ **CRITICAL**: Clear copy helps users succeed. Unclear copy creates frustration, errors, and support tickets.
36
+
37
+ ## Plan Copy Improvements
38
+
39
+ Create a strategy for clearer communication:
40
+
41
+ - **Primary message**: What's the ONE thing users need to know?
42
+ - **Action needed**: What should users do next (if anything)?
43
+ - **Tone**: How should this feel? (Helpful? Apologetic? Encouraging?)
44
+ - **Constraints**: Length limits, brand voice, localization considerations
45
+
46
+ **IMPORTANT**: Good UX writing is invisible. Users should understand immediately without noticing the words.
47
+
48
+ ## Improve Copy Systematically
49
+
50
+ Refine text across these common areas:
51
+
52
+ ### Error Messages
53
+ **Bad**: "Error 403: Forbidden"
54
+ **Good**: "You don't have permission to view this page. Contact your admin for access."
55
+
56
+ **Bad**: "Invalid input"
57
+ **Good**: "Email addresses need an @ symbol. Try: name@example.com"
58
+
59
+ **Principles**:
60
+ - Explain what went wrong in plain language
61
+ - Suggest how to fix it
62
+ - Don't blame the user
63
+ - Include examples when helpful
64
+ - Link to help/support if applicable
65
+
66
+ ### Form Labels & Instructions
67
+ **Bad**: "DOB (MM/DD/YYYY)"
68
+ **Good**: "Date of birth" (with placeholder showing format)
69
+
70
+ **Bad**: "Enter value here"
71
+ **Good**: "Your email address" or "Company name"
72
+
73
+ **Principles**:
74
+ - Use clear, specific labels (not generic placeholders)
75
+ - Show format expectations with examples
76
+ - Explain why you're asking (when not obvious)
77
+ - Put instructions before the field, not after
78
+ - Keep required field indicators clear
79
+
80
+ ### Button & CTA Text
81
+ **Bad**: "Click here" | "Submit" | "OK"
82
+ **Good**: "Create account" | "Save changes" | "Got it, thanks"
83
+
84
+ **Principles**:
85
+ - Describe the action specifically
86
+ - Use active voice (verb + noun)
87
+ - Match user's mental model
88
+ - Be specific ("Save" is better than "OK")
89
+
90
+ ### Help Text & Tooltips
91
+ **Bad**: "This is the username field"
92
+ **Good**: "Choose a username. You can change this later in Settings."
93
+
94
+ **Principles**:
95
+ - Add value (don't just repeat the label)
96
+ - Answer the implicit question ("What is this?" or "Why do you need this?")
97
+ - Keep it brief but complete
98
+ - Link to detailed docs if needed
99
+
100
+ ### Empty States
101
+ **Bad**: "No items"
102
+ **Good**: "No projects yet. Create your first project to get started."
103
+
104
+ **Principles**:
105
+ - Explain why it's empty (if not obvious)
106
+ - Show next action clearly
107
+ - Make it welcoming, not dead-end
108
+
109
+ ### Success Messages
110
+ **Bad**: "Success"
111
+ **Good**: "Settings saved! Your changes will take effect immediately."
112
+
113
+ **Principles**:
114
+ - Confirm what happened
115
+ - Explain what happens next (if relevant)
116
+ - Be brief but complete
117
+ - Match the user's emotional moment (celebrate big wins)
118
+
119
+ ### Loading States
120
+ **Bad**: "Loading..." (for 30+ seconds)
121
+ **Good**: "Analyzing your data... this usually takes 30-60 seconds"
122
+
123
+ **Principles**:
124
+ - Set expectations (how long?)
125
+ - Explain what's happening (when it's not obvious)
126
+ - Show progress when possible
127
+ - Offer escape hatch if appropriate ("Cancel")
128
+
129
+ ### Confirmation Dialogs
130
+ **Bad**: "Are you sure?"
131
+ **Good**: "Delete 'Project Alpha'? This can't be undone."
132
+
133
+ **Principles**:
134
+ - State the specific action
135
+ - Explain consequences (especially for destructive actions)
136
+ - Use clear button labels ("Delete project" not "Yes")
137
+ - Don't overuse confirmations (only for risky actions)
138
+
139
+ ### Navigation & Wayfinding
140
+ **Bad**: Generic labels like "Items" | "Things" | "Stuff"
141
+ **Good**: Specific labels like "Your projects" | "Team members" | "Settings"
142
+
143
+ **Principles**:
144
+ - Be specific and descriptive
145
+ - Use language users understand (not internal jargon)
146
+ - Make hierarchy clear
147
+ - Consider information scent (breadcrumbs, current location)
148
+
149
+ ## Apply Clarity Principles
150
+
151
+ Every piece of copy should follow these rules:
152
+
153
+ 1. **Be specific**: "Enter email" not "Enter value"
154
+ 2. **Be concise**: Cut unnecessary words (but don't sacrifice clarity)
155
+ 3. **Be active**: "Save changes" not "Changes will be saved"
156
+ 4. **Be human**: "Oops, something went wrong" not "System error encountered"
157
+ 5. **Be helpful**: Tell users what to do, not just what happened
158
+ 6. **Be consistent**: Use same terms throughout (don't vary for variety)
159
+
160
+ **NEVER**:
161
+ - Use jargon without explanation
162
+ - Blame users ("You made an error" → "This field is required")
163
+ - Be vague ("Something went wrong" without explanation)
164
+ - Use passive voice unnecessarily
165
+ - Write overly long explanations (be concise)
166
+ - Use humor for errors (be empathetic instead)
167
+ - Assume technical knowledge
168
+ - Vary terminology (pick one term and stick with it)
169
+ - Repeat information (headers restating intros, redundant explanations)
170
+ - Use placeholders as the only labels (they disappear when users type)
171
+
172
+ ## Verify Improvements
173
+
174
+ Test that copy improvements work:
175
+
176
+ - **Comprehension**: Can users understand without context?
177
+ - **Actionability**: Do users know what to do next?
178
+ - **Brevity**: Is it as short as possible while remaining clear?
179
+ - **Consistency**: Does it match terminology elsewhere?
180
+ - **Tone**: Is it appropriate for the situation?
181
+
182
+ Remember: You're a clarity expert with excellent communication skills. Write like you're explaining to a smart friend who's unfamiliar with the product. Be clear, be helpful, be human.
183
+
@@ -0,0 +1,142 @@
1
+ ---
2
+ name: colorize
3
+ description: "Add strategic color to features that are too monochromatic or lack visual interest, making interfaces more engaging and expressive. Use when the user mentions the design looking gray, dull, lacking warmth, needing more color, or wanting a more vibrant or expressive palette."
4
+ argument-hint: "[target]"
5
+ user-invocable: true
6
+ ---
7
+
8
+ Strategically introduce color to designs that are too monochromatic, gray, or lacking in visual warmth and personality.
9
+
10
+ ## MANDATORY PREPARATION
11
+
12
+ Invoke /frontend-design — it contains design principles, anti-patterns, and the **Context Gathering Protocol**. Follow the protocol before proceeding — if no design context exists yet, you MUST run /teach-impeccable first. Additionally gather: existing brand colors.
13
+
14
+ ---
15
+
16
+ ## Assess Color Opportunity
17
+
18
+ Analyze the current state and identify opportunities:
19
+
20
+ 1. **Understand current state**:
21
+ - **Color absence**: Pure grayscale? Limited neutrals? One timid accent?
22
+ - **Missed opportunities**: Where could color add meaning, hierarchy, or delight?
23
+ - **Context**: What's appropriate for this domain and audience?
24
+ - **Brand**: Are there existing brand colors we should use?
25
+
26
+ 2. **Identify where color adds value**:
27
+ - **Semantic meaning**: Success (green), error (red), warning (yellow/orange), info (blue)
28
+ - **Hierarchy**: Drawing attention to important elements
29
+ - **Categorization**: Different sections, types, or states
30
+ - **Emotional tone**: Warmth, energy, trust, creativity
31
+ - **Wayfinding**: Helping users navigate and understand structure
32
+ - **Delight**: Moments of visual interest and personality
33
+
34
+ If any of these are unclear from the codebase, Ask the user using AskUserQuestion.
35
+
36
+ **CRITICAL**: More color ≠ better. Strategic color beats rainbow vomit every time. Every color should have a purpose.
37
+
38
+ ## Plan Color Strategy
39
+
40
+ Create a purposeful color introduction plan:
41
+
42
+ - **Color palette**: What colors match the brand/context? (Choose 2-4 colors max beyond neutrals)
43
+ - **Dominant color**: Which color owns 60% of colored elements?
44
+ - **Accent colors**: Which colors provide contrast and highlights? (30% and 10%)
45
+ - **Application strategy**: Where does each color appear and why?
46
+
47
+ **IMPORTANT**: Color should enhance hierarchy and meaning, not create chaos. Less is more when it matters more.
48
+
49
+ ## Introduce Color Strategically
50
+
51
+ Add color systematically across these dimensions:
52
+
53
+ ### Semantic Color
54
+ - **State indicators**:
55
+ - Success: Green tones (emerald, forest, mint)
56
+ - Error: Red/pink tones (rose, crimson, coral)
57
+ - Warning: Orange/amber tones
58
+ - Info: Blue tones (sky, ocean, indigo)
59
+ - Neutral: Gray/slate for inactive states
60
+
61
+ - **Status badges**: Colored backgrounds or borders for states (active, pending, completed, etc.)
62
+ - **Progress indicators**: Colored bars, rings, or charts showing completion or health
63
+
64
+ ### Accent Color Application
65
+ - **Primary actions**: Color the most important buttons/CTAs
66
+ - **Links**: Add color to clickable text (maintain accessibility)
67
+ - **Icons**: Colorize key icons for recognition and personality
68
+ - **Headers/titles**: Add color to section headers or key labels
69
+ - **Hover states**: Introduce color on interaction
70
+
71
+ ### Background & Surfaces
72
+ - **Tinted backgrounds**: Replace pure gray (`#f5f5f5`) with warm neutrals (`oklch(97% 0.01 60)`) or cool tints (`oklch(97% 0.01 250)`)
73
+ - **Colored sections**: Use subtle background colors to separate areas
74
+ - **Gradient backgrounds**: Add depth with subtle, intentional gradients (not generic purple-blue)
75
+ - **Cards & surfaces**: Tint cards or surfaces slightly for warmth
76
+
77
+ **Use OKLCH for color**: It's perceptually uniform, meaning equal steps in lightness *look* equal. Great for generating harmonious scales.
78
+
79
+ ### Data Visualization
80
+ - **Charts & graphs**: Use color to encode categories or values
81
+ - **Heatmaps**: Color intensity shows density or importance
82
+ - **Comparison**: Color coding for different datasets or timeframes
83
+
84
+ ### Borders & Accents
85
+ - **Accent borders**: Add colored left/top borders to cards or sections
86
+ - **Underlines**: Color underlines for emphasis or active states
87
+ - **Dividers**: Subtle colored dividers instead of gray lines
88
+ - **Focus rings**: Colored focus indicators matching brand
89
+
90
+ ### Typography Color
91
+ - **Colored headings**: Use brand colors for section headings (maintain contrast)
92
+ - **Highlight text**: Color for emphasis or categories
93
+ - **Labels & tags**: Small colored labels for metadata or categories
94
+
95
+ ### Decorative Elements
96
+ - **Illustrations**: Add colored illustrations or icons
97
+ - **Shapes**: Geometric shapes in brand colors as background elements
98
+ - **Gradients**: Colorful gradient overlays or mesh backgrounds
99
+ - **Blobs/organic shapes**: Soft colored shapes for visual interest
100
+
101
+ ## Balance & Refinement
102
+
103
+ Ensure color addition improves rather than overwhelms:
104
+
105
+ ### Maintain Hierarchy
106
+ - **Dominant color** (60%): Primary brand color or most used accent
107
+ - **Secondary color** (30%): Supporting color for variety
108
+ - **Accent color** (10%): High contrast for key moments
109
+ - **Neutrals** (remaining): Gray/black/white for structure
110
+
111
+ ### Accessibility
112
+ - **Contrast ratios**: Ensure WCAG compliance (4.5:1 for text, 3:1 for UI components)
113
+ - **Don't rely on color alone**: Use icons, labels, or patterns alongside color
114
+ - **Test for color blindness**: Verify red/green combinations work for all users
115
+
116
+ ### Cohesion
117
+ - **Consistent palette**: Use colors from defined palette, not arbitrary choices
118
+ - **Systematic application**: Same color meanings throughout (green always = success)
119
+ - **Temperature consistency**: Warm palette stays warm, cool stays cool
120
+
121
+ **NEVER**:
122
+ - Use every color in the rainbow (choose 2-4 colors beyond neutrals)
123
+ - Apply color randomly without semantic meaning
124
+ - Put gray text on colored backgrounds—it looks washed out; use a darker shade of the background color or transparency instead
125
+ - Use pure gray for neutrals—add subtle color tint (warm or cool) for sophistication
126
+ - Use pure black (`#000`) or pure white (`#fff`) for large areas
127
+ - Violate WCAG contrast requirements
128
+ - Use color as the only indicator (accessibility issue)
129
+ - Make everything colorful (defeats the purpose)
130
+ - Default to purple-blue gradients (AI slop aesthetic)
131
+
132
+ ## Verify Color Addition
133
+
134
+ Test that colorization improves the experience:
135
+
136
+ - **Better hierarchy**: Does color guide attention appropriately?
137
+ - **Clearer meaning**: Does color help users understand states/categories?
138
+ - **More engaging**: Does the interface feel warmer and more inviting?
139
+ - **Still accessible**: Do all color combinations meet WCAG standards?
140
+ - **Not overwhelming**: Is color balanced and purposeful?
141
+
142
+ Remember: Color is emotional and powerful. Use it to create warmth, guide attention, communicate meaning, and express personality. But restraint and strategy matter more than saturation and variety. Be colorful, but be intentional.
@@ -0,0 +1,201 @@
1
+ ---
2
+ name: critique
3
+ description: "Evaluate design from a UX perspective, assessing visual hierarchy, information architecture, emotional resonance, cognitive load, and overall quality with quantitative scoring, persona-based testing, and actionable feedback. Use when the user asks to review, critique, evaluate, or give feedback on a design or component."
4
+ argument-hint: "[area (feature, page, component...)]"
5
+ user-invocable: true
6
+ ---
7
+
8
+ ## MANDATORY PREPARATION
9
+
10
+ Invoke /frontend-design — it contains design principles, anti-patterns, and the **Context Gathering Protocol**. Follow the protocol before proceeding — if no design context exists yet, you MUST run /teach-impeccable first. Additionally gather: what the interface is trying to accomplish.
11
+
12
+ ---
13
+
14
+ Conduct a holistic design critique, evaluating whether the interface actually works — not just technically, but as a designed experience. Think like a design director giving feedback.
15
+
16
+ ## Phase 1: Design Critique
17
+
18
+ Evaluate the interface across these dimensions:
19
+
20
+ ### 1. AI Slop Detection (CRITICAL)
21
+
22
+ **This is the most important check.** Does this look like every other AI-generated interface from 2024-2025?
23
+
24
+ Review the design against ALL the **DON'T** guidelines in the frontend-design skill — they are the fingerprints of AI-generated work. Check for the AI color palette, gradient text, dark mode with glowing accents, glassmorphism, hero metric layouts, identical card grids, generic fonts, and all other tells.
25
+
26
+ **The test**: If you showed this to someone and said "AI made this," would they believe you immediately? If yes, that's the problem.
27
+
28
+ ### 2. Visual Hierarchy
29
+ - Does the eye flow to the most important element first?
30
+ - Is there a clear primary action? Can you spot it in 2 seconds?
31
+ - Do size, color, and position communicate importance correctly?
32
+ - Is there visual competition between elements that should have different weights?
33
+
34
+ ### 3. Information Architecture & Cognitive Load
35
+ > *Consult [cognitive-load](reference/cognitive-load.md) for the working memory rule and 8-item checklist*
36
+ - Is the structure intuitive? Would a new user understand the organization?
37
+ - Is related content grouped logically?
38
+ - Are there too many choices at once? Count visible options at each decision point — if >4, flag it
39
+ - Is the navigation clear and predictable?
40
+ - **Progressive disclosure**: Is complexity revealed only when needed, or dumped on the user upfront?
41
+ - **Run the 8-item cognitive load checklist** from the reference. Report failure count: 0–1 = low (good), 2–3 = moderate, 4+ = critical.
42
+
43
+ ### 4. Emotional Journey
44
+ - What emotion does this interface evoke? Is that intentional?
45
+ - Does it match the brand personality?
46
+ - Does it feel trustworthy, approachable, premium, playful — whatever it should feel?
47
+ - Would the target user feel "this is for me"?
48
+ - **Peak-end rule**: Is the most intense moment positive? Does the experience end well (confirmation, celebration, clear next step)?
49
+ - **Emotional valleys**: Check for onboarding frustration, error cliffs, feature discovery gaps, or anxiety spikes at high-stakes moments (payment, delete, commit)
50
+ - **Interventions at negative moments**: Are there design interventions where users are likely to feel frustrated or anxious? (progress indicators, reassurance copy, undo options, social proof)
51
+
52
+ ### 5. Discoverability & Affordance
53
+ - Are interactive elements obviously interactive?
54
+ - Would a user know what to do without instructions?
55
+ - Are hover/focus states providing useful feedback?
56
+ - Are there hidden features that should be more visible?
57
+
58
+ ### 6. Composition & Balance
59
+ - Does the layout feel balanced or uncomfortably weighted?
60
+ - Is whitespace used intentionally or just leftover?
61
+ - Is there visual rhythm in spacing and repetition?
62
+ - Does asymmetry feel designed or accidental?
63
+
64
+ ### 7. Typography as Communication
65
+ - Does the type hierarchy clearly signal what to read first, second, third?
66
+ - Is body text comfortable to read? (line length, spacing, size)
67
+ - Do font choices reinforce the brand/tone?
68
+ - Is there enough contrast between heading levels?
69
+
70
+ ### 8. Color with Purpose
71
+ - Is color used to communicate, not just decorate?
72
+ - Does the palette feel cohesive?
73
+ - Are accent colors drawing attention to the right things?
74
+ - Does it work for colorblind users? (not just technically — does meaning still come through?)
75
+
76
+ ### 9. States & Edge Cases
77
+ - Empty states: Do they guide users toward action, or just say "nothing here"?
78
+ - Loading states: Do they reduce perceived wait time?
79
+ - Error states: Are they helpful and non-blaming?
80
+ - Success states: Do they confirm and guide next steps?
81
+
82
+ ### 10. Microcopy & Voice
83
+ - Is the writing clear and concise?
84
+ - Does it sound like a human (the right human for this brand)?
85
+ - Are labels and buttons unambiguous?
86
+ - Does error copy help users fix the problem?
87
+
88
+ ## Phase 2: Present Findings
89
+
90
+ Structure your feedback as a design director would:
91
+
92
+ ### Design Health Score
93
+ > *Consult [heuristics-scoring](reference/heuristics-scoring.md)*
94
+
95
+ Score each of Nielsen's 10 heuristics 0–4. Present as a table:
96
+
97
+ | # | Heuristic | Score | Key Issue |
98
+ |---|-----------|-------|-----------|
99
+ | 1 | Visibility of System Status | ? | [specific finding or "—" if solid] |
100
+ | 2 | Match System / Real World | ? | |
101
+ | 3 | User Control and Freedom | ? | |
102
+ | 4 | Consistency and Standards | ? | |
103
+ | 5 | Error Prevention | ? | |
104
+ | 6 | Recognition Rather Than Recall | ? | |
105
+ | 7 | Flexibility and Efficiency | ? | |
106
+ | 8 | Aesthetic and Minimalist Design | ? | |
107
+ | 9 | Error Recovery | ? | |
108
+ | 10 | Help and Documentation | ? | |
109
+ | **Total** | | **??/40** | **[Rating band]** |
110
+
111
+ Be honest with scores. A 4 means genuinely excellent. Most real interfaces score 20–32.
112
+
113
+ ### Anti-Patterns Verdict
114
+ **Start here.** Pass/fail: Does this look AI-generated? List specific tells from the skill's Anti-Patterns section. Be brutally honest.
115
+
116
+ ### Overall Impression
117
+ A brief gut reaction — what works, what doesn't, and the single biggest opportunity.
118
+
119
+ ### What's Working
120
+ Highlight 2–3 things done well. Be specific about why they work.
121
+
122
+ ### Priority Issues
123
+ The 3–5 most impactful design problems, ordered by importance.
124
+
125
+ For each issue, tag with **P0–P3 severity** (consult [heuristics-scoring](reference/heuristics-scoring.md) for severity definitions):
126
+ - **[P?] What**: Name the problem clearly
127
+ - **Why it matters**: How this hurts users or undermines goals
128
+ - **Fix**: What to do about it (be concrete)
129
+ - **Suggested command**: Which command could address this (from: /audit, /critique, /normalize, /polish, /distill, /clarify, /optimize, /harden, /animate, /colorize, /bolder, /quieter, /delight, /extract, /adapt, /onboard, /typeset, /arrange, /overdrive, /teach-impeccable)
130
+
131
+ ### Persona Red Flags
132
+ > *Consult [personas](reference/personas.md)*
133
+
134
+ Auto-select 2–3 personas most relevant to this interface type (use the selection table in the reference). If `CLAUDE.md` contains a `## Design Context` section from `teach-impeccable`, also generate 1–2 project-specific personas from the audience/brand info.
135
+
136
+ For each selected persona, walk through the primary user action and list specific red flags found:
137
+
138
+ **Alex (Power User)**: No keyboard shortcuts detected. Form requires 8 clicks for primary action. Forced modal onboarding. ⚠️ High abandonment risk.
139
+
140
+ **Jordan (First-Timer)**: Icon-only nav in sidebar. Technical jargon in error messages ("404 Not Found"). No visible help. ⚠️ Will abandon at step 2.
141
+
142
+ Be specific — name the exact elements and interactions that fail each persona. Don't write generic persona descriptions; write what broke for them.
143
+
144
+ ### Minor Observations
145
+ Quick notes on smaller issues worth addressing.
146
+
147
+ **Remember**:
148
+ - Be direct — vague feedback wastes everyone's time
149
+ - Be specific — "the submit button" not "some elements"
150
+ - Say what's wrong AND why it matters to users
151
+ - Give concrete suggestions, not just "consider exploring..."
152
+ - Prioritize ruthlessly — if everything is important, nothing is
153
+ - Don't soften criticism — developers need honest feedback to ship great design
154
+
155
+ ## Phase 3: Ask the User
156
+
157
+ **After presenting findings**, use targeted questions based on what was actually found. Ask the user using AskUserQuestion. These answers will shape the action plan.
158
+
159
+ Ask questions along these lines (adapt to the specific findings — do NOT ask generic questions):
160
+
161
+ 1. **Priority direction**: Based on the issues found, ask which category matters most to the user right now. For example: "I found problems with visual hierarchy, color usage, and information overload. Which area should we tackle first?" Offer the top 2–3 issue categories as options.
162
+
163
+ 2. **Design intent**: If the critique found a tonal mismatch, ask whether it was intentional. For example: "The interface feels clinical and corporate. Is that the intended tone, or should it feel warmer/bolder/more playful?" Offer 2–3 tonal directions as options based on what would fix the issues found.
164
+
165
+ 3. **Scope**: Ask how much the user wants to take on. For example: "I found N issues. Want to address everything, or focus on the top 3?" Offer scope options like "Top 3 only", "All issues", "Critical issues only".
166
+
167
+ 4. **Constraints** (optional — only ask if relevant): If the findings touch many areas, ask if anything is off-limits. For example: "Should any sections stay as-is?" This prevents the plan from touching things the user considers done.
168
+
169
+ **Rules for questions**:
170
+ - Every question must reference specific findings from Phase 2 — never ask generic "who is your audience?" questions
171
+ - Keep it to 2–4 questions maximum — respect the user's time
172
+ - Offer concrete options, not open-ended prompts
173
+ - If findings are straightforward (e.g., only 1–2 clear issues), skip questions and go directly to Phase 4
174
+
175
+ ## Phase 4: Recommended Actions
176
+
177
+ **After receiving the user's answers**, present a prioritized action summary reflecting the user's priorities and scope from Phase 3.
178
+
179
+ ### Action Summary
180
+
181
+ List recommended commands in priority order, based on the user's answers:
182
+
183
+ 1. **`/command-name`** — Brief description of what to fix (specific context from critique findings)
184
+ 2. **`/command-name`** — Brief description (specific context)
185
+ ...
186
+
187
+ **Rules for recommendations**:
188
+ - Only recommend commands from: /audit, /critique, /normalize, /polish, /distill, /clarify, /optimize, /harden, /animate, /colorize, /bolder, /quieter, /delight, /extract, /adapt, /onboard, /typeset, /arrange, /overdrive, /teach-impeccable
189
+ - Order by the user's stated priorities first, then by impact
190
+ - Each item's description should carry enough context that the command knows what to focus on
191
+ - Map each Priority Issue to the appropriate command
192
+ - Skip commands that would address zero issues
193
+ - If the user chose a limited scope, only include items within that scope
194
+ - If the user marked areas as off-limits, exclude commands that would touch those areas
195
+ - End with `/polish` as the final step if any fixes were recommended
196
+
197
+ After presenting the summary, tell the user:
198
+
199
+ > You can ask me to run these one at a time, all at once, or in any order you prefer.
200
+ >
201
+ > Re-run `/critique` after fixes to see your score improve.
@@ -0,0 +1,106 @@
1
+ # Cognitive Load Assessment
2
+
3
+ Cognitive load is the total mental effort required to use an interface. Overloaded users make mistakes, get frustrated, and leave. This reference helps identify and fix cognitive overload.
4
+
5
+ ---
6
+
7
+ ## Three Types of Cognitive Load
8
+
9
+ ### Intrinsic Load — The Task Itself
10
+ Complexity inherent to what the user is trying to do. You can't eliminate this, but you can structure it.
11
+
12
+ **Manage it by**:
13
+ - Breaking complex tasks into discrete steps
14
+ - Providing scaffolding (templates, defaults, examples)
15
+ - Progressive disclosure — show what's needed now, hide the rest
16
+ - Grouping related decisions together
17
+
18
+ ### Extraneous Load — Bad Design
19
+ Mental effort caused by poor design choices. **Eliminate this ruthlessly** — it's pure waste.
20
+
21
+ **Common sources**:
22
+ - Confusing navigation that requires mental mapping
23
+ - Unclear labels that force users to guess meaning
24
+ - Visual clutter competing for attention
25
+ - Inconsistent patterns that prevent learning
26
+ - Unnecessary steps between user intent and result
27
+
28
+ ### Germane Load — Learning Effort
29
+ Mental effort spent building understanding. This is *good* cognitive load — it leads to mastery.
30
+
31
+ **Support it by**:
32
+ - Progressive disclosure that reveals complexity gradually
33
+ - Consistent patterns that reward learning
34
+ - Feedback that confirms correct understanding
35
+ - Onboarding that teaches through action, not walls of text
36
+
37
+ ---
38
+
39
+ ## Cognitive Load Checklist
40
+
41
+ Evaluate the interface against these 8 items:
42
+
43
+ - [ ] **Single focus**: Can the user complete their primary task without distraction from competing elements?
44
+ - [ ] **Chunking**: Is information presented in digestible groups (≤4 items per group)?
45
+ - [ ] **Grouping**: Are related items visually grouped together (proximity, borders, shared background)?
46
+ - [ ] **Visual hierarchy**: Is it immediately clear what's most important on the screen?
47
+ - [ ] **One thing at a time**: Can the user focus on a single decision before moving to the next?
48
+ - [ ] **Minimal choices**: Are decisions simplified (≤4 visible options at any decision point)?
49
+ - [ ] **Working memory**: Does the user need to remember information from a previous screen to act on the current one?
50
+ - [ ] **Progressive disclosure**: Is complexity revealed only when the user needs it?
51
+
52
+ **Scoring**: Count the failed items. 0–1 failures = low cognitive load (good). 2–3 = moderate (address soon). 4+ = high cognitive load (critical fix needed).
53
+
54
+ ---
55
+
56
+ ## The Working Memory Rule
57
+
58
+ **Humans can hold ≤4 items in working memory at once** (Miller's Law revised by Cowan, 2001).
59
+
60
+ At any decision point, count the number of distinct options, actions, or pieces of information a user must simultaneously consider:
61
+ - **≤4 items**: Within working memory limits — manageable
62
+ - **5–7 items**: Pushing the boundary — consider grouping or progressive disclosure
63
+ - **8+ items**: Overloaded — users will skip, misclick, or abandon
64
+
65
+ **Practical applications**:
66
+ - Navigation menus: ≤5 top-level items (group the rest under clear categories)
67
+ - Form sections: ≤4 fields visible per group before a visual break
68
+ - Action buttons: 1 primary, 1–2 secondary, group the rest in a menu
69
+ - Dashboard widgets: ≤4 key metrics visible without scrolling
70
+ - Pricing tiers: ≤3 options (more causes analysis paralysis)
71
+
72
+ ---
73
+
74
+ ## Common Cognitive Load Violations
75
+
76
+ ### 1. The Wall of Options
77
+ **Problem**: Presenting 10+ choices at once with no hierarchy.
78
+ **Fix**: Group into categories, highlight recommended, use progressive disclosure.
79
+
80
+ ### 2. The Memory Bridge
81
+ **Problem**: User must remember info from step 1 to complete step 3.
82
+ **Fix**: Keep relevant context visible, or repeat it where it's needed.
83
+
84
+ ### 3. The Hidden Navigation
85
+ **Problem**: User must build a mental map of where things are.
86
+ **Fix**: Always show current location (breadcrumbs, active states, progress indicators).
87
+
88
+ ### 4. The Jargon Barrier
89
+ **Problem**: Technical or domain language forces translation effort.
90
+ **Fix**: Use plain language. If domain terms are unavoidable, define them inline.
91
+
92
+ ### 5. The Visual Noise Floor
93
+ **Problem**: Every element has the same visual weight — nothing stands out.
94
+ **Fix**: Establish clear hierarchy: one primary element, 2–3 secondary, everything else muted.
95
+
96
+ ### 6. The Inconsistent Pattern
97
+ **Problem**: Similar actions work differently in different places.
98
+ **Fix**: Standardize interaction patterns. Same type of action = same type of UI.
99
+
100
+ ### 7. The Multi-Task Demand
101
+ **Problem**: Interface requires processing multiple simultaneous inputs (reading + deciding + navigating).
102
+ **Fix**: Sequence the steps. Let the user do one thing at a time.
103
+
104
+ ### 8. The Context Switch
105
+ **Problem**: User must jump between screens/tabs/modals to gather info for a single decision.
106
+ **Fix**: Co-locate the information needed for each decision. Reduce back-and-forth.