body {
/*
	text-align: center;
	font-family: Verdana, Arial, Helvetica, sans-serif;
*/
	background-color: #191b1f;
/*
	font-size: 12px;
	margin: 0px auto;
	padding: 0px;
*/
}

html {
	overflow-y: scroll;
	overflow: -moz-scrollbars-vertical;
}

/*
div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, textarea, input, p, blockquote, table, tr, th, td {
	margin: 0px; 
	padding: 0px;
    -webkit-margin-before: 0px;
    -webkit-margin-after: 0px;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
}
*/

a {
	color: #395B82;
}

a:hover {
	/*background-position: 0px 0px;*/
}

ul, li {
	list-style-type: none;
}

a:focus, li:focus {
	outline: none;
}

em {
	color: #BE5232;
	font-style: normal;
    font-weight: normal;
}

/*
div {
	display: block;
}

div p, table, ul {
	color: #606060;
	font-size: 10px;
}


table {
	font-size: 12px;
}

form, fieldset, img {
	border: none;
}
*/

div.center, p.center, table td.center {
    text-align: center;
}

div.justify, p.justify, table td.justify {
    text-align: justify;
}

div.center div, div.center p, div.center table, div.center form {
    text-align: left; margin-left: auto; margin-right: auto;
}

obfuscate-email::after {
	content: attr(data-domain);
}

obfuscate-email::before {
	content: attr(data-user) "\0040";
}

.opacity-blur {
	-webkit-filter: blur(5px);
	-moz-filter: blur(5px);
    -ms-filter: blur(5px);
    -o-filter: blur(5px);
	filter: blur(5px);
}

.opacity-blur-clear {
	-webkit-filter: blur(0px);
	-moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
	filter: blur(0px);
}

.flex-container {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-content: center;
    -ms-flex-line-pack: center;
    align-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

[class*="col-"], div[role="main"] {
	text-align: center;
}

div#container {
	background-color: #f9f9f9;
    position: absolute;
    top: 0;
    width: 100%;
}

div#container > footer {
	display: block;
	background-color: #1c1f23;
}

div#container div#navbar > div {
    background: transparent url("../images/navbar.png") repeat-x scroll left top;
    height: 63px;
    transition-duration: 0.3s;
    transition-property: background-color, color;
    transition-timing-function: ease-out;
}

div#container div#navbar > div:hover {
	background-color: #ffcc33;
	background-image: none;
}

div#container div#navbar > [class*="col-sm"] {
    padding: 0px;
}

hr.line-separator, hr.line-separator-blue, hr.line-separator-orange, hr.line-separator-yellow {
	height: 3px;
	margin: 15px auto 20px;
	padding: 0;
	text-align: center;
	border: none;
}

hr.line-separator-blue, div.blue hr.line-separator {
	background: rgba(0, 0, 0, 0) url("../images/line-separator-blue.png") no-repeat scroll center top;
}

hr.line-separator-orange, div.orange hr.line-separator {
	background: rgba(0, 0, 0, 0) url("../images/line-separator-orange.png") no-repeat scroll center top;
}

hr.line-separator-yellow, div.yellow hr.line-separator {
	background: rgba(0, 0, 0, 0) url("../images/line-separator-yellow.png") no-repeat scroll center top;
}

sup {
    bottom: 1ex;
}

sup, sub {
    font-size: 10px;
    height: 0;
    line-height: 1;
    position: relative;
    vertical-align: baseline;
}

div#container div#banner.slim {
	min-height: 220px;
}

