/* -------------------- Clearfix and Border Setup -------------------- */
.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}
.clearfix:after {
    clear: both;
}
.clearfix {
    *zoom: 1;
}
*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/* -------------------- Text and Fonts -------------------- */
body {
	font-family: 'Roboto', sans-serif;
	background: rgb(242,243,246);
}
.headings_container{
	padding-bottom: 10px;
}
.headings_underline {
    position: absolute;
	margin-top: -4px;
    width: calc(100% - 40px);
	width: -moz-calc(100% - 40px);
	width: -webkit-calc(100% - 40px);
	height: 0;
	border-bottom: 4px solid rgba(0,0,0,0.1);
}
h1 {
	font-family: 'Roboto', sans-serif;
	font-size: 30pt;
	font-weight: 300;
	color: rgb(43,43,43);
	border-bottom: 4px solid rgb(25,168,199);
	display: inline-block;
    padding-bottom: 6px;
    margin-bottom: 0;
}
h2 {
	font-size: 20pt;
	font-weight: 100;	
}
h3 {
	font-size: 13pt;
	font-weight: 400;	
}
h4 {
	font-size: 8pt;
	font-weight: 400;
	margin: 0;
	margin-left: 3px;
}
p {
	font-size: 13pt;
	font-weight: 300;	
}
ul {
	font-size: 13pt;
	font-weight: 300;
	list-style-type: square;
}
ul a{
	color: #000;
	text-decoration: underline;
}
hr {
	border: 0;
	height: 1px;
	background: rgb(43,43,43);
}
footer a {
	font-weight: 300;	
	color: rgb(200,200,200);
	text-decoration: none;
}
/* -------------------- Main Page Layout -------------------- */
html, body {
	margin: 0;
	padding: 0;
	height: 100%;
}
.res_width {
	width: calc(100% - 20px);
	width: -moz-calc(100% - 20px);
	width: -webkit-calc(100% - 20px);
	max-width: 1300px;
	margin: 0 auto;
}
#wrapper {
	min-height: 100%;
	position: relative;
}

#content {
	padding: 0px 20px 70px 20px;
	background: #fff;
	border: 1px solid rgb(230,230,230);
 	position:relative;
}

.transition {	
	transition: 0.1s ease-in-out;
	-moz-transition: 0.1s ease-in-out;
	-webkit-transition: 0.1s ease-in-out;
}

/* -------------------- Notifications -------------------- */
.notification_size {
	width: calc (100% - 20px);
	width: -moz-calc (100% - 20px);
	width: -webkit-calc (100% - 20px);
	padding: 10px;
	font-size: 12pt;
	font-weight: 300;
	margin: 20px 0px 20px 0px;
}
.notification_info {
	background: rgb(218,236,251);
	border-left: 5px solid rgb(32,120,201);
}
.notification_success {
	background: rgb(239,254,185);
	border-left: 5px solid rgb(154,198,1);
}
.notification_warning {
	background: rgb(255,234,169);
	border-left: 5px solid rgb(249,181,22);
}
.notification_error {
	background: rgb(252,202,195);
	border-left: 5px solid rgb(219,63,35);
}
.notification_grey {
	background: rgb(242,242,242);
	border-left: 5px solid rgb(170,170,170);
}

/* -------------------- Quotes -------------------- */

blockquote {
	background: hsla(0, 0%, 34%, 0.05);
	border: 1px solid hsla(0, 0%, 34%, 0.05);
	quotes: "\201C" "\201D";
}
blockquote:before {
	font: bold 65px/1px Times, serif;
	color: rgb(25,168,199);
	position: absolute;
}
blockquote:before {
	content:open-quote;
	margin:35px 0 0 15px;
}
blockquote p {	
	font-size: 11pt;
}
.quote {
	font-style: italic;
	margin: 20px 20px 0 60px;
}
.quotee {
	text-align: right;
	margin-right: 40px;
}

