/*
Based off of the Ayu theme
Original by Dempfi (https://github.com/dempfi/ayu)
*/

:root {
	--main-background-color: #0f1419;
	--main-color: #c5c5c5;
	--settings-input-color: #ffb454;
	--sidebar-background-color: #14191f;
	--sidebar-background-color-hover: rgba(70, 70, 70, 0.33);
	--code-block-background-color: #191f26;
	--scrollbar-track-background-color: transparent;
	--scrollbar-thumb-background-color: #5c6773;
	--scrollbar-color: #5c6773 #24292f;
	--headings-border-bottom-color: #5c6773;
	--border-color: #5c6773;
	--button-background-color: #141920;
}

.slider {
	background-color: #ccc;
}
.slider:before {
	background-color: white;
}
input:focus + .slider {
	box-shadow: 0 0 0 2px #0a84ff, 0 0 0 6px rgba(10, 132, 255, 0.3);
}

h1, h2, h3, h4 {
	color: white;
}
h1.fqn  a {
	color: #fff;
}
h4 {
	border: none;
}

.docblock code {
	color: #ffb454;
}
.code-header {
	color: #e6e1cf;
}
.docblock pre > code, pre > code {
	color: #e6e1cf;
}
.item-info code {
	color: #e6e1cf;
}
.docblock a > code {
	color: #39AFD7 !important;
}
pre, .rustdoc.source .example-wrap {
	color: #e6e1cf;
}