div#container div#banner {
	min-height: 350px;
    width: 100%;
	margin-top: 57px;
    background-color: #727272;																		/* For browsers that do not support gradients */
	background: transparent -webkit-linear-gradient(bottom, #494949 0px, #727272 100%) repeat-x;	/* For Safari 5.1 to 6.0 */
    background: transparent -o-linear-gradient(bottom, #494949 0px, #727272 100%) repeat-x;			/* For Opera 11.1 to 12.0 */
    background: transparent -moz-linear-gradient(bottom, #494949 0px, #727272 100%) repeat-x;		/* For Firefox 3.6 to 15 */
    background: transparent linear-gradient(bottom, #494949 0px, #727272 100%) repeat-x;			/* Standard syntax */
}

div#container div#banner .caption {
	text-align: center;
	width: 100%;
	left: 0px;
	right: 0px;
	color: white;
    padding: 4% 5px 25px 5px;
    position: relative;
    right: 0;
}

div#container div#banner .caption a {
   margin-top: 40px;
}

div#container div#banner .caption h1 strong {
	color: #7e9ac6;
}

div#container div.php#banner .caption h1 strong {
	color: #8a9fe0;
}

div#container div.aspnet#banner .caption h1 strong {
	color: #00adef;
}

div#container div.aspnetcore#banner .caption h1 strong {
    color: #b26dde;
}

div#container div.java#banner .caption h1 strong {
    color: #ffa553;
}

div#container div.marketing#banner .caption h1 strong {
	color: #ff9637;
}

div#container div.email#banner .caption h1 strong {
	color: #ffff66;
}

div#container div.svn#banner .caption h1 strong {
	color: #7e9ac6;
}

div#container div#banner.database {
	/* background-image: linear-gradient(to bottom, #171a53, transparent); */
	background: #33355b none;
}

div#container div#banner .caption h1, div#container div#banner .caption h2 {
	text-shadow: 0 5px 2px rgba(0, 0, 0, 0.6);
	word-wrap: break-word;
}

div#container div#banner .caption h1 {
	font-size: 5.5em;
}

div#container div#banner.database .caption h1 {
	font-size: 4.5em;
}

div#container div#banner .caption h2 {
	font-size: 1.5em;
}

@media screen and (max-width: 640px) {

	div#container div#banner .caption h1 {
		font-size: 3.4em !important;
	}

}

div#container div#banner #banner {
/*
	-webkit-filter: grayscale(80%);
	-moz-filter: grayscale(80%);
    -ms-filter: grayscale(80%);
    -o-filter: grayscale(80%);
	filter: grayscale(80%);
	opacity: 0.9;
*/
    max-width: 100%;
	min-width: 1500px;
	height: 400px;
    position: absolute;
    z-index: 0;
	top: 58px;
}

.text-center {
	text-align: center !important;
}

.text-justify {
	text-align: justify !important;
}

.text-left {
	text-align: left !important;
}

.text-right {
	text-align: right !important;
}

.text-bold {
    font-weight: bold !important;
}

.nopadding {
	padding: 0px !important;
}


/*
.col-(@numCols, @colIdx) {
	width: (100% / @numCols) * @colIdx;
	float: left;
}
*/

.col-5 .col-xs-1 { width: 20%; }
.col-5 .col-xs-2 { width: 40%; }
.col-5 .col-xs-3 { width: 60%; }
.col-5 .col-xs-4 { width: 80%; }
.col-5 .col-xs-5 { width: 100%; }
@media (min-width: 768px) {
	.col-5 .col-sm-1 { width: 20%; }
	.col-5 .col-sm-2 { width: 40%; }
	.col-5 .col-sm-3 { width: 60%; }
	.col-5 .col-sm-4 { width: 80%; }
	.col-5 .col-sm-5 { width: 100%; }
}
@media (min-width: 992px) {
    .col-5 .col-md-1 { width: 20%; }
    .col-5 .col-md-2 { width: 40%; }
    .col-5 .col-md-3 { width: 60%; }
    .col-5 .col-md-4 { width: 80%; }
    .col-5 .col-md-5 { width: 100%; }
}
@media (min-width: 1200px) {
    .col-5 .col-lg-1 { width: 20%; }
    .col-5 .col-lg-2 { width: 40%; }
    .col-5 .col-lg-3 { width: 60%; }
    .col-5 .col-lg-4 { width: 80%; }
    .col-5 .col-lg-5 { width: 100%; }
}

