html {
	font-family: sans-serif;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%
}

body {
	margin: 0
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block
}

audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: baseline
}

audio:not([controls]) {
	display: none;
	height: 0
}

[hidden],
template {
	display: none
}

a {
	background-color: transparent
}

a:active,
a:hover {
	outline: 0
}

abbr[title] {
	border-bottom: 1px dotted
}

b,
strong {
	font-weight: 700
}

dfn {
	font-style: italic
}

h1 {
	font-size: 2em;
	margin: .67em 0
}

mark {
	background: #ff0;
	color: #000
}

small {
	font-size: 80%
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline
}

sup {
	top: -.5em
}

sub {
	bottom: -.25em
}

img {
	border: 0
}

svg:not(:root) {
	overflow: hidden
}

figure {
	margin: 1em 40px
}

hr {
	box-sizing: content-box;
	height: 0
}

pre {
	overflow: auto
}

code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
	font-size: 1em
}

button,
input,
optgroup,
select,
textarea {
	color: inherit;
	font: inherit;
	margin: 0
}

button {
	overflow: visible
}

button,
select {
	text-transform: none
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
	-webkit-appearance: button;
	cursor: pointer
}

button[disabled],
html input[disabled] {
	cursor: default
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0
}

input {
	line-height: normal
}

input[type=checkbox],
input[type=radio] {
	box-sizing: border-box;
	padding: 0
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
	height: auto
}

input[type=search] {
	-webkit-appearance: textfield;
	box-sizing: content-box
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
	-webkit-appearance: none
}

fieldset {
	border: 1px solid silver;
	margin: 0 2px;
	padding: .35em .625em .75em
}

legend {
	border: 0;
	padding: 0
}

textarea {
	overflow: auto
}

optgroup {
	font-weight: 700
}

table {
	border-collapse: collapse;
	border-spacing: 0
}

td,
th {
	padding: 0
}

.highlight table td {
	padding: 5px
}

.highlight table pre {
	margin: 0
}

.highlight .cm {
	color: #998;
	font-style: italic
}

.highlight .cp {
	color: #999;
	font-weight: 700
}

.highlight .c1 {
	color: #998;
	font-style: italic
}

.highlight .cs {
	color: #999;
	font-weight: 700;
	font-style: italic
}

.highlight .c,
.highlight .cd {
	color: #998;
	font-style: italic
}

.highlight .err {
	color: #a61717;
	background-color: #e3d2d2
}

.highlight .gd {
	color: #000;
	background-color: #fdd
}

.highlight .ge {
	color: #000;
	font-style: italic
}

.highlight .gr {
	color: #a00
}

.highlight .gh {
	color: #999
}

.highlight .gi {
	color: #000;
	background-color: #dfd
}

.highlight .go {
	color: #888
}

.highlight .gp {
	color: #555
}

.highlight .gs {
	font-weight: 700
}

.highlight .gu {
	color: #aaa
}

.highlight .gt {
	color: #a00
}

.highlight .kc {
	color: #000;
	font-weight: 700
}

.highlight .kd {
	color: #000;
	font-weight: 700
}

.highlight .kn {
	color: #000;
	font-weight: 700
}

.highlight .kp {
	color: #000;
	font-weight: 700
}

.highlight .kr {
	color: #000;
	font-weight: 700
}

.highlight .kt {
	color: #458;
	font-weight: 700
}

.highlight .k,
.highlight .kv {
	color: #000;
	font-weight: 700
}

.highlight .mf {
	color: #099
}

.highlight .mh {
	color: #099
}

.highlight .il {
	color: #099
}

.highlight .mi {
	color: #099
}

.highlight .mo {
	color: #099
}

.highlight .m,
.highlight .mb,
.highlight .mx {
	color: #099
}

.highlight .sb {
	color: #d14
}

.highlight .sc {
	color: #d14
}

.highlight .sd {
	color: #d14
}

.highlight .s2 {
	color: #d14
}

.highlight .se {
	color: #d14
}

.highlight .sh {
	color: #d14
}

.highlight .si {
	color: #d14
}

.highlight .sx {
	color: #d14
}

.highlight .sr {
	color: #009926
}

.highlight .s1 {
	color: #d14
}

.highlight .ss {
	color: #990073
}

