/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font: 400 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: #111; background-color: #fdfdfd; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; display: flex; min-height: 100vh; flex-direction: column; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** `main` element */
main { display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */ }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4 { font-weight: 400; }

h5 { font-size: 1em; font-weight: bold; }

h6 { font-size: 1em; font-weight: 400; }

/** Links */
a { color: #2a7ae2; text-decoration: none; }

a:visited { color: #1756a9; }

a:hover { color: #111; text-decoration: underline; }

.social-media-list a:hover { text-decoration: none; }

.social-media-list a:hover .username { text-decoration: underline; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }

blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #f8f8ff; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }

pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }

@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.footer-col-wrapper:after, .wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.svg-icon { width: 16px; height: 16px; display: inline-block; fill: #828282; padding-right: 5px; vertical-align: text-top; }

.svg-icon-novalign { width: 16px; height: 16px; display: inline-block; fill: #828282; padding-right: 5px; }

.social-media-list li + li { padding-top: 5px; }

/** Tables */
table { margin-bottom: 30px; width: 100%; text-align: left; color: #3f3f3f; border-collapse: collapse; border: 0px solid #e8e8e8; }

table tr:nth-child(odd) { background-color: #f7f7f7; }

table th, table td { padding: 10px 15px; }

table th { background-color: #f0f0f0; border: 0px solid #dedede; border-bottom-color: #c9c9c9; }

table td { border: 0px solid #e8e8e8; }

/** Site header */
.site-header { min-height: 55.95px; }

.site-title { font-family: "Lato"; font-size: 26px; font-weight: 400; color: black; line-height: 54px; margin-bottom: 0; -webkit-touch-callout: none; /* iOS Safari */ -webkit-user-select: none; /* Safari */ -khtml-user-select: none; /* Konqueror HTML */ -moz-user-select: none; /* Old versions of Firefox */ -ms-user-select: none; /* Internet Explorer/Edge */ user-select: none; /* Chrome, Edge, Opera and Firefox */ }

.site-title:link, .site-title:visited { color: black; }

.site-title:hover, .site-title:active { text-decoration: none; }

@media screen and (max-width: 450px) { .site-title { padding-right: 36px; } }

.site-nav-wrapper { position: relative; }

.centered { text-align: center; }

.site-nav { font-size: 19.2px; line-height: 48px; }

.site-nav .nav-trigger { display: none; }

.site-nav .menu-icon { display: none; }

.site-nav .page-link { color: #111; line-height: 1.5; }

.site-nav .page-link:link, .site-nav .page-link:visited { padding: 10px 20px; border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; text-align: center; text-decoration: none; display: inline-block; }

.site-nav .page-link:hover, .site-nav .page-link:active { background-color: #f8f8f8; }

.site-nav .page-link.highlight { background-color: #ffe8c8; }

.site-nav .page-link.highlight:hover, .site-nav .page-link.highlight:active { background-color: #f90; }

@media screen and (max-width: 450px) { .site-nav { position: absolute; top: -45.975px; right: 15px; background-color: #fdfdfd; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; } .site-nav label[for="nav-trigger"] { display: block; float: right; width: 36px; height: 36px; z-index: 2; cursor: pointer; } .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; } .site-nav .menu-icon > svg { fill: #424242; } .site-nav input ~ .trigger { clear: both; display: none; } .site-nav input:checked ~ .trigger { display: block; padding-bottom: 5px; } .site-nav .page-link { display: block; padding: 5px 10px; margin-left: 20px; } .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; padding: 30px 0; background: #e8e8e8; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(30% - (30px / 2)); width: calc(30% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); } .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

@media screen and (max-width: 450px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

/** Page content */
.page-content { padding: 15px 0; flex: 1; }

.page-heading { font-size: 32px; }

.post-list-heading { font-size: 28px; }

.post-list { margin-left: 0; list-style: none; }

.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { font-size: 42px; letter-spacing: -1px; line-height: 1; }

@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }

.post-content h2 { font-size: 32px; }

@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }

.post-content h3 { font-size: 26px; }

@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }

.post-content h4 { font-size: 20px; }

@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Syntax highlighting styles */
.highlight { background: #fff; }

.highlighter-rouge .highlight { background: #f8f8ff; }

.highlight .c { color: #998; font-style: italic; }

.highlight .err { color: #a61717; background-color: #e3d2d2; }

.highlight .k { color: #005cc5; }

.highlight .cm { color: #998; font-style: italic; }

.highlight .cp { color: #555; }

.highlight .c1 { color: #998; font-style: italic; }

.highlight .cs { color: #999; font-style: italic; }

.highlight .gd { color: #000; background-color: #fdd; }

.highlight .gd .x { color: #000; background-color: #faa; }

.highlight .ge { font-style: italic; }

.highlight .gr { color: #a00; }

.highlight .gh { color: #999; }

.highlight .gi { color: #000; background-color: #dfd; }

.highlight .gi .x { color: #000; background-color: #afa; }

.highlight .go { color: #888; }

.highlight .gp { color: #555; }

.highlight .gs { font-weight: bold; }

.highlight .gu { color: #aaa; }

.highlight .gt { color: #a00; }

.highlight .kc { font-weight: bold; }

.highlight .kd { font-weight: bold; }

.highlight .kp { font-weight: bold; }

.highlight .kr { font-weight: bold; }

.highlight .kt { color: #d73a49; }

.highlight .m { color: #099; }

.highlight .s { color: #032f62; }

.highlight .na { color: #008080; }

.highlight .nb { color: #0086B3; }

.highlight .nc { color: #d73a49; }

.highlight .no { color: #008080; }

.highlight .ni { color: #800080; }

.highlight .ne { color: #6f42c1; }

.highlight .nf { color: #6f42c1; }

.highlight .fm { color: #660; }

.highlight .nn { color: #555; }

.highlight .nt { color: #000080; }

.highlight .nv { color: #008080; }

.highlight .w { color: #bbb; }

.highlight .mf { color: #099; }

.highlight .mh { color: #099; }

.highlight .mi { color: #099; }

.highlight .mo { color: #099; }

.highlight .sb { color: #032f62; }

.highlight .sc { color: #032f62; }

.highlight .sd { color: #032f62; }

.highlight .s2 { color: #032f62; }

.highlight .se { color: #032f62; }

.highlight .sh { color: #032f62; }

.highlight .si { color: #032f62; }

.highlight .sx { color: #032f62; }

.highlight .sr { color: #009926; }

.highlight .s1 { color: #032f62; }

.highlight .ss { color: #990073; }

.highlight .bp { color: #999; }

.highlight .vc { color: #008080; }

.highlight .vg { color: #008080; }

.highlight .vi { color: #008080; }

.highlight .il { color: #099; }

@font-face { font-family: 'Lato'; font-style: normal; font-weight: 400; src: local(""), url("/assets/lato-v20-latin-regular.woff2") format("woff2"), url("/assets/lato-v20-latin-regular.woff") format("woff"); font-display: swap; }

@media print { body { width: 900px; } }

@media print { .no-print { display: none; } }

@media screen { .no-screen { display: none; } }

.no-select { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }

.no-overflow { overflow-wrap: break-word; word-wrap: break-word; -ms-word-break: break-all; word-break: break-all; word-break: break-word; }

img.emoji { height: 1.1em; width: 1.1em; margin: 0 0.05em 0 0.1em; vertical-align: -0.15em; }

.cover-wrapper { display: none; }

@media screen and (max-width: 1200px) { .cover-wrapper { display: block; } }

@media print { .cover-wrapper { display: block; } }

.wide-cover-wrapper { position: relative; z-index: 1; }

@media screen and (max-width: 1200px) { .wide-cover-wrapper { display: none; } }

@media print { .wide-cover-wrapper { display: none; } }

.wide-cover-title-wrapper { position: absolute; bottom: 20px; width: 100%; text-align: center; z-index: 2; }

.wide-cover-title { padding: 10px; display: inline-block; }

.block-toc-wrapper { background: #f4f4f4; margin: 25px 10px 25px 10px; padding-top: 15px; padding-bottom: 1px; border-radius: 5px; display: none; }

@media screen and (max-width: 1500px) { .block-toc-wrapper { display: block; } }

@media print { .block-toc-wrapper { display: block; } }

@media screen and (max-width: 1500px) { .side-toc-reminder { display: none; } }

@media print { .side-toc-reminder { display: none; } }

.side-toc-wrapper { position: -webkit-sticky; position: sticky; top: 10px; margin-top: 15px; float: left; }

@media screen and (max-width: 1500px) { .side-toc-wrapper { display: none; } }

@media print { .side-toc-wrapper { display: none; } }

#table-of-contents a { color: grey; }

a.toc-active { font-weight: bold; }

.frame { position: relative; width: 100%; padding-bottom: 56.25%; margin-bottom: 16px; }

.frame iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

div.social-flex { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-around; align-items: flex-start; align-content: flex-start; }

img.social-logo { width: 60px; padding: 10px; z-index: 1; }

div.social-extra-wrapper { position: relative; }

img.social-extra { width: 24px; position: absolute; top: 55px; left: 55px; z-index: 2; }

table.quote { border: 0; position: relative; left: -5%; width: 105%; margin-bottom: 10px; background: white; }

tr.quote { border: 0; background: white; }

th.quote_bracket { font-family: "Lato"; border: 0; padding: 10px; padding-top: 5px; padding-bottom: 5px; font-weight: 400; font-size: 300%; width: 1%; min-width: 30px; white-space: nowrap; vertical-align: middle; text-align: right; color: #999; background: white; }

th.quote_text { border: 0; padding: 10px; padding-top: 5px; padding-bottom: 5px; font-weight: 400; font-style: italic; color: #555; background: white; }

th.quote_source { border: 0; padding: 10px; padding-top: 5px; padding-bottom: 5px; font-weight: 400; text-align: right; font-size: 87.5%; color: black; background: white; }

th.quote_corner { background: white; }

div.block-note { font-style: italic; border-left: solid 2px #999; color: #555; margin: 20px 0 20px; padding: 0 20px; }

div.side-note-wrapper { position: relative; }

div.side-note { display: block; position: absolute; float: right; height: 170px; width: 170px; right: -220px; font-size: 87.5%; }

.switch { margin-top: -12px; float: right; position: relative; display: inline-block; width: 60px; height: 34px; }

.switch input { opacity: 0; width: 0; height: 0; }

.slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #ddd; -webkit-transition: .4s; transition: .4s; }

.slider:before { position: absolute; content: ""; height: 26px; width: 26px; left: 4px; bottom: 4px; background-color: white; -webkit-transition: .4s; transition: .4s; }

input:checked + .slider { background-color: #cec; }

input:focus + .slider { box-shadow: 0 0 1px #cec; }

input:checked + .slider:before { -webkit-transform: translateX(26px); -ms-transform: translateX(26px); transform: translateX(26px); }

@media screen and (min-width: 600px) { .selectors-wrapper { display: flex; justify-content: center; flex-flow: wrap; float: right; margin-top: -60px; } }

@media screen and (max-width: 600px) { .selectors-wrapper { display: none; } }

.selector-wrapper { display: inline-block; text-align: center; width: 140px; height: 50px; line-height: 50px; }

.selector-wrapper input[type="radio"] { display: none; }

.selector-wrapper label { display: inline-block; width: 130px; height: 40px; line-height: 40px; text-align: center; vertical-align: middle; background: #e5f1ff; color: #000; cursor: pointer; border-radius: 5px; }

.selector-wrapper input[type="radio"]:checked + label { background: #09f; color: #fff; }

/*# sourceMappingURL=main.css.map */