custom.css 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050
  1. /**
  2. * Various tweaks to the Read the Docs theme to better conform with Godot's
  3. * visual identity. Many colors are also overridden to use CSS variables.
  4. * This makes it possible to provide an automatically-used dark theme
  5. * based on browser preferences.
  6. */
  7. /* Default (light) theme colors */
  8. :root {
  9. --body-color: #404040;
  10. --content-wrap-background-color: #efefef;
  11. --content-background-color: #fcfcfc;
  12. --logo-opacity: 1.0;
  13. --navbar-background-color: #333f67;
  14. --navbar-background-color-hover: #29355c;
  15. --navbar-background-color-active: #212d51;
  16. --navbar-current-background-color: #212d51;
  17. --navbar-current-background-color-hover: #182343;
  18. --navbar-current-background-color-active: #131e3b;
  19. --navbar-level-1-color: #c3e3ff;
  20. --navbar-level-2-color: #b8d6f0;
  21. --navbar-level-3-color: #a3c4e1;
  22. --navbar-heading-color: #ff7381;
  23. --navbar-scrollbar-color: #d45a66;
  24. --navbar-scrollbar-hover-color: #b14550;
  25. --navbar-scrollbar-active-color: #72383e;
  26. --navbar-scrollbar-background: #131e2b;
  27. --link-color: #2980b9;
  28. --link-color-hover: #3091d1;
  29. --link-color-active: #105078;
  30. --link-color-visited: #9b59b6;
  31. --external-reference-icon: url("data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjEyIiB3aWR0aD0iMTIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGcgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjk4MGI5Ij48cGF0aCBkPSJtNy41IDcuMXYzLjRoLTZ2LTZoMy40Ii8+PHBhdGggZD0ibTUuNzY1IDFoNS4yMzV2NS4zOWwtMS41NzMgMS41NDctMS4zMS0xLjMxLTIuNzI0IDIuNzIzLTIuNjktMi42ODggMi44MS0yLjgwOC0xLjMxMy0xLjMxeiIvPjwvZz48L3N2Zz4K");
  32. --hr-color: #e1e4e5;
  33. --table-row-odd-background-color: #f3f6f6;
  34. --code-background-color: #fff;
  35. --code-border-color: #e1e4e5;
  36. --code-literal-color: #d04c60;
  37. --input-background-color: #fcfcfc;
  38. --input-focus-border-color: #5f8cff;
  39. --search-input-background-color: #e6eef3; /* derived from --input-background-color */
  40. --search-match-color: #2c6b96; /* derived from --link-color */
  41. --search-match-background-color: #e3f2fd; /* derived from --link-color */
  42. --search-active-color: #efefef;
  43. --search-credits-background-color: #333f67; /* derived from --navbar-background-color */
  44. --search-credits-color: #b3b3b3; /* derived from --footer-color */
  45. --search-credits-link-color: #4392c5; /* derived from --link-color */
  46. --highlight-background-color: #f5ffe1;
  47. --highlight-background-emph-color: #dbe6c3;
  48. --highlight-default-color: #404040;
  49. --highlight-comment-color: #408090;
  50. --highlight-keyword-color: #007020;
  51. --highlight-keyword2-color: #902000;
  52. --highlight-number-color: #208050;
  53. --highlight-decorator-color: #4070a0;
  54. --highlight-type-color: #007020;
  55. --highlight-type2-color: #0e84b5;
  56. --highlight-function-color: #06287e;
  57. --highlight-operator-color: #666666;
  58. --highlight-string-color: #4070a0;
  59. --admonition-note-background-color: #e7f2fa;
  60. --admonition-note-color: #404040;
  61. --admonition-note-title-background-color: #6ab0de;
  62. --admonition-note-title-color: #fff;
  63. --admonition-attention-background-color: #ffedcc;
  64. --admonition-attention-color: #404040;
  65. --admonition-attention-title-background-color: #f0b37e;
  66. --admonition-attention-title-color: #fff;
  67. --admonition-danger-background-color: #fcf3f2;
  68. --admonition-danger-color: #404040;
  69. --admonition-danger-title-background-color: #e9a499;
  70. --admonition-danger-title-color: #fff;
  71. --admonition-tip-background-color: #dbfaf4;
  72. --admonition-tip-color: #404040;
  73. --admonition-tip-title-background-color: #1abc9c;
  74. --admonition-tip-title-color: #fff;
  75. --kbd-background-color: #fafbfc;
  76. --kbd-outline-color: #d1d5da;
  77. --kbd-shadow-color: #b0b7bf;
  78. --kbd-text-color: #444d56;
  79. --btn-neutral-background-color: #f3f6f6;
  80. --btn-neutral-hover-background-color: #e5ebeb;
  81. --footer-color: #808080;
  82. }
  83. /* Dark theme colors */
  84. @media (prefers-color-scheme: dark) {
  85. :root {
  86. --body-color: rgba(255, 255, 255, 0.85);
  87. --content-wrap-background-color: #202326;
  88. --content-background-color: #2e3236;
  89. /* Decrease the logo opacity when using the dark theme to be less distracting */
  90. --logo-opacity: 0.85;
  91. --navbar-background-color: #25282b;
  92. --navbar-background-color-hover: #333639;
  93. --navbar-background-color-active: #111417;
  94. --navbar-current-background-color: #333639;
  95. --navbar-current-background-color-hover: #44474a;
  96. --navbar-current-background-color-active: #222528;
  97. --navbar-level-1-color: #ddd;
  98. --navbar-level-2-color: #ccc;
  99. --navbar-level-3-color: #bbb;
  100. --navbar-heading-color: #ee7381;
  101. --navbar-scrollbar-color: #be5460;
  102. --navbar-scrollbar-hover-color: #963e48;
  103. --navbar-scrollbar-active-color: #5f3034;
  104. --navbar-scrollbar-background: #1c1e21;
  105. --link-color: #8cf;
  106. --link-color-hover: #9df;
  107. --link-color-active: #6ad;
  108. --link-color-visited: #cb99f6;
  109. --external-reference-icon: url("data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjEyIiB3aWR0aD0iMTIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGcgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjOGNmIj48cGF0aCBkPSJtNy41IDcuMXYzLjRoLTZ2LTZoMy40Ii8+PHBhdGggZD0ibTUuNzY1IDFoNS4yMzV2NS4zOWwtMS41NzMgMS41NDctMS4zMS0xLjMxLTIuNzI0IDIuNzIzLTIuNjktMi42ODggMi44MS0yLjgwOC0xLjMxMy0xLjMxeiIvPjwvZz48L3N2Zz4K");
  110. --hr-color: #555;
  111. --table-row-odd-background-color: #3b3e41;
  112. --code-background-color: #434649;
  113. --code-border-color: #505356;
  114. --code-literal-color: #faa;
  115. --input-background-color: #333537;
  116. --input-focus-border-color: #5f8cff;
  117. --search-input-background-color: #43464a; /* derived from --input-background-color */
  118. --search-match-color: #52b4ff; /* derived from --link-color */
  119. --search-match-background-color: #414c56; /* derived from --link-color */
  120. --search-active-color: #202326;
  121. --search-credits-background-color: #202123; /* derived from --navbar-background-color */
  122. --search-credits-color: #6b6b6b; /* derived from --footer-color */
  123. --search-credits-link-color: #628fb1; /* derived from --link-color */
  124. /* Colors taken from the Godot script editor with the Adaptive theme */
  125. --highlight-background-color: #202531;
  126. --highlight-background-emph-color: #2d3444;
  127. --highlight-default-color: rgba(255, 255, 255, 0.85);
  128. --highlight-comment-color: rgba(204, 206, 211, 0.5);
  129. --highlight-keyword-color: #ff7085;
  130. --highlight-keyword2-color: #42ffc2;
  131. --highlight-number-color: #a1ffe0;
  132. --highlight-decorator-color: #abc8ff;
  133. --highlight-type-color: #8effda;
  134. --highlight-type2-color: #c6ffed;
  135. --highlight-function-color: #57b3ff;
  136. --highlight-operator-color: #abc8ff;
  137. --highlight-string-color: #ffeca1;
  138. --admonition-note-background-color: #303d4f;
  139. --admonition-note-color: #bfeeff;
  140. --admonition-note-title-background-color: #305070;
  141. --admonition-note-title-color: #bfefff;
  142. --admonition-attention-background-color: #444033;
  143. --admonition-attention-color: #ffeeaf;
  144. --admonition-attention-title-background-color: #665022;
  145. --admonition-attention-title-color: #ffeeaf;
  146. --admonition-danger-background-color: #433;
  147. --admonition-danger-color: #fcc;
  148. --admonition-danger-title-background-color: #633;
  149. --admonition-danger-title-color: #fcc;
  150. --admonition-tip-background-color: #28382d;
  151. --admonition-tip-color: #dfd;
  152. --admonition-tip-title-background-color: #336648;
  153. --admonition-tip-title-color: #dfd;
  154. --kbd-background-color: #595b5d;
  155. --kbd-outline-color: #3d4144;
  156. --kbd-shadow-color: #1e2023;
  157. --kbd-text-color: #e2f2ff;
  158. --btn-neutral-background-color: #404040;
  159. --btn-neutral-hover-background-color: #505050;
  160. --footer-color: #aaa;
  161. }
  162. }
  163. body,
  164. h1,
  165. h2,
  166. h3,
  167. h4,
  168. h5,
  169. h6,
  170. input[type="text"],
  171. input[type="button"],
  172. input[type="reset"],
  173. input[type="submit"],
  174. textarea,
  175. legend,
  176. .btn,
  177. .rst-content .toctree-wrapper p.caption,
  178. .rst-versions {
  179. /* Use a system font stack for better performance (no Web fonts required) */
  180. font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  181. }
  182. h1,
  183. h2,
  184. h3,
  185. h4,
  186. h5,
  187. h6,
  188. legend,
  189. .rst-content .toctree-wrapper p.caption {
  190. /* Use a lighter font for headers (Medium instead of Bold) */
  191. font-weight: 500;
  192. }
  193. /* See <https://github.com/godotengine/godot-docs/pull/5876> for context. */
  194. .rst-content .align-right,
  195. .rst-content .align-left {
  196. clear: both;
  197. }
  198. .rst-content div.figure p.caption {
  199. /* Tweak caption styling to be closer to typical captions */
  200. text-align: center;
  201. margin-top: 8px;
  202. opacity: 0.75;
  203. }
  204. .rst-content div.figure.figure-w480 {
  205. max-width: 480px;
  206. }
  207. .rst-content div.figure img {
  208. border: 1px solid var(--body-color);
  209. }
  210. p,
  211. article ul,
  212. article ol,
  213. .wy-plain-list-disc,
  214. .wy-plain-list-decimal,
  215. .rst-content ol.arabic,
  216. .rst-content .section ul,
  217. .rst-content .toctree-wrapper ul,
  218. .rst-content .section ol {
  219. /* Increase the line height slightly to account for the different font */
  220. line-height: 25px;
  221. }
  222. .rst-content section ul li {
  223. /* Increase spacing between list items. */
  224. margin-top: 8px;
  225. margin-bottom: 8px;
  226. }
  227. body,
  228. .rst-content table.docutils thead {
  229. color: var(--body-color);
  230. }
  231. a {
  232. color: var(--link-color);
  233. }
  234. .sphinx-tabs-tab {
  235. color: var(--link-color);
  236. }
  237. .sphinx-tabs-tab[aria-selected="true"] {
  238. background-color: var(--code-background-color);
  239. border-bottom: 1px solid var(--code-background-color);
  240. }
  241. .sphinx-tabs-panel {
  242. background-color: var(--code-background-color);
  243. }
  244. a:hover {
  245. color: var(--link-color-hover);
  246. text-decoration: underline;
  247. }
  248. a:active {
  249. /* Add visual feedback when clicking on a link */
  250. color: var(--link-color-active);
  251. }
  252. a:visited {
  253. color: var(--link-color-visited);
  254. }
  255. a.btn:hover {
  256. text-decoration: none;
  257. }
  258. /* Style external links differently to make them easier to distinguish from internal links. */
  259. .reference.external {
  260. background-position: center right;
  261. background-repeat: no-repeat;
  262. background-image: var(--external-reference-icon);
  263. padding-right: 13px;
  264. }
  265. hr,
  266. #search-results .search li:first-child,
  267. #search-results .search li {
  268. border-color: var(--hr-color);
  269. }
  270. /* JavaScript documentation directives */
  271. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dt,
  272. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dl:not(.field-list) > dt {
  273. background-color: var(--admonition-note-background-color);
  274. border-color: var(--admonition-note-title-background-color);
  275. color: var(--admonition-note-color);
  276. }
  277. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dl dt {
  278. background-color: transparent;
  279. border-color: transparent;
  280. color: var(--footer-color);
  281. }
  282. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).class dt,
  283. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).function dt,
  284. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).method dt,
  285. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).attribute dt {
  286. font-weight: 600;
  287. padding: 0 8px;
  288. margin-bottom: 1px;
  289. width: 100%;
  290. }
  291. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).class > dt,
  292. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).function > dt,
  293. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).method > dt,
  294. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).attribute > dt {
  295. font-family: SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, Courier, monospace;
  296. font-size: 90%;
  297. font-weight: normal;
  298. margin-bottom: 16px;
  299. padding: 6px 8px;
  300. }
  301. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .sig-prename.descclassname {
  302. color: var(--highlight-type2-color);
  303. font-weight: normal;
  304. }
  305. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .sig-name.descname {
  306. color: var(--highlight-function-color);
  307. font-weight: 700;
  308. }
  309. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .sig-paren,
  310. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .optional {
  311. color: var(--highlight-operator-color) !important;
  312. font-weight: normal;
  313. padding: 0 2px;
  314. }
  315. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .optional {
  316. font-style: italic;
  317. }
  318. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .sig-param,
  319. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).class dt > em,
  320. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).function dt > em,
  321. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).method dt > em {
  322. color: var(--code-literal-color);
  323. font-style: normal;
  324. padding: 0 4px;
  325. }
  326. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .k {
  327. font-style: normal;
  328. }
  329. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) .sig-param,
  330. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).class dt > .optional ~ em,
  331. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).function dt > .optional ~ em,
  332. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).method dt > .optional ~ em {
  333. color: var(--highlight-number-color);
  334. font-style: italic;
  335. }
  336. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple).class dt > em.property {
  337. color: var(--highlight-keyword-color);
  338. }
  339. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dt a.headerlink {
  340. color: var(--link-color) !important;
  341. }
  342. html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.glossary):not(.simple) dt a.headerlink:visited {
  343. color: var(--link-color-visited);
  344. }
  345. html.writer-html5 .rst-content dl.field-list > dd strong {
  346. font-family: SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, Courier, monospace;
  347. }
  348. footer,
  349. #search-results .context {
  350. color: var(--footer-color);
  351. }
  352. /* Sphinx Search extension */
  353. /* .wy-body-for-nav is used for higher rule specificity */
  354. /* Search popup body */
  355. .wy-body-for-nav .search__outer {
  356. background-color: var(--content-background-color);
  357. border: 2px solid var(--content-background-color);
  358. }
  359. .wy-body-for-nav .search__cross svg {
  360. fill: var(--body-color);
  361. }
  362. .wy-body-for-nav .search__outer::-webkit-scrollbar-track {
  363. border-radius: 10px;
  364. background-color: var(--content-background-color);
  365. }
  366. .wy-body-for-nav .search__outer::-webkit-scrollbar {
  367. width: 7px;
  368. height: 7px;
  369. background-color: var(--content-background-color);
  370. }
  371. .wy-body-for-nav .search__outer::-webkit-scrollbar-thumb {
  372. border-radius: 10px;
  373. background-color: var(--hr-color);
  374. }
  375. /* Search input */
  376. .wy-body-for-nav .search__outer__input {
  377. background-color: var(--search-input-background-color);
  378. background-image: none;
  379. border-radius: 50px;
  380. border: 2px solid transparent;
  381. color: var(--body-color);
  382. height: 36px;
  383. padding: 6px 12px;
  384. }
  385. .wy-body-for-nav .search__outer__input:focus {
  386. border-color: var(--input-focus-border-color);
  387. }
  388. .wy-body-for-nav .search__outer .bar:after,
  389. .wy-body-for-nav .search__outer .bar:before {
  390. display: none;
  391. }
  392. /* Search results item */
  393. .wy-body-for-nav .search__result__single {
  394. border-bottom-color: var(--hr-color);
  395. }
  396. /* Search item title */
  397. .wy-body-for-nav .search__result__title {
  398. color: var(--link-color);
  399. border-bottom: none;
  400. font-size: 120%;
  401. font-weight: 400;
  402. }
  403. /* Search item section */
  404. .wy-body-for-nav .outer_div_page_results:hover,
  405. .wy-body-for-nav .search__result__box .active {
  406. background-color: var(--search-active-color);
  407. }
  408. .wy-body-for-nav .search__result__subheading{
  409. color: var(--body-color);
  410. font-size: 100%;
  411. font-weight: 400;
  412. }
  413. .wy-body-for-nav .search__result__content {
  414. color: var(--footer-color);
  415. }
  416. /* Search item matching substring */
  417. .wy-body-for-nav .search__outer .search__result__title span,
  418. .wy-body-for-nav .search__outer .search__result__content span {
  419. color: var(--search-match-color);
  420. border-bottom: 1px solid var(--search-match-color);
  421. background-color: var(--search-match-background-color);
  422. padding: 0 2px;
  423. }
  424. .wy-body-for-nav .search__result__subheading span {
  425. border-bottom-color: var(--body-color);
  426. }
  427. /* Search empty results */
  428. /* The original styles are inlined, see https://github.com/readthedocs/readthedocs-sphinx-search/issues/48 */
  429. .wy-body-for-nav .search__result__box {
  430. color: var(--body-color) !important;
  431. }
  432. /* Search footer & credits */
  433. .wy-body-for-nav .rtd__search__credits {
  434. background-color: var(--search-credits-background-color);
  435. border-color: var(--search-credits-background-color);
  436. color: var(--search-credits-color);
  437. padding: 4px 8px;
  438. }
  439. .wy-body-for-nav .rtd__search__credits a {
  440. color: var(--search-credits-link-color);
  441. }
  442. /* Main sections */
  443. .wy-nav-content-wrap {
  444. background-color: var(--content-wrap-background-color);
  445. }
  446. .wy-nav-content {
  447. background-color: var(--content-background-color);
  448. }
  449. .wy-body-for-nav {
  450. background-color: var(--content-wrap-background-color);
  451. }
  452. @media only screen and (min-width: 769px) {
  453. .wy-body-for-nav {
  454. /* Center the page on wide displays for better readability */
  455. max-width: 1100px;
  456. margin: 0 auto;
  457. }
  458. }
  459. /* Table display tweaks */
  460. .rst-content table.docutils,
  461. .wy-table-bordered-all td,
  462. .rst-content table.docutils td,
  463. .wy-table thead th,
  464. .rst-content table.docutils thead th,
  465. .rst-content table.field-list thead th {
  466. border-color: var(--code-border-color);
  467. }
  468. .wy-table-odd td,
  469. .wy-table-striped tr:nth-child(2n-1) td,
  470. .rst-content table.docutils:not(.field-list) tr:nth-child(2n-1) td {
  471. background-color: var(--table-row-odd-background-color);
  472. }
  473. /* Override table no-wrap */
  474. /* The first column cells are not verbose, no need to wrap them */
  475. .wy-table-responsive table td:not(:nth-child(1)),
  476. .wy-table-responsive table th:not(:nth-child(1)) {
  477. white-space: normal;
  478. }
  479. /* Make sure not to wrap keyboard shortcuts */
  480. .wy-table-responsive table td kbd {
  481. white-space: nowrap;
  482. }
  483. /* Code display tweaks */
  484. code,
  485. .rst-content tt,
  486. .rst-content code {
  487. font-size: 14px;
  488. background-color: var(--code-background-color);
  489. border: 1px solid var(--code-border-color);
  490. }
  491. .rst-content tt.literal,
  492. .rst-content code.literal {
  493. color: var(--code-literal-color);
  494. }
  495. .rst-content div[class^="highlight"] {
  496. border-color: var(--code-border-color);
  497. }
  498. .rst-content pre.literal-block,
  499. .rst-content div[class^="highlight"] pre,
  500. .rst-content .linenodiv pre {
  501. /* Increase the font size and line height in code blocks */
  502. font-size: 14px;
  503. line-height: 1.5;
  504. }
  505. /* Code tab display tweaks */
  506. .ui.tabular.menu .active.item,
  507. .ui.segment {
  508. background-color: var(--code-background-color);
  509. }
  510. /* Syntax highlighting */
  511. /* Remove default red boxes around Pygments errors */
  512. .highlight .err {
  513. border: none;
  514. }
  515. .highlight {
  516. background-color: var(--highlight-background-color);
  517. }
  518. /* Emphasized lines */
  519. .highlight .hll {
  520. background-color: var(--highlight-background-emph-color);
  521. }
  522. .highlight .gh /* Generic.Heading */,
  523. .highlight .gu /* Generic.Subheading */,
  524. .highlight .go /* Generic.Output */,
  525. .highlight .gt /* Generic.Traceback */ {
  526. color: var(--highlight-default-color);
  527. }
  528. .highlight .c /* Comment */,
  529. .highlight .c1 /* Comment.Single */,
  530. .highlight .cm /* Comment.Multiline */,
  531. .highlight .cs /* Comment.Special */ {
  532. color: var(--highlight-comment-color);
  533. }
  534. .highlight .bp /* Name.Builtin.Pseudo */,
  535. .highlight .k /* Keyword */,
  536. .highlight .kc /* Keyword.Constant */,
  537. .highlight .kd /* Keyword.Declaration */,
  538. .highlight .kn /* Keyword.Namespace */,
  539. .highlight .kp /* Keyword.Pseudo */,
  540. .highlight .kr /* Keyword.Reserved */,
  541. .highlight .kt /* Keyword.Type */,
  542. .highlight .ow /* Operator.Word */ {
  543. color: var(--highlight-keyword-color);
  544. }
  545. .highlight .ch /* Comment.Hashbang */,
  546. .highlight .cp /* Comment.Preproc */ {
  547. color: var(--highlight-keyword2-color);
  548. }
  549. .highlight .m /* Literal.Number */,
  550. .highlight .mf /* Literal.Number.Float */,
  551. .highlight .mi /* Literal.Number.Integer */,
  552. .highlight .il /* Literal.Number.Integer.Long */,
  553. .highlight .mb /* Literal.Number.Bin */,
  554. .highlight .mh /* Literal.Number.Hex */,
  555. .highlight .mo /* Literal.Number.Oct */ {
  556. color: var(--highlight-number-color);
  557. }
  558. .highlight .na /* Name.Attribute */,
  559. .highlight .nd /* Name.Decorator */,
  560. .highlight .ni /* Name.Entity */,
  561. .highlight .nl /* Name.Label */ {
  562. color: var(--highlight-decorator-color);
  563. }
  564. .highlight .nb /* Name.Builtin */,
  565. .highlight .ne /* Name.Exception */ {
  566. color: var(--highlight-type-color);
  567. }
  568. .highlight .nc /* Name.Class */,
  569. .highlight .nn /* Name.Namespace */,
  570. .highlight .no /* Name.Constant */,
  571. .highlight .nv /* Name.Variable */,
  572. .highlight .vc /* Name.Variable.Class */,
  573. .highlight .vg /* Name.Variable.Global */,
  574. .highlight .vi /* Name.Variable.Instance */,
  575. .highlight .vm /* Name.Variable.Magic */ {
  576. color: var(--highlight-type2-color);
  577. }
  578. .highlight .nf /* Name.Function */,
  579. .highlight .fm /* Name.Function.Magic */,
  580. .highlight .nt /* Name.Tag */ {
  581. color: var(--highlight-function-color);
  582. }
  583. .highlight .o /* Operator */,
  584. .highlight .si /* Literal.String.Interpol */,
  585. .highlight .sx /* Literal.String.Other */,
  586. .highlight .sr /* Literal.String.Regex */,
  587. .highlight .ss /* Literal.String.Symbol */ {
  588. color: var(--highlight-operator-color);
  589. }
  590. .highlight .cpf/* Comment.PreprocFile */,
  591. .highlight .s /* Literal.String */,
  592. .highlight .s1 /* Literal.String.Single */,
  593. .highlight .s2 /* Literal.String.Double */,
  594. .highlight .sc /* Literal.String.Char */,
  595. .highlight .se /* Literal.String.Escape */,
  596. .highlight .sa /* Literal.String.Affix */,
  597. .highlight .sb /* Literal.String.Backtick */,
  598. .highlight .dl /* Literal.String.Delimiter */,
  599. .highlight .sd /* Literal.String.Doc */,
  600. .highlight .sh /* Literal.String.Heredoc */ {
  601. color: var(--highlight-string-color);
  602. }
  603. /* Admonition tweaks */
  604. .rst-content .admonition.note,
  605. .rst-content .admonition.seealso {
  606. background-color: var(--admonition-note-background-color);
  607. color: var(--admonition-note-color);
  608. }
  609. .rst-content .admonition.note .admonition-title,
  610. .rst-content .admonition.seealso .admonition-title {
  611. background-color: var(--admonition-note-title-background-color);
  612. color: var(--admonition-note-title-color);
  613. }
  614. .rst-content .admonition.attention,
  615. .rst-content .admonition.caution,
  616. .rst-content .admonition.warning {
  617. background-color: var(--admonition-attention-background-color);
  618. color: var(--admonition-attention-color);
  619. }
  620. .rst-content .admonition.attention .admonition-title,
  621. .rst-content .admonition.caution .admonition-title,
  622. .rst-content .admonition.warning .admonition-title {
  623. background-color: var(--admonition-attention-title-background-color);
  624. color: var(--admonition-attention-title-color);
  625. }
  626. .rst-content .admonition.danger {
  627. background-color: var(--admonition-danger-background-color);
  628. color: var(--admonition-danger-color);
  629. }
  630. .rst-content .admonition.danger .admonition-title {
  631. background-color: var(--admonition-danger-title-background-color);
  632. color: var(--admonition-danger-title-color);
  633. }
  634. .rst-content .admonition.tip,
  635. .rst-content .admonition.important {
  636. background-color: var(--admonition-tip-background-color);
  637. color: var(--admonition-tip-color);
  638. }
  639. .rst-content .admonition.tip .admonition-title,
  640. .rst-content .admonition.important .admonition-title {
  641. background-color: var(--admonition-tip-title-background-color);
  642. color: var(--admonition-tip-title-color);
  643. }
  644. /* Keyboard shortcuts tweaks */
  645. kbd, .kbd {
  646. background-color: var(--kbd-background-color);
  647. border: 1px solid var(--kbd-outline-color);
  648. border-radius: 3px;
  649. box-shadow: inset 0 -1px 0 var(--kbd-shadow-color);
  650. color: var(--kbd-text-color);
  651. display: inline-block;
  652. font-size: 12px;
  653. line-height: 11px;
  654. padding: 4px 5px;
  655. vertical-align: middle;
  656. }
  657. /* Unset excessive styles for nested kbd tags. */
  658. kbd.compound > kbd,
  659. kbd.compound > .kbd,
  660. .kbd.compound > kbd,
  661. .kbd.compound > .kbd {
  662. border: none;
  663. box-shadow: none;
  664. padding: 0;
  665. }
  666. /* Buttons */
  667. .btn-neutral {
  668. background-color: var(--btn-neutral-background-color) !important;
  669. color: var(--body-color) !important;
  670. }
  671. .btn-neutral:hover {
  672. background-color: var(--btn-neutral-hover-background-color) !important;
  673. }
  674. .btn-neutral:visited {
  675. color: var(--body-color) !important;
  676. }
  677. /* Navigation bar logo and search */
  678. .logo {
  679. opacity: var(--logo-opacity);
  680. }
  681. .wy-side-nav-search > a img.logo {
  682. /* Fixed size to prevent reflows and support hiDPI displays */
  683. /* A 5 pixel margin is added on each side. The logo itself displays at 200×200 at 100% scaling. */
  684. width: 210px;
  685. height: 210px;
  686. }
  687. .wy-side-nav-search {
  688. background-color: var(--navbar-background-color);
  689. }
  690. .wy-side-nav-search.fixed {
  691. position: fixed;
  692. }
  693. @media only screen and (min-width: 769px) {
  694. /* Simulate a drop shadow that only affects the bottom edge */
  695. /* This is used to indicate the search bar is fixed */
  696. .wy-side-nav-search.fixed-and-scrolled::after {
  697. content: '';
  698. position: absolute;
  699. left: 0;
  700. bottom: -8px;
  701. width: 300px;
  702. height: 8px;
  703. pointer-events: none;
  704. background: linear-gradient(hsla(0, 0%, 0%, 0.2), transparent);
  705. }
  706. }
  707. .wy-side-nav-search > a:hover,
  708. .wy-side-nav-search .wy-dropdown > a:hover {
  709. background-color: var(--navbar-background-color-hover);
  710. }
  711. .wy-side-nav-search > a:active,
  712. .wy-side-nav-search .wy-dropdown > a:active {
  713. background-color: var(--navbar-background-color-active);
  714. }
  715. .wy-side-nav-search input[type="text"] {
  716. background-color: var(--input-background-color);
  717. color: var(--body-color);
  718. /* Avoid reflowing when toggling the focus state */
  719. border: 2px solid transparent;
  720. box-shadow: none;
  721. /* Make visual feedback instant */
  722. transition: none;
  723. font-size: 14px;
  724. }
  725. .wy-side-nav-search input[type="text"]:focus {
  726. border: 2px solid var(--input-focus-border-color);
  727. }
  728. .wy-side-nav-search input[type="text"]::placeholder {
  729. color: var(--body-color);
  730. opacity: 0.55;
  731. }
  732. /* Navigation bar */
  733. .wy-nav-side {
  734. background-color: var(--navbar-background-color);
  735. }
  736. @media only screen and (min-width: 769px) {
  737. .wy-nav-side {
  738. /* Required to center the page on wide displays */
  739. left: inherit;
  740. }
  741. }
  742. .wy-menu-vertical header,
  743. .wy-menu-vertical p.caption {
  744. color: var(--navbar-heading-color);
  745. /* Improves the appearance of uppercase text */
  746. letter-spacing: 0.75px;
  747. }
  748. /* Mobile navigation */
  749. .wy-nav-top,
  750. .wy-nav-top a {
  751. background-color: var(--navbar-background-color);
  752. color: var(--navbar-level-1-color);
  753. }
  754. /* Version branch label below the logo */
  755. .wy-side-nav-search > div.version {
  756. color: var(--navbar-level-3-color);
  757. opacity: 0.9;
  758. }
  759. /* First level of navigation items */
  760. .wy-menu-vertical a {
  761. color: var(--navbar-level-1-color);
  762. }
  763. .wy-menu-vertical a:hover {
  764. background-color: var(--navbar-background-color-hover);
  765. color: var(--navbar-level-1-color);
  766. }
  767. .wy-menu-vertical a:active {
  768. background-color: var(--navbar-background-color-active);
  769. }
  770. .wy-menu-vertical li.toctree-l1.current > a {
  771. border: none;
  772. }
  773. .wy-side-nav-search, .wy-menu-vertical a, .wy-menu-vertical a button.toctree-expand,
  774. .wy-menu-vertical li.toctree-l1 a button.toctree-expand,
  775. .wy-menu-vertical li.toctree-l2 a button.toctree-expand {
  776. color: var(--navbar-level-3-color);
  777. opacity: 0.9;
  778. margin-right: 8px;
  779. }
  780. .wy-side-nav-search, .wy-menu-vertical a, .wy-menu-vertical a:hover button.toctree-expand,
  781. .wy-menu-vertical li.toctree-l1 a:hover button.toctree-expand,
  782. .wy-menu-vertical li.toctree-l2 a:hover button.toctree-expand {
  783. color: var(--navbar-level-2-color);
  784. opacity: 1;
  785. }
  786. .wy-side-nav-search, .wy-menu-vertical a, .wy-menu-vertical a:active button.toctree-expand,
  787. .wy-menu-vertical li.toctree-l1 a:active button.toctree-expand,
  788. .wy-menu-vertical li.toctree-l2 a:active button.toctree-expand {
  789. color: var(--navbar-level-1-color);
  790. opacity: 1;
  791. }
  792. /* Second (and higher) levels of navigation items */
  793. .wy-menu-vertical li.current a {
  794. /* Make long words always display on a single line, keep wrapping for multiple words */
  795. /* This fixes the class reference titles' display with very long class names */
  796. display: flex;
  797. }
  798. .wy-menu-vertical li.current a,
  799. .wy-menu-vertical li.toctree-l2.current > a,
  800. .wy-menu-vertical li.toctree-l2.current li.toctree-l3 > a,
  801. .wy-menu-vertical li.toctree-l2.current li.toctree-l4 > a {
  802. background-color: var(--navbar-current-background-color);
  803. color: var(--navbar-level-2-color);
  804. border-color: var(--navbar-current-background-color);
  805. }
  806. .wy-menu-vertical li.current a:hover,
  807. .wy-menu-vertical li.toctree-l2.current > a:hover,
  808. .wy-menu-vertical li.toctree-l2.current li.toctree-l3 > a:hover,
  809. .wy-menu-vertical li.toctree-l3.current li.toctree-l4 > a:hover {
  810. background-color: var(--navbar-current-background-color-hover);
  811. }
  812. .wy-menu-vertical li.current a:active,
  813. .wy-menu-vertical li.toctree-l2.current > a:active,
  814. .wy-menu-vertical li.toctree-l2.current li.toctree-l3 > a:active,
  815. .wy-menu-vertical li.toctree-l3.current li.toctree-l4 > a:active {
  816. background-color: var(--navbar-current-background-color-active);
  817. }
  818. .wy-menu-vertical a {
  819. /* This overrides 8px margin added in other multi-selector rules */
  820. margin-right: 0;
  821. }
  822. /* Banner panel in sidebar */
  823. .wy-nav-side .ethical-rtd.fixed {
  824. position: fixed;
  825. }
  826. /* Version selector (only visible on Read the Docs) */
  827. .rst-versions {
  828. background-color: var(--navbar-current-background-color);
  829. }
  830. @media only screen and (min-width: 769px) {
  831. .rst-versions {
  832. /* Required to center the page on wide displays */
  833. left: inherit;
  834. }
  835. }
  836. .rst-versions a,
  837. .rst-versions .rst-current-version,
  838. .rst-versions .rst-current-version .fa,
  839. .rst-versions .rst-other-versions dd a {
  840. color: var(--navbar-level-1-color);
  841. }
  842. .rst-versions .rst-other-versions small {
  843. color: var(--navbar-level-3-color);
  844. }
  845. .rst-versions .rst-other-versions dd a:hover {
  846. text-decoration: underline;
  847. }
  848. .rst-versions .rst-other-versions {
  849. color: var(--navbar-heading-color);
  850. }
  851. .rst-versions .rst-current-version {
  852. background-color: var(--navbar-current-background-color);
  853. }
  854. .rst-versions .rst-current-version:hover {
  855. background-color: var(--navbar-current-background-color-hover);
  856. }
  857. .rst-versions .rst-current-version:active {
  858. background-color: var(--navbar-current-background-color-active);
  859. }
  860. /* Hide the obnoxious automatic highlight in search results */
  861. .rst-content .highlighted {
  862. background-color: transparent;
  863. font-weight: inherit;
  864. padding: 0;
  865. }
  866. /* Allows the scrollbar to be shown in the sidebar */
  867. @media only screen and (min-width: 769px) {
  868. .wy-side-scroll {
  869. overflow: hidden;
  870. }
  871. .wy-nav-side .wy-side-scroll .ethical-rtd {
  872. width: calc(300px - 1.25em);
  873. padding: 0 0 0 1em;
  874. }
  875. }
  876. .wy-menu.wy-menu-vertical {
  877. overflow-y: auto;
  878. overflow-x: hidden;
  879. max-height: calc(100% - 348px);
  880. }
  881. @media screen and (max-width: 768px) {
  882. .wy-nav-side {
  883. padding-bottom: 44px;
  884. }
  885. .wy-menu.wy-menu-vertical {
  886. overflow-y: initial;
  887. max-height: initial;
  888. }
  889. }
  890. /* Scrollbar styling */
  891. .wy-menu.wy-menu-vertical {
  892. scrollbar-color: var(--navbar-scrollbar-color) var(--navbar-scrollbar-background);
  893. }
  894. .wy-menu.wy-menu-vertical::-webkit-scrollbar {
  895. width: .75rem;
  896. }
  897. .wy-menu.wy-menu-vertical::-webkit-scrollbar-track {
  898. background-color: var(--navbar-scrollbar-background);
  899. }
  900. .wy-menu.wy-menu-vertical::-webkit-scrollbar-thumb {
  901. background-color: var(--navbar-scrollbar-color);
  902. }
  903. /* Firefox does the dimming on hover automatically. We emulate it for Webkit-based browsers. */
  904. .wy-menu.wy-menu-vertical::-webkit-scrollbar-thumb:hover {
  905. background-color: var(--navbar-scrollbar-hover-color);
  906. }
  907. .wy-menu.wy-menu-vertical::-webkit-scrollbar-thumb:active {
  908. background-color: var(--navbar-scrollbar-active-color);
  909. }