name: mb-bet description: "Open, update, close, list, and narrate Main Branch business bets from repo truth. Use when the operator wants to frame an operating bet, track progress, capture a verdict, or draft public-safe narration." loops: [decide, reflect, ship]
Bet
Shared source: The portable workflow contract lives in
workflows/mb-bet/workflow.md. This Claude skill is the Claude Code shell over
that source.
Shared contract markers: Keep these aligned with the shared source.
Required commands:
mb status --json --peekmb start --jsonmb doctor repair --planmb validate --cross-refs --jsonmb checkpoint --plan --jsonmb similar-bets "<thesis>" --repo . --jsonmb books exposure --repo . --bet bets/YYYY-MM-DD-slug.md --jsonmb books exposure --repo . --active --json
Required fact paths:
money_pathmoney_path.objects.proof.qualityvalidation.file_contractscontent_strategyranked_actionsupdatereadinessdrift.itemsbrain.betsbrain.bets.activebrain.bets.due_soonbrain.bets.overduebrain.bets.exit_criteriarelationship_health.sections.betsrelationship_health.gapscheckpoint.pendingcheckpoint.pending.blockersbooksruntime.codex_cliruntime.claude_code
Approval gates: updates_repairs_migrations, file_writes, checkpoint,
provider_mutation, publishing_or_spend, customer_contact, private_data,
destructive_operations, structured_collection, and
public_issue_or_proposal.
Public/private boundaries: no_secrets, no_raw_provider_exports,
no_raw_transcripts, no_customer_member_data,
no_private_runtime_settings, no_private_dms_or_gated_communities,
no_raw_finance_legal_records, and no_raw_ledger_rows.
Core flow: Bet is a time-boxed wager, not an offer or push. Preserve new,
update, close, list, and narrate modes.
Marker phrase: new, update, close, list, and narrate.
Keep bets/YYYY-MM-DD-slug.md and the strict contract for typed links and
reverse linked_bets; aggregate exposure privacy; public-safe narration;
mb validate --cross-refs; checkpoint plan; and the Codex support boundary of
read-only planning until runtime smoke proves lifecycle writes.
Business bets are hub nodes in bets/. They connect decisions, research,
pushes, logs, documents, and outcomes without replacing any of them. Legacy
campaigns/ records may still be linked for old repos, but new coordinated
work uses pushes/.
A bet is not an offer. An offer is a durable thing the business sells. A bet is
a time-boxed operating hypothesis with appetite, target, deadline, evidence,
and a verdict. A successful bet may graduate into an offer, workflow, content
pillar, push, or decision; a failed bet should be closed with learning.
For the full offer/bet/push/proof routing rubric, use
.claude/reference/business-primitives/offer-bet-push-proof.md.
Use /mb-bet for five modes:
new- open a bet with hypothesis, appetite, MoneyPath anchor, metric, target, deadline, and links.update- add progress and link new evidence.close- record result, verdict, learning, and follow-up links.list- summarize active bets and deadlines.narrate- draft public-safe site, community, or social copy from repo truth.
Do not publish automatically. Narration drafts are files or message drafts only.
Repo Rules
Work from the business repo. If unsure, confirm that core/, research/,
decisions/, or bets/ exists in the current directory. If not, ask the
operator to start Claude from the business repo or run /mb-start.
CLI facts first: Use mb status --json --peek for active bets and repo
readiness before direct file reads. Use mb validate --cross-refs after
bet/link edits instead of hand-checking relationship health in prose.
Before writing, run:
mb status --json --peek
Use the result to spot active bets and repo readiness. After writing or editing bet files, run:
mb validate --cross-refs
If validation warns about missing bidirectional bet links, repair the linked file frontmatter when it is clearly in scope.
Bet Frontmatter
Every bet file lives at bets/YYYY-MM-DD-slug.md and uses this frontmatter:
---
status: open
opened: YYYY-MM-DD
deadline: YYYY-MM-DD
appetite: "2 weeks"
appetite_tier: small
hypothesis: "If we do X for Y, Z will happen because..."
metric: "qualified calls booked"
target: "10 qualified calls by deadline"
result: ""
owner: ""
money_path:
required: true
bet_id: YYYY-MM-DD-slug
exposure_cap:
amount: 500
currency: USD
anchor_required_before: execution
kill_rubric:
failure_signals:
- id: no-qualified-calls
metric: qualified_calls
comparator: <
threshold: 3
by: YYYY-MM-DD
action: kill
double_down_signals:
- id: profitable-signal
metric: cost_per_qualified_call
comparator: <=
threshold: 150
action: double_down
linked_decisions: []
linked_research: []
linked_pushes: []
linked_campaigns: []
linked_outcomes: []
public: false
channels: []
tags: []
---
Allowed statuses: open, paused, closed, canceled.
Allowed appetite_tier values: trivial, small, material, strategic.
Keep appetite human-readable, and use appetite_tier for rough financial
weight. The tier should match the operator's appetite thresholds in
core/finance/books.md when that file exists.
When an owner is known, use the existing team member slug from
core/team/<slug>.md. Ask before creating a new team file, and keep owner
enforcement future-scoped unless the bet schema validates it.
For financially material bets, use money_path.bet_id equal to the filename
stem and tag private hledger transactions with bet:<id>. Check exposure with:
mb books exposure --repo . --bet bets/YYYY-MM-DD-slug.md --json
For active bets:
mb books exposure --repo . --active --json
Treat the exposure output as safe aggregate evidence only. Do not ask for or paste raw ledger rows, payees, account names, account numbers, private vault paths, or transaction memos into bet files.
Use kill_rubric.failure_signals and kill_rubric.double_down_signals for
pre-committed exit and scale criteria. mb status --json evaluates only
declared rubrics against explicit metrics: or metric_values: frontmatter;
it does not infer kill criteria from prose.
Use repo-relative paths in link fields:
linked_decisions:decisions/*.mdlinked_research:research/*.mdlinked_pushes(official):pushes/YYYY-MM-DD-slug/push.mdor push artifactslinked_campaigns(legacy compatibility, leave as[]for new bets):campaigns/*/campaign.mdrecords on existing repos that have not yet migrated. New bets always include both fields withlinked_pushespopulated andlinked_campaigns: []. When the operator is on a legacy campaigns/ repo, recommendmb doctorandmb migrate campaigns --planbefore creating new push work.linked_outcomes:log/*.md,documents/*.md, or outcome artifacts
When linking an existing file to a bet, add the reverse link too:
linked_bets:
- bets/YYYY-MM-DD-slug.md
After adding or changing typed linked_* frontmatter, add or repair the
body-level ## Related links mirror with Markdown relative links. If the
mirror is missing or stale, run mb doctor repair --plan and ask before
mb doctor repair --apply; use the connection decision matrix in
docs/business-connections.md and do not invent relationships from body links.
Mode: new
Use when the operator says they want to try, launch, test, prove, or make a bet.
- Ask only for missing essentials: hypothesis, appetite, appetite tier, exposure cap or MoneyPath anchor requirement, deadline, metric, target, kill/double-down signals, public/private posture, channels, and any known linked files.
- If the idea also sounds like a new offer, ask whether it is only a wager for
now or whether the operator wants to preserve a durable offer candidate too.
Do not create, rename, delete, or move
core/offers/folders without an accepted decision, approved migration plan, or explicit instruction. - Create
bets/YYYY-MM-DD-slug.md. Ifmoney_path.requiredis true, setmoney_path.bet_idtoYYYY-MM-DD-slug; do not invent private ledger details. - Add reverse
linked_betsfrontmatter to linked decisions, research, pushes (or legacy campaigns), and outcome files when those files already exist and the edit is clearly safe. - End with the file path, deadline, target, and next action.
Body template:
# Bet Title
## Why This Bet
[The operating tension or opportunity.]
## Hypothesis
[Same claim as frontmatter, with context.]
## Work Plan
- [ ] [Concrete action]
## Evidence Log
- YYYY-MM-DD - Bet opened.
## Result
Open.
## Narration Notes
[Public-safe angles, claims to avoid, proof needed before sharing.]
## Related links
- [Existing linked file](../decisions/YYYY-MM-DD-example.md)
Mode: update
Use when work happened but the bet is not finished.
- Read the bet and linked files.
- Append a dated
Evidence Logentry. - Update
linked_decisions,linked_research,linked_pushes(or legacylinked_campaigns), orlinked_outcomesif new files now matter. - Keep
resultblank unless there is a real result. - Repair reverse
linked_betsfields on newly linked files.
Mode: close
Use when the deadline passed, the target is hit, or the operator decides to stop.
- Ask for the actual result if repo evidence is not enough.
- Set
status: closedorstatus: canceled. - Fill
resultwith the measured outcome and verdict. - Add a
## Learningsection or update it if present. - Link outcome files and add reverse
linked_betsfields. - If the bet changes durable offer truth, suggest a follow-up decision before
editing
core/offer.mdorcore/offers/<slug>/offer.md. - Graduation options: update an existing offer, create a new offer candidate, create a push/playbook, update proof, or justify a linked child repo. Keep the closed bet as history.
- For paused, dead, superseded, or canceled offer ideas, preserve the record and mark status/verdict; do not delete offer folders as cleanup.
Mode: list
Summarize active bets from mb status --json --peek and direct file reads:
- deadline
- status
- target
- metric
- appetite tier and exposure cap when declared
- missing MoneyPath or missing exit criteria
- triggered kill or double-down signals
- public/private posture
- blocked or overdue signals
Keep it short. End with the next bet that needs attention.
Mode: narrate
Draft public-safe narration from the bet and linked repo truth. Do not invent results, metrics, claims, testimonials, or publishing channels.
Ask the operator which surface if unclear:
- site
- community
- social
Draft format:
# Narration Draft
Surface: [site/community/social]
Source bet: bets/YYYY-MM-DD-slug.md
## Public Angle
[What can be shared safely.]
## Draft
[Post or page copy.]
## Claims To Verify
- [Any metric, result, or proof that needs source confirmation.]
## Source Links
- [repo-relative paths read]
If the bet has public: false, ask before drafting public copy. Offer a private
internal retrospective instead.
Exit
Tell the operator what changed, which files were linked, and whether validation
passed. If bet files or linked repo truth changed, run mb checkpoint --plan --json, show the proposed checkpoint and any blockers, validate the chosen
message with mb checkpoint --validate "..." --json, and save with
mb checkpoint --message "..." --yes only after operator approval.
End with the exact next command:
mb status