Theme System
14 built-in themes, terminal color schemes, and custom theme sharing via export and import.
Overview
Canopy's theme system controls the appearance of all app UI chrome: surfaces, text, borders, accents, shadows, and frosted glass effects. Each theme is built from a hand-crafted color palette that gets compiled into over 140 CSS tokens, giving every surface a consistent look.
The app ships with 14 built-in themes, split evenly between dark and light. Daintree is the default dark theme (eucalyptus green accent) and Bondi Beach is the default light theme (deep coastal teal). On first launch, Canopy picks whichever matches your operating system's current appearance.
If none of the built-in options are quite right, you can export any theme as a JSON file, edit the colors, and import it back as a custom theme. See Theme Export and Import below.
App themes and terminal color schemes are two separate settings. The app theme controls all UI chrome (sidebar, toolbar, panels, dock). Terminal color schemes control ANSI output rendering inside terminal panels. Both live under Settings > Appearance, but on different subtabs.
Built-in Themes
Every built-in theme draws its palette from a real-world natural ecosystem. The accent color anchors the visual identity, while surface and text colors are tuned to complement it. All 14 themes include frosted glass effects powered by per-theme material blur and saturation values.
Dark Themes
| Theme | Accent | Inspired by |
|---|---|---|
| Daintree | #36CE94 eucalyptus green | Daintree Rainforest, QLD, Australia |
| Arashiyama | #C46240 terracotta copper | Arashiyama Bamboo Grove, Kyoto, Japan |
| Fiordland | #3AB7C5 fjord teal | Fiordland, South Island, New Zealand |
| Galapagos | #4A9E7F ocean teal-green | Galapagos Islands, Ecuador |
| Highlands | #9B86AE heather purple | Scottish Highlands, Scotland |
| Namib | #86ABC3 desert sky blue | Namib Desert, Namibia |
| Redwoods | #4E9A53 forest green | Redwood National Park, California, USA |
Light Themes
| Theme | Accent | Inspired by |
|---|---|---|
| Bondi Beach | #145A44 deep teal-green | Bondi Beach, Sydney, Australia |
| Atacama | #9B4B2A rust terracotta | Atacama Desert, Chile |
| Bali | #228243 tropical green | Bali, Indonesia |
| Hokkaido | #586CD6 frost indigo | Hokkaido, Japan |
| Serengeti | #A28224 savanna gold | Serengeti National Park, Tanzania |
| Svalbard | #2D7A96 arctic blue | Svalbard Archipelago, Norway |
| Table Mountain | #A8456E fynbos rose | Table Mountain, Cape Town, South Africa |
Changing Your Theme
Open Settings → Appearance → App to access the theme picker. The picker shows a large hero image card for the active theme with its name, location, and a strip of palette swatches. Click the dropdown to browse all available themes, grouped into Dark and Light sections.
Each theme in the dropdown shows its own hero image, name, location subtitle, and palette strip so you can compare at a glance. Selecting a new theme applies it immediately across the entire app.
Use the shuffle button (next to the theme dropdown) to cycle through all 14 themes in random order. It's a quick way to discover themes you might not have tried.
During the first-run welcome dialog, Canopy prompts you to choose between Daintree and Bondi Beach. It auto-selects based on your OS appearance, but you can switch. A note below the choice cards points to Settings → Appearance for access to all 14 themes.
Match System Appearance
The Match system appearance toggle in the theme picker lets Canopy follow your operating system's dark/light mode. When enabled, the app switches automatically whenever your OS appearance changes.
Two sub-pickers appear below the toggle: Preferred dark theme and Preferred light theme. These let you choose which specific theme to use for each mode. The defaults are Daintree for dark and Bondi Beach for light.
One thing to note: manually selecting a theme from the main picker while follow-system is active will automatically disable the toggle. This prevents the OS from overriding a deliberate choice.
Terminal Color Schemes
Terminal color schemes control the ANSI color palette used inside terminal panels: the foreground, background, and 16 ANSI colors that programs use for syntax highlighting, status output, and prompts. They're configured separately from the app theme under Settings → Appearance → Terminal.
The Terminal subtab also includes font size (8–24 px), font family (JetBrains Mono or system monospace), and dock density controls, among others. Color scheme selection is the focus of this section.
Choosing a Color Scheme
The color scheme picker is a two-column scrollable grid. Each card shows a mini terminal mockup rendered with the scheme's actual colors, displaying sample output like $ ls src/, $ git status, and test results so you can see how the scheme looks in practice.
A sticky search input sits at the top of the grid for filtering by name. Light schemes display a small "light" badge on their card. Selecting a scheme applies it immediately to all open terminal and agent panels — both use ANSI rendering.
Match App Theme
Match App Theme is the default selection and keeps your terminal colors in sync with whatever app theme you're using. Rather than a fixed palette, it reads the active theme's terminal color tokens and applies them to the terminal in real time.
Daintree and Bondi Beach have hand-crafted terminal color mappings designed alongside their app themes. All other app themes supply their own terminal colors through CSS custom properties, so every theme gets a distinct terminal palette that complements its UI chrome. There's no generic fallback here: switching from Fiordland to Highlands gives you a genuinely different terminal look.
The hybrid input bar (the command input inside terminal panels) also derives its colors from the active terminal scheme. Background, foreground, cursor, and chip colors all update to match, keeping the input bar visually consistent with the terminal output above it.
Match App Theme is dynamic. When you switch app themes, the terminal colors update automatically. If you'd rather lock in a specific terminal look regardless of which app theme you're using, pick one of the named schemes instead.
Built-in Schemes
Canopy ships with 25 built-in terminal color schemes. Seven are Canopy originals designed to pair with the app's own themes, and eighteen are community favorites ported from popular editor and terminal projects.
Canopy originals
- Match App Theme — dynamic, derives colors from the active app theme
- Daintree — dark, eucalyptus green accent paired with the Daintree app theme
- Fiordland — dark, cold fjord palette with teal cursor
- Canopy Ember — dark, warm terracotta and ember tones
- Redwoods — dark, forest brown and green
- Hokkaido — light, frost-blue winter palette
- Bondi — light, coastal teal paired with the Bondi Beach app theme
Community dark schemes
- Dracula
- One Dark
- Monokai
- Solarized Dark
- GitHub Dark
- Catppuccin Mocha
- Tokyo Night
- Gruvbox Dark
- Everforest Dark
- Oceanic Next
- Kanagawa Dragon
- Tomorrow Night
Community light schemes
- Solarized Light
- Rosé Pine Dawn
- Catppuccin Latte
- Atom One Light
- Gruvbox Light
- Ayu Light
Importing Custom Schemes
If the built-in options don't cover your preferred palette, you can import custom color schemes from files. The Import color scheme... button sits below the picker grid in the Terminal subtab.
Click the button to open a native file dialog. Select a color scheme file and it's added to your list immediately, becoming the active scheme. Imported schemes persist across app restarts.
Three file formats are supported:
- iTerm2 (
.itermcolors) — the XML plist format used by iTerm2 and many other macOS terminals. This is the most widely shared format in the terminal theming community. - Base16 JSON — JSON files with
base00throughbase0Fkeys, following the Base16 convention popular in the Neovim and editor theming ecosystem. - VS Code JSON — JSON files with
terminal.ansiBlack,terminal.background, and similar keys matching VS Code's terminal color token format.
Format detection is automatic based on file extension and key patterns. Any ANSI slots missing from the imported file get filled with sensible defaults.
The iTerm2-Color-Schemes GitHub repository has over 200 free .itermcolors files you can import directly into Canopy. It's a quick way to try a wide range of palettes.
Imported custom schemes can't currently be removed through the Settings UI. Once a scheme is imported, it stays in your list. Selecting a different scheme is the simplest way to stop using one you no longer want.
Theme Export and Import
Canopy supports sharing themes via JSON files. The Export app theme and Import app theme buttons in the theme picker let you save any theme to a file, edit the colors, and share it with others.
Exporting a Theme
Export works on any theme, including the built-in ones. The exported file is a clean JSON document ready for sharing or editing.
- Open Settings > Appearance and select the theme you want to export
- Click Export app theme... below the theme picker
- Choose a save location in the file dialog. The filename defaults to
ThemeName.json
The exported file contains the theme's name, type (dark or light), and the full set of color tokens. Internal metadata like location and builtin flags are stripped, so the file is clean for redistribution. Cancelling the save dialog does nothing (no error message).
Importing a Theme
Importing adds a theme to your custom themes list and immediately switches to it.
- Open Settings > Appearance and click Import app theme... below the theme picker
- Select a
.jsontheme file from the file dialog - The theme loads, validates, and activates. You'll see a confirmation:
Imported "Theme Name".
If the file has warnings (see below), the message changes to Imported "Theme Name" with N warning(s). and lists the specific issues. Cancelling the file dialog is silent.
The Theme File Format
Exported themes use a straightforward JSON structure with the theme name, type, and a tokens object containing color values:
{
"name": "My Custom Theme",
"type": "dark",
"tokens": {
"surface-canvas": "#1a1a2e",
"surface-sidebar": "#1e1e34",
"surface-panel": "#232340",
"text-primary": "#e8e8ed",
"text-secondary": "#a0a0b0",
"accent-primary": "#36ce94",
"border-default": "#2a2a45"
}
} You don't need to specify all ~140 token keys. Any tokens you leave out fall back to the defaults from the matching built-in theme: Daintree for dark themes, Bondi Beach for light themes. A handful of core tokens (surfaces, text, accent, borders) is enough to define a distinct look.
The importer also accepts a flat format where token keys sit at the root level alongside metadata fields. Both formats work identically.
If you omit the type field, Canopy infers whether the theme is dark or light from the luminance of the surface colors. Including type explicitly avoids the inference warning.
Import Warnings
Warnings are non-fatal. The theme still imports and activates, but a message appears below the buttons listing anything that might need attention.
- Inferred type — the file didn't include a
typefield, so Canopy guessed dark or light from the color values. Adding"type": "dark"or"type": "light"to the file makes it explicit. - Unknown tokens — the
tokensobject contains keys that Canopy doesn't recognize. These are silently ignored. This can happen when importing a theme from a newer version of Canopy into an older one. - Contrast issues — certain text/surface color combinations don't meet WCAG contrast ratios. Canopy checks key pairs like
text-primaryon surface colors (4.5:1 minimum),text-secondaryon panels (3.0:1 minimum), and terminal foreground on terminal background. Low-contrast themes will still import but may be difficult to read.
Sharing Themes
Theme sharing is file-based and works with any transfer method. Export a .json file, send it via Slack, email, or commit it to a repo, and the recipient imports it. An exported file can be re-imported without any data loss, so round-tripping works cleanly.
Built-in themes are fully exportable, which makes them a great starting point for team themes. Export a built-in, adjust the accent colors and surfaces to match your team's branding, and distribute the file. Everyone imports the same file and gets an identical setup.
Imported themes appear in the auto-switching picker and the random shuffle pool alongside the built-in options.
Color Vision Accessibility
Canopy offers color vision deficiency (CVD) modes to make status indicators and terminal output more distinguishable. These are available in Settings > Appearance under the Color Vision section.
Three modes are available:
- Default: standard color palette, no adjustments.
- Red-Green (Deuteranopia and Protanopia): remaps red and green status indicators to more distinguishable alternatives.
- Blue-Yellow (Tritanopia): remaps blue and yellow indicators similarly.
CVD modes affect status indicator colors (success, danger, GitHub state colors) and terminal ANSI color mappings. They don't change the overall theme accent color or surface palette, so your chosen theme still looks like itself.