nimdoc.css 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905
  1. /*
  2. Stylesheet for use with Docutils/rst2html.
  3. See http://docutils.sf.net/docs/howto/html-stylesheets.html for how to
  4. customize this style sheet.
  5. Modified from Chad Skeeters' rst2html-style
  6. https://bitbucket.org/cskeeters/rst2html-style/
  7. Modified by Boyd Greenfield and narimiran
  8. */
  9. :root {
  10. --primary-background: #fff;
  11. --secondary-background: ghostwhite;
  12. --third-background: #e8e8e8;
  13. --border: #dde;
  14. --text: #222;
  15. --anchor: #07b;
  16. --anchor-focus: #607c9f;
  17. --input-focus: #1fa0eb;
  18. --strong: #3c3c3c;
  19. --hint: #9A9A9A;
  20. --nim-sprite-base64: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAN4AAAA9CAYAAADCt9ebAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFFmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDggNzkuMTY0MDM2LCAyMDE5LzA4LzEzLTAxOjA2OjU3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMCAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDE5LTEyLTAzVDAxOjAzOjQ4KzAxOjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAxOS0xMi0wM1QwMjoyODo0MSswMTowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAxOS0xMi0wM1QwMjoyODo0MSswMTowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDozMzM0ZjAxYS0yMDExLWE1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");
  21. --keyword: #5e8f60;
  22. --identifier: #222;
  23. --comment: #484a86;
  24. --operator: #155da4;
  25. --punctuation: black;
  26. --other: black;
  27. --escapeSequence: #c4891b;
  28. --number: #252dbe;
  29. --literal: #a4255b;
  30. --raw-data: #a4255b;
  31. }
  32. [data-theme="dark"] {
  33. --primary-background: #171921;
  34. --secondary-background: #1e202a;
  35. --third-background: #2b2e3b;
  36. --border: #0e1014;
  37. --text: #fff;
  38. --anchor: #8be9fd;
  39. --anchor-focus: #8be9fd;
  40. --input-focus: #8be9fd;
  41. --strong: #bd93f9;
  42. --hint: #7A7C85;
  43. --nim-sprite-base64: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAARMAAABMCAYAAABOBlMuAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFFmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDggNzkuMTY0MDM2LCAyMDE5LzA4LzEzLTAxOjA2OjU3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMCAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDE5LTEyLTAzVDAxOjE4OjIyKzAxOjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAxOS0xMi0wM1QwMToyMDoxMCswMTowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAxOS0xMi0wM1QwMToyMDoxMCswMTowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDplZGViMzU3MC1iNmZjLWQy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");
  44. --keyword: #ff79c6;
  45. --identifier: #f8f8f2;
  46. --comment: #6272a4;
  47. --operator: #ff79c6;
  48. --punctuation: #f8f8f2;
  49. --other: #f8f8f2;
  50. --escapeSequence: #bd93f9;
  51. --number: #bd93f9;
  52. --literal: #f1fa8c;
  53. --raw-data: #8be9fd;
  54. }
  55. .theme-switch-wrapper {
  56. display: flex;
  57. align-items: center;
  58. }
  59. .theme-switch-wrapper em {
  60. margin-left: 10px;
  61. font-size: 1rem;
  62. }
  63. .theme-switch {
  64. display: inline-block;
  65. height: 22px;
  66. position: relative;
  67. width: 50px;
  68. }
  69. .theme-switch input {
  70. display: none;
  71. }
  72. .slider {
  73. background-color: #ccc;
  74. bottom: 0;
  75. cursor: pointer;
  76. left: 0;
  77. position: absolute;
  78. right: 0;
  79. top: 0;
  80. transition: .4s;
  81. }
  82. .slider:before {
  83. background-color: #fff;
  84. bottom: 4px;
  85. content: "";
  86. height: 13px;
  87. left: 4px;
  88. position: absolute;
  89. transition: .4s;
  90. width: 13px;
  91. }
  92. input:checked + .slider {
  93. background-color: #66bb6a;
  94. }
  95. input:checked + .slider:before {
  96. transform: translateX(26px);
  97. }
  98. .slider.round {
  99. border-radius: 17px;
  100. }
  101. .slider.round:before {
  102. border-radius: 50%;
  103. }
  104. html {
  105. font-size: 100%;
  106. -webkit-text-size-adjust: 100%;
  107. -ms-text-size-adjust: 100%; }
  108. body {
  109. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  110. font-weight: 400;
  111. font-size: 1.125em;
  112. line-height: 1.5;
  113. color: var(--text);
  114. background-color: var(--primary-background); }
  115. /* Skeleton grid */
  116. .container {
  117. position: relative;
  118. width: 100%;
  119. max-width: 1050px;
  120. margin: 0 auto;
  121. padding: 0;
  122. box-sizing: border-box; }
  123. .column,
  124. .columns {
  125. width: 100%;
  126. float: left;
  127. box-sizing: border-box;
  128. margin-left: 1%;
  129. }
  130. .column:first-child,
  131. .columns:first-child {
  132. margin-left: 0; }
  133. .three.columns {
  134. width: 22%;
  135. }
  136. .nine.columns {
  137. width: 77.0%; }
  138. .twelve.columns {
  139. width: 100%;
  140. margin-left: 0; }
  141. @media screen and (max-width: 860px) {
  142. .three.columns {
  143. display: none;
  144. }
  145. .nine.columns {
  146. width: 98.0%;
  147. }
  148. body {
  149. font-size: 1em;
  150. line-height: 1.35;
  151. }
  152. }
  153. cite {
  154. font-style: italic !important; }
  155. /* Nim search input */
  156. div#searchInputDiv {
  157. margin-bottom: 1em;
  158. }
  159. input#searchInput {
  160. width: 80%;
  161. }
  162. /*
  163. * Some custom formatting for input forms.
  164. * This also fixes input form colors on Firefox with a dark system theme on Linux.
  165. */
  166. input {
  167. -moz-appearance: none;
  168. background-color: var(--secondary-background);
  169. color: var(--text);
  170. border: 1px solid var(--border);
  171. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  172. font-size: 0.9em;
  173. padding: 6px;
  174. }
  175. input:focus {
  176. border: 1px solid var(--input-focus);
  177. box-shadow: 0 0 3px var(--input-focus);
  178. }
  179. select {
  180. -moz-appearance: none;
  181. background-color: var(--secondary-background);
  182. color: var(--text);
  183. border: 1px solid var(--border);
  184. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  185. font-size: 0.9em;
  186. padding: 6px;
  187. }
  188. select:focus {
  189. border: 1px solid var(--input-focus);
  190. box-shadow: 0 0 3px var(--input-focus);
  191. }
  192. /* Docgen styles */
  193. /* Links */
  194. a {
  195. color: var(--anchor);
  196. text-decoration: none;
  197. }
  198. a span.Identifier {
  199. text-decoration: underline;
  200. text-decoration-color: #aab;
  201. }
  202. a.reference-toplevel {
  203. font-weight: bold;
  204. }
  205. a.toc-backref {
  206. text-decoration: none;
  207. color: var(--text); }
  208. a.link-seesrc {
  209. color: #607c9f;
  210. font-size: 0.9em;
  211. font-style: italic; }
  212. a:hover,
  213. a:focus {
  214. color: var(--anchor-focus);
  215. text-decoration: underline; }
  216. a:hover span.Identifier {
  217. color: var(--anchor);
  218. }
  219. sub,
  220. sup {
  221. position: relative;
  222. font-size: 75%;
  223. line-height: 0;
  224. vertical-align: baseline; }
  225. sup {
  226. top: -0.5em; }
  227. sub {
  228. bottom: -0.25em; }
  229. img {
  230. width: auto;
  231. height: auto;
  232. max-width: 100%;
  233. vertical-align: middle;
  234. border: 0;
  235. -ms-interpolation-mode: bicubic; }
  236. @media print {
  237. * {
  238. color: black !important;
  239. text-shadow: none !important;
  240. background: transparent !important;
  241. box-shadow: none !important; }
  242. a,
  243. a:visited {
  244. text-decoration: underline; }
  245. a[href]:after {
  246. content: " (" attr(href) ")"; }
  247. abbr[title]:after {
  248. content: " (" attr(title) ")"; }
  249. .ir a:after,
  250. a[href^="javascript:"]:after,
  251. a[href^="#"]:after {
  252. content: ""; }
  253. pre,
  254. blockquote {
  255. border: 1px solid #999;
  256. page-break-inside: avoid; }
  257. thead {
  258. display: table-header-group; }
  259. tr,
  260. img {
  261. page-break-inside: avoid; }
  262. img {
  263. max-width: 100% !important; }
  264. @page {
  265. margin: 0.5cm; }
  266. h1 {
  267. page-break-before: always; }
  268. h1.title {
  269. page-break-before: avoid; }
  270. p,
  271. h2,
  272. h3 {
  273. orphans: 3;
  274. widows: 3; }
  275. h2,
  276. h3 {
  277. page-break-after: avoid; }
  278. }
  279. p {
  280. margin-top: 0.5em;
  281. margin-bottom: 0.5em;
  282. }
  283. small {
  284. font-size: 85%; }
  285. strong {
  286. font-weight: 600;
  287. font-size: 0.95em;
  288. color: var(--strong);
  289. }
  290. em {
  291. font-style: italic; }
  292. h1 {
  293. font-size: 1.8em;
  294. font-weight: 400;
  295. padding-bottom: .25em;
  296. border-bottom: 6px solid var(--third-background);
  297. margin-top: 2.5em;
  298. margin-bottom: 1em;
  299. line-height: 1.2em; }
  300. h1.title {
  301. padding-bottom: 1em;
  302. border-bottom: 0px;
  303. font-size: 2.5em;
  304. text-align: center;
  305. font-weight: 900;
  306. margin-top: 0.75em;
  307. margin-bottom: 0em;
  308. }
  309. h2 {
  310. font-size: 1.3em;
  311. margin-top: 2em; }
  312. h2.subtitle {
  313. text-align: center; }
  314. h3 {
  315. font-size: 1.125em;
  316. font-style: italic;
  317. margin-top: 1.5em; }
  318. h4 {
  319. font-size: 1.125em;
  320. margin-top: 1em; }
  321. h5 {
  322. font-size: 1.125em;
  323. margin-top: 0.75em; }
  324. h6 {
  325. font-size: 1.1em; }
  326. ul,
  327. ol {
  328. padding: 0;
  329. margin-top: 0.5em;
  330. margin-left: 0.75em; }
  331. ul ul,
  332. ul ol,
  333. ol ol,
  334. ol ul {
  335. margin-bottom: 0;
  336. margin-left: 1.25em; }
  337. li {
  338. list-style-type: circle;
  339. }
  340. ul.simple-boot li {
  341. list-style-type: none;
  342. margin-left: 0em;
  343. margin-bottom: 0.5em;
  344. }
  345. ol.simple > li, ul.simple > li {
  346. margin-bottom: 0.2em;
  347. margin-left: 0.4em }
  348. ul.simple.simple-toc > li {
  349. margin-top: 1em;
  350. }
  351. ul.simple-toc {
  352. list-style: none;
  353. font-size: 0.9em;
  354. margin-left: -0.3em;
  355. margin-top: 1em; }
  356. ul.simple-toc > li {
  357. list-style-type: none;
  358. }
  359. ul.simple-toc-section {
  360. list-style-type: circle;
  361. margin-left: 0.8em;
  362. color: #6c9aae; }
  363. ul.nested-toc-section {
  364. list-style-type: circle;
  365. margin-left: -0.75em;
  366. color: var(--text);
  367. }
  368. ul.nested-toc-section > li {
  369. margin-left: 1.25em;
  370. }
  371. ol.arabic {
  372. list-style: decimal; }
  373. ol.loweralpha {
  374. list-style: lower-alpha; }
  375. ol.upperalpha {
  376. list-style: upper-alpha; }
  377. ol.lowerroman {
  378. list-style: lower-roman; }
  379. ol.upperroman {
  380. list-style: upper-roman; }
  381. ul.auto-toc {
  382. list-style-type: none; }
  383. dl {
  384. margin-bottom: 1.5em; }
  385. dt {
  386. margin-bottom: -0.5em;
  387. margin-left: 0.0em; }
  388. dd {
  389. margin-left: 2.0em;
  390. margin-bottom: 3.0em;
  391. margin-top: 0.5em; }
  392. hr {
  393. margin: 2em 0;
  394. border: 0;
  395. border-top: 1px solid #aaa; }
  396. blockquote {
  397. font-size: 0.9em;
  398. font-style: italic;
  399. padding-left: 0.5em;
  400. margin-left: 0;
  401. border-left: 5px solid #bbc;
  402. }
  403. .pre {
  404. font-family: "Source Code Pro", Monaco, Menlo, Consolas, "Courier New", monospace;
  405. font-weight: 500;
  406. font-size: 0.85em;
  407. color: var(--text);
  408. background-color: var(--third-background);
  409. padding-left: 3px;
  410. padding-right: 3px;
  411. border-radius: 4px;
  412. }
  413. pre {
  414. font-family: "Source Code Pro", Monaco, Menlo, Consolas, "Courier New", monospace;
  415. color: var(--text);
  416. font-weight: 500;
  417. display: inline-block;
  418. box-sizing: border-box;
  419. min-width: 100%;
  420. padding: 0.5em;
  421. margin-top: 0.5em;
  422. margin-bottom: 0.5em;
  423. font-size: 0.85em;
  424. white-space: pre !important;
  425. overflow-y: hidden;
  426. overflow-x: visible;
  427. background-color: var(--secondary-background);
  428. border: 1px solid var(--border);
  429. -webkit-border-radius: 6px;
  430. -moz-border-radius: 6px;
  431. border-radius: 6px; }
  432. .pre-scrollable {
  433. max-height: 340px;
  434. overflow-y: scroll; }
  435. /* Nim line-numbered tables */
  436. .line-nums-table {
  437. width: 100%;
  438. table-layout: fixed; }
  439. table.line-nums-table {
  440. border-radius: 4px;
  441. border: 1px solid #cccccc;
  442. background-color: ghostwhite;
  443. border-collapse: separate;
  444. margin-top: 15px;
  445. margin-bottom: 25px; }
  446. .line-nums-table tbody {
  447. border: none; }
  448. .line-nums-table td pre {
  449. border: none;
  450. background-color: transparent; }
  451. .line-nums-table td.blob-line-nums {
  452. width: 28px; }
  453. .line-nums-table td.blob-line-nums pre {
  454. color: #b0b0b0;
  455. -webkit-filter: opacity(75%);
  456. text-align: right;
  457. border-color: transparent;
  458. background-color: transparent;
  459. padding-left: 0px;
  460. margin-left: 0px;
  461. padding-right: 0px;
  462. margin-right: 0px; }
  463. table {
  464. max-width: 100%;
  465. background-color: transparent;
  466. margin-top: 0.5em;
  467. margin-bottom: 1.5em;
  468. border-collapse: collapse;
  469. border-color: var(--third-background);
  470. border-spacing: 0;
  471. font-size: 0.9em;
  472. }
  473. table th, table td {
  474. padding: 0px 0.5em 0px;
  475. border-color: var(--third-background);
  476. }
  477. table th {
  478. background-color: var(--third-background);
  479. border-color: var(--third-background);
  480. font-weight: bold; }
  481. table th.docinfo-name {
  482. background-color: transparent;
  483. text-align: right;
  484. }
  485. table tr:hover {
  486. background-color: var(--third-background); }
  487. /* rst2html default used to remove borders from tables and images */
  488. .borderless, table.borderless td, table.borderless th {
  489. border: 0; }
  490. table.borderless td, table.borderless th {
  491. /* Override padding for "table.docutils td" with "! important".
  492. The right padding separates the table cells. */
  493. padding: 0 0.5em 0 0 !important; }
  494. .first {
  495. /* Override more specific margin styles with "! important". */
  496. margin-top: 0 !important; }
  497. .last, .with-subtitle {
  498. margin-bottom: 0 !important; }
  499. .hidden {
  500. display: none; }
  501. blockquote.epigraph {
  502. margin: 2em 5em; }
  503. dl.docutils dd {
  504. margin-bottom: 0.5em; }
  505. object[type="image/svg+xml"], object[type="application/x-shockwave-flash"] {
  506. overflow: hidden; }
  507. div.figure {
  508. margin-left: 2em;
  509. margin-right: 2em; }
  510. div.footer, div.header {
  511. clear: both;
  512. text-align: center;
  513. color: #666;
  514. font-size: smaller; }
  515. div.footer {
  516. padding-top: 5em;
  517. }
  518. div.line-block {
  519. display: block;
  520. margin-top: 1em;
  521. margin-bottom: 1em; }
  522. div.line-block div.line-block {
  523. margin-top: 0;
  524. margin-bottom: 0;
  525. margin-left: 1.5em; }
  526. div.topic {
  527. margin: 2em; }
  528. div.search_results {
  529. background-color: var(--third-background);
  530. margin: 3em;
  531. padding: 1em;
  532. border: 1px solid #4d4d4d;
  533. }
  534. div#global-links ul {
  535. margin-left: 0;
  536. list-style-type: none;
  537. }
  538. div#global-links > simple-boot {
  539. margin-left: 3em;
  540. }
  541. hr.docutils {
  542. width: 75%; }
  543. img.align-left, .figure.align-left, object.align-left {
  544. clear: left;
  545. float: left;
  546. margin-right: 1em; }
  547. img.align-right, .figure.align-right, object.align-right {
  548. clear: right;
  549. float: right;
  550. margin-left: 1em; }
  551. img.align-center, .figure.align-center, object.align-center {
  552. display: block;
  553. margin-left: auto;
  554. margin-right: auto; }
  555. .align-left {
  556. text-align: left; }
  557. .align-center {
  558. clear: both;
  559. text-align: center; }
  560. .align-right {
  561. text-align: right; }
  562. /* reset inner alignment in figures */
  563. div.align-right {
  564. text-align: inherit; }
  565. p.attribution {
  566. text-align: right;
  567. margin-left: 50%; }
  568. p.caption {
  569. font-style: italic; }
  570. p.credits {
  571. font-style: italic;
  572. font-size: smaller; }
  573. p.label {
  574. white-space: nowrap; }
  575. p.rubric {
  576. font-weight: bold;
  577. font-size: larger;
  578. color: maroon;
  579. text-align: center; }
  580. p.topic-title {
  581. font-weight: bold; }
  582. pre.address {
  583. margin-bottom: 0;
  584. margin-top: 0;
  585. font: inherit; }
  586. pre.literal-block, pre.doctest-block, pre.math, pre.code {
  587. margin-left: 2em;
  588. margin-right: 2em; }
  589. pre.code .ln {
  590. color: grey; }
  591. /* line numbers */
  592. pre.code, code {
  593. background-color: #eeeeee; }
  594. pre.code .comment, code .comment {
  595. color: #5c6576; }
  596. pre.code .keyword, code .keyword {
  597. color: #3B0D06;
  598. font-weight: bold; }
  599. pre.code .literal.string, code .literal.string {
  600. color: #0c5404; }
  601. pre.code .name.builtin, code .name.builtin {
  602. color: #352b84; }
  603. pre.code .deleted, code .deleted {
  604. background-color: #DEB0A1; }
  605. pre.code .inserted, code .inserted {
  606. background-color: #A3D289; }
  607. span.classifier {
  608. font-style: oblique; }
  609. span.classifier-delimiter {
  610. font-weight: bold; }
  611. span.option {
  612. white-space: nowrap; }
  613. span.problematic {
  614. color: #b30000; }
  615. span.section-subtitle {
  616. /* font-size relative to parent (h1..h6 element) */
  617. font-size: 80%; }
  618. span.DecNumber {
  619. color: var(--number); }
  620. span.BinNumber {
  621. color: var(--number); }
  622. span.HexNumber {
  623. color: var(--number); }
  624. span.OctNumber {
  625. color: var(--number); }
  626. span.FloatNumber {
  627. color: var(--number); }
  628. span.Identifier {
  629. color: var(--identifier); }
  630. span.Keyword {
  631. font-weight: 600;
  632. color: var(--keyword); }
  633. span.StringLit {
  634. color: var(--literal); }
  635. span.LongStringLit {
  636. color: var(--literal); }
  637. span.CharLit {
  638. color: var(--literal); }
  639. span.EscapeSequence {
  640. color: var(--escapeSequence); }
  641. span.Operator {
  642. color: var(--operator); }
  643. span.Punctuation {
  644. color: var(--punctuation); }
  645. span.Comment, span.LongComment {
  646. font-style: italic;
  647. font-weight: 400;
  648. color: var(--comment); }
  649. span.RegularExpression {
  650. color: darkviolet; }
  651. span.TagStart {
  652. color: darkviolet; }
  653. span.TagEnd {
  654. color: darkviolet; }
  655. span.Key {
  656. color: #252dbe; }
  657. span.Value {
  658. color: #252dbe; }
  659. span.RawData {
  660. color: var(--raw-data); }
  661. span.Assembler {
  662. color: #252dbe; }
  663. span.Preprocessor {
  664. color: #252dbe; }
  665. span.Directive {
  666. color: #252dbe; }
  667. span.Command, span.Rule, span.Hyperlink, span.Label, span.Reference,
  668. span.Other {
  669. color: var(--other); }
  670. /* Pop type, const, proc, and iterator defs in nim def blocks */
  671. dt pre > span.Identifier, dt pre > span.Operator {
  672. color: var(--identifier);
  673. font-weight: 700; }
  674. dt pre > span.Keyword ~ span.Identifier, dt pre > span.Identifier ~ span.Identifier,
  675. dt pre > span.Operator ~ span.Identifier, dt pre > span.Other ~ span.Identifier {
  676. color: var(--identifier);
  677. font-weight: inherit; }
  678. /* Nim sprite for the footer (taken from main page favicon) */
  679. .nim-sprite {
  680. display: inline-block;
  681. width: 51px;
  682. height: 14px;
  683. background-position: 0 0;
  684. background-size: 51px 14px;
  685. -webkit-filter: opacity(50%);
  686. background-repeat: no-repeat;
  687. background-image: var(--nim-sprite-base64);
  688. margin-bottom: 5px; }
  689. span.pragmadots {
  690. /* Position: relative frees us up to make the dots
  691. look really nice without fucking up the layout and
  692. causing bulging in the parent container */
  693. position: relative;
  694. /* 1px down looks slightly nicer */
  695. top: 1px;
  696. padding: 2px;
  697. background-color: var(--third-background);
  698. border-radius: 4px;
  699. margin: 0 2px;
  700. cursor: pointer;
  701. font-size: 0.8em;
  702. }
  703. span.pragmadots:hover {
  704. background-color: var(--hint);
  705. }
  706. span.pragmawrap {
  707. display: none;
  708. }
  709. span.attachedType {
  710. display: none;
  711. visibility: hidden;
  712. }