.highlight .s {
	color: #d14
}

.highlight .na {
	color: teal
}

.highlight .bp {
	color: #999
}

.highlight .nb {
	color: #0086b3
}

.highlight .nc {
	color: #458;
	font-weight: 700
}

.highlight .no {
	color: teal
}

.highlight .nd {
	color: #3c5d5d;
	font-weight: 700
}

.highlight .ni {
	color: purple
}

.highlight .ne {
	color: #900;
	font-weight: 700
}

.highlight .nf {
	color: #900;
	font-weight: 700
}

.highlight .nl {
	color: #900;
	font-weight: 700
}

.highlight .nn {
	color: #555
}

.highlight .nt {
	color: navy
}

.highlight .vc {
	color: teal
}

.highlight .vg {
	color: teal
}

.highlight .vi {
	color: teal
}

.highlight .nv {
	color: teal
}

.highlight .ow {
	color: #000;
	font-weight: 700
}

.highlight .o {
	color: #000;
	font-weight: 700
}

.highlight .w {
	color: #bbb
}

.highlight {
	background-color: #f8f8f8
}

* {
	box-sizing: border-box
}

body {
	padding: 0;
	margin: 0;
	font-family: open sans, helvetica neue, Helvetica, Arial, sans-serif;
	font-size: 16px;
	line-height: 1.5;
	color: #606c71
}

a {
	color: #1e6bb8;
	text-decoration: none
}

a:hover {
	text-decoration: underline
}

.btn {
	display: inline-block;
	margin-bottom: 1rem;
	color: rgba(255, 255, 255, .7);
	background-color: rgba(255, 255, 255, .08);
	border-color: rgba(255, 255, 255, .2);
	border-style: solid;
	border-width: 1px;
	border-radius: .3rem;
	transition: color .2s, background-color .2s, border-color .2s
}

.btn:hover {
	color: rgba(255, 255, 255, .8);
	text-decoration: none;
	background-color: rgba(255, 255, 255, .2);
	border-color: rgba(255, 255, 255, .3)
}

.btn+.btn {
	margin-left: 1rem
}