/* -------------------- Navigation -------------------- */
nav {
	width: 100%;
	background: rgb(43,43,43);
	font-size: 13pt;
	font-weight: 300;
	position: relative;
}
nav ul {
	padding: 0;
	margin: 0 auto;
	width: 601px;
}
nav li {
	display: inline;
	float: left;
}
nav a {
	color: #fff;
	display: inline-block;
	text-align: center;
	text-decoration: none;
	line-height: 68px;
	padding: 5px 25px 5px 25px;
}
nav li a {
	border-right: 1px solid rgb(100,100,100);
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
nav li:last-child a {
	border-right: 0;
}
nav a:hover, nav a:active {
	background: rgb(25,168,199);
}
nav a#pull {
	display: none;
}
nav img {
	margin: 0px 0px -19px 0px; 
	height: 50px;
}
/*Styles for screen 600px and lower*/
@media screen and (max-width: 614px) {
	nav { 
  		height: auto;
  	}
  	nav ul {
  		width: 100%;
  		display: block;
  		height: auto;
  	}
  	nav li {
  		width: 50%;
  		float: left;
  		position: relative;
  	}
  	nav li a {
		border-bottom: 1px solid rgb(100,100,100);
		border-right: 1px solid rgb(100,100,100);
	}
  	nav a {
	  	text-align: left;
	  	width: 100%;
	  	text-indent: 25px;
		padding: 0px 0px 0px 0px;
  	}
  	.flex-direction-nav a {  		
    	visibility: none;
  	}
}
/*Styles for screen 515px and lower*/
@media only screen and (max-width : 480px) {
	.res_width {
		width: 100%;
	}
	nav {
		border-bottom: 0;
	}
	nav ul {
		display: none;
		height: auto;
	}
	nav a#pull {
		display: block;
		background: rgb(60,60,60);
		width: 100%;
		position: relative;
	}
	nav a#pull:after {
		content:"";
		background: url('../images/nav-icon.svg') no-repeat;
		width: 42px;
		height: 42px;
		display: inline-block;
		position: absolute;
		right: 25px;
		top: 22px;
	}
}
/*Smartphone*/
@media only screen and (max-width : 370px) {
	nav li {
		display: block;
		float: none;
		width: 100%;
	}
	nav li a {
		border-bottom: 1px solid rgb(100,100,100);
	}
}

body#page_products #nav_products, body#page_support #nav_support, body#page_contact #nav_contact {
	border-bottom: 5px solid rgb(25,168,199);
	padding-bottom: 0px;
}

/* -------------------- Product Buy Now -------------------- */
#buy_now a {
	font-size: 14pt;
	font-weight: 300;
	text-decoration: none;
	color: rgb(255,255,255);
	margin-bottom: 30px;
}
#buy_now:hover a {
	color: rgb(255,255,255);	
}
.grid_link_buy {
	float: left;
	text-align: center;
	padding: 10px 0px 10px 0px;
}
.grid_prod_buy {
	width: 100%;
	margin-top: 4px;
	background: rgb(25,168,199);	
}
a.grid_prod_buy:hover {	
	background: rgb(43,43,43);	
}

/* -------------------- Footer and Scroll Top -------------------- */
footer {
	width: 100%;
	font-size: 8pt;
	padding: 20px 0px 20px 0px;
	text-align: center;
	color: rgb(200,200,200);
	background: rgb(43,43,43);
	border-top: 6px solid rgb(25,168,199);
	position: absolute;
	bottom: 0;
}
.go-top {
	position: fixed;
	bottom: 10%;
	right: 0;
	padding: 16px 13px 14px 12px;
	text-decoration: none;
	background: rgba(25,168,199,0.8);
	display: none;
}
.go-top:hover {
	background: rgb(25,168,199);
}

/* -------------------- 404 -------------------- */
#aberforth {
	max-width: 40%;
	min-width: 250px;
    display: block;
	margin: 0 auto;
}