/* ==UserStyle==
@name docs.rs Catppuccin
@namespace github.com/catppuccin/userstyles/styles/docs.rs
@homepageURL https://github.com/catppuccin/userstyles/tree/main/styles/docs.rs
@version 2026.01.16
@updateURL https://github.com/catppuccin/userstyles/raw/main/styles/docs.rs/catppuccin.user.less
@supportURL https://github.com/catppuccin/userstyles/issues?q=is%3Aopen+is%3Aissue+label%3Adocs.rs
@description Soothing pastel theme for docs.rs
@author Catppuccin
@license MIT
@preprocessor less
@var select lightFlavor "Light Flavor" ["latte:Latte*", "frappe:Frappé", "macchiato:Macchiato", "mocha:Mocha"]
@var select darkFlavor "Dark Flavor" ["latte:Latte", "frappe:Frappé", "macchiato:Macchiato", "mocha:Mocha*"]
@var select accentColor "Accent" ["rosewater:Rosewater", "flamingo:Flamingo", "pink:Pink", "mauve:Mauve*", "red:Red", "maroon:Maroon", "peach:Peach", "yellow:Yellow", "green:Green", "teal:Teal", "blue:Blue", "sapphire:Sapphire", "sky:Sky", "lavender:Lavender", "subtext0:Gray"]
==/UserStyle== */
@import "https://userstyles.catppuccin.com/lib/lib.less";
@-moz-document domain("docs.rs"), domain("doc.rust-lang.org") {
:root:not([data-docs-rs-theme]) {
@media (prefers-color-scheme: light) {
#catppuccin(@lightFlavor);
}
@media (prefers-color-scheme: dark) {
#catppuccin(@darkFlavor);
}
}
:root[data-docs-rs-theme="dark"] {
#catppuccin(@darkFlavor);
}
:root[data-docs-rs-theme="light"] {
#catppuccin(@lightFlavor);
}
#catppuccin(@flavor) {
#lib.palette();
#lib.defaults();
--color-background-code: @mantle;
--color-background: @base;
--input-color: @text;
--input-box-shadow-focus: 0 0 8px 4px @accent;
--color-border-light: @surface2;
--color-border: @surface0;
--color-doc-link-background: @accent;
--color-doc-link-hover: @accent;
--color-error-hover: red;
--color-error: red;
--color-macro: red;
--color-menu-border: red;
--color-menu-header-background: red;
--color-navbar-standard: @text;
--color-standard: @subtext1;
--color-brand: @text;
--color-struct: red;
--color-type: @peach;
--color-url: @accent;
--color-warn-background: @peach;
--color-warn-msg: @crust;
--color-warn-hover: red;
--color-warn: @peach;
--color-background-input: @mantle;
--color-table-header-background: @surface0;
--color-table-header: @text;
--color-search-focus: red;
--chart-title-color: red;
--chart-grid: red;
--main-background-color: @base;
--main-color: @text;
--settings-input-color: @accent;
--settings-input-border-color: @surface0;
--settings-button-color: @text;
--settings-button-border-focus: @accent;
--settings-menu-filter: @subtext0-filter;
--settings-menu-hover-filter: @subtext1-filter;
--sidebar-background-color: @mantle;
--sidebar-background-color-hover: @crust;
--sidebar-border-color: @overlay1;
--sidebar-resizer-hover: @sky;
--sidebar-resizer-active: @sapphire;
--source-sidebar-background-selected: @surface0;
--source-sidebar-background-hover: @base;
--code-block-background-color: @mantle;
--headings-border-bottom-color: @overlay1;
--border-color: @surface0;
--button-background-color: @mantle;
--right-side-color: @surface2;
--code-attribute-color: @yellow;
--toggles-color: @subtext1;
--search-input-focused-border-color: @accent;
--copy-path-button-color: @text;
--codeblock-error-hover-color: @red;
--codeblock-error-color: fade(@red, 70%);
--codeblock-ignore-hover-color: @red;
--codeblock-ignore-color: fade(@red, 70%);
--warning-border-color: red;
--type-link-color: @sky;
--trait-link-color: @mauve;
--assoc-item-link-color: @yellow;
--function-link-color: @green;
--macro-link-color: @green;
--keyword-link-color: @yellow;
--mod-link-color: @accent;
--link-color: @accent;
--sidebar-link-color: @accent;
--sidebar-current-link-background-color: @surface0;
--search-result-link-focus-background-color: fade(@accent, 20%);
--search-result-border-color: @surface0;
--search-color: @text;
--search-error-code-background-color: red;
--search-results-alias-color: red;
--search-results-grey-color: @subtext1;
--search-tab-title-count-color: @subtext0;
--search-tab-button-not-selected-border-top-color: @crust;
--search-tab-button-not-selected-background: @crust;
--search-tab-button-selected-border-top-color: @accent;
--search-tab-button-selected-background: @base;
--stab-background-color: @surface0;
--stab-code-color: @accent;
--code-highlight-kw-color: @mauve;
--code-highlight-kw-2-color: @mauve;
--code-highlight-lifetime-color: @blue;
--code-highlight-prelude-color: @yellow;
--code-highlight-prelude-val-color: @yellow;
--code-highlight-number-color: @peach;
--code-highlight-string-color: @green;
--code-highlight-literal-color: @red;
--code-highlight-attribute-color: @yellow;
--code-highlight-self-color: @red;
--code-highlight-macro-color: @blue;
--code-highlight-question-mark-color: @teal;
--code-highlight-comment-color: @overlay2;
--code-highlight-doc-comment-color: @overlay2;
--color-syntax-foreground: inherit;
--color-syntax-attribute: @yellow;
--color-syntax-background: @mantle;
--color-syntax-bool: @red;
--color-syntax-comment: @overlay2;
--color-syntax-doc-comment: @overlay2;
--color-syntax-keyword1: @mauve;
--color-syntax-keyword2: @mauve;
--color-syntax-lifetime: @blue;
--color-syntax-macro: @blue;
--color-syntax-number: @peach;
--color-syntax-prelude-ty: @yellow;
--color-syntax-prelude-val: @yellow;
--color-syntax-question-mark: @teal;
--color-syntax-self: @red;
--color-syntax-string: @green;
--src-line-numbers-span-color: @accent;
--src-line-number-highlighted-background-color: fade(@accent, 30%);
--test-arrow-color: #dedede;
--test-arrow-background-color: red;
--test-arrow-hover-color: #dedede;
--test-arrow-hover-background-color: red;
--target-background-color: fade(@accent, 10%);
--target-border-color: @accent;
--kbd-color: @text;
--kbd-background: @mantle;
--kbd-box-shadow-color: @surface1;
--crate-search-hover-border: red;
--src-sidebar-background-selected: @surface0;
--src-sidebar-background-hover: @surface1;
--table-alt-row-background-color: @mantle;
--codeblock-link-background: fade(@surface0, 50%);
--scrape-example-toggle-line-background: red;
--scrape-example-toggle-line-hover-background: red;
--scrape-example-code-line-highlight: fade(@accent, 40%);
--scrape-example-code-line-highlight-focus: fade(@accent, 40%);
--scrape-example-help-border-color: @subtext0;
--scrape-example-help-color: @subtext1;
--scrape-example-help-hover-border-color: @text;
--scrape-example-help-hover-color: @text;
--scrape-example-code-wrapper-background-start: @base;
--scrape-example-code-wrapper-background-end: @base;
select {
background-color: @mantle;
border-color: @surface0;
}
hr {
border-color: @overlay1;
}
.rust-logo {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
img[alt="Change settings"] {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
#settings-menu {
img[alt="Change settings"] {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
> a:not(:has(img))::before {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
}
.setting-check input:checked {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
#copy-path {
@raw: '';
@raw_before: '';
> img {
@svg: escape(replace(@raw, "%COLOR%", @subtext0));
content: url("data:image/svg+xml,@{svg}");
filter: none;
}
&:hover > img {
@svg: escape(replace(@raw, "%COLOR%", @text));
content: url("data:image/svg+xml,@{svg}");
filter: none;
}
&:not(:has(> img)) {
&::before {
@svg: escape(replace(@raw_before, "%COLOR%", @subtext0));
content: url("data:image/svg+xml,@{svg}");
filter: none;
}
&:hover::before {
@svg: escape(replace(@raw_before, "%COLOR%", @text));
content: url("data:image/svg+xml,@{svg}");
filter: none;
}
}
}
details.toggle {
@plus: escape(
''
);
@minus: escape(
''
);
> summary::before {
background: url("data:image/svg+xml,@{plus}") no-repeat top left;
filter: none;
}
&[open] > summary::before {
background: url("data:image/svg+xml,@{minus}") no-repeat top left;
}
}
.src #sidebar-button > a::before {
@svg: escape(
''
);
content: url("data:image/svg+xml,@{svg}");
}
.pure-menu-link {
color: @subtext0;
&:hover {
color: @text;
}
}
.pure-table {
&,
td,
th {
border-color: @surface0;
}
}
}
}