/* http://prismjs.com/download.html?themes=prism-coy&languages=markup+css+clike+javascript+apacheconf+bash+c+cpp+java+markdown+perl+php+sql&plugins=line-highlight+line-numbers */
/**
 * prism.js Coy theme for JavaScript, CoffeeScript, CSS and HTML
 * Based on https://github.com/tshedor/workshop-wp-theme (Example: http://workshop.kansan.com/category/sessions/basics or http://workshop.timshedor.com/category/sessions/basics);
 * @author Tim  Shedor
 */

code[class*="language-"],
pre[class*="language-"] 
{
	color: black;
	font-family: Consolas, Monaco, 'Andale Mono', monospace;
	direction: ltr;
	text-align: left;
	white-space: pre;
	word-spacing: normal;
	word-break: 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-"] 
{
	position: relative;
	margin: .5em 0;
	-webkit-box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf;
	   -moz-box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf;
	        box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf;
	border-left: 10px solid #358ccb;
	background-color: #fdfdfd;
	background-image: -webkit-linear-gradient(transparent 50%, rgba( 69, 142, 209, 0.04 ) 50%);
	background-image:    -moz-linear-gradient(transparent 50%, rgba( 69, 142, 209, 0.04 ) 50%);
	background-image:     -ms-linear-gradient(transparent 50%, rgba( 69, 142, 209, 0.04 ) 50%);
	background-image:      -o-linear-gradient(transparent 50%, rgba( 69, 142, 209, 0.04 ) 50%);
	background-image: linear-gradient(transparent 50%, rgba( 69, 142, 209, 0.04 ) 50%);
	background-size: 3em 3em;
	background-origin: content-box;
	overflow: visible;
	max-height: 30em;
}

code[class*="language"] 
{
	max-height: inherit;
	height: 100%;
	padding: 0 1em;
	display: block;
	overflow: auto;
}

/* Margin bottom to accomodate shadow */
:not(pre) > code[class*="language-"],
pre[class*="language-"] 
{
	background-color: #fdfdfd;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	margin-bottom: 1em;
}

/* Inline code */
:not(pre) > code[class*="language-"] 
{
	position: relative;
	padding: .2em;
	-webkit-border-radius: 0.3em;
	   -moz-border-radius: 0.3em;
	    -ms-border-radius: 0.3em;
	     -o-border-radius: 0.3em;
	        border-radius: 0.3em;
	color: #c92c2c;
	border: 1px solid rgba(0, 0, 0, 0.1);
}

pre[class*="language-"]:before,
pre[class*="language-"]:after 
{
	content: '';
	z-index: -2;
	display: block;
	position: absolute;
	bottom: 0.75em;
	left: 0.18em;
	width: 40%;
	height: 20%;
	-webkit-box-shadow: 0px 13px 8px #979797;
	   -moz-box-shadow: 0px 13px 8px #979797;
	        box-shadow: 0px 13px 8px #979797;
	-webkit-transform: rotate( -2deg );
	   -moz-transform: rotate( -2deg );
	    -ms-transform: rotate( -2deg );
	     -o-transform: rotate( -2deg );
	        transform: rotate( -2deg );
}

:not(pre) > code[class*="language-"]:after,
pre[class*="language-"]:after 
{
	right: 0.75em;
	left: auto;
	-webkit-transform: rotate( 2deg );
	   -moz-transform: rotate( 2deg );
	    -ms-transform: rotate( 2deg );
	     -o-transform: rotate( 2deg );
	        transform: rotate( 2deg );
}

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

.token.punctuation 
{
	color: #5F6364;
}

.token.property,
.token.tag,
.token.boolean,
.token.number,
.token.function-name,
.token.constant,
.token.symbol,
.token.deleted 
{
	color: #c92c2c;
}

.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.function,
.token.builtin,
.token.inserted 
{
	color: #2f9c0a;
}

.token.operator,
.token.entity,
.token.url,
.token.variable 
{
	color: #a67f59;
	background: rgba( 255, 255, 255, 0.5 );
}

.token.atrule,
.token.attr-value,
.token.keyword,
.token.class-name 
{
	color: #1990b8;
}

.token.regex,
.token.important 
{
	color: #e90;
}

.language-css .token.string,
.style .token.string 
{
	color: #a67f59;
	background: rgba( 255, 255, 255, 0.5 );
}

.token.important 
{
	font-weight: normal;
}

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

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

.token.entity 
{
	cursor: help;
}

.namespace 
{
	opacity: .7;
}

@media screen and (max-width: 767px) 
{
	pre[class*="language-"]:before,
	pre[class*="language-"]:after 
	{
		bottom: 14px;
		-webkit-box-shadow: none;
		   -moz-box-shadow: none;
		        box-shadow: none;
	}

}

/* Plugin styles */
.token.tab:not(:empty):before,
.token.cr:before,
.token.lf:before 
{
	color: #e0d7d1;
}

/* Plugin styles: Line Numbers */
pre[class*="language-"].line-numbers 
{
	padding-left: 0;
}

pre[class*="language-"].line-numbers code 
{
	padding-left: 3.8em;
}

pre[class*="language-"].line-numbers .line-numbers-rows 
{
	left: 0;
}

/* Plugin styles: Line Highlight */
pre[class*="language-"][data-line] 
{
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 0;
}

pre[data-line] code 
{
	position: relative;
	padding-left: 4em;
}

pre .line-highlight 
{
	margin-top: 0;
}

pre[data-line] 
{
	position: relative;
	padding: 1em 0 1em 3em;
}

.line-highlight 
{
	position: absolute;
	left: 0;
	right: 0;
	padding: inherit 0;
	margin-top: 1em; /* Same as .prism’s padding-top */

	background: hsla(24, 20%, 50%,.08);
	background: -webkit-linear-gradient(left, hsla(24, 20%, 50%,.1) 70%, hsla(24, 20%, 50%,0));
	background:    -moz-linear-gradient(left, hsla(24, 20%, 50%,.1) 70%, hsla(24, 20%, 50%,0));
	background:      -o-linear-gradient(left, hsla(24, 20%, 50%,.1) 70%, hsla(24, 20%, 50%,0));
	background: linear-gradient(left, hsla(24, 20%, 50%,.1) 70%, hsla(24, 20%, 50%,0));
	
	pointer-events: none;
	
	line-height: inherit;
	white-space: pre;
}

.line-highlight:before,
.line-highlight[data-end]:after 
{
	content: attr(data-start);
	position: absolute;
	top: .4em;
	left: .6em;
	min-width: 1em;
	padding: 0 .5em;
	background-color: hsla( 24, 20%, 50%,.4 );
	color: hsl( 24, 20%, 95% );
	font: bold 65%/1.5 sans-serif;
	text-align: center;
	vertical-align: .3em;
	border-radius: 999px;
	text-shadow: none;
	box-shadow: 0 1px white;
}

.line-highlight[data-end]:after 
{
	content: attr(data-end);
	top: auto;
	bottom: .4em;
}

pre.line-numbers 
{
	position: relative;
	padding-left: 3.8em;
	counter-reset: linenumber;
}

pre.line-numbers > code 
{
	position: relative;
}

.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 
{
	pointer-events: none;
	display: block;
	counter-increment: linenumber;
}

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