@media (max-width: 479px) {
	.mobile-hide { display: none !important; }
}

@media (min-width: 768px) {
	.desktop-hide { display: none !important; }
}

.uppercase {
	text-transform: uppercase;	
}

.hidden {
	display: none !important;
}

em {
	color: #950000;
}

div.error {
    margin-top: 5px;
    margin-bottom: 30px;
    text-align: center;
}

label.error {
	color: #973218;
    display: none;
	display: inline;
}

label.success {
    margin-left: 5px;
    padding-left: 20px;
	position: absolute;
	display: inline;
}

input.error, textarea.error, select.error {
    border: 1px solid #FF934E;
    background-color: #FFE19D;
}

.ajax-loader {
	background-image: url("../images/ajax-loader.svg");
    background-repeat: no-repeat;
    background-size: 27px;
    width: 27px;
    height: 100%;
    position: absolute;
    top: 6px;
    right: -40px;
    border: none;
    display: none;
}

#waiting {
	display: none;
	vertical-align: middle;
	text-align: center;
	background: transparent url("../images/ajax-loader.svg") no-repeat center center;
    background-size: 96px;
	width: 96px;
	height: 96px;
	color: #3E3E3E;
	font-family: Arial, "Franklin Gothic Medium", Verdana, sans-serif;
	font-weight: bold;
	font-size: 14px;
	margin-left: 45%;
    margin-top: 22%;
	position: fixed;
	z-index: 10002;
}

#overlay {
	display: none;
	background-color: #F2F2F2;
	opacity: 0.6;
	-moz-opacity: 0.6;
	filter:	alpha(opacity=60);
	position: fixed;
	height: 100%;
	width: 100%;
	left: 0px;
	top: 0px;
	position: fixed;
	z-index: 10001;
}

.alert {
	padding: 10px;
	text-align: left;
}

.alert .icon {
    display: inline-block;
    font: normal normal normal 16px/1 FontAwesome;
    font-size: inherit;
}

.alert .icon-external-link:before {
	margin-left: 5px;
    content: "\f08e";
}

.alert-warning {
    color: #a37432;
    background: #fbf8f3;
    border-color: #e9d5b8;
	margin-top: 20px;
	margin-bottom: 0px;
}

.alert-error {
    color: #d2173c;
    background: #fbf8f3;
    border-color: #feb1a9;
}

.col-centered {
    float: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.strikethrough-font {
	text-decoration: line-through;
}

.col-0-5 {
	flex: 0 0 4.166666665%;
	max-width: 4.166666665%;
	display: inline-block;
	position: relative;
	width: 100%;
	min-height: 1px;
	padding-right: 15px;
	padding-left: 15px;
}

.col-1-5 {
	flex: 0 0 12.499999995%;
	max-width: 12.499999995%;
	display: inline-block;
	position: relative;
	width: 100%;
	min-height: 1px;
	padding-right: 15px;
	padding-left: 15px;
}

.col-2-5 {
	flex: 0 0 20.8333325%;
	max-width: 20.8333325%;
	display: inline-block;
	position: relative;
	width: 100%;
	min-height: 1px;
	padding-right: 15px;
	padding-left: 15px;
}

@media (min-width:576px) {

	.col-md-0-5 {
		flex: 0 0 4.166666665%;
		max-width: 4.166666665%;
		display: inline-block;
		position: relative;
		width: 100%;
		min-height: 1px;
		padding-right: 15px;
		padding-left: 15px;
	}

	.col-md-1-5 {
		flex: 0 0 12.499999995%;
		max-width: 12.499999995%;
		display: inline-block;
		position: relative;
		width: 100%;
		min-height: 1px;
		padding-right: 15px;
		padding-left: 15px;
	}

	.col-md-2-5 {
		flex: 0 0 20.8333325%;
		max-width: 20.8333325%;
		display: inline-block;
		position: relative;
		width: 100%;
		min-height: 1px;
		padding-right: 15px;
		padding-left: 15px;
	}

}