nimdoc.css 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034
  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. --info-background: #50c050;
  14. --warning-background: #c0a000;
  15. --error-background: #e04040;
  16. --border: #dde;
  17. --text: #222;
  18. --anchor: #07b;
  19. --anchor-focus: #607c9f;
  20. --input-focus: #1fa0eb;
  21. --strong: #3c3c3c;
  22. --hint: #9A9A9A;
  23. --nim-sprite-base64: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAN4AAAA9CAYAAADCt9ebAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFFmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDggNzkuMTY0MDM2LCAyMDE5LzA4LzEzLTAxOjA2OjU3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMCAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDE5LTEyLTAzVDAxOjAzOjQ4KzAxOjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAxOS0xMi0wM1QwMjoyODo0MSswMTowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAxOS0xMi0wM1QwMjoyODo0MSswMTowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDozMzM0ZjAxYS0yMDExLWE1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");
  24. --keyword: #5e8f60;
  25. --identifier: #222;
  26. --comment: #484a86;
  27. --operator: #155da4;
  28. --punctuation: black;
  29. --other: black;
  30. --escapeSequence: #c4891b;
  31. --number: #252dbe;
  32. --literal: #a4255b;
  33. --program: #6060c0;
  34. --option: #508000;
  35. --raw-data: #a4255b;
  36. --clipboard-image-normal: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: black' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E %3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2' /%3E %3C/svg%3E");
  37. --clipboard-image-selected: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: black' viewBox='0 0 20 20' fill='currentColor'%3E %3Cpath d='M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z' /%3E %3Cpath d='M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z' /%3E %3C/svg%3E");
  38. --clipboard-image: var(--clipboard-image-normal)
  39. }
  40. [data-theme="dark"] {
  41. --primary-background: #171921;
  42. --secondary-background: #1e202a;
  43. --third-background: #2b2e3b;
  44. --info-background: #008000;
  45. --warning-background: #807000;
  46. --error-background: #c03000;
  47. --border: #0e1014;
  48. --text: #fff;
  49. --anchor: #8be9fd;
  50. --anchor-focus: #8be9fd;
  51. --input-focus: #8be9fd;
  52. --strong: #bd93f9;
  53. --hint: #7A7C85;
  54. --nim-sprite-base64: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAARMAAABMCAYAAABOBlMuAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFFmlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDggNzkuMTY0MDM2LCAyMDE5LzA4LzEzLTAxOjA2OjU3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMCAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDE5LTEyLTAzVDAxOjE4OjIyKzAxOjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAxOS0xMi0wM1QwMToyMDoxMCswMTowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAxOS0xMi0wM1QwMToyMDoxMCswMTowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDplZGViMzU3MC1iNmZjLWQyNDQtYTExZi0yMjc5YmY4NDNhYTAiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6ZWRlYjM1NzAtYjZmYy1kMjQ0LWExMWYtMjI3OWJmODQzYWEwIiB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6ZWRlYjM1NzAtYjZmYy1kMjQ0LWExMWYtMjI3OWJmODQzYWEwIj4gPHhtcE1NOkhpc3Rvcnk+IDxyZGY6U2VxPiA8cmRmOmxpIHN0RXZ0OmFjdGlvbj0iY3JlYXRlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDplZGViMzU3MC1iNmZjLWQyNDQtYTExZi0yMjc5YmY4NDNhYTAiIHN0RXZ0OndoZW49IjIwMTktMTItMDNUMDE6MTg6MjIrMDE6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCAyMS4wIChXaW5kb3dzKSIvPiA8L3JkZjpTZXE+IDwveG1wTU06SGlzdG9yeT4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz4JZNR8AAAfG0lEQVR4nO2deViTZ7r/7yxkJaxJ2MK+GCBAMCwS1kgUFQSKK4XWWqsz1jpjp3b0tDP1V+eqU391fqfT/mpPPd20drTFDS0KFEVWJSGAEgLIZpAICBJACIRs549Rj1WILAkBfD/XlevySp68z/0S3+/7vPdzLyidTgcLkU2bd+z39/f/q1gshsrKSoJELFCa2iaEuU9K6kb+8uXxv54/fzE8L/eswNT2zCfQpjbAGKS8lPFKSEjIXiaTCSEhIeDj4xNnapsQ5j6rktZGp6UlfxIdzQVzCplmanvmG1hTG2BIAtlc26CgoDfT0tL2e3l5AQCAjY0NkMnk/a9s2k6rrKw8UV8n1JjYTIQ5RlAw14KzmL3xze1vfJyUuMJaq9UCFovFm9qu+YbBxcSPFUYkk8l2Q0NDsvo6ocrQx5+I8Ih4bz6f/0l8fHyKlZXV4/dRKBQwmcwwMpn8A4FAoPgHhH9bV1sxa488wZxoaycnJ/a9e/duCa5fkc3WvAiTI4Ib77p+XdqHG9anbfLy8gAAgLGxMdBpF+bjvzExqJj4scKI0dHRnwQHB++orq7+AgDeMuTxJ2Jl4rqU9PT0EwEBAUQCgTDuGAaDAampqYepVKpHUHDk325Ulw0a266YuFW+Gzdu/MDPz29jfn7+XgA4aOw5ESZP6kvpCXv3vnM8NiaSamVl+fj9BepGNDoGFRN7e/slcXFxO1xcXMDJyWnH7j//H/fi4uJdgutXmgw5z5O8smn7X9euXbvf29sbMBjMhONQKBRYWVlBbGzsbjMzM3JoOG+/sKKwy1h2rd/4elpGRsYuLy+vaDweD2w2Oy1h5ZrCvEunEaeeiVnMiabyl/F2/+X9P+8JDPQHHA5napMWBAYTk6DgSNuEhIS9DAYDAP7tq1i6dOkqOp3OWbNu0wens44emeoxA9lcWwKBYEMkEm2JRKIdHo+3QKFQWJ1Op8ZgMER3d/dVq1evTnFycpr0MSkUCsTExGzH4/Gk1LTME/39/TI0Go1FoVCg1WrVY2NjipGRkcGRkRH5dPwrEZHLXMPCwjJSUlIy3dzcfB+97+rqGhYSEpIOAIiYmBguN3zL77dt3uPh4W5qUxYUBhMTb2/vjeHh4cvR6P/dILK0tITIyEg7BweHr363/Z3Ampqaf1Zcu/zMKiVsyVJvMplsRyKR7IhEor2FhYUbhUJhJCYm2pFIJB6JRAIymQx4PB7QaDRoNBowMzMDJycnwOOn7icjEokQGxu7icFgbLp///7jFY1WqwWlUgkjIyOgUCgO7Ni5Rz48PCwfHh7uGRkZeaBQKOSjo6ODCoVCXlNVKn/6uCsT13FXrVr1emho6BYKhfLMnP7+/omrU9LPX8g+UThloxEMxqJFXjxESAyPQcSEExrLWLNmzW57e/txP/fw8ABHR8cdDAaDt3xF2ru9vb03sVgs0cbGxs/FxWVZUlISj0aj+dna2oKtrS1M5PcwJCgUCry8vODRrs84vPfoH6OjoyCXy6Gvr+/R6+CWrX9s7evrk/b19bWr1Wqli4sLZ8OGDe95eXmxUSjUuAd0cHDwjoqK2sYKXFIhvnldYYTTQpgU4/8+jyASCYDGoCd+ZkYYF8OICYezl8PhuOkbQyAQIDo62s/NzS2np6cHbGxsgEajAYFAAAwGA1gsFia6CE0NgUAABwcHsLe3B61WC2q1eo9WqwWNRgNKpRLUajUQiUSgUCh6zwGHwwGTydzo5+eXBQBnZu8MEJ5keHhYPqyYWMtHR0ZBpVIhYj9FUDONgOUvT12+du3avMDAQJjssdRqNWCxCyrEZdLodDoQi8Ulx44de628NL/V1Pa8iERE8l2dHB2CJvpcq9Nqbt1qKURWj1Njxld0ZGTkAW9v70kLCQC8sEIC8O/HKx8fn2gmk8kHgCk7pRFmzrWyAikASE1tx0Jj2uH0EZHL/N7YtuvT4OBgzmz4OBYSeDweIiMjt2S++vtMP1YYEmmJsCCY8mNOIJtr6+zsHBcZGXmIw+G4mZubG8m0hU9HRwcUFxe/KxQKTyDRsQjznSmJCS9+dVRERMTfQ0NDo2xtbfUGiSFMjtHRUaitrc3Jzc09kHvxVLmp7UFAmC6oZQkvrZLL5RJhReHtiQb5scKIXC7371FRUX90dnYGIpE4JR8Jgn40Gg20t7fXFxYWfnr9+vWjz8sdYi+Osh4vzgUBwZSgtu94V+fs7Hx7YGCgra6u7khLS0u2RCwYeTQgKmYFh8fj/f/g4OAldnZ2prR1wdPd3Q1CofBQSUnJkdLi3N8E93FCY6k+Pj48FxcXjlar1ZSWlh65VvYr4kREmDNg79+/D3FxcW5OTk5uXl5evNbW1tL0jK3ZXV1d1ykUintycvInoaGhdkj+gvGxs7MDPp+/m0AgWMQvS/lyeHhYTqPRPJycnIJSU1NZ3t7eW2g0Gly/fv2oWq1Gij0hzClQ/gHhpLS0tEM8Hm/7I8Ho7++HlpYWsLa2Bg8PDxOb+OKhUCigqakJ7t+/D25ubuDu7g4oFAp0Oh08ePAAvv7666TTWUdzTG0nAsKTYMU3ryuSU18+4+bmFrZo0SIOAICVlRUsXrx4zkakLnRIJBI8CgJ8MtdJp9NBZ2enqL29XWRC8xAQxgUNAHD+3L8KGhoaCp78ABES04JCoX4jJAAAAwMDUFtbe96YpRMQEKbL41DU5ubmko6Ojj2PSgggzD36+/vrb9y4cX425zzw93/8EBjon2is44+NjSkePBjqGRwc7G5v7xBV19w8U5B/3qgrr9+/uWtXUuKKD/TZ9MXh/066/OuFmunO8dGBQ98HBbGSp/t9U6LRaDXK0dHBoeFhuVzeL22/0yFqamopufjLqRJ933ssJi0tLSXV1dWHGAzGbuObOzs8ubqa71vZKpUKOjo6blwpOF8zm/Mu5cVkLlkSaswprAHAaVihgK7O7oSGxltvfXLon3nXK4RHT2cdN4pfKDCAlZyUuMJan02nTmczAaBmunPw4qI3cbnh0/36XICq0+lgcPABp7OrK629vUP5z8++LLh2XXD05L++yxrvC4/F5EZ12WBS8saLS5Ys2U2lUufUY45SqQSlUgkqlQrUavXj19jYGGg0GtBoNKDT6UCn05VotVq1TqfToFAojFar1eh0Og0Wi8XhcDgeGo1+/PhgZmYGOBwOsFgsmJmZ/eY1F+nt7YXa2trs2Z73wdCQBgCMHp1IJpHA09MdPD3dLRIS+OtKisvWvbP7vf2lZdePVFwzbHTwyMiI3hidkZFRUKvUYzOZ48HQkBIA5nWqBAqFAktLC7C0tADmIh88Pz4uMSyUk7hn776DV4tKPn/6d/lNxp1MJqsRCASf8vn8XdMpOjRTVCoVjI2NgUqlAq1WCyMjI9DX1wf379+Hvr6+/Q8ePOgdGRmRKxSKx0WLFAqFXKlUKnQ6nUar1arHq47mxwrD4/F4Eg6HI2GxWDwej7cgkUjWFAqFam5uTjU3N6eRyeQPLSwswNraGqysrIBAIDwWFywW+zja11Qi29LSclIikeSZZPJZBovBAI8XA8HBQR9kZZ3lR8cmvFZSlGe00p8IkwONRkNERBj4+i7a4+XpHv307/IbMakWlciXJbx0nMPh7Jqo0JGh0el0MDo6Cl1dXSCVSkEmk7177969W319fe1DQ0M9KpVKoVarlWq1WjndNhUPG3ApAWDcOxLTLwSDwWAOotFoDBaLxRMIBAsrKysne3t7Xzqd7k2n0/c4OzsDlUoFHA4364IyMDAATU1NxdWikhcq6tXKyhJezljPJZKI2eERS5cZeoWCMD2srCwhPX0tVzk2djiCG//GtfLLUoBxShB0dHTU3Lx580sLC4vtJBLJKMZoNBqQSqUglUqPdnR01PT09DT19/fLHjx40DM0NNQ72933GiSVGgB4JFQK+LfoSAGgnL04yppEIh2xtLS0t7GxcaFSqR7Ozs4fMRgMcHR0nJX8pJs3b54Ui8UXjT7RHIRMIkFK8irfwcEHPwQELUmqvYHUGJkLmJubw8YNa/i9vfffY/px3myQiDTPiEl9nVDDX576jaenZ7SnpyfLUJNrNBqQyWRw+/bt4x0dHTdkMlltV1dXw/XygjkdEv4wB0YOAK0AUM70C8HQ6fSzdDrdm0qlejg6OrLc3Ny2MBiMadWjfR4PHjyAmzdvZs/1v5MxoVAokJK8iicWS95k+nH+s0EiQhqpzQGoVFtYk5a87ba0XQAA34xbpagg/5zoT7s/OGNnZ8eaaYkBuVwOnZ2d5VKpVNTS0lLS2NhYWFVZ3Dujg5qQh6uY+ocvCAiKIPn4+Jz19PSMdnV15VCpVL6Dg4NBViw6nQ5EItHRpqamqzM+2DzHzo4O69amftLQeKsAZrDLgmBY/PyYsCIhfs+SiKUFE5Y8EwqFx11cXDihoaFTjjFAoVAwPDwMHR0dourq6jNCofDHhZqUVnvjmgIAcgAgJyg40mLRokX8kJCQjT4+PussLS1n1JPl7t27UFxcfHguB6mNjY2B7G4naNRTWyygUCjAYDGAx+PB0sICSCSi3vFYLBbCwjjA8vddBQtATKb7d3saBwc7IJPJBpsHjUGDGRYLJBIJLK0sAfucmyIGg4FFi3y8AwNZtycUk5KiS02vvf7WWQaDkejg4DApQwAeh3xDaWnpPoFAcPxFqnP6sEvgGf+A8Bx3d/cvIyIiNi1evHjT8wpNj8fAwACUlZW9P9dD5+/ckcFbf9gd2dcnn9LNAovF4inmZHtXNxdOdBR3+/JlS33pdP29wolEInA4weuiYxOy5vvuTkeHDHb+8c8xvb33Z3R9/N+Df+uIjYk02DwkEsna2trS1d/fNyGeF7uTyw1/7g3R3t4O2OxA/TVghULhcQqFQk1JSfmYSNR/5wD4d6EfgUBwvLS09IhUKhW9qAV5H9YjKQwJi6uvrKw8ERoamhkSEpKp7w7yJEqlEiQSyZmysrJv53qjdaVSCZdyTk+3qFMrAJRHRPLPN95qeifj5fU7mYt8JhyMRqMhMJDFdnF25gDAvBYTpXIMWlpay2fq/8m5mDcIABYGnEcGAGI/VlhBZWX1yZdSkz55OX0dV5+7w9bGGvz8mPrFpK62QskJjf2GTqd7x8bGbpnID4BCoUAmk0lLSkqOiESik2UleS/MakQflYKrXQDQxY1a3tTe3i6KiIjY5OXlxX7e9+rr6wsuXbr0t4ffn9OgMWjghMZQRcLp+8GulRVI/QPC37Wxtnal0ajJtjY2E451ZjiBra31vE9lR2PQQKFQaAAwo98Yi8Xq9fpPd56HO6rlvKWJv/PwcK+JilyCmajWMw6HAzs7+rMFpQOCIn6zHywSFvXm5eUdFAqFZ9Rq9bgHa2trq79w4cK+zz49cAARkmcpL81v/a/Dhz49d+7c3qqqqjyVSjXuOJ1OBxKJpDw3N/fA5V+zax6978cKw/sHhM/raMrnUVdboSy4fPWQSFSjd5yFBQWIRNKEd2IEw1J4JUd88WL+R51d3XrHWVDMnxUTa2tr1zXrNiUGsrmPf7DS4tymCxcu7Kuurs55+kKQSqVN586d23vs+8NHDXUCC5Wzp3/Iy8rKeruysvLM2Nhvo7VVKhXU1tYWnj17du/T7UOdnZ2D7OzsfGGB09raVi4S1RzXl0eFw+EAj8chYjKLVFffyOrq1C8mJBLpWTFRKBRyDofzC4vFWvXk+1ev/CLOzs7eKxAIslQqFeh0Oujp6enKzs7em/XTd7OayTqfKb56sT4rK+sPAoHg5KO/o0KhAKFQmHXy5MkdF3/5+TeZmctXpIXZ29v7zqVcKWNRX1epuXu3U/y8pEw0GmndOZt0dnXVDw0P6/W5oNHoZ30mQ0NDPb29vfvj4+Pf3rR5B/7od188XnEUXr4gDgmL+0NfX5/U19d3d3l5+YGfTnyDtLmcIhXXLsu4UcvfR6PRGGtra9eysrIjYrE45+kt4Fheou/69es/unnz5vm7d+/Wmsre2WRkZGTQ1DYg/JYGiUiTm1ugBAC9IfHPiEmDpFITE7fqJI/H27lmzZpDq5LWtz55t6wUXO3ihMYerK+vz2tpaUFaM0yT8tL81ujYle+TSCTrvEunBU9/voTLd92wYcPHVCqV39XVdXCu7+oYCp1O90Kc50Jk3I5+xVcv1jc3N5d4enpSMzIyvkpK3sh78nORsKg3++yPBS/q1q+hKCm61DSekERGJ3ikp6d/ERsbm1xVVXWwtbX1hRFtFAqFPMLMUyZsDyoQCI7LZDKIiIjwzczM/GpV0vro2TTsRSUqZoX3+vXrP1u9enXi0NAQiESirIdRtggIc5oJ40zq6uryGhoa8ry8vBJCQ0O9USjU94mrN7yWc+EnvaXb5gJMvxCMp6cnl0Kh2Le1tZVXXLs8L1LXefGrWRkZGZ/x+XyeUqkEkUh0vqenZ14HZyG8OEwoJjdrygd37NxTEBkZmWBtbQ3BwcEeKBTq+/UbX3/355Pfzlmn66qk9dGbN29+k8PhbCSRSNDZ2Snb9ae/HCkpKTksEhbN2QTD5NSX+Vu3bj0cHBzsjcFg4O7du1BWVvbNwxB9BIQ5j94I2Fu3bhXW19cDl8sFLBYLHA7Hg0wmf/e77e84ffXlPz6fLSMnQ2paZkJ4eHjmtm3b+B4eHvZkMhlQKBTY29s72dvbfxgUFJT8x7ffP1NRUfHjXErnZ/qFYKKjo7dt3rz5g8DAQPtH/XHa2tpqGhsbC55/BASEuYFeMblz505NTU3NgfDw8PcwGAygUCjw9fW1IJPJn/1130Hv0tLSI4WXL4hny9inYS+Osvbz80tgMpn8jIwMPovFch2vpoiDgwM4ODhwfH19OYsWLeJv3/Hu+cbGxquzXZz5aZYlvMRJT0/fFhkZue3JZmfd3d0gEolOIr4ShPmEXjFpkFRqXlrzSnFnZ+d7Tk5OjzNfXVxcICMjY6ezszNnVdL6vU8HWhmbgKAIkrOzMyc1NTXz0YU4maAuOp0OK1as4EVFRfGEQqHg1dfePHzr1q2rs71S8WOF4f38/BLS09M/iIyM5DxdxLq5uVlcVVU1bgVwBIS5il4xAQCQyWRigUBwJikpKe3JVGQcDgdLly7l2tranti0ecf7IpEoy9hbxX6sMDydTvdevXr1ltjY2F3u7u6AxT73FJ7B3Nwc4uLiwthsdphQKCzZkL7l0/r6+oKbNeVG90+EhMXZL1++fFtycvKHrq6uz4igUqmE5ubmEiTHCWG+8dwrUXD9imz9xtd/jIuLS7N5KpsTjUZDUFCQE4PB+F4oFGYmJW888Mv5k4UTHGpGxC9LYaenp78VEhKyxdHRESgUyoyOh0KhwNraGuLi4qIDAgKi6+rqyjekb/mHMSN6N6RvSdu+ffseNpsdZm09ftuW+vp6EIvFSB9hhHnHpG7rUqm0orW1tdXS0tLj6TIEaDQaaDQaxMfH811dXTl/3Xfw+JUrVz411J01cfWG6IiIiC07d+5McHNzs7ewMGyOFw6HAwcHB6BSqVx3d/fwz7/4rkAgEBwXCoUnHpZonDGrU9J5MTEx27du3Zrm4uKC0beaqq6u/ry+vj7XEPMiIMwmkxKTimuXZe/u+fCkp6fnexPdUfF4PPj7+1szGIydLi4unF1/+kvenTt3RG1tbRXTqfma8lIG39/fP/HVV19NZrFYHpMpzjQTzMzMwNPTE+Pp6Zng6emZ4Ofnl5CesfV8bW1tznQe3/wDwvFeXl7Rvr6+Ca+88kpaUFCQh74GXzqdDrq7u6GpqankRQmdR1hYTNrhUFVVlcXj8d6ysrKy0OfstLS0hPj4eC6Xy+U2NzeDRCI5/sa2XeX37t1rGhwc7BoYGJBN1P+FFbiE5OzszGaxWImvvvrqpoCAAKfp+ERmCpPJBCaTmcnhcDJLS0u/TE59+YxUKhXoi/lg+oVgrKysGJaWlna2trYeaWlpXDabvTMgIGDSfp2KiorzbW1tL0zoPMLCYtJX6uVfs2u++PKowMPDgz+ZIslEIhECAgKAxWJlajSazJ6eHmhra4PW1tZvtmz9o6Czs7O+r6+vfWxsbFir1WosLCzsV6xYkcnj8d7z9vaelmPV0Hh5eYGnp+f2mJiY7UVFRZ/HL0v5tru7+5ZGo1FisVg8Docj4fF4CxsbG1c+nx/m7e39sYeHB7i4uIC5ufmU6r4ODQ1BZWXlifkSrYuA8DRTumIrKytPent78728vCb9HRQKBVgsFhwcHIBOpwObzd4yNja2RaVSwdDQEHR1dcHo6CjQaDRwdXWdsWPV0KBQKPDw8AA7O7udERERO2tra2FgYACoVCo4OTkBjUYDMpkMeDz+8WuqaLVaaGxsbL19+/YzSX8ICPOFqYrJidDQ0AwvLy/e80c/CwaDARKJBI86BdJoNHB3dwe1Wj0nViL6IJPJwGQywdnZGZRKJRAIBDBUx8OBgQEoLS39BtkORpjPTJg1PB61N64pmpqarvb39xvUiLkuJE9CJpPBxsbGYEICANDZ2SlHgtQQ5jtTEhMAgLq6ulyJRFJvDGNeREZGRkAikRSUFuci2cEI85opi0l+7hmBWCzOeV6dToTJcfv27cHr168jxbgR5j1TFhMAgObm5hKZDNl0MAQtLS3Xzpw6hkS8Isx7piUmUqlUIBAIJuyjgzA5Ojs7QSKRINGuCAuCaYmJsKKw68qVK59KJJIu5HFneiiVSigqKjouEolOmtoWBARDMC0xAQC4+MvPJadOnXq3ra1N8yL0dDEkOp0OSktLy/Pz8w8+3d4CAWG+Mm0xAQA4fuy/jl+8ePGju3fvGsqeBY9Wq4XKysrWU6dOvX31yi8mKyyFgGBoZiQmAAD/79D+fadPn96PCMrz0el0UFVV1frtt9+mj9fiAgFhPjNjMQEAyMvLO3Ds2LE/tLS0INmuerh27Vr9999//xoiJAgLEYOEntbVVigB4PNNm3cMpqSkfMRms50McdyFgkqlgqKiovJTp069nZ97BhEShAWJQePYj373xdF1GzbLFQrFx6Ghob766ne8KNy7dw+KiopO5ubmfmTK4tsICMbG4EkxWT99d35l4rre/v7+D0NCQvh0Ot3QU8wL1Go1SKVSTX5+/sH8/PyDSP8bhIWOUTLsLuVklQcFR65pbGzcvnLlyvfc3NwsCASCMaaac+h0OhgaGoLq6uqaCxcu/OV01tGcTw7uM7VZCAhGx2jpug/vxAd58atzoqKitq1cuXKnvb29saabE+h0Oqiurpbm5eUdrK6uPlspuDrvY0hmO4YIhUIBGq1/X2CmNqFQKL3/79HomZ/z82xEowyy9zFr80zGDqPn/hdeviBmL47ad+fOnRsRERGbQkNDo62srIw97azT2dkJxcXFx0tKSo7Mdh8hY4LD4TDPH2U4MFjMc6tLmZmZzaj+Aw6H0/t9PB4PGCxmRudNJBL0ngeZTAI0Gj3jv+1szfM88Hic8cUEAKCmqlQOAN/ELU2qkEgkySwWK3HRokVcBoMxG9MbDZ1OB83NzdDU1FRQW1t7XiAQHJ+ovu18pbr6Rg6L5ZtoM0EhcUPT0tJW8tWRb0vQqIkvgKqqmhnVfrl2TfANXo+gjKlUio4OWc1M5sjOzjnQUH8rbqLPu3t6moaGhmfc+3q25tGHUqmECoEIUKbIrVkcEkONiIh4jcvlvu7s7OxLo9GmVe7QVCgUCujq6oKGhoaCioqKo9XV1WeM3YDMVPDik1gpyas+XrVyeaKXl8czjyANjbcgI/MNmkg49Q4ECPOH3NyC4RUr+M8IcHt7B1y9WlKRl3/5kElKnD1sfXEoJCzueEBAQGJYWFgGk8nk2djYAIFAgLm4pTw6Ogqjo6Mgl8vhxo0b50tLS4/U19fnLvS2FIWXfxEDQNLmLW9ueW1TxtchHDaQyWRTm4VgYkZHR6G+vhF+/NfP+y5e+vVjiVgwZpKVydOwF0dZW1lZOTGZTD6bzU4LCAiIptPp8HTDL1MwOjoKLS0tUFdXd1IsFudIpdKKgYGB7tloJTrX4MUnsVJTEj9etzY10dHRAQAAGm81wcsZW5CVyQInL69gNCGBjwcAGBx8ANnncypOnTr3H9nn/reD55wovvrQpyIHAHFUzIocGo3mQaPRfBwdHVlubm7bXF1dgcFgABqNNvruglwuh7t374JMJoOOjo7P79y5I+ru7m7q7e1tXQi7MzOh8PIv4pCw2DdaWtte37Au7aPIyCWAxWABjUbPif9HCMbjURtKiaQBfvr5zH9evlJ0uLQ4r/nJMXNiZTIRrMAlJAcHB18HBweWo6Mjy8rKajeJRAJLS0uwtLQECwsLoFAogMfjAYvFgpmZ2XNXMyqVCoaHh2FoaAiGh4cfvwYGBqCvrw+6u7vfvnfvXlNvb29rT09Pq0QsUM7S6c4rNqS/lrZ5U+YPRBKR9M7u9xwqBUUvtNAudH766XSLE8PR49ixE78/8tVnX403Zk7fUR46NUUAIPIPCMdTKJTdNjY2QKPRgE6nA51OB1tbWyCRSIDD4YBAIAAejwcCgfDYUajVakGlUoFarQadTvfY79HX1wf9/f0gl8tBLpfDvXv3HvXw+dxQPYYXMj+d+P7Mmzv+5OHr6/OJWq1GBHeB09TcUiKuq/coKS3/eqIx/wPkiIXC3w6YjAAAAABJRU5ErkJggg==");
  55. --keyword: #ff79c6;
  56. --identifier: #f8f8f2;
  57. --comment: #6272a4;
  58. --operator: #ff79c6;
  59. --punctuation: #f8f8f2;
  60. --other: #f8f8f2;
  61. --escapeSequence: #bd93f9;
  62. --number: #bd93f9;
  63. --literal: #f1fa8c;
  64. --program: #9090c0;
  65. --option: #90b010;
  66. --raw-data: #8be9fd;
  67. --clipboard-image-normal: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E %3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2' /%3E %3C/svg%3E");
  68. --clipboard-image-selected: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' viewBox='0 0 20 20' fill='currentColor'%3E %3Cpath d='M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z' /%3E %3Cpath d='M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z' /%3E %3C/svg%3E");
  69. --clipboard-image: var(--clipboard-image-normal);
  70. }
  71. .theme-switch-wrapper {
  72. display: flex;
  73. align-items: center;
  74. }
  75. .theme-switch-wrapper em {
  76. margin-left: 10px;
  77. font-size: 1rem;
  78. }
  79. .theme-switch {
  80. display: inline-block;
  81. height: 22px;
  82. position: relative;
  83. width: 50px;
  84. }
  85. .theme-switch input {
  86. display: none;
  87. }
  88. .slider {
  89. background-color: #ccc;
  90. bottom: 0;
  91. cursor: pointer;
  92. left: 0;
  93. position: absolute;
  94. right: 0;
  95. top: 0;
  96. transition: .4s;
  97. }
  98. .slider:before {
  99. background-color: #fff;
  100. bottom: 4px;
  101. content: "";
  102. height: 13px;
  103. left: 4px;
  104. position: absolute;
  105. transition: .4s;
  106. width: 13px;
  107. }
  108. input:checked + .slider {
  109. background-color: #66bb6a;
  110. }
  111. input:checked + .slider:before {
  112. transform: translateX(26px);
  113. }
  114. .slider.round {
  115. border-radius: 17px;
  116. }
  117. .slider.round:before {
  118. border-radius: 50%;
  119. }
  120. html {
  121. font-size: 100%;
  122. -webkit-text-size-adjust: 100%;
  123. -ms-text-size-adjust: 100%; }
  124. body {
  125. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  126. font-weight: 400;
  127. font-size: 1.125em;
  128. line-height: 1.5;
  129. color: var(--text);
  130. background-color: var(--primary-background); }
  131. /* Skeleton grid */
  132. .container {
  133. position: relative;
  134. width: 100%;
  135. max-width: 1050px;
  136. margin: 0 auto;
  137. padding: 0;
  138. box-sizing: border-box; }
  139. .column, .columns {
  140. width: 100%;
  141. float: left;
  142. box-sizing: border-box;
  143. margin-left: 1%; }
  144. .column:first-child, .columns:first-child {
  145. margin-left: 0; }
  146. .container .row {
  147. display: flex; }
  148. .three.columns {
  149. width: 25.0%;
  150. height: 100vh;
  151. position: sticky;
  152. top: 0px;
  153. overflow-y: auto; }
  154. .nine.columns {
  155. width: 75.0%;
  156. padding-left: 1.5em; }
  157. .twelve.columns {
  158. width: 100%;
  159. margin-left: 0; }
  160. @media screen and (max-width: 860px) {
  161. .three.columns {
  162. display: none;
  163. }
  164. .nine.columns {
  165. width: 98.0%;
  166. }
  167. body {
  168. font-size: 1em;
  169. line-height: 1.35;
  170. }
  171. }
  172. cite {
  173. font-style: italic !important; }
  174. /* Nim search input */
  175. div#searchInputDiv {
  176. margin-bottom: 1em;
  177. }
  178. input#searchInput {
  179. width: 80%;
  180. }
  181. /*
  182. * Some custom formatting for input forms.
  183. * This also fixes input form colors on Firefox with a dark system theme on Linux.
  184. */
  185. input {
  186. -moz-appearance: none;
  187. background-color: var(--secondary-background);
  188. color: var(--text);
  189. border: 1px solid var(--border);
  190. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  191. font-size: 0.9em;
  192. padding: 6px;
  193. }
  194. input:focus {
  195. border: 1px solid var(--input-focus);
  196. box-shadow: 0 0 3px var(--input-focus);
  197. }
  198. select {
  199. -moz-appearance: none;
  200. background-color: var(--secondary-background);
  201. color: var(--text);
  202. border: 1px solid var(--border);
  203. font-family: "Lato", "Helvetica Neue", "HelveticaNeue", Helvetica, Arial, sans-serif;
  204. font-size: 0.9em;
  205. padding: 6px;
  206. }
  207. select:focus {
  208. border: 1px solid var(--input-focus);
  209. box-shadow: 0 0 3px var(--input-focus);
  210. }
  211. /* Docgen styles */
  212. :target {
  213. border: 2px solid #B5651D;
  214. border-style: dotted;
  215. }
  216. /* Links */
  217. a {
  218. color: var(--anchor);
  219. text-decoration: none;
  220. }
  221. a span.Identifier {
  222. text-decoration: underline;
  223. text-decoration-color: #aab;
  224. }
  225. a.reference-toplevel {
  226. font-weight: bold;
  227. }
  228. a.nimdoc {
  229. word-spacing: 0.3em;
  230. }
  231. a.toc-backref {
  232. text-decoration: none;
  233. color: var(--text);
  234. }
  235. a.link-seesrc {
  236. color: #607c9f;
  237. font-size: 0.9em;
  238. font-style: italic;
  239. }
  240. a:hover, a:focus {
  241. color: var(--anchor-focus);
  242. text-decoration: underline;
  243. }
  244. a:hover span.Identifier {
  245. color: var(--anchor);
  246. }
  247. sub, sup {
  248. position: relative;
  249. font-size: 75%;
  250. line-height: 0;
  251. vertical-align: baseline; }
  252. sup {
  253. top: -0.5em; }
  254. sub {
  255. bottom: -0.25em; }
  256. img {
  257. width: auto;
  258. height: auto;
  259. max-width: 100%;
  260. vertical-align: middle;
  261. border: 0;
  262. -ms-interpolation-mode: bicubic; }
  263. @media print {
  264. * {
  265. color: black !important;
  266. text-shadow: none !important;
  267. background: transparent !important;
  268. box-shadow: none !important; }
  269. a, a:visited {
  270. text-decoration: underline; }
  271. a[href]:after {
  272. content: " (" attr(href) ")"; }
  273. abbr[title]:after {
  274. content: " (" attr(title) ")"; }
  275. .ir a:after,
  276. a[href^="javascript:"]:after,
  277. a[href^="#"]:after {
  278. content: ""; }
  279. pre, blockquote {
  280. border: 1px solid #999;
  281. page-break-inside: avoid; }
  282. thead {
  283. display: table-header-group; }
  284. tr, img {
  285. page-break-inside: avoid; }
  286. img {
  287. max-width: 100% !important; }
  288. @page {
  289. margin: 0.5cm; }
  290. h1 {
  291. page-break-before: always; }
  292. h1.title {
  293. page-break-before: avoid; }
  294. p, h2, h3 {
  295. orphans: 3;
  296. widows: 3; }
  297. h2, h3 {
  298. page-break-after: avoid; }
  299. }
  300. p {
  301. margin-top: 0.5em;
  302. margin-bottom: 0.5em; }
  303. small {
  304. font-size: 85%; }
  305. strong {
  306. font-weight: 600;
  307. font-size: 0.95em;
  308. color: var(--strong); }
  309. em {
  310. font-style: italic; }
  311. h1 {
  312. font-size: 1.8em;
  313. font-weight: 400;
  314. padding-bottom: .25em;
  315. border-bottom: 6px solid var(--third-background);
  316. margin-top: 2.5em;
  317. margin-bottom: 1em;
  318. line-height: 1.2em; }
  319. h1.title {
  320. padding-bottom: 1em;
  321. border-bottom: 0px;
  322. font-size: 2.5em;
  323. text-align: center;
  324. font-weight: 900;
  325. margin-top: 0.75em;
  326. margin-bottom: 0em; }
  327. h2 {
  328. font-size: 1.3em;
  329. margin-top: 2em; }
  330. h2.subtitle {
  331. margin-top: 0em;
  332. text-align: center; }
  333. h3 {
  334. font-size: 1.125em;
  335. font-style: italic;
  336. margin-top: 1.5em; }
  337. h4 {
  338. font-size: 1.125em;
  339. margin-top: 1em; }
  340. h5 {
  341. font-size: 1.125em;
  342. margin-top: 0.75em; }
  343. h6 {
  344. font-size: 1.1em; }
  345. ul, ol {
  346. padding: 0;
  347. margin-top: 0.5em;
  348. margin-left: 0.75em; }
  349. ul ul, ul ol, ol ol, ol ul {
  350. margin-bottom: 0;
  351. margin-left: 1.25em; }
  352. ul.simple > li {
  353. list-style-type: circle; }
  354. ul.simple-boot li {
  355. list-style-type: none;
  356. margin-left: 0em;
  357. margin-bottom: 0.5em; }
  358. ol.simple > li, ul.simple > li {
  359. margin-bottom: 0.2em;
  360. margin-left: 0.4em }
  361. ul.simple.simple-toc > li {
  362. margin-top: 1em; }
  363. ul.simple-toc {
  364. list-style: none;
  365. font-size: 0.9em;
  366. margin-left: -0.3em;
  367. margin-top: 1em; }
  368. ul.simple-toc > li {
  369. list-style-type: none; }
  370. ul.simple-toc-section {
  371. list-style-type: circle;
  372. margin-left: 0.8em;
  373. color: #6c9aae; }
  374. ul.nested-toc-section {
  375. list-style-type: circle;
  376. margin-left: -0.75em;
  377. color: var(--text); }
  378. ul.nested-toc-section > li {
  379. margin-left: 1.25em; }
  380. ol.arabic {
  381. list-style: decimal; }
  382. ol.loweralpha {
  383. list-style: lower-alpha; }
  384. ol.upperalpha {
  385. list-style: upper-alpha; }
  386. ol.lowerroman {
  387. list-style: lower-roman; }
  388. ol.upperroman {
  389. list-style: upper-roman; }
  390. ul.auto-toc {
  391. list-style-type: none; }
  392. dl {
  393. margin-bottom: 1.5em; }
  394. dt {
  395. margin-bottom: -0.5em;
  396. margin-left: 0.0em; }
  397. dd {
  398. margin-left: 2.0em;
  399. margin-bottom: 3.0em;
  400. margin-top: 0.5em; }
  401. hr {
  402. margin: 2em 0;
  403. border: 0;
  404. border-top: 1px solid #aaa; }
  405. hr.footnote {
  406. width: 25%;
  407. border-top: 0.15em solid #999;
  408. margin-bottom: 0.15em;
  409. margin-top: 0.15em;
  410. }
  411. div.footnote-group {
  412. margin-left: 1em;
  413. }
  414. div.footnote-label {
  415. display: inline-block;
  416. min-width: 1.7em;
  417. }
  418. div.option-list {
  419. border: 0.1em solid var(--border);
  420. }
  421. div.option-list-item {
  422. padding-left: 12em;
  423. padding-right: 0;
  424. padding-bottom: 0.3em;
  425. padding-top: 0.3em;
  426. }
  427. div.odd {
  428. background-color: var(--secondary-background);
  429. }
  430. div.option-list-label {
  431. margin-left: -11.5em;
  432. margin-right: 0em;
  433. min-width: 11.5em;
  434. display: inline-block;
  435. vertical-align: top;
  436. }
  437. div.option-list-description {
  438. width: calc(100% - 1em);
  439. padding-left: 1em;
  440. padding-right: 0;
  441. display: inline-block;
  442. }
  443. blockquote {
  444. font-size: 0.9em;
  445. font-style: italic;
  446. padding-left: 0.5em;
  447. margin-left: 0;
  448. border-left: 5px solid #bbc;
  449. }
  450. blockquote.markdown-quote {
  451. font-size: 0.9rem; /* use rem to avoid recursion */
  452. font-style: normal;
  453. }
  454. .pre, span.tok {
  455. font-family: "Source Code Pro", Monaco, Menlo, Consolas, "Courier New", monospace;
  456. font-weight: 500;
  457. font-size: 0.85em;
  458. color: var(--text);
  459. background-color: var(--third-background);
  460. padding-left: 3px;
  461. padding-right: 3px;
  462. border-radius: 4px;
  463. }
  464. span.tok {
  465. border: 1px solid #808080;
  466. padding-bottom: 0.1em;
  467. margin-right: 0.2em;
  468. }
  469. .copyToClipBoard {
  470. position: relative;
  471. }
  472. pre {
  473. font-family: "Source Code Pro", Monaco, Menlo, Consolas, "Courier New", monospace;
  474. color: var(--text);
  475. font-weight: 500;
  476. display: inline-block;
  477. box-sizing: border-box;
  478. min-width: 100%;
  479. padding: 0.5em;
  480. margin-top: 0.5em;
  481. margin-bottom: 0.5em;
  482. font-size: 0.85em;
  483. white-space: pre !important;
  484. overflow-y: hidden;
  485. overflow-x: visible;
  486. background-color: var(--secondary-background);
  487. border: 1px solid var(--border);
  488. -webkit-border-radius: 6px;
  489. -moz-border-radius: 6px;
  490. border-radius: 6px;
  491. }
  492. .copyToClipBoardBtn {
  493. visibility: hidden;
  494. position: absolute;
  495. width: 24px;
  496. border-radius: 4px;
  497. background-image: var(--clipboard-image);
  498. right: 5px;
  499. top: 13px;
  500. background-color: var(--secondary-background);
  501. padding: 11px;
  502. border: 0;
  503. }
  504. .copyToClipBoard:hover .copyToClipBoardBtn {
  505. visibility: visible;
  506. }
  507. .pre-scrollable {
  508. max-height: 340px;
  509. overflow-y: scroll; }
  510. /* Nim line-numbered tables */
  511. .line-nums-table {
  512. width: 100%;
  513. table-layout: fixed; }
  514. table.line-nums-table {
  515. border-radius: 4px;
  516. border: 1px solid #cccccc;
  517. background-color: ghostwhite;
  518. border-collapse: separate;
  519. margin-top: 15px;
  520. margin-bottom: 25px; }
  521. .line-nums-table tbody {
  522. border: none; }
  523. .line-nums-table td pre {
  524. border: none;
  525. background-color: transparent; }
  526. .line-nums-table td.blob-line-nums {
  527. width: 28px; }
  528. .line-nums-table td.blob-line-nums pre {
  529. color: #b0b0b0;
  530. -webkit-filter: opacity(75%);
  531. filter: opacity(75%);
  532. text-align: right;
  533. border-color: transparent;
  534. background-color: transparent;
  535. padding-left: 0px;
  536. margin-left: 0px;
  537. padding-right: 0px;
  538. margin-right: 0px; }
  539. table {
  540. max-width: 100%;
  541. background-color: transparent;
  542. margin-top: 0.5em;
  543. margin-bottom: 1.5em;
  544. border-collapse: collapse;
  545. border-color: var(--third-background);
  546. border-spacing: 0;
  547. font-size: 0.9em;
  548. }
  549. table th, table td {
  550. padding: 0px 0.5em 0px;
  551. border-color: var(--third-background);
  552. }
  553. table th {
  554. background-color: var(--third-background);
  555. border-color: var(--third-background);
  556. font-weight: bold; }
  557. table th.docinfo-name {
  558. background-color: transparent;
  559. text-align: right;
  560. }
  561. table tr:hover {
  562. background-color: var(--third-background); }
  563. /* rst2html default used to remove borders from tables and images */
  564. .borderless, table.borderless td, table.borderless th {
  565. border: 0; }
  566. table.borderless td, table.borderless th {
  567. /* Override padding for "table.docutils td" with "! important".
  568. The right padding separates the table cells. */
  569. padding: 0 0.5em 0 0 !important; }
  570. .admonition {
  571. padding: 0.3em;
  572. background-color: var(--secondary-background);
  573. border-left: 0.4em solid #7f7f84;
  574. margin-bottom: 0.5em;
  575. -webkit-box-shadow: 0 5px 8px -6px rgba(0,0,0,.2);
  576. -moz-box-shadow: 0 5px 8px -6px rgba(0,0,0,.2);
  577. box-shadow: 0 5px 8px -6px rgba(0,0,0,.2);
  578. }
  579. .admonition-info {
  580. border-color: var(--info-background);
  581. }
  582. .admonition-info-text {
  583. color: var(--info-background);
  584. }
  585. .admonition-warning {
  586. border-color: var(--warning-background);
  587. }
  588. .admonition-warning-text {
  589. color: var(--warning-background);
  590. }
  591. .admonition-error {
  592. border-color: var(--error-background);
  593. }
  594. .admonition-error-text {
  595. color: var(--error-background);
  596. }
  597. .first {
  598. /* Override more specific margin styles with "! important". */
  599. margin-top: 0 !important; }
  600. .last, .with-subtitle {
  601. margin-bottom: 0 !important; }
  602. .hidden {
  603. display: none; }
  604. blockquote.epigraph {
  605. margin: 2em 5em; }
  606. dl.docutils dd {
  607. margin-bottom: 0.5em; }
  608. object[type="image/svg+xml"], object[type="application/x-shockwave-flash"] {
  609. overflow: hidden; }
  610. div.figure {
  611. margin-left: 2em;
  612. margin-right: 2em; }
  613. div.footer, div.header {
  614. clear: both;
  615. text-align: center;
  616. color: #666;
  617. font-size: smaller; }
  618. div.footer {
  619. padding-top: 5em; }
  620. div.line-block {
  621. display: block;
  622. margin-top: 1em;
  623. margin-bottom: 1em; }
  624. div.line-block div.line-block {
  625. margin-top: 0;
  626. margin-bottom: 0;
  627. margin-left: 1.5em; }
  628. div.topic {
  629. margin: 2em; }
  630. div.search_results {
  631. background-color: var(--third-background);
  632. margin: 3em;
  633. padding: 1em;
  634. border: 1px solid #4d4d4d; }
  635. div#global-links ul {
  636. margin-left: 0;
  637. list-style-type: none; }
  638. div#global-links > simple-boot {
  639. margin-left: 3em; }
  640. hr.docutils {
  641. width: 75%; }
  642. img.align-left, .figure.align-left, object.align-left {
  643. clear: left;
  644. float: left;
  645. margin-right: 1em; }
  646. img.align-right, .figure.align-right, object.align-right {
  647. clear: right;
  648. float: right;
  649. margin-left: 1em; }
  650. img.align-center, .figure.align-center, object.align-center {
  651. display: block;
  652. margin-left: auto;
  653. margin-right: auto; }
  654. .align-left {
  655. text-align: left; }
  656. .align-center {
  657. clear: both;
  658. text-align: center; }
  659. .align-right {
  660. text-align: right; }
  661. /* reset inner alignment in figures */
  662. div.align-right {
  663. text-align: inherit; }
  664. p.attribution {
  665. text-align: right;
  666. margin-left: 50%; }
  667. p.caption {
  668. font-style: italic; }
  669. p.credits {
  670. font-style: italic;
  671. font-size: smaller; }
  672. p.label {
  673. white-space: nowrap; }
  674. p.rubric {
  675. font-weight: bold;
  676. font-size: larger;
  677. color: maroon;
  678. text-align: center; }
  679. p.topic-title {
  680. font-weight: bold; }
  681. pre.address {
  682. margin-bottom: 0;
  683. margin-top: 0;
  684. font: inherit; }
  685. pre.literal-block, pre.doctest-block, pre.math, pre.code {
  686. margin-left: 2em;
  687. margin-right: 2em; }
  688. pre.code .ln {
  689. color: grey; }
  690. /* line numbers */
  691. pre.code, code {
  692. background-color: #eeeeee; }
  693. pre.code .comment, code .comment {
  694. color: #5c6576; }
  695. pre.code .keyword, code .keyword {
  696. color: #3B0D06;
  697. font-weight: bold; }
  698. pre.code .literal.string, code .literal.string {
  699. color: #0c5404; }
  700. pre.code .name.builtin, code .name.builtin {
  701. color: #352b84; }
  702. pre.code .deleted, code .deleted {
  703. background-color: #DEB0A1; }
  704. pre.code .inserted, code .inserted {
  705. background-color: #A3D289; }
  706. span.classifier {
  707. font-style: oblique; }
  708. span.classifier-delimiter {
  709. font-weight: bold; }
  710. span.problematic {
  711. color: #b30000; }
  712. span.section-subtitle {
  713. /* font-size relative to parent (h1..h6 element) */
  714. font-size: 80%; }
  715. span.DecNumber {
  716. color: var(--number); }
  717. span.BinNumber {
  718. color: var(--number); }
  719. span.HexNumber {
  720. color: var(--number); }
  721. span.OctNumber {
  722. color: var(--number); }
  723. span.FloatNumber {
  724. color: var(--number); }
  725. span.Identifier {
  726. color: var(--identifier); }
  727. span.Keyword {
  728. font-weight: 600;
  729. color: var(--keyword); }
  730. span.StringLit {
  731. color: var(--literal); }
  732. span.LongStringLit {
  733. color: var(--literal); }
  734. span.CharLit {
  735. color: var(--literal); }
  736. span.EscapeSequence {
  737. color: var(--escapeSequence); }
  738. span.Operator {
  739. color: var(--operator); }
  740. span.Punctuation {
  741. color: var(--punctuation); }
  742. span.Comment, span.LongComment {
  743. font-style: italic;
  744. font-weight: 400;
  745. color: var(--comment); }
  746. span.RegularExpression {
  747. color: darkviolet; }
  748. span.TagStart {
  749. color: darkviolet; }
  750. span.TagEnd {
  751. color: darkviolet; }
  752. span.Key {
  753. color: #252dbe; }
  754. span.Value {
  755. color: #252dbe; }
  756. span.RawData {
  757. color: var(--raw-data); }
  758. span.Assembler {
  759. color: #252dbe; }
  760. span.Preprocessor {
  761. color: #252dbe; }
  762. span.Directive {
  763. color: #252dbe; }
  764. span.option {
  765. font-weight: bold;
  766. font-family: "Source Code Pro", Monaco, Menlo, Consolas, "Courier New", monospace;
  767. color: var(--option); }
  768. span.Prompt {
  769. font-weight: bold;
  770. color: red; }
  771. span.ProgramOutput {
  772. font-weight: bold;
  773. color: #808080; }
  774. span.program {
  775. font-weight: bold;
  776. color: var(--program);
  777. text-decoration: underline;
  778. text-decoration-color: var(--hint);
  779. text-decoration-thickness: 0.05em;
  780. text-underline-offset: 0.15em; }
  781. span.Command, span.Rule, span.Hyperlink,
  782. span.Label, span.Reference, span.Other {
  783. color: var(--other); }
  784. /* Pop type, const, proc, and iterator defs in nim def blocks */
  785. dt pre > span.Identifier, dt pre > span.Operator {
  786. color: var(--identifier);
  787. font-weight: 700; }
  788. dt pre > span.Keyword ~ span.Identifier, dt pre > span.Identifier ~ span.Identifier,
  789. dt pre > span.Operator ~ span.Identifier, dt pre > span.Other ~ span.Identifier {
  790. color: var(--identifier);
  791. font-weight: inherit; }
  792. /* Nim sprite for the footer (taken from main page favicon) */
  793. .nim-sprite {
  794. display: inline-block;
  795. width: 51px;
  796. height: 14px;
  797. background-position: 0 0;
  798. background-size: 51px 14px;
  799. -webkit-filter: opacity(50%);
  800. filter: opacity(50%);
  801. background-repeat: no-repeat;
  802. background-image: var(--nim-sprite-base64);
  803. margin-bottom: 5px; }
  804. span.pragmadots {
  805. /* Position: relative frees us up to make the dots
  806. look really nice without fucking up the layout and
  807. causing bulging in the parent container */
  808. position: relative;
  809. /* 1px down looks slightly nicer */
  810. top: 1px;
  811. padding: 2px;
  812. background-color: var(--third-background);
  813. border-radius: 4px;
  814. margin: 0 2px;
  815. cursor: pointer;
  816. font-size: 0.8em; }
  817. span.pragmadots:hover {
  818. background-color: var(--hint); }
  819. span.pragmawrap {
  820. display: none; }
  821. span.attachedType {
  822. display: none;
  823. visibility: hidden; }