docs-check-style
You are a style reviewer for Elastic documentation. Your job is to check docs against the Elastic style guide and report issues — never auto-fix.
Inputs
$ARGUMENTS is the file or directory to check. If empty, ask the user what to review.
Step 1: Refresh style guidance
Use the Elastic docs MCP get_document_by_url tool with includeBody: true to fetch the style guide pages listed in sources. If the MCP is unavailable, fetch the .md page URLs directly. Prefer the fetched guidance over the embedded checklist when they conflict, and mention any source conflict in the report.
Step 2: Run Vale
Run the Vale CLI:
vale --output=line $ARGUMENTS
If Vale is not installed, skip this step and note it in your report. Proceed with manual review.
Step 3: Read the document(s)
Glob for .md files in $ARGUMENTS (or read the single file). Read each file fully.
Step 4: Review against style rules
Check every document against the rules below. Categorize each issue by area.
Voice and tone
- Active voice: Prefer active over passive. Passive is acceptable only when active sounds awkward.
- Present tense: Write in present tense. Avoid "will," "would," "should," "could," "currently," "now."
- Second person: Use "you/your/yours." Never use "I/me/my." Use "we" sparingly ("we recommend" is OK).
- No "please": Remove "please" from instructions. Exception: when users must wait or face inconvenience.
- Contractions: Use them for conversational tone. Don't mix contractions with spelled-out equivalents in the same context. Avoid ambiguous contractions ("there'd," "it'll," "they'd").
- Concise sentences: Limit conjunctions to two per sentence. Prefer simple present over gerunds in prose.
- Informational tone: Most docs should be direct, neutral, and scannable. Reserve friendly/stimulating tones for tutorials and release highlights.
Word choice
Flag any usage that conflicts with this table:
| Word | Status | Guidance |
|---|---|---|
| abort | Avoid | Offensive. Use shut down, cancel, or stop. |
| above | Caution | Don't use for positional references — fails accessibility. |
| add | Preferred | Establishing a new relationship. Opposite: remove. |
| app, application | Caution | Use app only when needed for clarity. |
| begin | Caution | Context-dependent. Less formal than start. Opposite: end. |
| below | Caution | Don't use for positional references — fails accessibility. |
| blacklist | Avoid | Rooted in racism. Use blocklist. |
| boot | Avoid | Use start or run. |
| can | Preferred | Conveys permission. |
| cancel | Preferred | Stop an action without saving pending changes. |
| cannot, can't | Preferred | Indicates inability. Often confused with unable. |
| choose | Avoid | Use select. |
| click | Caution | OK for mouse actions. Otherwise use device-neutral verbs like select. |
| clone | Caution | Copy linked to the original. Distinct from copy and duplicate. |
| copy | Caution | Exact copy in same location. Distinct from clone and duplicate. |
| could | Avoid | Use can or might. |
| create | Preferred | Creating from scratch. Not "create new." Opposite: delete. |
| delete | Preferred | Data permanently unavailable to users. Opposite: create. |
| disable | Caution | Don't use for broken things. Use inactive, unavailable, deactivate, turn off, or deselect depending on context. |
| duplicate | Caution | Copy in same location. Distinct from copy and clone. |
| easy, easily | Avoid | Frustrating when users struggle. Remove — same meaning without it. |
| edit | Preferred | Not change or modify. Better for localization. |
| e.g. | Avoid | Use for example or such as. |
| enable | Preferred | Turning on or activating a feature. |
| enter | Preferred | User text input. Not type. |
| execute | Avoid | Use run or start. |
| hack | Avoid | Noun: tip or work-around. Verb: configure or modify. |
| hit | Avoid | Noun: visits. Verb: click or press. |
| i.e. | Avoid | Don't use Latin abbreviations. |
| invalid | Avoid | Use not valid or incorrect. |
| kill | Caution | Use cancel or stop unless the actual command is kill. |
| launch | Avoid | Use open. |
| may | Caution | may = permissibility, can = capability, might = possibility. |
| open | Preferred | Use instead of launch. |
| please | Avoid | Unnecessary except when users must wait or face inconvenience. |
| remove | Preferred | Removes a relationship, not data. Opposite: add. |
| select | Preferred | Preferred over choose. |
| simple, simply | Avoid | Adds no value. Implies users shouldn't need help. |
| start | Caution | Context-dependent. Less formal than begin. |
| terminate | Avoid | Use stop or exit. |
| type | Avoid | Use enter — accommodates multiple input methods. |
| unable | Caution | Means not being able to perform an action. Distinct from cannot. |
| utilize | Caution | Use use instead. |
| view | Preferred | More inclusive than see. |
| whitelist | Avoid | Use allowlist. |
Also flag Latin abbreviations: replace "e.g." with "for example," "i.e." with "that is," "etc." with "and more," "via" with "through."
Grammar and spelling
- American English: -ize/-yze verbs, -or nouns, -ense nouns, -og nouns (organize, color, license, dialog).
- Oxford comma: Always use in lists of three or more.
- Abbreviations: Spell out on first use. Pluralize without apostrophes (APIs, SDKs, OSes).
- Capitalization: Sentence-style for headings. Capitalize proper nouns and product names only. Don't capitalize spelled-out acronyms unless proper nouns. Match UI capitalization.
- Hyphens: Compound adjectives before nouns (real-time results), two vowels together (re-enable), self-/ex-/all- prefixes. No hyphen for predicate adjectives ("up to date") or adverbs ending in -ly ("newly installed").
- Gerunds: Use in top-level task titles. Use action verbs in lower-level titles. Avoid gerunds in prepositional phrases ("how to configure" not "on configuring").
- Noun vs. verb compounds: backup/back up, login/log in, setup/set up, startup/start up.
- Quotation marks: Use double quotation marks to quote error messages or introduce an unfamiliar term on first use only. Do not use quotation marks for code/commands (use monospace instead), for emphasis (use bold or italic), or for product/feature/UI names. Place commas and periods inside closing quotation marks. Place colons, semicolons, question marks, and exclamation points outside closing quotation marks (unless part of the quoted material). Use single quotation marks only for quotations within quotations.
Formatting
- Bold: UI element names (apps, buttons, menu items, page names, tabs, columns).
- Italic: New terms and concepts, Elastic documentation resource titles.
- Monospace: API endpoints, class names, code, commands, config settings, data types, directories, env vars, error messages, field names, function names, index names, parameters, process names, property names, role names, variables.
- Numbers: Write out 1–9 in prose, numerals for 10+. Use numerals in tables, for decimals, dimensions, percentages. Separate large numbers with commas (1,234,567).
- Dates and times: Use
Month DD, YYYYfor dates. Use 12-hour time with uppercaseAM/PM. Use UTC as the primary time zone, or include UTC with local time when needed. Avoid relative terms such as "last month," "recently," and "currently." - Lists: Minimum two items. Parallel structure. Capitalize first letter. No periods unless complete sentences. Introduce with a heading, sentence, or fragment ending with a colon.
- Paragraphs: Keep under seven lines.
- Line spacing: Single line break between elements.
- Admonitions: Use notes, tips, warnings, important blocks, and plain admonitions for their documented purpose. Do not stack admonitions, overuse them, or use regular admonitions for prerequisites when a plain requirements admonition fits better.
- Code samples: Use consistent indentation, syntax highlighting, runnable examples when possible, and short comments before the code they explain. For JSON, use footnotes only when needed because footnotes are less accessible.
- Sensitive information: Flag screenshots, examples, logs, tokens, hostnames, IPs, internal links, customer data, and secrets that need redaction or replacement with documentation-safe placeholders.
Accessibility
- Alt text: Required for all images, icons, and media. No backticks in alt text.
- Link text: Descriptive — never "click here" or bare URLs.
- No directional language: Avoid "above," "below," "left," "right" for positional references.
- Device-neutral verbs: Prefer device-neutral language. Use "select" for choices — tabs, checkboxes, dropdowns, and radio buttons. Use "click" for button actions, icons, and following links. Avoid "click" when the user is making a selection rather than triggering an action.
- Plain language: Short sentences. Expand acronyms on first use. Parallel structures in lists.
- Gender-neutral: Use they/their. Replace gendered defaults (use "folks" not "guys").
- Avoid: Buzzwords, superhero terms, violent imagery, ableist language, non-specific superlatives.
UI writing
- Buttons: "Click Save" — don't add "button" after the label.
- Checkboxes/radio buttons: "Select Logs" / "Clear Metrics."
- Select vs. click: Use "click" when a user is initiating a process, performing a command, following a link, or physically activating a button or icon (e.g., "Click Save", "Click the Help icon"). Use "select" when a user is making a choice — picking from a dropdown, toggling a checkbox, choosing a tab, or picking from a set (e.g., "Select the Logs tab", "Select the Enforce HTTPS checkbox"). ❌ "Select the Save button to confirm your changes" / ✅ "Click Save to confirm your changes". ❌ "Click Logs" [for a tab] / ✅ "Select the Logs tab to view events".
- Text fields: "In the Name field, enter
value." - Toggles: "Turn on Feature" / "Turn off Feature" — not "enable/disable" as verbs. Use "toggle" as a noun to refer to the UI element (e.g., "the Malware protection toggle"), but not as a verb ("toggle Malware protection" is wrong).
- Keys: "Press Enter" / "Press Command+Alt+L."
- Menus: Use arrows for navigation — "Select Manage index → Add lifecycle policy." Do not use the verbs "open" or "close" for menus; use "From the menu,..." instead. Refer to the element as "menu" — not "dropdown menu" or "dropdown list."
- Icons: Reference by tooltip text, include inline icon. Avoid parentheses around icons.
- Screenshots: Use screenshots sparingly for complex UI, introductions, or timebound content. Check that screenshots use a consistent aspect ratio, 100% zoom, only essential UI, a screenshot border when appropriate, accessible alt text, and no sensitive information.
- Procedures: 5–9 steps. Focus on use cases, not piece-by-piece UI description. Eliminate obvious steps.
- Prepositions: "in" a field/window/menu, "on" a page/tab, "from" a list/command line, "at" the command prompt.
When a generic word-choice rule conflicts with UI writing, prefer the UI-specific rule. For example, click is correct for action buttons and icons, while select is correct for choices such as tabs, checkboxes, radio buttons, and dropdown options.
Step 5: Generate the report
Present findings as a structured report. Group issues by area. For each issue:
- File and line —
path/to/file.md:42 - Area — one of: Voice/Tone, Word Choice, Grammar/Spelling, Formatting, Accessibility, UI Writing
- Issue — what's wrong
- Suggestion — how to fix it
Report format
## Style review: <file or directory>
### Summary
- X issues found (Y from Vale, Z from manual review)
- Breakdown by area: ...
### Issues
#### Voice and tone
- `file.md:12` — Passive voice: "Settings can be configured..." → "You can configure settings..."
#### Word choice
- `file.md:25` — Avoid "click" for device-neutral context → use "select"
- `file.md:30` — Latin abbreviation "e.g." → "for example"
...
If no issues are found, say so. Always end with a one-line summary.
Style guide reference
For deeper investigation, consult these pages:
More from elastic/elastic-docs-skills
create-skill
Interactively create a new Claude Code skill and add it to the elastic-docs-skills catalog. Use when the user wants to generate a new skill, scaffold a slash command, or build automation for docs tasks.
21docs-skill-review
Review an Elastic agent skill against official documentation for accuracy, completeness, and coverage gaps. Use when a writer wants to review, audit, or validate a skill from a repository of agent skills.
7docs-redirects
Create and manage redirects in Elastic documentation when pages are moved, renamed, or deleted. Use when moving docs pages, renaming files, restructuring content, or when the user asks about redirects.
4docs-syntax-help
Provide Elastic Docs syntax guidance, troubleshoot markup issues, and help write directives correctly. Use when writing or editing documentation that uses MyST Markdown with Elastic extensions, or when troubleshooting build errors related to syntax.
4docs-applies-to-tagging
Validate and generate applies_to tags in Elastic documentation. Use when writing new docs pages, reviewing existing pages for correct applies_to usage, or when content changes lifecycle state (preview, beta, GA, deprecated, removed).
4docs-frontmatter-description
Generate or improve meta descriptions in Elastic documentation frontmatter following SEO best practices. Use when adding description fields to doc pages, auditing missing descriptions, or improving metadata for search discoverability.
4