plugins/stardust/skills/uplift/SKILL.md
One-shot brand-faithful presales redesign of a website page. The user provides only the URL; everything else — extraction, tension identification, three differentiated variants (one fully cinematic), validation — is derived from the captured brand surface. Use when the user asks to "uplift", "refresh", or "redesign a site for presales" without wanting to coordinate the extract / direct / prototype chain themselves.
npx skillsauth add adobe/skills upliftInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
One entry point. One URL. Three presales-quality redesign variants.
uplift collapses the extract → direct → prototype × 3 chain into a
single opinionated command that picks every variability axis from the
captured brand surface rather than asking the user. The output is the
same as the long-form chain (state.json, brand-review.html, three
proposed files, motion validation) — the user just doesn't have to
coordinate it.
--page <slug> overrides.../prototype/reference/motion-registers.md § Selection
heuristic.reference/what-if-candidates.md. Different traits per variant.prototype/SKILL.md Phases 2.5–2.8 fires, including cinematic
Pass 6 for variant C.<URL> — required. The page to redesign. Defaults to homepage when
the URL has no path (https://example.com/ → home).--page <slug> — optional. Override the slug if the URL points
elsewhere or the user wants a different surface.--cinematic-register <name> — optional. Override the auto-picked
register for variant C. One of arrival, kinetic-display,
live-systems, editorial, kinetic-grid. Recorded as
registerSource: "user-override" in C's provenance.--two-variants — optional. Render only A and C (skip B). Useful
when the brand surface is thin and a forced three-way differentiation
would produce a weak middle (per the stop condition below).There are no other flags. Everything else is derived from the captured brand surface or governed by the underlying skills' contracts.
../stardust/SKILL.md § Setup): impeccable dep check, context
loader, state read.extract will fail without it —
surface the same install message extract would).stardust/state.json if present. If a previous uplift
ran against the same URL on a recent date, ask whether the user
wants to refresh the extraction or render against the existing
capture.Six phases. Phases 1, 4, 5 delegate to existing skills; phases 2,
3, 6 are owned by uplift.
stardust:extract)Invoke stardust:extract <URL> --single (single-page mode).
Extract owns:
stardust/current/_brand-extraction.json (palette + type + motifs
stardust/current/pages/home.json (full per-page capture).stardust/current/brand-review.html with the tensions detectors
applied — this is the load-bearing input for Phase 2.stardust/current/PRODUCT.md and DESIGN.md (descriptive — the
current state, not the target).uplift does not crawl beyond one page. The brand surface from a
single homepage is sufficient for three variants; multi-page extract
is what stardust:extract (without --single) is for.
uplift)Read stardust/current/brand-review.html § Tensions surfaced and
_brand-extraction.json. Produce two artifacts:
stardust/uplift-improvements.mdFive specific weaknesses observed in the captured site. Same load-bearing contract as the existing presales workflow: without specifics, "make it better" has no claim. Categories:
Refuse to proceed if fewer than 3 specific weaknesses can be named (see § Stop conditions).
Format (mirrors the provenance shape used by the rest of stardust):
---
_provenance:
writtenBy: stardust:uplift
writtenAt: <ISO-8601>
againstInput: <URL>
readArtifacts:
- stardust/current/_brand-extraction.json
- stardust/current/pages/<slug>.json
- stardust/current/brand-review.html
---
# Improvements — <URL>
1. **[dated-pattern]** <one-line headline> — <captured evidence>.
2. **[ia-clutter]** <one-line headline> — <captured evidence>.
3. **[contrast-or-density]** <one-line headline> — <captured evidence>.
4. **[cliché]** <one-line headline> — <captured evidence>.
5. **[missed-opportunity]** <one-line headline> — <captured evidence>.
The bracketed tag preceding each weakness is the category from the list above. The headline is the one-sentence summary the agent will restate when variant A's shape brief applies the fix.
stardust/uplift-questions.mdSix to eight "what if we leaned into…" candidates derived from the
captured brand surface. Each candidate cites the captured evidence
that makes it concrete. Candidates are picked from the closed
catalog in reference/what-if-candidates.md:
For each candidate the agent generates: a one-line "what if…" phrasing, the captured evidence that makes the candidate concrete, the variant role it best serves (B's composition bet vs C's cinematic bet), and whether the candidate is disqualified for this brand (e.g. "Photography re-foregrounding disqualified — the captured photography is generic stock; amplifying it would expose the weakness").
The disqualification step is what keeps the agent from reflexively picking the same candidate for every brand.
uplift)Default: three variants (A + B + C). When --two-variants is
active, skip § 3c (B's candidate selection) and the direction.md
authored in § 3d declares only A + C. Phase 4 then writes only
DESIGN-A and DESIGN-C files at the project root, and Phase 5
renders accordingly. All downstream contracts (variant
differentiation, motion validation on C, summary in Phase 6)
operate over the reduced variant set without modification.
Read PRODUCT.md Brand Personality (from stardust/current/PRODUCT.md)
and apply the heuristic in ../prototype/reference/motion-registers.md
§ Selection heuristic. Record the picked register + the one-line
rationale.
The candidate must be the one the picked register naturally amplifies through motion:
| Picked register | Natural candidate |
|---|---|
| arrival | Signature-gesture extension OR Photography re-foregrounding |
| kinetic-display | Display-typography amplification |
| live-systems | Live-data promotion |
| editorial | Photography re-foregrounding OR Voice-register pivot |
| kinetic-grid | Motif vocabulary swap |
Pick from the remaining (non-disqualified, non-C) candidates in
uplift-questions.md. Prefer:
brand-review.html § Tensions.stardust/direction.mdWrite the resolved direction with three variant declarations:
## Variant A — Faithful + improvements
Role: risk-averse green-light. "Yes, that's us, with the obvious
fixes."
Composition: same as captured.
Motion: static (no cinematic layer).
Improvements applied: <list from uplift-improvements.md>.
## Variant B — What if we amplified <captured trait>?
Role: design-team motivator. The brand's underused capability
foregrounded.
What if: "<one-line "what if…" framing>"
Captured trait amplified: <trait from uplift-questions.md>
Evidence: <captured citation>
Composition: <specific layout strategy that amplifies the trait>
Motion: static (no cinematic layer).
## Variant C — What if motion was part of the identity?
Role: visionary pitch. The brand's third dimension — kinetic.
What if: "<one-line "what if…" framing tied to the register>"
Cinematic register: <register> (auto-picked from PRODUCT.md
Brand Personality)
Captured trait amplified: <trait — the one register naturally
amplifies>
Evidence: <captured citation>
Composition: identical IA to A; the bet is motion, not layout.
Motion: cinematic, register <register>.
stardust:direct)Invoke stardust:direct with the resolved direction. Pass the
three-variant declaration as the input phrase ("uplift presales
redesign — three variants per stardust/direction.md"). Direct owns:
uplift does not duplicate any of those checks; it relies on
direct's existing validators to refuse if the variants violate
the brand-faithful contract.
stardust:prototype)Invoke prototype once with the page slug:
stardust:prototype <slug>
Prototype detects N > 1 variants from the per-variant DESIGN-A,
DESIGN-B, DESIGN-C files that direct wrote in Phase 4 and
iterates internally — authoring <slug>-A-shape.md / -B-shape.md
/ -C-shape.md and emitting <slug>-A-proposed.html /
<slug>-B-proposed.html / <slug>-C-proposed.html per the
variant-convergence detector contract
(../prototype/SKILL.md § Phase 2.5 / Discipline 10).
Cinematic motion fires per-variant from the per-variant DESIGN
file, not from a CLI flag. Because Phase 4 wrote
extensions.motion.register into DESIGN-C.json only (A and B
omit it), prototype's Phase 2.4 (motion application) fires only
for variant C. Variant C emits both <slug>-C-proposed.html
(the static reference) and <slug>-C-cinematic.html (the
register-applied surface). Variants A and B render static, never
acquiring the motion runtime.
Prototype owns:
$impeccable craft delegation, per variant.DESIGN-<id>.json
declares an extensions.motion.register.../prototype/reference/motion-validation.md.The single invocation lets prototype's canon-fold-back (Phase 5
of prototype) carry through A → B → C consistently inside one run.
Multi-variant rendering is driven by the presence of multiple
DESIGN-<id>.json files at the project root, not by a CLI selector
— prototype has no --variant <id> input.
uplift)After all three prototypes mark prototyped in state.json:
Open all three in the browser using the open shell command (not
playwright-cli open) so VFS paths are served via the preview service
worker:
open stardust/prototypes/<slug>-A-proposed.html
open stardust/prototypes/<slug>-B-proposed.html
open stardust/prototypes/<slug>-C-cinematic.html
playwright-cli open bypasses the preview service worker and produces
a FILE NOT FOUND error for VFS paths. Always use open <vfs-path> for
local prototype files.
Print the three-pitch summary in the chat:
uplift complete — three variants for <URL>
A · Tomorrow's version of the site you have today.
Improvements applied: <count>.
File: stardust/prototypes/<slug>-A-proposed.html
Pitch: "yes, that's us, fixed."
B · What if we amplified <captured trait>?
Trait: <name>.
Composition bet: <one-line summary>.
File: stardust/prototypes/<slug>-B-proposed.html
Pitch: "the brand's underused capability, foregrounded."
C · What if motion was part of the identity?
Cinematic register: <register>.
Motion bet: <one-line summary>.
File: stardust/prototypes/<slug>-C-cinematic.html
Pitch: "the brand's third dimension."
Differentiation: A vs B ≥ 2 changes (✓), A vs C ≥ 2 changes (✓),
B vs C ≥ 2 changes (✓).
Validation: all three pass critique + audit + adapt; C additionally
passes motion validation Pass 6.
Next: iterate any variant via chat ("make B's hero quieter") or
approve via the standard prototype approval flow (records the
approval in state.json).
The summary is the user's only direct touchpoint with the three variants. Keep it short — the work is on disk and openable.
| Variant | Pitch | Composition | Motion | Stakeholder |
|---|---|---|---|---|
| A | "Tomorrow's version." | Same IA + improvements applied | Static | Risk-averse green-light buyer |
| B | "What if we amplified <captured trait>?" | One captured-but-underused trait foregrounded in IA / composition / voice | Static | Design team that wants brand exploration |
| C | "What if motion was part of the identity?" | Same IA as A | Fully cinematic, register from brand surface | Visionary buyer + design lead |
This contract is non-negotiable. The "C is cinematic" rule is
how uplift reliably ships a third proposition that's defensibly
different from A and B (rather than the C-cliff failure mode of
"everything from B but bigger").
If the captured brand surface can't support three differentiated
variants (e.g. the palette has only one color, the captured page
has only two sections, the brand register doesn't map cleanly to
any motion register), reduce to two variants (A + C) via
--two-variants rather than ship three weak ones.
Inherited from the underlying skills — uplift does not re-state
them but relies on them being enforced:
direct/SKILL.md § Mode A.direct/SKILL.md § IA-priority preservation audit.sectionPadding.desktop at ≤ 64px. Enforced by
direct/SKILL.md § Hard floor enforcement.direct/SKILL.md § Variant
differentiation contract.prototype/reference/proposed-file-shell.md § Content sourcing
hierarchy.[data-placeholder] not invented. Enforced
by prototype/SKILL.md Phase 2 § Content sourcing scan.prototype/reference/motion-validation.md § Pass 6f motion
C-cliff detector.prefers-reduced-motion: reduce.
Enforced by prototype/reference/motion-validation.md § Pass 6b.When any of these gates refuses, uplift surfaces the refusal
verbatim from the underlying skill — the user sees the specific
violation, not a generic "uplift failed" message.
Stop and ask only if:
(a) Extract fails — site unreachable, structure unparseable,
bot-management blocks past the headed-Chrome fallback.
(b) Brand surface insufficient — palette has fewer than 2
distinct colors after clustering; OR the captured page has
fewer than 3 sections; OR the captured PRODUCT.md Brand
Personality maps to none of the five motion registers.
Surface honestly: "the captured brand surface is too thin
for three differentiated variants — render one strong variant
instead?"
(c) Improvements list empty — Phase 2a cannot name 3 specific
weaknesses. Without specifics, variant A has no brief and
"uplift" has no claim. Surface honestly.
(d) Two candidates equally weak — if B's "what if…" candidate
and C's cinematic candidate would amplify the same captured
trait, the variants would not differentiate. Switch to
--two-variants (A + C only).
(e) Hard rule conflict — captured palette has a single color,
captured typography has no display register, captured site
has no system components. Brand-faithful constraint
impossible without invention. Surface and ask.
The skill does not stop for confirmation in normal flow. The "PROCEED. Run all phases without stopping" property of the original presales prompt is preserved.
stardust/
├── state.json ← extracted + 3× prototyped
├── direction.md ← resolved direction + 3 variant declarations
├── uplift-improvements.md ← load-bearing 5-weakness list
├── uplift-questions.md ← 6–8 "what if…" candidate list with disqualifications
├── current/ ← from extract
│ ├── PRODUCT.md
│ ├── DESIGN.md
│ ├── DESIGN.json
│ ├── brand-review.html
│ ├── _brand-extraction.json
│ ├── _crawl-log.json
│ ├── pages/<slug>.json
│ └── assets/
└── prototypes/
├── <slug>-A-shape.md
├── <slug>-A-proposed.html ← faithful + improvements
├── <slug>-B-shape.md
├── <slug>-B-proposed.html ← "what if amplifying <trait>"
├── <slug>-C-shape.md
├── <slug>-C-proposed.html ← static fallback for C
├── <slug>-C-cinematic.html ← cinematic variant C
├── lenis.min.js ← copied from skill assets
└── lenis.min.css
PRODUCT.md ← shared (Mode A)
DESIGN.md / DESIGN.json ← shared
DESIGN-A.md / DESIGN-A.json
DESIGN-B.md / DESIGN-B.json
DESIGN-C.md / DESIGN-C.json ← carries motion.register
extract → direct → prototype chain.prototype approval flow.
Migration is stardust:migrate.reference/what-if-candidates.md — the closed catalog of 8
captured-trait amplification candidates that B and C pick from.../prototype/reference/motion-registers.md — register catalog
and selection heuristic used in Phase 3a.../prototype/reference/motion-validation.md § Pass 6 —
cinematic-mode validation gates that fire for variant C.../prototype/SKILL.md § Inputs — --cinematic flag passed
through from uplift; multi-variant rendering driven by the
per-variant DESIGN-<id>.json files direct wrote in Phase 4,
not by a CLI selector.../direct/SKILL.md § Phase 2.6 — multi-variant fork; uplift
passes the three-variant declaration through.../stardust/reference/data-attributes.md — structural section
attributes applied by prototype to all three variants.../prototype/reference/proposed-file-shell.md — content
sourcing hierarchy and placeholder convention.development
Start AEM Workflows on AEM as a Cloud Service using all available triggering mechanisms. Use when starting workflows manually via the Timeline UI, programmatically via WorkflowSession.startWorkflow(), via the HTTP Workflow API, through Manage Publication, or passing initial metadata and payload to a workflow instance.
development
Single entry point for all AEM as a Cloud Service Workflow skills. Covers workflow model design, custom process step and participant chooser development, launcher configuration, workflow triggering, and production support including debugging stuck/failed workflows, triaging incidents with Cloud Manager logs, thread pool analysis, and Sling Job diagnostics for the Granite Workflow Engine.
development
[BETA] Implement custom AEM Workflow Java components on AEM as a Cloud Service. This skill is in beta. Verify all outputs before applying them to production projects. Use when writing WorkflowProcess steps, ParticipantStepChooser implementations, registering services via OSGi DS R6 annotations, reading step arguments from MetaDataMap, accessing JCR payload via WorkflowSession adapter, reading and writing workflow metadata and variables, and handling errors with WorkflowException for retry behavior.
development
Start AEM Workflows on AEM 6.5 LTS using all available triggering mechanisms. Use when starting workflows manually via the Timeline UI, programmatically via WorkflowSession.startWorkflow(), via the HTTP Workflow API, through Manage Publication, through replication triggers, or passing initial metadata and payload to a workflow instance.