@media screen and (min-width:64em) {
	.btn {
		padding: .75rem 1rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.btn {
		padding: .6rem .9rem;
		font-size: .9rem
	}
}

@media screen and (max-width:42em) {
	.btn {
		display: block;
		width: 100%;
		padding: .75rem;
		font-size: .9rem
	}

	.btn+.btn {
		margin-top: 1rem;
		margin-left: 0
	}
}

/* .page-header {
	color: #fff;
	text-align: center;
	background-color: #159957;
	background-image: linear-gradient(120deg, #1559E7, #15999D)
} */

@media screen and (min-width:64em) {
	.page-header {
		padding: 5rem 6rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.page-header {
		padding: 3rem 4rem
	}
}

@media screen and (max-width:42em) {
	.page-header {
		padding: 2rem 1rem
	}
}

.project-name {
	margin-top: 0;
	margin-bottom: .1rem
}

@media screen and (min-width:64em) {
	.project-name {
		font-size: 3.25rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.project-name {
		font-size: 2.25rem
	}
}

@media screen and (max-width:42em) {
	.project-name {
		font-size: 1.75rem
	}
}

.project-tagline {
	margin-bottom: 2rem;
	font-weight: 400;
	opacity: .7
}

@media screen and (min-width:64em) {
	.project-tagline {
		font-size: 1.25rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.project-tagline {
		font-size: 1.15rem
	}
}

@media screen and (max-width:42em) {
	.project-tagline {
		font-size: 1rem
	}
}

.main-content {
	word-wrap: break-word
}

.main-content :first-child {
	margin-top: 0
}

@media screen and (min-width:64em) {
	.main-content {
		max-width: 64rem;
		padding: 2rem 6rem;
		margin: 0 auto;
		font-size: 1.1rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.main-content {
		padding: 2rem 4rem;
		font-size: 1.1rem
	}
}

@media screen and (max-width:42em) {
	.main-content {
		padding: 2rem 1rem;
		font-size: 1rem
	}
}

.main-content img {
	max-width: 100%
}

.main-content h1,
.main-content h2,
.main-content h3,
.main-content h4,
.main-content h5,
.main-content h6 {
	margin-top: 1.5rem;
	margin-bottom: 1rem;
	font-weight: 400;
	color: #159957
}

.main-content p {
	margin-bottom: 1em
}

.main-content code {
	padding: 2px 4px;
	font-family: Consolas, liberation mono, Menlo, Courier, monospace;
	font-size: .9rem;
	color: #567482;
	background-color: #f3f6fa;
	border-radius: .3rem
}

.main-content pre {
	padding: .8rem;
	margin-top: 0;
	margin-bottom: 1rem;
	font: 1rem Consolas, liberation mono, Menlo, Courier, monospace;
	color: #567482;
	word-wrap: normal;
	background-color: #f3f6fa;
	border: solid 1px #dce6f0;
	border-radius: .3rem
}

.main-content pre>code {
	padding: 0;
	margin: 0;
	font-size: .9rem;
	color: #567482;
	word-break: normal;
	white-space: pre;
	background: 0 0;
	border: 0
}

.main-content .highlight {
	margin-bottom: 1rem
}

.main-content .highlight pre {
	margin-bottom: 0;
	word-break: normal
}

.main-content .highlight pre,
.main-content pre {
	padding: .8rem;
	overflow: auto;
	font-size: .9rem;
	line-height: 1.45;
	border-radius: .3rem;
	-webkit-overflow-scrolling: touch
}

.main-content pre code,
.main-content pre tt {
	display: inline;
	max-width: initial;
	padding: 0;
	margin: 0;
	overflow: initial;
	line-height: inherit;
	word-wrap: normal;
	background-color: transparent;
	border: 0
}

.main-content pre code:before,
.main-content pre code:after,
.main-content pre tt:before,
.main-content pre tt:after {
	content: normal
}

.main-content ul,
.main-content ol {
	margin-top: 0
}

.main-content blockquote {
	padding: 0 1rem;
	margin-left: 0;
	color: #819198;
	border-left: .3rem solid #dce6f0;
	quotes: "\201C""\201D";
}
.main-content blockquote p {
	display: flex;
	flex-direction: column;
	gap: 0.5em;
}

.main-content blockquote>:first-child {
	margin-top: 0
}

.main-content blockquote>:last-child {
	margin-bottom: 0
}

.main-content table {
	display: block;
	width: 100%;
	overflow: auto;
	word-break: normal;
	word-break: keep-all;
	-webkit-overflow-scrolling: touch
}

.main-content table th {
	font-weight: 700
}

.main-content table th,
.main-content table td {
	padding: .5rem 1rem;
	border: 1px solid #e9ebec
}

.main-content dl {
	padding: 0
}

.main-content dl dt {
	padding: 0;
	margin-top: 1rem;
	font-size: 1rem;
	font-weight: 700
}

.main-content dl dd {
	padding: 0;
	margin-bottom: 1rem
}

.main-content hr {
	height: 2px;
	padding: 0;
	margin: 1rem 0;
	background-color: #eff0f1;
	border: 0
}

.site-footer {
	padding-top: 2rem;
	margin-top: 2rem;
	border-top: solid 1px #eff0f1
}

@media screen and (min-width:64em) {
	.site-footer {
		font-size: 1rem
	}
}

@media screen and (min-width:42em) and (max-width:64em) {
	.site-footer {
		font-size: 1rem
	}
}

@media screen and (max-width:42em) {
	.site-footer {
		font-size: .9rem
	}
}

.site-footer-owner {
	display: block;
	font-weight: 700
}

.site-footer-credits {
	color: #819198
}

h4 span {
	font-size: 0.9em;
	margin-left: 5px;
	color: #999;
	font-weight: 400;
}

.site-footer-credits a {
	color: #819198;
}

section div {
	margin-bottom: 30px;
}

.highlighter-rouge {
	margin-bottom: 20px;
}

@font-face {
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 400;
	src: local('Open Sans Regular'), local('OpenSans-Regular'), url(https://gstatic.loli.net/s/opensans/v15/mem8YaGs126MiZpBA-UFVZ0e.ttf) format('truetype');
}

@font-face {
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 700;
	src: local('Open Sans Bold'), local('OpenSans-Bold'), url(https://gstatic.loli.net/s/opensans/v15/mem5YaGs126MiZpBA-UN7rgOUuhs.ttf) format('truetype');
}