Help us improve
Share bugs, ideas, or general feedback.
From summer
Defines a game's visual style by building an art bible with references, palette, mood, lighting plan, and do/don't list. Writes to .summer/art-bible.md.
npx claudepluginhub summerengine/summer-engine-agent --plugin summerHow this skill is triggered — by the user, by Claude, or both
Slash command
/summer:art-direction.summer/**project.godot**/*.tscnThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
A consistent art direction is what makes a low-budget game *look* like a finished game. Most solo devs lose this fight by mixing styles — a toon-shaded character on a photoreal terrain, a pixel UI over a smooth 3D world. This skill builds an art bible the rest of the project obeys: references, palette, mood, lighting plan, post-processing, and a do/don't list. It writes to `.summer/art-bible.md...
Defines a visual direction with style pillars, shape language, color intent, and readability rules for consistent art execution across teams.
Analyzes and improves UI/UX of browser games with visual polish, atmospheres, backgrounds, particles, animations, transitions, and juice effects. Use for aesthetic and player experience upgrades.
Generates 3-4 rough concept variants of a character, environment, or prop for art direction exploration. Use when the user wants to explore visual directions before committing to a final asset.
Share bugs, ideas, or general feedback.
A consistent art direction is what makes a low-budget game look like a finished game. Most solo devs lose this fight by mixing styles — a toon-shaded character on a photoreal terrain, a pixel UI over a smooth 3D world. This skill builds an art bible the rest of the project obeys: references, palette, mood, lighting plan, post-processing, and a do/don't list. It writes to .summer/art-bible.md — the file every rendering / shader / lighting / VFX skill reads later.
Core principle: Constraint produces style. A game with 15 colors total looks more intentional than a game with infinite-color textures. Pick the constraint, then defend it.
Ask exactly this:
Two or three references — games, films, art books, anything visual. What's the vibe?
Don't suggest. Listen. References are the single most reliable signal of what they actually want. If they say one game, ask for one more — single-reference art bibles converge into a clone of that game.
If they freeze, offer 4 axes (not games):
Pick the one that feels right: a) painterly + warm + handcrafted (Sable, Tunic), b) crisp + saturated + toon (Hi-Fi Rush, Splatoon), c) dark + moody + grounded (Dishonored, Inside), d) lo-fi + nostalgic + crunchy (Dusk, Faith).
Read .summer/GameSoul.md
Brief might say "horror" — that constrains palette and lighting. Brief might say "cozy" — that forbids harsh contrast. Quote it back:
Brief is "cozy farming sim". That rules out harsh shadows and saturated reds. Confirming.
This is the technique question, not the mood question. Force a choice:
| Technique | When | Pro | Con |
|---|---|---|---|
| Toon / cel-shaded | Stylized 3D, expressive characters | Forgiving on textures, ages well | Can feel generic without strong palette |
| PBR realistic | Grounded sim, horror, military | Lighting does the work | Asset cost is brutal solo |
| Lo-fi PS1 | Nostalgia, horror, indie cred | Tiny assets, fast iteration | Niche audience appeal |
| Flat / matte | Minimalist puzzle, casual | Cheapest to author | Limited mood range |
| Painterly (textured-shaded) | Story-led, fantasy | Distinctive | Requires consistent texture authoring |
| 2D pixel | Retro, platformer, RPG | Mature pipeline | Animation cost scales fast |
| 2D hand-drawn | Narrative, indie | Distinctive, expressive | Animation cost extreme |
Ask:
One technique. Which is it?
If they pick more than one ("PBR characters in a toon world"), name the conflict and force a hierarchy:
Mixed techniques rarely cohere. If you mean "stylized PBR with toon outlines" — that's one technique (PBR + post-process outline). If you mean "toon characters in a PBR world" — that's two, and they'll fight. Pick one as primary.
A palette is 6-15 colors total. Not a vibe, not "warm tones" — actual hex codes. Force it.
Walk:
Primary background — what color does the screen mostly read as?
Secondary background — second most common?
Accent — what does the player's eye go to?
Warning / damage — what reads as bad?
Reward / pickup — what reads as good?
UI base — text, frames
UI emphasis — buttons, callouts
Skin / character — if applicable
State candidates as hex. For a "cozy farming" game:
#3a4a3a primary BG (deep moss green)
#5e6f4f secondary BG (sage)
#e6c068 accent (golden wheat)
#a83e3e warning (warm red, not pure red)
#c8a268 reward (warm tan)
#1f1a16 UI base (warm near-black, NOT pure black)
#f4ecdf UI text (cream, NOT pure white)
#e3b08a skin warm
#a8784f skin cool
Pure white (#ffffff) and pure black (#000000) are almost always wrong — they break the palette. Flag it if the user pitches them.
Ask:
Palette above. Adjust any, or lock it?
Three to five adjectives. Concrete, not vague.
Bad: "cool, atmospheric, immersive." Good: "soft, hand-warmed, slightly melancholic, golden-hour."
Ask:
Three to five adjectives that aren't 'cool' or 'atmospheric'. Pick from concrete sensory words.
State the plan in one block. For Godot 4.5:
Sun: DirectionalLight3D, color #fff2d9, energy 0.9, angle ~30° (warm low-angle)
Sky: ProceduralSkyMaterial, sky_top_color #6b88a3, sky_horizon_color #d8b88e
Ambient: AmbientLight #4a5570, energy 0.15
Indoor fills: OmniLight3D color #ffd9a8, energy 0.6, range 4m
NEVER: pure-white DirectionalLight, no ambient, hard cube shadows
For 2D:
Base: CanvasModulate #f4ecdf, gentle warm wash
Accent: PointLight2D for fireflies / lanterns, color from accent palette
NEVER: full-bright modulation, no soft falloff
Godot 4.5 post stack: Glow, SDFGI, SSAO, SSR, Adjustments, Color Correction (LUT). State opinions, not options.
Glow: ON, threshold 0.9, intensity 0.5 (soft bloom on highlights only)
SDFGI: OFF for vertical-slice scope (perf cost; bake light probes later)
SSAO: ON, light_affect 0.3 (just enough for grounding)
SSR: OFF unless we have wet/glass surfaces
Color correction: Filmic tonemap, slight S-curve LUT toward warm
Vignette (custom shader): ON, subtle, 0.15 strength
Chromatic aberration: OFF (overused, looks cheap)
Film grain: ON only if mood adjective is "lo-fi" or "vintage"
Make these calls. Don't enumerate options.
This is the contract. Five do's, five don'ts. Specific, enforceable.
## DO
- All colors come from the palette. New asset? Pick the closest existing color, don't invent.
- Outline shader on character + interactable props (no outline on environment).
- Soft shadows (DirectionalLight3D shadow_blur 1.5).
- Warm key + cool fill — never both warm or both cool.
- Texture filter: Linear with mipmaps OFF for crunchy near-pixel feel.
## DON'T
- No pure white (#ffffff). Use #f4ecdf.
- No pure black (#000000). Use #1f1a16.
- No realistic photo-textures. All textures must read as "painted" at 1m distance.
- No procedural sky shaders mid-day with full sun — too generic. Always angle the sun.
- No chromatic aberration / lens flare / motion blur — they're cheap and date-fast.
Some art-direction calls translate to project.godot settings. Apply them.
Preferred (Summer MCP):
summer_project_setting(key="rendering/textures/canvas_textures/default_texture_filter", value="2") # Linear no mipmaps if pixel-art-ish
summer_project_setting(key="rendering/environment/defaults/default_clear_color", value="Color(0.227, 0.290, 0.227)") # palette primary
summer_project_setting(key="rendering/anti_aliasing/quality/msaa_3d", value="2") # MSAA 2x for clean edges
If a WorldEnvironment node is in the main scene, set its environment defaults to match the lighting plan:
summer_inspect_node(path="./World/WorldEnvironment")
summer_set_prop(path="./World/WorldEnvironment/...", key="...", value="...")
Ask before each:
May I update
project.godot's default clear color to the palette primary, and enable MSAA 2x?
Fallback (no MCP): print the project.godot snippet for the user to paste.
Always write the bible. Path: .summer/art-bible.md.
# Art Bible — <Game Name>
**References:** <2-3 specific games / films>
**Technique:** <one of the 7 above>
**Mood:** <3-5 concrete adjectives>
## Palette
| Hex | Role |
|---|---|
| #3a4a3a | Primary BG |
| #5e6f4f | Secondary BG |
| ... | ... |
## Lighting plan
- Sun: DirectionalLight3D, color #fff2d9, energy 0.9
- Sky: ProceduralSkyMaterial top #6b88a3, horizon #d8b88e
- Ambient: #4a5570 energy 0.15
- Indoor fills: OmniLight3D color #ffd9a8 range 4m
- NEVER: pure-white sun, no ambient
## Post-processing
- Glow: ON, threshold 0.9
- SDFGI: OFF (vertical-slice scope)
- SSAO: ON, 0.3
- SSR: OFF
- Tonemap: Filmic
- Vignette: subtle 0.15
- Chromatic aberration: OFF
## DO
- ...
## DON'T
- ...
Ask:
May I create
.summer/art-bible.mdwith this bible?
End with:
Bible saved. Next:
/summer:audio-directionto define the sonic identity that pairs with this look./summer:vfxto design particle / hit-feedback styles within the palette.- Open the project's
WorldEnvironmentnode and dial in the lighting plan.- Or generate first-pass concept assets via
summer_generate_imageusing the palette + mood as the prompt prefix.
| Mistake | Fix |
|---|---|
| Vague palette ("warm tones") | Hex codes only. 6-15 of them. Locked. |
| Pure white / pure black | Off-white (#f4ecdf) and off-black (#1f1a16). Pure values blow out the palette. |
| Single reference | At least two references. Single = clone. |
| Mixing techniques | Toon characters in a PBR world fight. Pick one technique, stick to it. |
| No "DON'T" list | The DON'T list is the actual contract. The DO is aspirational. |
| Chromatic aberration / motion blur | Cheap, overused, date-fast. Off by default. |
| Procedural skybox without angle | Mid-day sun + uniform fog reads generic. Always angle the sun. |
| Skipping the lighting plan | Lighting is art direction in 3D. Without a plan, every level looks different. |
| Adopting "AAA realism" at vertical-slice scope | Asset cost is brutal solo. Stylized always wins. |
| Calling SetResourceProperty on inline sub_resources | Silent fail. See references/mcp-tools-reference.md § Trap. |
This skill writes one design doc (.summer/art-bible.md) and may modify project.godot settings + the main scene's WorldEnvironment. Always ask. See references/collaborative-protocol.md.
No template — this is a workflow that produces the bible the rest of the project obeys. After the bible exists, every summer: rendering / lighting / shader / VFX skill reads it.
references/collaborative-protocol.mdreferences/godot-version.md — Godot 4.5 rendering API notes (Compositor moved in 4.4 / 4.5)references/mcp-tools-reference.mdscene-and-project/brainstorm-game/SKILL.md — produces the brief that anchors the bibleaudio/audio-direction/SKILL.md — the sonic counterpartrendering-and-lighting/3d-lighting/SKILL.md — implements the lighting planshaders/shader-basics/SKILL.md — for outline / toon shaderspost-processing/bloom-and-glow/SKILL.md — implements the glow rulepost-processing/color-grading/SKILL.md — implements the LUT and tonemap call