.rust-logo {
	filter: drop-shadow(1px 0 0px #fff)
		drop-shadow(0 1px 0 #fff)
		drop-shadow(-1px 0 0 #fff)
		drop-shadow(0 -1px 0 #fff);
}

.sidebar .current,
.sidebar a:hover {
	background-color: transparent;
	color: #ffb44c;
}

.sidebar-elems .location {
	color: #ff7733;
}

.line-numbers span { color: #5c6773; }
.line-numbers .line-highlighted {
	color: #708090;
	background-color: rgba(255, 236, 164, 0.06);
	padding-right: 4px;
	border-right: 1px solid #ffb44c;
}

.search-results a:hover {
	color: #fff !important;
	background-color: #3c3c3c;
}

.search-results a:focus {
	color: #fff !important;
	background-color: #3c3c3c;
}
.search-results a {
	color: #0096cf;
}
.search-results a div.desc {
	color: #c5c5c5;
}

.content .item-info::before { color: #ccc; }

.content span.foreigntype, .content a.foreigntype { color: #ffa0a5; }
.content span.union, .content a.union { color: #ffa0a5; }
.content span.constant, .content a.constant,
.content span.static, .content a.static { color: #39AFD7; }
.content span.primitive, .content a.primitive { color: #ffa0a5; }
.content span.traitalias, .content a.traitalias { color: #39AFD7; }
.content span.keyword, .content a.keyword { color: #39AFD7; }

.content span.externcrate, .content span.mod, .content a.mod {
	color: #39AFD7;
}
.content span.struct, .content a.struct {
	color: #ffa0a5;
}
.content span.enum, .content a.enum {
	color: #ffa0a5;
}
.content span.trait, .content a.trait {
	color: #39AFD7;
}
.content span.type, .content a.type {
	color: #39AFD7;
}
.content span.type,
.content a.type,
.block a.current.type { color: #39AFD7; }
.content span.associatedtype,
.content a.associatedtype,
.block a.current.associatedtype { color: #39AFD7; }
.content span.fn, .content a.fn, .content span.method,
.content a.method, .content span.tymethod,
.content a.tymethod, .content .fnname {
	color: #fdd687;
}
.content span.attr, .content a.attr, .content span.derive,
.content a.derive, .content span.macro, .content a.macro {
	color: #a37acc;
}

.sidebar a { color: #53b1db; }
.sidebar a.current.type { color: #53b1db; }
.sidebar a.current.associatedtype { color: #53b1db; }

pre.rust .comment { color: #788797; }
pre.rust .doccomment { color: #a1ac88; }

a {
	color: #39AFD7;
}

.sidebar h2 a,
.sidebar h3 a {
	color: white;
}
body.source .example-wrap pre.rust a {
	background: #333;
}

details.rustdoc-toggle > summary.hideme > span,
details.rustdoc-toggle > summary::before {
	color: #999;
}

details.rustdoc-toggle > summary::before {
	filter: invert(100%);
}

#crate-search-div::after {
	/* match border-color; uses https://codepen.io/sosuke/pen/Pjoqqp */
	filter: invert(41%) sepia(12%) saturate(487%) hue-rotate(171deg) brightness(94%) contrast(94%);
}
#crate-search:hover, #crate-search:focus {
	border-color: #e0e0e0 !important;
}
#crate-search-div:hover::after, #crate-search-div:focus-within::after {
	filter: invert(98%) sepia(12%) saturate(81%) hue-rotate(343deg) brightness(113%) contrast(76%);
}

.search-input {
	color: #fff;
}

.module-item .stab,
.import-item .stab {
	color: #000;
}

.stab {
	color: #c5c5c5;
	background: #314559 !important;
}

.stab.portability > code {
	color: #e6e1cf;
	background: none;
}

.rightside:not(a),
.out-of-band {
	color: grey;
}

.result-name .primitive > i, .result-name .keyword > i {
	color: #788797;
}

.line-numbers :target { background-color: transparent; }

/* Code highlighting */
pre.rust .number, pre.rust .string { color: #b8cc52; }
pre.rust .kw, pre.rust .kw-2, pre.rust .prelude-ty,
pre.rust .bool-val, pre.rust .prelude-val,
pre.rust .lifetime { color: #ff7733; }
pre.rust .macro, pre.rust .macro-nonterminal { color: #a37acc; }
pre.rust .question-mark {
	color: #ff9011;
}
pre.rust .self {
	color: #36a3d9;
	font-style: italic;
}
pre.rust .attribute {
	color: #e6e1cf;
}

.example-wrap > pre.line-number {
	color: #5c67736e;
	border: none;
}

a.test-arrow {
	font-size: 100%;
	color: #788797;
	border-radius: 4px;
	background-color: rgba(57, 175, 215, 0.09);
}

a.test-arrow:hover {
	background-color: rgba(57, 175, 215, 0.368);
	color: #c5c5c5;
}

.toggle-label,
.code-attribute {
	color: #999;
}

:target {
	background: rgba(255, 236, 164, 0.06);
	border-right: 3px solid rgba(255, 180, 76, 0.85);
}

pre.compile_fail {
	border-left: 2px solid rgba(255,0,0,.4);
}

pre.compile_fail:hover, .information:hover + pre.compile_fail {
	border-left: 2px solid #f00;
}

pre.should_panic {
	border-left: 2px solid rgba(255,0,0,.4);
}

pre.should_panic:hover, .information:hover + pre.should_panic {
	border-left: 2px solid #f00;
}

pre.ignore {
	border-left: 2px solid rgba(255,142,0,.6);
}

pre.ignore:hover, .information:hover + pre.ignore {
	border-left: 2px solid #ff9200;
}

.tooltip.compile_fail {
	color: rgba(255,0,0,.5);
}

.information > .compile_fail:hover {
	color: #f00;
}

.tooltip.should_panic {
	color: rgba(255,0,0,.5);
}

.information > .should_panic:hover {
	color: #f00;
}

.tooltip.ignore {
	color: rgba(255,142,0,.6);
}

.information > .ignore:hover {
	color: #ff9200;
}

.search-failed a {
	color: #39AFD7;
}

.tooltip::after {
	background-color: #314559;
	color: #c5c5c5;
}

.tooltip::before {
	border-color: transparent #314559 transparent transparent;
}

.notable-traits-tooltiptext {
	background-color: #314559;
}

#titles > button.selected {
	background-color: #141920 !important;
	border-bottom: 1px solid #ffb44c !important;
	border-top: none;
}

#titles > button:not(.selected) {
	background-color: transparent !important;
	border: none;
}

#titles > button:hover {
	border-bottom: 1px solid rgba(242, 151, 24, 0.3);
}

#titles > button > div.count {
	color: #888;
}

/* rules that this theme does not need to set, here to satisfy the rule checker */
/* note that a lot of these are partially set in some way (meaning they are set
individually rather than as a group) */
/* FIXME: these rules should be at the bottom of the file but currently must be
above the `@media (max-width: 700px)` rules due to a bug in the css checker */
/* see https://github.com/rust-lang/rust/pull/71237#issuecomment-618170143 */
.search-input:focus {}
.content span.attr,.content a.attr,.block a.current.attr,.content span.derive,.content a.derive,
.block a.current.derive,.content span.macro,.content a.macro,.block a.current.macro {}
.content span.struct,.content a.struct,.block a.current.struct {}
#titles>button:hover,#titles>button.selected {}
.content span.typedef,.content a.typedef,.block a.current.typedef {}
.content span.union,.content a.union,.block a.current.union {}
pre.rust .lifetime {}
.stab.unstable {}
h2,
h3:not(.impl):not(.method):not(.type):not(.tymethod), h4:not(.method):not(.type):not(.tymethod) {}
.content span.enum,.content a.enum,.block a.current.enum {}
.content span.constant,.content a.constant,.block a.current.constant,.content span.static,
.content a.static, .block a.current.static {}
.content span.keyword,.content a.keyword,.block a.current.keyword {}
.content span.traitalias,.content a.traitalias,.block a.current.traitalias {}
.content span.fn,.content a.fn,.block a.current.fn,.content span.method,.content a.method,
.block a.current.method,.content span.tymethod,.content a.tymethod,.block a.current.tymethod,
.content .fnname {}
pre.rust .kw {}
pre.rust .self,pre.rust .bool-val,pre.rust .prelude-val,pre.rust .attribute {}
.content span.foreigntype,.content a.foreigntype,.block a.current.foreigntype {}
.stab.deprecated {}
.content a.attr,.content a.derive,.content a.macro {}
.stab.portability {}
.content span.primitive,.content a.primitive,.block a.current.primitive {}
.content span.externcrate,.content span.mod,.content a.mod,.block a.current.mod {}
pre.rust .kw-2,pre.rust .prelude-ty {}
.content span.trait,.content a.trait,.block a.current.trait {}

.search-results a:focus span {}
a.result-trait:focus {}
a.result-traitalias:focus {}
a.result-mod:focus,
a.result-externcrate:focus {}
a.result-mod:focus {}
a.result-externcrate:focus {}
a.result-enum:focus {}
a.result-struct:focus {}
a.result-union:focus {}
a.result-fn:focus,
a.result-method:focus,
a.result-tymethod:focus {}
a.result-type:focus {}
a.result-associatedtype:focus {}
a.result-foreigntype:focus {}
a.result-attr:focus,
a.result-derive:focus,
a.result-macro:focus {}
a.result-constant:focus,
a.result-static:focus {}
a.result-primitive:focus {}
a.result-keyword:focus {}

.sidebar a.current.enum {}
.sidebar a.current.struct {}
.sidebar a.current.foreigntype {}
.sidebar a.current.attr,
.sidebar a.current.derive,
.sidebar a.current.macro {}
.sidebar a.current.union {}
.sidebar a.current.constant
.sidebar a.current.static {}
.sidebar a.current.primitive {}
.sidebar a.current.externcrate
.sidebar a.current.mod {}
.sidebar a.current.trait {}
.sidebar a.current.traitalias {}
.sidebar a.current.fn,
.sidebar a.current.method,
.sidebar a.current.tymethod {}
.sidebar a.current.keyword {}

kbd {
	color: #c5c5c5;
	background-color: #314559;
	box-shadow: inset 0 -1px 0 #5c6773;
}

#settings-menu > a, #help-button > button {
	color: #fff;
}

#settings-menu > a img {
	filter: invert(100);
}

#copy-path {
	color: #fff;
}
#copy-path > img {
	filter: invert(70%);
}
#copy-path:hover > img {
	filter: invert(100%);
}

#settings-menu > a:hover, #settings-menu > a:focus,
#help-button > button:hover, #help-button > button:focus {
	border-color: #e0e0e0;
}

.search-results .result-name span.alias {
	color: #c5c5c5;
}
.search-results .result-name span.grey {
	color: #999;
}

#source-sidebar > .title {
	color: #fff;
}
#source-sidebar div.files > a:hover, details.dir-entry summary:hover,
#source-sidebar div.files > a:focus, details.dir-entry summary:focus {
	background-color: #14191f;
	color: #ffb44c;
}
#source-sidebar div.files > a.selected {
	background-color: #14191f;
	color: #ffb44c;
}

.scraped-example-list .scrape-help {
	border-color: #aaa;
	color: #eee;
}
.scraped-example-list .scrape-help:hover {
	border-color: white;
	color: white;
}
.more-examples-toggle summary, .more-examples-toggle .hide-more {
	color: #999;
}
.scraped-example .example-wrap .rust span.highlight {
	background: rgb(91, 59, 1);
}
.scraped-example .example-wrap .rust span.highlight.focus {
	background: rgb(124, 75, 15);
}
.scraped-example:not(.expanded) .code-wrapper:before {
	background: linear-gradient(to bottom, rgba(15, 20, 25, 1), rgba(15, 20, 25, 0));
}
.scraped-example:not(.expanded) .code-wrapper:after {
	background: linear-gradient(to top, rgba(15, 20, 25, 1), rgba(15, 20, 25, 0));
}
.toggle-line-inner {
	background: #999;
}
.toggle-line:hover .toggle-line-inner {
	background: #c5c5c5;
}
