SuperDoc’s UI is styled with CSS variables.Documentation Index
Fetch the complete documentation index at: https://docs.superdoc.dev/llms.txt
Use this file to discover all available pages before exploring further.
createTheme() generates a class name that sets those variables; you apply the class to <html> and every SuperDoc surface picks it up: toolbar, comments, dropdowns, context menu, popovers.
The fast path
theme is a className string. Apply it to <html> (not the editor container) so popovers, dropdowns, and the comments sidebar all pick up the same tokens. Some of those surfaces render outside the editor element.
What themes affect
Toolbar buttons, comments sidebar, dropdowns, context menu, search bar, dialog surfaces. Any chrome SuperDoc renders. The document content itself (paragraphs, headings, tables) renders with its own styles from the DOCX.When to drop to CSS variables
createTheme() covers the common case. For component-level overrides, use the vars option or set raw --sd-* variables in your stylesheet:
Common pitfalls
- Theme class on the wrong element. Add it to
document.documentElement(the<html>tag), not the editor’s container. Popovers render at the body level and won’t pick up the theme otherwise. - CSP environments.
createTheme()injects a<style>tag. If you serve with a strict CSP, usebuildTheme()instead: it returns{ className, css }so you can inject the CSS yourself with the right nonce.
Where to next
- Editor > Theming > Overview: the full theming guide
- Editor > Theming > Custom themes: every
createTheme()option and CSS variable - Editor > Theming > CSS variable migration: old → new token mapping for v1

