/* Prism Code */

/* PrismJS 1.23.0
https://prismjs.com/download.html#themes=prism-tomorrow&languages=css+css-extras&plugins=line-numbers+inline-color+toolbar+copy-to-clipboard */
/**
 * prism.js tomorrow night eighties for JavaScript, CoffeeScript, CSS and HTML
 * Based on https://github.com/chriskempson/tomorrow-theme
 * @author Rose Pritchard
 */

.dark code[class*="language-"],
.dark pre[class*="language-"] {
	color: #ccc;
}

code[class*="language-"],
pre[class*="language-"] {
	color: hsl(0 0% 20%);
	background: none;
	font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
	font-size: 0.8rem;
	text-align: left;
	white-space: pre;
	word-spacing: normal;
	word-break: normal;
	word-wrap: normal;
	line-height: 1.5;

	-moz-tab-size: 4;
	-o-tab-size: 4;
	tab-size: 4;

	-webkit-hyphens: none;
	-moz-hyphens: none;
	-ms-hyphens: none;
	hyphens: none;

}

/* Code blocks */
pre[class*="language-"] {
	padding:1rem;
	margin: 1rem 0rem;
	overflow: auto;
	outline: transparent;
}

:not(pre)>code[class*="language-"],
pre[class*="language-"] {
	background: hsl(0, 0%, 100%);
}

.dark :not(pre)>code[class*="language-"],
.dark pre[class*="language-"] {
	background: #2d2d2d;
}

/* Inline code */
:not(pre)>code[class*="language-"] {
	padding: .1em;
	white-space: normal;
}

pre {
	height: 100%;
	display: flex;
	flex-direction: column;
	border: 1px solid var(--border);
}

.token.comment,
.token.block-comment,
.token.prolog,
.token.doctype,
.token.cdata {
	color: #999;
}

.dark .token.punctuation {
	color: #ccc;
}

.token-punctuation {
	color: red;
}

.token.tag,
.token.attr-name,
.token.namespace,
.token.deleted {
	color: #e2777a;
}

.token.function-name {
	color: #6196cc;
}

.token.boolean,
.token.number,
.token.function {
	color: hsl(10 100% 50%);
}

.dark .token.boolean,
.dark .token.number,
.dark .token.function {
	color: hsl(20 100% 70%);
}

.token.property,
.token.class-name,
.token.constant,
.token.symbol {
	color: #f8c555;
}

.token.selector,
.token.important,
.token.atrule,
.token.keyword,
.token.builtin {
	color: hsl(280 80% 50%);
}

.dark .token.selector,
.dark .token.important,
.dark .token.atrule,
.dark .token.keyword,
.dark .token.builtin {
	color: hsl(280 80% 80%);
}

.token.string,
.token.char,
.token.attr-value,
.token.regex,
.token.variable {
	color: #7ec699;
}

.token.operator,
.token.entity,
.token.url {
	color: hsl(140 100% 30%);
}

.dark .token.operator,
.dark .token.entity,
.dark .token.url {
	color: hsl(140 100% 80%);
}

.token.important,
.token.bold {
	font-weight: bold;
}

.token.italic {
	font-style: italic;
}

.token.entity {
	cursor: help;
}

.token.inserted {
	color: green;
}

pre[class*="language-"].line-numbers {
	position: relative;
	padding-left: 3.8em;
	counter-reset: linenumber;
}

pre[class*="language-"].line-numbers>code {
	position: relative;
	white-space: inherit;
}

.line-numbers .line-numbers-rows {
	position: absolute;
	pointer-events: none;
	top: 0;
	font-size: 100%;
	left: -3.8em;
	width: 3em;
	/* works for line-numbers below 1000 lines */
	letter-spacing: -1px;
	border-right: 1px solid #999;

	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;

}

.line-numbers-rows>span {
	display: block;
	counter-increment: linenumber;
}

.line-numbers-rows>span:before {
	content: counter(linenumber);
	color: #999;
	display: block;
	padding-right: 0.8em;
	text-align: right;
}

span.inline-color-wrapper {
	/*
    * The background image is the following SVG inline in base 64:
    *
    * <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2">
    *     <path fill="gray" d="M0 0h2v2H0z"/>
    *     <path fill="white" d="M0 0h1v1H0zM1 1h1v1H1z"/>
    * </svg>
    *
    * SVG-inlining explained:
    * https://stackoverflow.com/a/21626701/7595472
    */
	background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyIDIiPjxwYXRoIGZpbGw9ImdyYXkiIGQ9Ik0wIDBoMnYySDB6Ii8+PHBhdGggZmlsbD0id2hpdGUiIGQ9Ik0wIDBoMXYxSDB6TTEgMWgxdjFIMXoiLz48L3N2Zz4=");
	/* This is to prevent visual glitches where one pixel from the repeating pattern could be seen. */
	background-position: center;
	background-size: 110%;

	display: inline-block;
	height: 1.333ch;
	width: 1.333ch;
	margin: 0 .333ch;
	box-sizing: border-box;
	border: 1px solid white;
	outline: 1px solid rgba(0, 0, 0, .5);
	overflow: hidden;
}

span.inline-color {
	display: block;
	/* To prevent visual glitches again */
	height: 120%;
	width: 120%;
}

div.code-toolbar {
	height: 100%;
	position: relative;
}

div.code-toolbar>.toolbar {
	position: absolute;
	top: .3em;
	right: .2em;
	opacity: 1;
}

div.code-toolbar:hover>.toolbar {
	opacity: 1;
}

/* Separate line b/c rules are thrown out if selector is invalid.
    IE11 and old Edge versions don't support :focus-within. */
div.code-toolbar:focus-within>.toolbar {
	opacity: 1;
}

div.code-toolbar>.toolbar .toolbar-item {
	display: inline-block;
}

div.code-toolbar>.toolbar a {
	cursor: pointer;
}

div.code-toolbar>.toolbar button {
	background: none;
	border: 0;
	color: inherit;
	font: inherit;
	line-height: normal;
	overflow: visible;
	padding: 0;
	-webkit-user-select: none;
	/* for button */
	-moz-user-select: none;
	-ms-user-select: none;
}

div.code-toolbar>.toolbar a,
div.code-toolbar>.toolbar button {
	color: #bbb;
	font-size: 1rem;
	padding: 0.5rem;
	font-family: sans-serif;
	background: hsl(0, 0%, 25%);
	outline: transparent;
	cursor: pointer;
}

div.code-toolbar>.toolbar a:hover,
div.code-toolbar>.toolbar a:focus,
div.code-toolbar>.toolbar button:hover,
div.code-toolbar>.toolbar button:focus,
div.code-toolbar>.toolbar span:hover,
div.code-toolbar>.toolbar span:focus {
	background: hsl(0, 0%, 40%);
	text-decoration: none;
}