arkaos 2.52.0 → 2.54.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.
- package/VERSION +1 -1
- package/departments/marketing/skills/growth-loop/SKILL.md +140 -23
- package/departments/marketing/workflows/growth-loop.yaml +141 -0
- package/departments/strategy/skills/growth-strategy/SKILL.md +135 -6
- package/departments/strategy/workflows/blue-ocean.yaml +136 -0
- package/departments/strategy/workflows/growth.yaml +139 -0
- package/package.json +1 -1
- package/pyproject.toml +1 -1
package/VERSION
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
2.
|
|
1
|
+
2.54.0
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: mkt/growth-loop
|
|
3
3
|
description: >
|
|
4
|
-
Design sustainable growth loops (viral, paid, product) that compound over time.
|
|
5
|
-
Replaces linear funnels with self-reinforcing cycles.
|
|
4
|
+
Design sustainable growth loops (viral, paid, content, product, community) that compound over time.
|
|
5
|
+
Replaces linear funnels with self-reinforcing cycles. Spec + math + instrumentation + 30-day experiment plan.
|
|
6
6
|
allowed-tools: [Read, Write, Edit, Agent, WebFetch, WebSearch]
|
|
7
7
|
---
|
|
8
8
|
|
|
@@ -22,43 +22,160 @@ does not replace the vault.
|
|
|
22
22
|
|
|
23
23
|
# Growth Loop Design — `/mkt growth-loop`
|
|
24
24
|
|
|
25
|
-
> **
|
|
25
|
+
> **Lead:** Luna (Marketing Director) | **Cross-dept:** Pedro (Paid Specialist) + Tomas (Strategy) + Helena (CFO) | **Framework:** Growth Loops (Andrew Chen / Reforge)
|
|
26
26
|
|
|
27
27
|
## Why Loops > Funnels
|
|
28
28
|
|
|
29
|
-
Funnels are linear: input stops → output stops.
|
|
30
|
-
Loops are circular: output feeds next cycle's input.
|
|
29
|
+
Funnels are linear: input stops → output stops. Every new customer requires fresh top-of-funnel work. CAC stays flat or rises.
|
|
31
30
|
|
|
32
|
-
|
|
31
|
+
Loops are circular: **output feeds the next cycle's input**. The system gets stronger with use. CAC trends toward zero on the marginal customer.
|
|
32
|
+
|
|
33
|
+
A growing business is the sum of working loops, not the sum of funnels.
|
|
34
|
+
|
|
35
|
+
## Loop Type Decision Matrix
|
|
36
|
+
|
|
37
|
+
Pick the primary loop based on product DNA, retention shape, and unit economics. Mixing loop types without committing to a primary produces zero compounding.
|
|
38
|
+
|
|
39
|
+
| Loop type | Default product DNA | Min retention | Min unit econ | Compounding rate | Typical payback |
|
|
40
|
+
|---|---|---|---|---|---|
|
|
41
|
+
| **Viral** | UGC, communication, multiplayer | D30 ≥ 25% | Free or freemium | K-factor (target > 0.5) | Weeks |
|
|
42
|
+
| **Paid** | Clear LTV signal, AOV ≥ CAC × 3 | D30 ≥ 30% | LTV/CAC ≥ 3 | Reinvest ratio | 6-12 months |
|
|
43
|
+
| **Content** | Searchable problem space, repeat searcher | Brand recall | Long-tail compound | Page-month growth | 3-12 months |
|
|
44
|
+
| **Product** | Multi-user by design (invite, share, embed) | D30 ≥ 40% | Free trial / freemium | Natural rate of growth | Months |
|
|
45
|
+
| **Community** | Identity-driven adoption, practitioner audience | D90 ≥ 50% | LTV scales with engagement | Member-second-order growth | Quarters |
|
|
46
|
+
|
|
47
|
+
If you don't pass any minimum, **fix retention first**. Loops on broken retention amplify churn.
|
|
48
|
+
|
|
49
|
+
## The 5 Loop Types Fully Spec'd
|
|
33
50
|
|
|
34
51
|
### 1. Viral Loop (User-Generated)
|
|
52
|
+
|
|
35
53
|
```
|
|
36
|
-
User creates content → Content indexed/shared → New user discovers → Signs up → REPEAT
|
|
54
|
+
User creates content → Content indexed/shared → New user discovers → Signs up → Creates content → REPEAT
|
|
37
55
|
```
|
|
38
|
-
|
|
39
|
-
|
|
56
|
+
|
|
57
|
+
Worked example: Pinterest, YouTube, Notion templates, Figma community files.
|
|
58
|
+
|
|
59
|
+
Key metric: **K-factor** = invites sent × conversion rate. K > 1 = exponential. K = 0.5 means each new user brings 0.5 more (sub-viral but compounds with paid).
|
|
60
|
+
|
|
61
|
+
Failure modes: K declines as audience saturates → loop dies. Invite incentives without product value → users opt out. Content production without index → SEO doesn't pick up.
|
|
62
|
+
|
|
63
|
+
Instrumentation needed: sign-up event with source (viral_invite vs organic), invite-sent event with recipient_id, conversion event from invite landing.
|
|
40
64
|
|
|
41
65
|
### 2. Paid Loop (Revenue-Funded)
|
|
66
|
+
|
|
42
67
|
```
|
|
43
68
|
User pays → Revenue reinvested in ads → New user acquired → Pays → REPEAT
|
|
44
69
|
```
|
|
45
|
-
Example: DTC brands, SaaS with efficient paid
|
|
46
|
-
Requirement: LTV:CAC > 3:1, payback < 12 months
|
|
47
70
|
|
|
48
|
-
|
|
71
|
+
Worked example: DTC brands with strong AOV, SaaS with efficient paid (Notion, Webflow at scale), pure-play e-commerce.
|
|
72
|
+
|
|
73
|
+
Required unit economics: **LTV/CAC ≥ 3, CAC payback < 12 months**. Below those, the loop runs negative against runway.
|
|
74
|
+
|
|
75
|
+
Failure modes: Channel saturation drives CAC up faster than LTV improves. Single-channel concentration (90% Meta) collapses on platform changes. Attribution opacity prevents real ROI measurement → you reinvest into losing channels.
|
|
76
|
+
|
|
77
|
+
Instrumentation needed: per-channel CAC tracking, cohort LTV (D30/D90/D365), payback cohort analysis, attribution model (last-touch + multi-touch comparison).
|
|
78
|
+
|
|
79
|
+
### 3. Content Loop (Search-Driven)
|
|
80
|
+
|
|
81
|
+
```
|
|
82
|
+
User searches problem → Lands on content → Converts to lead/customer → Content earns links → Ranks higher → More searchers find it → REPEAT
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
Worked example: Ahrefs, HubSpot, Investopedia, Wirecutter.
|
|
86
|
+
|
|
87
|
+
Key metric: **Page-month growth rate** + **Domain Authority compounding**. New page-months publish faster than old page-months decay.
|
|
88
|
+
|
|
89
|
+
Failure modes: Content quality below SERP threshold → no ranking. No internal linking → no topical authority. AI-flood post-2024 raised the quality floor; thin content doesn't rank.
|
|
90
|
+
|
|
91
|
+
Instrumentation needed: GSC clicks/impressions per page, organic conversion rate per page, time-to-first-rank, total indexable pages.
|
|
92
|
+
|
|
93
|
+
### 4. Product Loop (Built-in Virality)
|
|
94
|
+
|
|
95
|
+
```
|
|
96
|
+
User uses product → Product surface exposes to others → Others see it / receive output → Sign up / install → REPEAT
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
Worked example: Slack (invite team), Dropbox (share file), Calendly (send invite link), Figma (share design link), Loom (share recording).
|
|
100
|
+
|
|
101
|
+
Key metric: **Natural rate of growth** = % of new users from product surface (not paid, not virally invited).
|
|
102
|
+
|
|
103
|
+
Failure modes: Product output stays inside the team (no external exposure surface). Sharing requires extra steps (high friction). Output looks bad outside the product (no brand impression).
|
|
104
|
+
|
|
105
|
+
Instrumentation needed: source attribution on first session (product_share_url vs organic vs paid), share-link click-to-signup conversion, output-publish event tracking.
|
|
106
|
+
|
|
107
|
+
### 5. Community Loop (Identity-Driven)
|
|
108
|
+
|
|
49
109
|
```
|
|
50
|
-
|
|
110
|
+
Practitioner joins community → Status from contributing → Other practitioners notice → Join → Contribute → REPEAT
|
|
51
111
|
```
|
|
52
|
-
Example: Slack (invite team), Dropbox (share files), Calendly (send invite)
|
|
53
|
-
Key metric: Natural rate of growth (organic + viral, no paid)
|
|
54
112
|
|
|
55
|
-
|
|
113
|
+
Worked example: Stack Overflow, Reddit communities, Substack networks, Slack practitioner groups, Discord servers.
|
|
114
|
+
|
|
115
|
+
Key metric: **Member-second-order growth** — for every new member, how many new members do they bring within 90 days?
|
|
116
|
+
|
|
117
|
+
Failure modes: Community grows but doesn't tie to product revenue (community-led ≠ revenue loop). Status hierarchy collapses → top contributors leave. Spam erodes signal → quality contributors disengage.
|
|
118
|
+
|
|
119
|
+
Instrumentation needed: cohort retention curves (D30/D90/D365), contribution distribution (Gini coefficient), second-order growth attribution.
|
|
120
|
+
|
|
121
|
+
## Loop Specification Format
|
|
122
|
+
|
|
123
|
+
Every loop spec must answer these 6 questions in the same shape:
|
|
124
|
+
|
|
125
|
+
```yaml
|
|
126
|
+
loop_name: <descriptive name>
|
|
127
|
+
loop_type: viral | paid | content | product | community
|
|
128
|
+
|
|
129
|
+
step_1_trigger:
|
|
130
|
+
what_happens: <observable event>
|
|
131
|
+
mechanism: <named mechanism, not vibes>
|
|
132
|
+
metric: <measurable target>
|
|
133
|
+
owner: <named human>
|
|
134
|
+
|
|
135
|
+
step_2_action:
|
|
136
|
+
what_user_does: <observable user action>
|
|
137
|
+
mechanism: <what makes this action likely>
|
|
138
|
+
metric: <conversion rate target>
|
|
139
|
+
owner: <named human>
|
|
140
|
+
|
|
141
|
+
step_3_output:
|
|
142
|
+
what_gets_produced: <artifact, signal, content, money>
|
|
143
|
+
visibility: <internal | shareable | indexed | broadcast>
|
|
144
|
+
metric: <output volume target>
|
|
145
|
+
owner: <named human>
|
|
146
|
+
|
|
147
|
+
step_4_reinput:
|
|
148
|
+
how_output_becomes_input: <named mechanism>
|
|
149
|
+
audience: <who sees the output>
|
|
150
|
+
metric: <reinput conversion rate>
|
|
151
|
+
owner: <named human>
|
|
152
|
+
|
|
153
|
+
cycle_time: <hours / days / weeks per full loop>
|
|
154
|
+
compounding_factor: <K-factor / reinvest ratio / page velocity / NRG / 2nd-order rate>
|
|
155
|
+
breakeven_threshold: <the number where loop self-sustains>
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
## Loop Design Checklist (pre-instrumentation)
|
|
159
|
+
|
|
160
|
+
Before instrumenting, the loop must pass these 8 checks. Failing any check means the loop is incoherent — fix the spec before tracking.
|
|
161
|
+
|
|
162
|
+
- [ ] **Output is observable** — the loop's output (artifact, signal, post, share) can be counted, not inferred
|
|
163
|
+
- [ ] **Re-input mechanism is named** — "users tell their friends" is vibes; "invite link with referral code on Day 7 prompt" is a mechanism
|
|
164
|
+
- [ ] **No infinite resource assumed** — the loop doesn't require infinite content production, infinite paid budget, or infinite founder time
|
|
165
|
+
- [ ] **Step ownership is human-named** — every step has a named owner, not "marketing team"
|
|
166
|
+
- [ ] **Cycle time is sub-quarterly** — at least one full loop completes within 90 days, otherwise feedback is too slow
|
|
167
|
+
- [ ] **Compounding factor is computable** — you can express the math: K-factor, reinvest ratio, NRG percentage
|
|
168
|
+
- [ ] **Breakeven threshold is named** — you know the number at which the loop self-sustains
|
|
169
|
+
- [ ] **Failure modes are listed** — the spec names 2-3 things that would kill the loop and the early signals
|
|
170
|
+
|
|
171
|
+
## Common Failure Modes Across All Loop Types
|
|
172
|
+
|
|
173
|
+
1. **Mistaking content for loop** — publishing content monthly isn't a loop unless each piece earns links/searches that bring new users
|
|
174
|
+
2. **No instrumentation** — without per-step tracking, you can't tell if the loop is working or if growth is from somewhere else
|
|
175
|
+
3. **Multiple half-loops** — running 3 loops at 0.3x compounding ≠ 1 loop at 1.0x. Pick a primary
|
|
176
|
+
4. **Loop without retention** — a loop on broken retention amplifies churn. Fix D30 first
|
|
177
|
+
5. **Loop ignores unit economics** — viral loops still need someone to pay eventually; product loops still need conversion rate
|
|
56
178
|
|
|
57
|
-
|
|
58
|
-
2. **Map the user action** — What does the user do?
|
|
59
|
-
3. **Find the output** — What does the action produce?
|
|
60
|
-
4. **Trace the reinput** — How does output bring new users?
|
|
61
|
-
5. **Measure the cycle** — How long is one loop? What's the conversion at each step?
|
|
62
|
-
6. **Optimize the bottleneck** — Which step has the biggest drop-off?
|
|
179
|
+
## Output → Obsidian: `WizardingCode/Marketing/GrowthLoops/<product>-<date>/`
|
|
63
180
|
|
|
64
|
-
|
|
181
|
+
Delivers: retention baseline + loop type selection rationale + full loop spec (all 4 steps with mechanism/metric/owner per step) + compounding math + unit economics check + instrumentation tracking spec + 30-day experiment plan + 1-page executive summary.
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
id: mkt-growth-loop
|
|
2
|
+
name: Growth Loop Design
|
|
3
|
+
description: Design a sustainable growth loop (viral / paid / content / product / community) that compounds over time
|
|
4
|
+
department: marketing
|
|
5
|
+
tier: enterprise
|
|
6
|
+
command: "/mkt growth-loop"
|
|
7
|
+
requires_branch: false
|
|
8
|
+
requires_spec: false
|
|
9
|
+
quality_gate_required: true
|
|
10
|
+
|
|
11
|
+
phases:
|
|
12
|
+
- id: brief
|
|
13
|
+
name: Growth Loop Brief
|
|
14
|
+
description: Frame product, current growth, audience, retention baseline, runway
|
|
15
|
+
agents:
|
|
16
|
+
- agent_id: marketing-director-luna
|
|
17
|
+
role: Frame product, current new-user volume, current retention curve (D1/D7/D30), runway
|
|
18
|
+
gate:
|
|
19
|
+
type: user_approval
|
|
20
|
+
description: User confirms product context, current growth, retention baseline
|
|
21
|
+
|
|
22
|
+
- id: retention-baseline
|
|
23
|
+
name: Retention Baseline
|
|
24
|
+
description: Measure the current retention curve and identify the activation moment
|
|
25
|
+
agents:
|
|
26
|
+
- agent_id: marketing-director-luna
|
|
27
|
+
role: Compute D1/D7/D30/D90 retention from existing analytics, identify activation event
|
|
28
|
+
- agent_id: strategy-director-tomas
|
|
29
|
+
role: Compare retention to category norms; flag whether product-market fit is plausible
|
|
30
|
+
parallel: true
|
|
31
|
+
gate:
|
|
32
|
+
type: user_approval
|
|
33
|
+
description: User approves retention baseline and activation event
|
|
34
|
+
outputs:
|
|
35
|
+
- type: document
|
|
36
|
+
format: markdown
|
|
37
|
+
obsidian_path: "WizardingCode/Marketing/GrowthLoops/Baseline/"
|
|
38
|
+
description: Retention baseline with activation event and category comparison
|
|
39
|
+
|
|
40
|
+
- id: loop-selection
|
|
41
|
+
name: Loop Type Selection
|
|
42
|
+
description: Pick the primary loop type (viral / paid / content / product / community) based on product DNA and retention curve
|
|
43
|
+
agents:
|
|
44
|
+
- agent_id: marketing-director-luna
|
|
45
|
+
role: Apply loop-type fitness matrix (retention shape × CAC payback × content production capacity)
|
|
46
|
+
- agent_id: paid-specialist-pedro
|
|
47
|
+
role: Paid-loop feasibility math (CAC × LTV × payback window)
|
|
48
|
+
parallel: true
|
|
49
|
+
gate:
|
|
50
|
+
type: user_approval
|
|
51
|
+
description: User approves loop type + secondary loop choice
|
|
52
|
+
|
|
53
|
+
- id: loop-design
|
|
54
|
+
name: Loop Specification
|
|
55
|
+
description: Spec the loop — Input → Action → Output → Re-input. Define every step's mechanism and metric
|
|
56
|
+
agents:
|
|
57
|
+
- agent_id: marketing-director-luna
|
|
58
|
+
role: Loop spec with named mechanism per step and target metric per step
|
|
59
|
+
gate:
|
|
60
|
+
type: user_approval
|
|
61
|
+
description: User approves the loop spec before instrumentation
|
|
62
|
+
outputs:
|
|
63
|
+
- type: document
|
|
64
|
+
format: markdown
|
|
65
|
+
obsidian_path: "WizardingCode/Marketing/GrowthLoops/Specs/"
|
|
66
|
+
description: Loop specification with per-step mechanisms and metrics
|
|
67
|
+
|
|
68
|
+
- id: compounding-math
|
|
69
|
+
name: Compounding Math
|
|
70
|
+
description: Compute the loop's compounding factor — viral coefficient K, content velocity, CAC payback — and the conditions for self-sustaining
|
|
71
|
+
agents:
|
|
72
|
+
- agent_id: marketing-director-luna
|
|
73
|
+
role: Compute K-factor / content compounding rate / payback window; identify the breakeven threshold
|
|
74
|
+
- agent_id: cfo-helena
|
|
75
|
+
role: Validate unit economics — LTV/CAC, contribution margin, runway impact
|
|
76
|
+
parallel: true
|
|
77
|
+
gate:
|
|
78
|
+
type: user_approval
|
|
79
|
+
description: User approves the loop economics
|
|
80
|
+
|
|
81
|
+
- id: instrumentation
|
|
82
|
+
name: Instrumentation
|
|
83
|
+
description: Define the tracking spec — every loop step needs an event + a dashboard widget
|
|
84
|
+
agents:
|
|
85
|
+
- agent_id: marketing-director-luna
|
|
86
|
+
role: Event schema per step, dashboard layout, owner per metric
|
|
87
|
+
- agent_id: tech-director-francisca
|
|
88
|
+
role: Tracking implementation feasibility check
|
|
89
|
+
parallel: true
|
|
90
|
+
gate:
|
|
91
|
+
type: auto
|
|
92
|
+
|
|
93
|
+
- id: experiment-plan
|
|
94
|
+
name: 30-Day Experiment Plan
|
|
95
|
+
description: First 30 days — what to test, what hypothesis per test, how to declare a win
|
|
96
|
+
agents:
|
|
97
|
+
- agent_id: marketing-director-luna
|
|
98
|
+
role: 3-5 prioritized experiments with hypothesis, MDE, success criteria
|
|
99
|
+
gate:
|
|
100
|
+
type: user_approval
|
|
101
|
+
description: User approves the 30-day experiment plan
|
|
102
|
+
|
|
103
|
+
- id: self-critique
|
|
104
|
+
name: Self-Critique
|
|
105
|
+
description: Stress-test the loop — is every step instrumented? Are dependencies named? What kills the loop?
|
|
106
|
+
agents:
|
|
107
|
+
- agent_id: marketing-director-luna
|
|
108
|
+
role: Loop coherence + failure-mode enumeration
|
|
109
|
+
gate:
|
|
110
|
+
type: auto
|
|
111
|
+
|
|
112
|
+
- id: quality-gate
|
|
113
|
+
name: Quality Gate
|
|
114
|
+
model_override: opus
|
|
115
|
+
description: Mandatory quality review
|
|
116
|
+
agents:
|
|
117
|
+
- agent_id: cqo-marta
|
|
118
|
+
role: Orchestrate quality review
|
|
119
|
+
- agent_id: copy-director-eduardo
|
|
120
|
+
role: Loop documentation clarity, no clichés, mechanism specificity
|
|
121
|
+
parallel: true
|
|
122
|
+
- agent_id: tech-director-francisca
|
|
123
|
+
role: Instrumentation correctness, tracking event integrity, dashboard feasibility
|
|
124
|
+
parallel: true
|
|
125
|
+
gate:
|
|
126
|
+
type: quality_gate
|
|
127
|
+
required_verdict: APPROVED
|
|
128
|
+
|
|
129
|
+
- id: delivery
|
|
130
|
+
name: Growth Loop Package Delivery
|
|
131
|
+
description: Compile the loop package — spec + economics + instrumentation + experiment plan
|
|
132
|
+
agents:
|
|
133
|
+
- agent_id: marketing-director-luna
|
|
134
|
+
role: Full growth loop package + 1-page executive summary
|
|
135
|
+
gate:
|
|
136
|
+
type: auto
|
|
137
|
+
outputs:
|
|
138
|
+
- type: document
|
|
139
|
+
format: markdown
|
|
140
|
+
obsidian_path: "WizardingCode/Marketing/GrowthLoops/"
|
|
141
|
+
description: Complete growth loop package — retention baseline + loop spec + compounding math + instrumentation spec + 30-day experiment plan + exec summary
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: strat/growth-strategy
|
|
3
3
|
description: >
|
|
4
|
-
Growth strategy
|
|
4
|
+
Growth strategy using Ansoff Matrix + adjacency framework + Greiner growth
|
|
5
|
+
phases. Picks the next growth vector with risk-adjusted feasibility and a
|
|
6
|
+
12-month execution roadmap.
|
|
5
7
|
allowed-tools: [Read, Write, Edit, Bash, Grep, Glob, Agent, WebFetch, WebSearch]
|
|
6
8
|
---
|
|
7
9
|
|
|
@@ -21,12 +23,139 @@ does not replace the vault.
|
|
|
21
23
|
|
|
22
24
|
# Growth Strategy — `/strat growth <business>`
|
|
23
25
|
|
|
24
|
-
> **
|
|
26
|
+
> **Lead:** Tomas (Chief Strategist) | **Cross-dept:** Helena (CFO) + Rita (Market Analyst) | **Frameworks:** Ansoff Matrix + Chris Zook Adjacencies + Greiner Growth Phases
|
|
25
27
|
|
|
26
|
-
## What
|
|
28
|
+
## What ships
|
|
27
29
|
|
|
28
|
-
|
|
30
|
+
A production growth strategy in 6 deliverables:
|
|
29
31
|
|
|
30
|
-
|
|
32
|
+
1. **Greiner phase diagnosis** — current phase + impending crisis prediction
|
|
33
|
+
2. **Ansoff Matrix mapping** — concrete options per quadrant with market sizing
|
|
34
|
+
3. **Adjacency analysis** — ranked adjacencies by distance × capability × attractiveness
|
|
35
|
+
4. **Growth vector selection** — primary + assist with explicit trade-off rationale
|
|
36
|
+
5. **Risk profile** — pre-mortem with top 5 risks + early warning signals + mitigations
|
|
37
|
+
6. **12-month execution roadmap** — quarter-by-quarter milestones with named owners
|
|
31
38
|
|
|
32
|
-
|
|
39
|
+
## Greiner Growth Phases (where are you in the curve?)
|
|
40
|
+
|
|
41
|
+
Larry Greiner's model says companies grow through 6 evolutionary phases, each ending in a predictable crisis. Knowing the phase predicts the crisis.
|
|
42
|
+
|
|
43
|
+
| # | Phase | Driver | Predictable Crisis | Resolution |
|
|
44
|
+
|---|---|---|---|---|
|
|
45
|
+
| 1 | **Creativity** | Founder vision + product-market fit | Leadership Crisis (founder can't manage operations) | Hire professional management |
|
|
46
|
+
| 2 | **Direction** | Top-down management + functional structure | Autonomy Crisis (middle managers blocked by HQ) | Delegate authority downward |
|
|
47
|
+
| 3 | **Delegation** | Decentralised operating units | Control Crisis (HQ loses visibility into BUs) | Build coordination systems |
|
|
48
|
+
| 4 | **Coordination** | Formal systems, planning, ROI gates | Red Tape Crisis (bureaucracy strangles decisions) | Collaboration via teams |
|
|
49
|
+
| 5 | **Collaboration** | Cross-functional teams, matrix structure | Growth Crisis (internal saturation, need new sources) | External alliances / M&A |
|
|
50
|
+
| 6 | **Alliances** | Partnerships, joint ventures, ecosystems | Identity Crisis (who are we?) | Reinvention / spin-out |
|
|
51
|
+
|
|
52
|
+
Diagnose by symptoms, not org-chart vibes. Each phase has specific decision-making patterns and pain points.
|
|
53
|
+
|
|
54
|
+
## The Ansoff Matrix (4 growth quadrants)
|
|
55
|
+
|
|
56
|
+
The 2×2 matrix on Products (existing / new) × Markets (existing / new). Each quadrant has a different risk profile.
|
|
57
|
+
|
|
58
|
+
```
|
|
59
|
+
EXISTING PRODUCTS NEW PRODUCTS
|
|
60
|
+
EXISTING MARKETS Market Penetration Product Development
|
|
61
|
+
(lowest risk) (medium-high risk)
|
|
62
|
+
- Cross-sell - Adjacent product
|
|
63
|
+
- Up-sell - Same customer expansion
|
|
64
|
+
- Win share from competitor
|
|
65
|
+
|
|
66
|
+
NEW MARKETS Market Development Diversification
|
|
67
|
+
(medium risk) (highest risk)
|
|
68
|
+
- New geo - New product + new market
|
|
69
|
+
- New segment - True new business
|
|
70
|
+
- New channel - Acquisition often required
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
Default risk-adjusted sequencing: start with **Market Penetration** until the law of diminishing returns hits (typically 70-80% market share in a defined segment). Then choose between Market Development and Product Development based on capability fit. Diversification only when first three quadrants are exhausted or a structural opportunity is undeniable.
|
|
74
|
+
|
|
75
|
+
## Chris Zook Adjacency Framework
|
|
76
|
+
|
|
77
|
+
For each candidate growth move, score on three dimensions:
|
|
78
|
+
|
|
79
|
+
1. **Distance from core** (1-10): How far is this from your repeatable model? 1 = same customer + same product + tweaks. 10 = different customer + different product + different capability.
|
|
80
|
+
2. **Capability fit** (1-10): Does it use your existing strengths? 10 = leverages your core competence. 1 = requires building all-new capability.
|
|
81
|
+
3. **Market attractiveness** (1-10): Size × growth × profitability of the target market.
|
|
82
|
+
|
|
83
|
+
Zook's empirical finding: **adjacency success rate drops 50% with every step away from core**. So the math:
|
|
84
|
+
|
|
85
|
+
```
|
|
86
|
+
expected_success_rate = 0.27 × (0.5 ^ distance_from_core_steps) × capability_fit_factor × market_factor
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
Adjacencies more than 2 steps from core have <10% historical success rate. Pick the closest viable adjacency, not the most attractive one.
|
|
90
|
+
|
|
91
|
+
## Growth Vector Decision Tree
|
|
92
|
+
|
|
93
|
+
```
|
|
94
|
+
Is current retention healthy (D30 > category norm)?
|
|
95
|
+
NO → Fix retention. No growth vector survives broken retention.
|
|
96
|
+
YES → Continue.
|
|
97
|
+
|
|
98
|
+
Have you saturated current market segment (>70% share or stalled)?
|
|
99
|
+
NO → Market Penetration is the default. Cross-sell, up-sell, win share.
|
|
100
|
+
YES → Continue.
|
|
101
|
+
|
|
102
|
+
Do you have unique capability that transfers?
|
|
103
|
+
YES → Product Development (new product to existing customers) OR
|
|
104
|
+
Market Development (existing product to new segment / geo).
|
|
105
|
+
Choose by capability fit score.
|
|
106
|
+
NO → Acquisition or partnership required. Diversification.
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
## Risk Profile Template
|
|
110
|
+
|
|
111
|
+
Every growth vector ships with a pre-mortem. Format:
|
|
112
|
+
|
|
113
|
+
```yaml
|
|
114
|
+
top_5_risks:
|
|
115
|
+
- name: <specific risk>
|
|
116
|
+
probability: low | medium | high
|
|
117
|
+
impact: low | medium | high | terminal
|
|
118
|
+
early_warning_signal: <observable signal in first 90 days>
|
|
119
|
+
mitigation: <named action if signal fires>
|
|
120
|
+
owner: <named human>
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
Risks must be specific. "Market might shift" is vibes; "if our top 3 partners renegotiate pricing in Q2 our gross margin drops below the cost floor" is a risk.
|
|
124
|
+
|
|
125
|
+
## 12-Month Roadmap Template
|
|
126
|
+
|
|
127
|
+
```
|
|
128
|
+
Q1: Foundation
|
|
129
|
+
Milestone: [specific outcome, not activity]
|
|
130
|
+
Owner: [named human]
|
|
131
|
+
Success metric: [measurable number]
|
|
132
|
+
|
|
133
|
+
Q2: First Proof
|
|
134
|
+
Milestone: [first measurable signal that vector is working]
|
|
135
|
+
Owner: [named]
|
|
136
|
+
Decision gate: [continue / pivot criteria]
|
|
137
|
+
|
|
138
|
+
Q3: Scale or Pivot
|
|
139
|
+
Decision: [scale signal observed? Y/N]
|
|
140
|
+
If scale: doubling milestone
|
|
141
|
+
If pivot: alternate vector selected
|
|
142
|
+
|
|
143
|
+
Q4: Compound
|
|
144
|
+
Milestone: [vector now self-sustaining or absorbed into ops]
|
|
145
|
+
Owner: [named]
|
|
146
|
+
Year-end metric: [measurable target tied to original brief]
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
Every quarter has a decision gate, not just a milestone. Roadmaps without decision gates become wish lists.
|
|
150
|
+
|
|
151
|
+
## Common Failure Modes
|
|
152
|
+
|
|
153
|
+
1. **Skipping retention check** — chasing growth on broken retention amplifies churn
|
|
154
|
+
2. **Ansoff diagonal-jumping** — jumping straight to Diversification without proving Market Penetration is exhausted
|
|
155
|
+
3. **Capability vanity** — picking the most attractive adjacency instead of the highest-fit one
|
|
156
|
+
4. **Greiner phase denial** — refusing to acknowledge the next crisis (e.g., founder won't delegate, stays in Direction phase past breakeven)
|
|
157
|
+
5. **Roadmap without decision gates** — quarterly milestones without "continue / pivot" criteria become marketing for the existing strategy
|
|
158
|
+
|
|
159
|
+
## Output → Obsidian: `WizardingCode/Strategy/Growth/<business>-<date>/`
|
|
160
|
+
|
|
161
|
+
Delivers: Greiner phase diagnosis + Ansoff Matrix mapping + adjacency analysis + vector selection rationale + risk profile (5 risks with mitigations) + 12-month roadmap with decision gates + 1-page executive summary.
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
id: strat-blue-ocean
|
|
2
|
+
name: Blue Ocean Strategy
|
|
3
|
+
description: Blue Ocean Strategy canvas with ERRC grid (Eliminate / Reduce / Raise / Create) — define uncontested market space
|
|
4
|
+
department: strategy
|
|
5
|
+
tier: enterprise
|
|
6
|
+
command: "/strat blue-ocean"
|
|
7
|
+
requires_branch: false
|
|
8
|
+
requires_spec: false
|
|
9
|
+
quality_gate_required: true
|
|
10
|
+
|
|
11
|
+
phases:
|
|
12
|
+
- id: brief
|
|
13
|
+
name: Market Brief
|
|
14
|
+
description: Define the current market, the industry's competitive factors, and the customer base under analysis
|
|
15
|
+
agents:
|
|
16
|
+
- agent_id: strategy-director-tomas
|
|
17
|
+
role: Frame current market, named competitors, customer segments
|
|
18
|
+
gate:
|
|
19
|
+
type: user_approval
|
|
20
|
+
description: User confirms market scope, competitor set, customer segments
|
|
21
|
+
|
|
22
|
+
- id: red-ocean-canvas
|
|
23
|
+
name: Red Ocean Strategy Canvas
|
|
24
|
+
description: Map the current industry on the Strategy Canvas — 6-10 competitive factors with relative levels
|
|
25
|
+
agents:
|
|
26
|
+
- agent_id: strategy-director-tomas
|
|
27
|
+
role: Identify 6-10 competitive factors the industry competes on; score each competitor 1-10
|
|
28
|
+
gate:
|
|
29
|
+
type: user_approval
|
|
30
|
+
description: User approves the red ocean canvas before ERRC analysis
|
|
31
|
+
outputs:
|
|
32
|
+
- type: document
|
|
33
|
+
format: markdown
|
|
34
|
+
obsidian_path: "WizardingCode/Strategy/BlueOcean/Canvas/"
|
|
35
|
+
description: Red Ocean Strategy Canvas with competitor scores per factor
|
|
36
|
+
|
|
37
|
+
- id: errc-grid
|
|
38
|
+
name: ERRC Grid
|
|
39
|
+
description: Apply the ERRC framework — Eliminate / Reduce / Raise / Create — to redesign the value curve
|
|
40
|
+
agents:
|
|
41
|
+
- agent_id: strategy-director-tomas
|
|
42
|
+
role: ERRC analysis on each competitive factor with rationale
|
|
43
|
+
- agent_id: market-analyst-rita
|
|
44
|
+
role: Non-customer analysis — what would the 3 tiers of non-customers value?
|
|
45
|
+
parallel: true
|
|
46
|
+
gate:
|
|
47
|
+
type: user_approval
|
|
48
|
+
description: User approves the ERRC grid
|
|
49
|
+
|
|
50
|
+
- id: non-customer-analysis
|
|
51
|
+
name: Non-Customer Analysis
|
|
52
|
+
description: Map the 3 tiers of non-customers (Soon-to-be, Refusing, Unexplored) and what would convert each tier
|
|
53
|
+
agents:
|
|
54
|
+
- agent_id: market-analyst-rita
|
|
55
|
+
role: Define 3 non-customer tiers with their reasons for not buying and conversion triggers
|
|
56
|
+
gate:
|
|
57
|
+
type: user_approval
|
|
58
|
+
description: User approves non-customer analysis
|
|
59
|
+
|
|
60
|
+
- id: blue-ocean-canvas
|
|
61
|
+
name: Blue Ocean Strategy Canvas
|
|
62
|
+
description: Draw the new value curve — the blue ocean position based on ERRC + non-customer insights
|
|
63
|
+
agents:
|
|
64
|
+
- agent_id: strategy-director-tomas
|
|
65
|
+
role: Blue Ocean Strategy Canvas with new value curve; quantify divergence from red ocean
|
|
66
|
+
gate:
|
|
67
|
+
type: user_approval
|
|
68
|
+
description: User approves the blue ocean canvas before viability test
|
|
69
|
+
outputs:
|
|
70
|
+
- type: document
|
|
71
|
+
format: markdown
|
|
72
|
+
obsidian_path: "WizardingCode/Strategy/BlueOcean/Canvas/"
|
|
73
|
+
description: Blue Ocean Strategy Canvas with new value curve and divergence analysis
|
|
74
|
+
|
|
75
|
+
- id: viability-test
|
|
76
|
+
name: Commercial Viability Test
|
|
77
|
+
description: Apply the BOS Sequence — Utility, Price, Cost, Adoption — to test whether the blue ocean is commercially viable
|
|
78
|
+
agents:
|
|
79
|
+
- agent_id: strategy-director-tomas
|
|
80
|
+
role: BOS Sequence test (Buyer Utility Map, Strategic Pricing, Target Cost, Adoption Hurdles)
|
|
81
|
+
- agent_id: cfo-helena
|
|
82
|
+
role: Cost feasibility check — does the target cost math work given the price corridor?
|
|
83
|
+
parallel: true
|
|
84
|
+
gate:
|
|
85
|
+
type: user_approval
|
|
86
|
+
description: User approves commercial viability before execution plan
|
|
87
|
+
|
|
88
|
+
- id: execution-plan
|
|
89
|
+
name: Execution Plan
|
|
90
|
+
description: 90-day execution — first product/service move, channels, organisational changes
|
|
91
|
+
agents:
|
|
92
|
+
- agent_id: strategy-director-tomas
|
|
93
|
+
role: 90-day execution plan with first move, channel implications, organisational changes
|
|
94
|
+
gate:
|
|
95
|
+
type: user_approval
|
|
96
|
+
description: User approves the 90-day execution plan
|
|
97
|
+
|
|
98
|
+
- id: self-critique
|
|
99
|
+
name: Self-Critique
|
|
100
|
+
description: Stress-test the blue ocean — is the divergence real? Are non-customer triggers credible? Does the cost math close?
|
|
101
|
+
agents:
|
|
102
|
+
- agent_id: strategy-director-tomas
|
|
103
|
+
role: Coherence + viability + execution feasibility cross-check
|
|
104
|
+
gate:
|
|
105
|
+
type: auto
|
|
106
|
+
|
|
107
|
+
- id: quality-gate
|
|
108
|
+
name: Quality Gate
|
|
109
|
+
model_override: opus
|
|
110
|
+
description: Mandatory quality review
|
|
111
|
+
agents:
|
|
112
|
+
- agent_id: cqo-marta
|
|
113
|
+
role: Orchestrate quality review
|
|
114
|
+
- agent_id: copy-director-eduardo
|
|
115
|
+
role: Canvas labels, non-customer prose, no clichés
|
|
116
|
+
parallel: true
|
|
117
|
+
- agent_id: tech-director-francisca
|
|
118
|
+
role: Visual canvas integrity, ERRC grid completeness, viability test math
|
|
119
|
+
parallel: true
|
|
120
|
+
gate:
|
|
121
|
+
type: quality_gate
|
|
122
|
+
required_verdict: APPROVED
|
|
123
|
+
|
|
124
|
+
- id: delivery
|
|
125
|
+
name: Blue Ocean Package Delivery
|
|
126
|
+
description: Compile the full blue ocean package
|
|
127
|
+
agents:
|
|
128
|
+
- agent_id: strategy-director-tomas
|
|
129
|
+
role: Full blue ocean package + 1-page executive summary
|
|
130
|
+
gate:
|
|
131
|
+
type: auto
|
|
132
|
+
outputs:
|
|
133
|
+
- type: document
|
|
134
|
+
format: markdown
|
|
135
|
+
obsidian_path: "WizardingCode/Strategy/BlueOcean/"
|
|
136
|
+
description: Complete blue ocean package — red ocean canvas + ERRC grid + non-customer analysis + blue ocean canvas + viability test + execution plan
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
id: strat-growth
|
|
2
|
+
name: Growth Strategy
|
|
3
|
+
description: Growth strategy using Ansoff Matrix + adjacencies + Greiner growth phases — pick the next growth vector with risk-adjusted feasibility
|
|
4
|
+
department: strategy
|
|
5
|
+
tier: enterprise
|
|
6
|
+
command: "/strat growth"
|
|
7
|
+
requires_branch: false
|
|
8
|
+
requires_spec: false
|
|
9
|
+
quality_gate_required: true
|
|
10
|
+
|
|
11
|
+
phases:
|
|
12
|
+
- id: brief
|
|
13
|
+
name: Growth Brief
|
|
14
|
+
description: Define current business state, current revenue mix, current growth rate, runway, success metric
|
|
15
|
+
agents:
|
|
16
|
+
- agent_id: strategy-director-tomas
|
|
17
|
+
role: Frame current business — products, markets, revenue mix, growth rate, runway
|
|
18
|
+
gate:
|
|
19
|
+
type: user_approval
|
|
20
|
+
description: User confirms business context and growth target
|
|
21
|
+
|
|
22
|
+
- id: greiner-diagnosis
|
|
23
|
+
name: Greiner Growth Phase Diagnosis
|
|
24
|
+
description: Identify which Greiner growth phase the business is in (Creativity / Direction / Delegation / Coordination / Collaboration / Alliances) and the predictable crisis
|
|
25
|
+
agents:
|
|
26
|
+
- agent_id: strategy-director-tomas
|
|
27
|
+
role: Greiner phase diagnosis with evidence; name the impending crisis
|
|
28
|
+
gate:
|
|
29
|
+
type: user_approval
|
|
30
|
+
description: User approves Greiner diagnosis
|
|
31
|
+
outputs:
|
|
32
|
+
- type: document
|
|
33
|
+
format: markdown
|
|
34
|
+
obsidian_path: "WizardingCode/Strategy/Growth/Diagnosis/"
|
|
35
|
+
description: Greiner growth phase diagnosis with crisis prediction
|
|
36
|
+
|
|
37
|
+
- id: ansoff-matrix
|
|
38
|
+
name: Ansoff Matrix Analysis
|
|
39
|
+
description: Map growth options across the 4 Ansoff quadrants (Market Penetration / Market Development / Product Development / Diversification)
|
|
40
|
+
agents:
|
|
41
|
+
- agent_id: strategy-director-tomas
|
|
42
|
+
role: Ansoff Matrix mapping with concrete options per quadrant
|
|
43
|
+
- agent_id: market-analyst-rita
|
|
44
|
+
role: Market sizing per quadrant option
|
|
45
|
+
parallel: true
|
|
46
|
+
gate:
|
|
47
|
+
type: user_approval
|
|
48
|
+
description: User approves Ansoff Matrix mapping before adjacency analysis
|
|
49
|
+
|
|
50
|
+
- id: adjacency-analysis
|
|
51
|
+
name: Adjacency Analysis
|
|
52
|
+
description: Apply Chris Zook's adjacency framework — score each adjacency by distance from core, capability fit, market attractiveness
|
|
53
|
+
agents:
|
|
54
|
+
- agent_id: strategy-director-tomas
|
|
55
|
+
role: Adjacency scoring (distance from core × capability fit × market attractiveness)
|
|
56
|
+
- agent_id: cfo-helena
|
|
57
|
+
role: Investment requirement and payback per adjacency
|
|
58
|
+
parallel: true
|
|
59
|
+
gate:
|
|
60
|
+
type: user_approval
|
|
61
|
+
description: User approves adjacency scoring
|
|
62
|
+
outputs:
|
|
63
|
+
- type: document
|
|
64
|
+
format: markdown
|
|
65
|
+
obsidian_path: "WizardingCode/Strategy/Growth/Adjacencies/"
|
|
66
|
+
description: Ranked adjacency analysis with investment + payback
|
|
67
|
+
|
|
68
|
+
- id: vector-selection
|
|
69
|
+
name: Growth Vector Selection
|
|
70
|
+
description: Pick the primary growth vector + assist vector based on Greiner phase, Ansoff quadrant, adjacency ranking
|
|
71
|
+
agents:
|
|
72
|
+
- agent_id: strategy-director-tomas
|
|
73
|
+
role: Vector selection with explicit trade-off rationale
|
|
74
|
+
gate:
|
|
75
|
+
type: user_approval
|
|
76
|
+
description: User approves primary + assist growth vector
|
|
77
|
+
|
|
78
|
+
- id: risk-feasibility
|
|
79
|
+
name: Risk & Feasibility
|
|
80
|
+
description: Stress-test the chosen vector — what kills it? What signals indicate it's working / failing?
|
|
81
|
+
agents:
|
|
82
|
+
- agent_id: strategy-director-tomas
|
|
83
|
+
role: Pre-mortem analysis — top 5 risks + early warning signals + mitigation per risk
|
|
84
|
+
- agent_id: cfo-helena
|
|
85
|
+
role: Runway impact per vector, breakeven scenario, downside math
|
|
86
|
+
parallel: true
|
|
87
|
+
gate:
|
|
88
|
+
type: user_approval
|
|
89
|
+
description: User approves risk profile
|
|
90
|
+
|
|
91
|
+
- id: execution-roadmap
|
|
92
|
+
name: 12-Month Execution Roadmap
|
|
93
|
+
description: Quarter-by-quarter milestones, owner per milestone, success metric per quarter
|
|
94
|
+
agents:
|
|
95
|
+
- agent_id: strategy-director-tomas
|
|
96
|
+
role: 12-month roadmap with quarterly milestones and named owners
|
|
97
|
+
gate:
|
|
98
|
+
type: user_approval
|
|
99
|
+
description: User approves the 12-month roadmap
|
|
100
|
+
|
|
101
|
+
- id: self-critique
|
|
102
|
+
name: Self-Critique
|
|
103
|
+
description: Stress-test coherence — does Greiner phase support the chosen vector? Does Ansoff position match adjacency ranking?
|
|
104
|
+
agents:
|
|
105
|
+
- agent_id: strategy-director-tomas
|
|
106
|
+
role: Coherence check across Greiner / Ansoff / adjacency / vector / roadmap
|
|
107
|
+
gate:
|
|
108
|
+
type: auto
|
|
109
|
+
|
|
110
|
+
- id: quality-gate
|
|
111
|
+
name: Quality Gate
|
|
112
|
+
model_override: opus
|
|
113
|
+
description: Mandatory quality review
|
|
114
|
+
agents:
|
|
115
|
+
- agent_id: cqo-marta
|
|
116
|
+
role: Orchestrate quality review
|
|
117
|
+
- agent_id: copy-director-eduardo
|
|
118
|
+
role: Diagnosis prose, vector rationale, no clichés
|
|
119
|
+
parallel: true
|
|
120
|
+
- agent_id: tech-director-francisca
|
|
121
|
+
role: Roadmap executability, milestone measurability, owner specificity
|
|
122
|
+
parallel: true
|
|
123
|
+
gate:
|
|
124
|
+
type: quality_gate
|
|
125
|
+
required_verdict: APPROVED
|
|
126
|
+
|
|
127
|
+
- id: delivery
|
|
128
|
+
name: Growth Strategy Package Delivery
|
|
129
|
+
description: Compile the full growth strategy package
|
|
130
|
+
agents:
|
|
131
|
+
- agent_id: strategy-director-tomas
|
|
132
|
+
role: Full growth package + 1-page executive summary
|
|
133
|
+
gate:
|
|
134
|
+
type: auto
|
|
135
|
+
outputs:
|
|
136
|
+
- type: document
|
|
137
|
+
format: markdown
|
|
138
|
+
obsidian_path: "WizardingCode/Strategy/Growth/"
|
|
139
|
+
description: Complete growth package — Greiner diagnosis + Ansoff Matrix + adjacency analysis + vector selection + risk profile + 12-month roadmap
|
package/package.json
CHANGED