/* RESETS & HTML5 STYLES
*/

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; }
audio[controls], canvas, video { display: inline-block; *display: inline; *zoom: 1; }
html { font-size: 100%; overflow-y: scroll; -webkit-overflow-scrolling: touch; -webkit-tap-highlight-color: rgba(0,0,0,0); -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }
body { margin: 0; font-size: 13px; line-height: 1.231;}
body, button, input, select, textarea { font-family: Arial, Helvetica, sans-serif; }
::-moz-selection { background: #16427f; color: #fff; text-shadow: none; }
::selection { background: #16427f; color: #fff; text-shadow: none; }
a:focus { outline:0; }
a:hover, a:active { outline: 0; }
abbr[title] { border-bottom: 1px dotted; }
b, strong { font-weight: bold; }
blockquote { margin: 1em 40px; }
dfn { font-style: italic; }
hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }
ins { background: #ff9; color: #000; text-decoration: none; }
mark { background: #ff0; color: #000; font-style: italic; font-weight: bold; }
pre, code, kbd, samp { font-family: monospace, monospace; _font-family: 'courier new', monospace; font-size: 1em; }
pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }
q { quotes: none; }
q:before, q:after { content: ""; content: none; }
small { font-size: 85%; }
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }

ul, ol { margin: 1em 0; padding: 0 0 0 40px; }
dd { margin: 0 0 0 40px; }
nav ul, nav ol { list-style: none; margin: 0; padding: 0; }
img { border: 0; -ms-interpolation-mode: bicubic; }
svg:not(:root) {overflow: hidden;}
figure { margin: 0; }
form { margin: 0; }
fieldset { border: 0; margin: 0; padding: 0; }
legend { border: 0; *margin-left: -7px; padding: 0; }
label { cursor: pointer; }
button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; }
button, input { line-height: normal; *overflow: visible; }
button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; }
input[type="checkbox"], input[type="radio"] { box-sizing: border-box; }
input[type="search"] { -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }
button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }
textarea { overflow: auto; vertical-align: top; }
input:valid, textarea:valid {  }
input:invalid, textarea:invalid { background-color: #f0dddd; }
table { border-collapse: collapse; border-spacing: 0; }

/* =============================================================================
   Primary styles
   Author: Adam Williams Web Design
   URL: http://awx2d.com
   ========================================================================== */

/* TYPOGRAPHY
*/

h1, h2, h3 {font-family: Georgia, Times, "Times New Roman", serif;}
h1 {font-size:2.769em;font-weight:lighter; margin: 0px 0px .5em 0px;color:#005dab;}
h2 {font-size:1.6em;font-weight:normal; margin: 0px 0px .5em 0px;color:#005dab;}
.news-listing h2 {text-align:center;text-shadow:#ccc 0 1px 1px;}

h3 {font-size:1.25em;font-weight:normal; margin: 0px 0px .25em 0px;color:#00a9a7;}
p, ul, ol {font-size:1em;line-height:1.6em;color:#0a2443;margin: 0px 0px 1em 0px;}
p {text-shadow:0 1px 0 #fff;}
a {color:#00a9a7;text-decoration:none;}
a:hover {text-decoration:underline;color:#003d66;}
.intro p {font-size:1.231em;color:#0a2443;}


article {
	margin: 0 0 20px 0;
}
	
article p {
	margin: 0 0 20px 0;
	line-height: 1.5;
	color: #666;
}

.product_left ul, 
.client_list {padding-left:0;margin-left:10px;}
.product_left ul li, 
.client_list li {
	background:url(../images/bullet.png) center left no-repeat;
	padding:0 15px;
	list-style:none;
	color:#0a2443;
}

/* LAYOUT
*/

body {background:#4dc8e9 url('../images/header_bg_extend.jpg') top center no-repeat;}
#container {width:960px;margin:0 auto;}
#container .container_header {float:left;width:100%;height:auto;background:#4dc8e9 url('../images/banner_large_extend.jpg') top center no-repeat;position:relative;}
#main {float:left;width:100%;background:#fff url('../images/main_bg.png') bottom center repeat-x;padding:10px 0 0 0;}
#primary_nav {width:100%;float:left;}
.globalwidth {width:880px;margin:0 auto;}
.content_left {float:left;width:60%;margin:30px 0 0 0;padding:0 0 30px 0;}
.content_right {float:left;width:40%;margin:30px 0 0 0;}
.product_left {float:left;width:50%;margin:30px 0 0 0;padding:0 0 30px 0;}
.product_right {float:left;width:50%;margin:30px 0 0 0;}

/* HEADER
*/
header {float:left;width:100%;height:325px;}
header .sub-nav {position:absolute;right:0px;top:30px;list-style:none;margin:0;padding:0;}
header .sub-nav li {display:inline;margin-right:20px;}
header .sub-nav li a {color:#31434a;font-size: 1.077em;}
header .sub-nav li a:hover {color:#fff;}
.sub-nav .about-us, 
.sub-nav .contact-us, 
.sub-nav .mcr {background:url('../images/sub_nav_icons.png') no-repeat; padding-right:20px;}
.sub-nav .about-us {background-position:right -22px;}
.sub-nav .contact-us {background-position:right -40px;}
.sub-nav .mcr {background-position:right -2px;}
header h1 a {
	float:left;
	width:209px;
	height:201px;
	text-indent:-9999px;
	margin:0;
	background:url('../images/logo.png') center center no-repeat;
	z-index:102;
	position:relative;
}
header .search {position:absolute;right:20px;top:55px;}
header, header .search, header h1, header .sub-nav {z-index:102;}

.search-goog {list-style:none;margin:0;padding:0;}

header form input#goog-wm-qt {
	outline:none !important;
	border:2px solid #45aac5 !important;
	border-width:1px !important;
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px;
	border-radius: 8px;
	-moz-box-shadow:inset 0 0 10px #45aac5;
	-webkit-box-shadow:inset 0 0 10px #45aac5;
	box-shadow:inset 0 0 10px #45aac5;
	width:170px !important;
	padding:0 18px !important;
	height:30px !important;
	line-height:30px !important;
	margin:0 !important;
	font-size:12px !important;
	color:#fff !important;
	background:#4ac1e1 url('../images/search_icon.png') 170px center no-repeat !important;
}

header form input#goog-wm-sb{display:none;color:#fff;}

header h3.tagline {position:absolute;top:140px;right:50px;width:50%;text-align:center;color:#fff;}

#container_quote {
	float:left;
	width:100%;
	border-top:1px solid #4dc8e9;
	background: #4dc8e9;
	background: -moz-linear-gradient(-45deg,  #4dc8e9 0%, #4dc8e9 60%, #90ddf1 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, right bottom, color-stop(0%,#4dc8e9), color-stop(60%,#4dc8e9), color-stop(100%,#90ddf1));		background: -webkit-linear-gradient(-45deg,  #4dc8e9 0%,#4dc8e9 60%,#90ddf1 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(-45deg,  #4dc8e9 0%,#4dc8e9 60%,#90ddf1 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(-45deg,  #4dc8e9 0%,#4dc8e9 60%,#90ddf1 100%); /* IE10+ */
	background: linear-gradient(-45deg,  #4dc8e9 0%,#4dc8e9 60%,#90ddf1 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4dc8e9', endColorstr='#90ddf1',GradientType=1 ); 
	/* IE6-9 fallback on horizontal gradient */
	/*4dc8e9 90ddf1*/
}

.breadcrumb {padding:20px 0;text-shadow:0 1px 1px #ccc;color:#0b7374;}
.breadcrumb a {color:#fff;}

#container_quote .header_quote .get_quote {
	background: url('../images/header_quote.png') no-repeat;
	width:310px;
	height:69px;
	line-height:69px;
	float:left;
	text-align:center;
	font-size: 1.4em;
}

.product_left .get_quote {text-indent:-9999px;display:block;width:217px;height:65px;background:url('../images/main_quote.png') no-repeat;}

/* SIDEBAR & TABLE STYLES
*/
.client_list {clear:both;}

/*th {font-size:14px;font-weight:normal;padding:12px 15px;}
td {border-top:1px solid #ddd;padding:10px 15px;color:#0a2443;}
tr:hover td{background:#0093D0;color:#fff;}*/

table {
	margin: 0 0 20px 0;
	padding: 0;
	}
table th,
table td {
	padding: 10px 20px;
	text-align: left;
	border-bottom: 1px solid #ccc;
	}
table th {
	border-width: 1px;
	}
table td {
	color: #666;
	}
table tr:last-child th,
table tr:last-child td {
	border-bottom: none;
	}
table tr:nth-child(even) {
	background: #eee;
	}		

/* NEWS LISTING 
*/

/*.news-listing ul {padding:0;margin:0;}
.news-listing ul li {float:left;width:90%;margin:0 0 5% 10%;list-style:none;}
.news-listing ul li a:hover {color:#00a9a7;}
.news-listing ul li p {color:#003d66;}*/
.news-listing {float:left;width:100%;padding:30px 0 0 0;border-top:4px solid #0093d0;}
.news-listing ul {padding:0;margin:0;}
.news-listing ul li {float:left;width:30%;margin-right:3.3%;list-style:none;}
.news-listing ul li p {color:#003d66;}

/* JOBS
*/

.jobs h2 {text-align:left;}
#popular_jobs {float:left;width:100%;padding:20px 0;}
.popular-searches {float:left;width:100%;margin:0;padding:0;list-style:none;}
.popular-searches li {
	margin: 5px 1.6% 0 1.6%;
	padding: 5px 0 0 0;
	border-top: 1px solid #eee;	
	float:left;
	width:30%;
}

/* LIST SNIPPETS - SLATS
*/

.featured-jobs, .jobs h2 {margin-left:20px;}
.featured-jobs ul.slats li h3 {font-size: 16px;}
.featured-jobs ul.slats li p span.meta {
	display: block;
	color: #999;
	line-height: 1.1;
	margin:0;
	}

.featured-jobs ul.slats li:last-child {
	margin: 0;
	padding: 0;
	border-bottom: none;
	}
.featured-jobs ul.slats li h3 {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.1;
	}
.featured-jobs ul.slats li p {
	font-size: 14px;
	line-height: 1.4;
	}


ul.slats li {
	margin: 0 0 10px 0;
	padding: 0 0 10px 0;
	border-bottom: 1px solid #eee;
	}
ul.slats li:last-child {
	margin: 0;
	padding: 0;
	border-bottom: none;
	}
ul.slats li h3 {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.1;
	}
ul.slats li h3 a img {
	float: left;
	margin: 0 10px 0 0;
	padding: 4px;
	border: 1px solid #eee;
	}
ul.slats li p {
	font-size: 14px;
	line-height: 1.4;
	}
ul.slats li p span {
	display: block;
	color: #999;
	line-height: 1.1;
	}				

/* PAGE STYLES
*/

.page {float:left;width:100%;font-size:16px;}
.page img {
	float:right;
	width:auto;
	margin:0 0 30px 30px;
	clear:right;
	border:1px solid #ccc;
	padding:1px;
	background:#fff;
	-webkit-box-shadow: 0px 1px 1px 0px #ccc;
	-moz-box-shadow: 0px 1px 1px 0px #ccc;
	box-shadow: 0px 1px 1px 0px #ccc;
	-webkit-border-radius: 2px;
	-moz-border-radius: 2px;
	border-radius: 2px;
}
.page h2.quote {float:right;width:50%;margin:30px 0 30px 30px;clear:right;}
.border_bottom {float:left;width:100%;border-bottom:4px solid #00a9a7;margin-bottom:30px;}
.page article {margin-top:30px;}


.brochures li {
	margin: 0 0 10px 0;
	padding: 0 0 10px 0;
	border-bottom: 1px solid #eee;
	list-style:none;
	float:left;
	width:100%;
	}
.brochures li:last-child {
	margin: 0;
	padding: 0;
	border-bottom: none;
	}
.brochures li h3 {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.1;
	}
.brochures li h3 a img {
	float: left;
	margin: 0 10px 0 0;
	padding: 4px;
	border: 1px solid #eee;
	}
.brochures li h3 a:hover img {
	background: #eee;
	}
.brochures li p {
	margin: 0 0 0 76px;
	font-size: 14px;
	line-height: 1.4;
	}
.brochures li p span {
	display: block;
	color: #999;
	}				

#group_overview img {
	float:right;
	margin:0 0 20px 20px;
	border:0;
	box-shadow:none;
	background:none;
	}
	
#group_overview .slats, .brochures {margin:0;padding:0;}

#group_overview .slats li {
	float:left;
	width:100%;
	list-style:none;
	margin: 0 0 10px 0;
	padding: 0 0 10px 0;
	border-bottom: 1px solid #eee;
	}
#group_overview .slats li:last-child {
	margin: 0;
	padding: 0;
	border-bottom: none;
	}
#group_overview .slats li h3 {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.1;
	}

#group_overview .slats li p {
	margin: 0;
	font-size: 14px;
	line-height: 1.4;
	}
#group_overview .slats li p span {
	display: block;
	color: #999;
	}

.job_nav {float:left;width:100%;clear:both;margin:10px 0;padding:0;}
.job_nav li {float:left;width:100%;list-style:none;margin:0;padding:0;}
.job_nav li img {float:left;width:auto;margin:0 5px 0 0;padding:0;}

/* HOMEPAGE SLIDESHOW
*/

.homepage #container .container_header {height:561px;}
.homepage #container_quote {height:80px;}
#slideshow {position:absolute;top:0;left:0;z-index:100;height:561px;}
#slideshow .slides_container {width:960px;overflow:hidden;position:relative;display:none;}
#slideshow .slides_container div.slide {width:960px;height:561px;display:block;}

/*	Next/prev buttons
*/

#slides .next, #slides .prev {
	background:url('../images/slideshow_arrows.png') top left no-repeat;
	position:absolute;
	top:501px;
	left:0px;
	width:46px;
	height:60px;
	display:block;
	z-index:101;
	text-indent:-9999px;
}
#slides .next {left:914px;background-position:bottom left;}

/*
	Pagination
*/

#slideshow .pagination {
	position:absolute;
	bottom:-80px;
	left:60px;
	width:800px;
	height:80px;
	line-height:80px;
	margin:0 auto;
	background:url('../images/slideshow_mask.png') bottom center no-repeat;
}

#slideshow .pagination li {display:inline;margin:0 1px;list-style:none;}
#slideshow .pagination li a {display:inline;padding:2px 20px 5px 20px;margin:0 20px;color:#fff;font-size:1.446em;}
#slideshow .pagination li.current a {border-bottom:4px solid #0093d0;}

/*
	Caption
*/

.caption {
	z-index:500;
	position:absolute;
	bottom:-265px;
	left:80px;
	height:181px;
	padding:5px 20px 0 20px;
	background:transparent url('../images/slideshow_mask.png') top left no-repeat;
	width:760px;
	font-size:1em;
	line-height:1.33;
	color:#fff;
	text-shadow:none;
}
.caption h2 {float:left;width:30%;margin-top:70px;color:#fff;text-shadow:0 1px 0 #003d66;}
.caption p {float:left;width:70%;margin-top:40px;color:#fff;text-shadow:0 1px 0 #003d66;}

/* CONTACT PAGES
*/

.google-maps {margin:10px 10px 10px 0;}

/* FORM STYLES
*/

form {margin-bottom:20px;}
form fieldset {
	margin: 0 0 10px 0;
	padding: 0 0 10px 0;
	font-size: 14px;
	border-bottom: 1px solid #eee;
	}
form fieldset.form-actions {
	margin: 0 0 0 20%;
	padding: 0;
	border: none;
	}
form fieldset.check {
	padding-left: 20%;	
	}
form fieldset label {
	float: left;
	width: 20%;
	margin: 4px 0 5px 0;
	font-weight: bold;
	}
form fieldset.check label {
	display: inline;
	float: none;
	width: auto;
	font-weight: normal;
	}
form fieldset.radio ul li label {
	display: inline;
	float: none;
	width: auto;
	font-weight: normal;
	}
form fieldset input.form-text,
form fieldset textarea {
	display: block;
	width: 50%;
	padding: 5px;
	font-size: 14px;
	border: 1px solid #ddd;
	background: #f5f5f5;
	-webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.05);
	-moz-box-shadow: inset 0 1px 2px rgba(0,0,0,.05);
	-webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.05);
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
	}
form fieldset input.form-text:focus {
	border: 1px solid #ccc;
	background: #fff;
	}
form fieldset textarea {
	height: 150px;
	}
form fieldset select {
	min-width: 25%;
	margin: 0;
	}
form fieldset.radio ul {
	margin: 5px 0 0 20%;
	}
form fieldset.radio ul li {
	margin: 0 0 5px 0;
	}
form fieldset.radio ul li:last-child {
	margin: 0;
	}
form fieldset p.form-help {
	margin: 5px 0 0 20%;
	font-size: 12px;
	color: #999;
	}
form input[type="submit"] {
	margin: 0;
	padding: 5px 10px;
	font-size: 12px;	
	font-weight: bold;
	border: 1px solid #ccc;
	background: #eee;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
	}
form input[type="submit"]:hover,
form input[type="submit"]:focus {
	border: 1px solid #bbb;
	background: #e5e5e5;
	}
form input[type="submit"]:active {
	border: 1px solid #ccc;
	background: #eee;
	}
@media screen and (max-width: 600px) {
	form fieldset label {
		display: block;
		float: none;
		width: auto;
		margin: 0 0 5px 0;
		}
	form fieldset.form-actions,
	form fieldset.check,
	form fieldset.radio ul,
	form fieldset p.form-help {
		margin-left: 0;
		padding-left: 0;
		}
	form fieldset input.form-text,
	form fieldset textarea {
		width: 100%;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		}
	}				

/* FOOTER 
*/

footer {float:left;width:100%;background:url('../images/footer_full_bg.png') center top no-repeat;}
footer .footer-primary {
	height:146px;
	padding:140px 0 0 0;
	background:url('../images/footer_primary_bg.png') top center no-repeat;
	text-align:center;
}
footer .footer-primary a, footer .footer-primary p, footer .footer-primary ul {color:#fff;text-shadow:0 1px 1px #066d6c;}
footer .footer-primary ul li {list-style:none;display:inline;}
footer .footer-primary ul li span {color:#fff;padding:0 5px;}
footer .footer-primary hr {border:2px solid #fff;background:#fff;margin:10px auto;width:200px;}
footer .footer-primary .sub-nav {display:none;}
footer .footer-primary .contact-info .strong, footer .footer-primary .contact-info-footer .strong {font-weight:bold;font-size:1.077em;}

footer .footer-secondary {
	float:left;
	width:100%;
	background:#9fa7ab url('../images/footer_secondary_bg.png') top center repeat-x;
	text-align:center;
}
footer .footer-secondary h2 {font-size:1.385em;color:#003d66;padding:25px 0 10px 0;}

#clients {float:left;width:100%;height:95px;margin:0 auto;padding:0;}
#clients li {display:inline;list-style:none;height:95px;}


/* CLIENT LIST
*/

#client-list {width:100%;margin:0;padding:0;}
#client-list li {float:left;width:33%;list-style:none;}
#client-list li span {display:block;text-align:center;padding:5%;}
#client-list li img {
	float:left;
	width:80%;
	padding:5%;
	margin:5%;
	border-radius:5px;
	-webkit-border-radius:5px;
	-moz-border-radius:5px;
	border:1px solid #b5bdc5;
	background:#d4dbdf;
	box-shadow: 1px 1px 2px #A9AC94;
	-moz-box-shadow: 1px 1px 2px #A9AC94;
	-webkit-box-shadow: 1px 1px 2px #A9AC94;
}

/* SUPERFISH - Required Styles
*/

.sf-menu li .access {display:none;}
.sf-menu, .sf-menu * 			{margin:0;padding:0;list-style:none;}
.sf-menu 						{line-height:1.0;}
.sf-menu ul 					{position:absolute;top:-999em;width:15em;}/* left offset of submenus need to match (see below) */
.sf-menu ul li 					{width:100%;}
.sf-menu li:hover 				{visibility:inherit;}
.sf-menu li 					{float:left;position:relative;}
.sf-menu a 						{display:block;position:relative;}
.sf-menu li:hover ul,
.sf-menu li.sfHover ul 			{left:0;top:4.1em;z-index:99;}/* match top ul list item height */
ul.sf-menu li:hover li ul,
ul.sf-menu li.sfHover li ul 	{top:-999em;}
ul.sf-menu li li:hover ul,
ul.sf-menu li li.sfHover ul 	{left:15em;top:0;} /* match ul width */
ul.sf-menu li li:hover li ul,
ul.sf-menu li li.sfHover li ul 	{top:-999em;}
ul.sf-menu li li li:hover ul,
ul.sf-menu li li li.sfHover ul 	{left:15em;top:0;}/* match ul width */
ul.sf-menu li.last-menu ul ul {left:-15em;}

/* SUPERFISH NAV SKIN
*/
nav#primary {
	position:absolute;
	top:200px;
	left:0;
	float:left;
	width:960px;
	height:53px;
	background:transparent url('../images/header_nav_bg.png');
	z-index:101;
	}
.sf-menu {
	position:relative;
}
.sf-menu a, .sf-menu a:visited  { color:#fff;text-decoration:none; }
.sf-menu li li {background: #9eb7c0;}
.sf-menu li li li {background:#ddd;}
.sf-menu li li:last-child a, .sf-menu li li li:last-child a, .sf-menu li:last-child a {border:0;}
.sf-menu li:hover, .sf-menu li.sfHover,
.sf-menu a:focus, .sf-menu a:hover, .sf-menu a:active {outline: 0;color:#044662;}
.sf-menu li ul li a, .sf-menu .primary-link ul li a {background-image:none;padding:10px 15px;color:#044662;border-bottom:1px solid #fff;}
.sf-menu li ul li a:hover, .sf-menu .primary-link ul li a:hover {color:#066d6c;background-image:none;}
.sf-menu li.primary-link a.active, .sf-menu li a:hover {color:#f84702;}
.sf-menu li.primary-link a {background: url('../images/sub_nav.png') center center no-repeat;}
.sf-menu li.primary-link a:hover, 
.sf-menu li.primary-link a.active {background: url('../images/sub_nav_hover.png') center center no-repeat;min-width:1px;}
.sf-menu li.primary-link .sf-with-ul {background:none;}
.sf-menu li a {min-width:1px;padding:15px 17px 25px 18px;}

/* ARROWS 
*/
.sf-menu a.sf-with-ul {padding-right:2.25em;min-width:1px;}
.sf-sub-indicator {
	position:		absolute;
	display:		block;
	right:			.75em;
	top:			1.05em; /* IE6 only */
	width:			10px;
	height:			10px;
	text-indent: 	-999em;
	overflow:		hidden;
	background:		url('../images/arrows-ffffff.png') no-repeat -10px -100px; /* 8-bit indexed alpha png. IE6 gets solid image only */
}
a > .sf-sub-indicator {  /* give all except IE6 the correct values */
	top:			.8em;
	background-position: 0 -100px; /* use translucent arrow for modern browsers*/
}
/* apply hovers to modern browsers */
a:focus > .sf-sub-indicator,
a:hover > .sf-sub-indicator,
a:active > .sf-sub-indicator,
li:hover > a > .sf-sub-indicator,
li.sfHover > a > .sf-sub-indicator {
	background-position: -10px -100px; /* arrow hovers for modern browsers*/
}

/* point right for anchors in subs */
.sf-menu ul .sf-sub-indicator { background-position:  -10px 0; }
.sf-menu ul a > .sf-sub-indicator { background-position:  0 0; }
/* apply hovers to modern browsers */
.sf-menu ul a:focus > .sf-sub-indicator,
.sf-menu ul a:hover > .sf-sub-indicator,
.sf-menu ul a:active > .sf-sub-indicator,
.sf-menu ul li:hover > a > .sf-sub-indicator,
.sf-menu ul li.sfHover > a > .sf-sub-indicator {
	background-position: -10px 0; /* arrow hovers for modern browsers*/
}


/* SF-MENU SHADOWS
*/
.sf-shadow ul {
	background:	url('../images/shadow.png') no-repeat bottom right;
	padding: 0 8px 9px 0;
	-moz-border-radius-bottomleft: 17px;
	-moz-border-radius-topright: 17px;
	-webkit-border-top-right-radius: 17px;
	-webkit-border-bottom-left-radius: 17px;
}
.sf-shadow ul.sf-shadow-off {
	background: transparent;
}

.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; }
.ir br { display: none; }
.hidden { display: none; visibility: hidden; }
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }
.invisible { visibility: hidden; }

/* Contain floats: nicolasgallagher.com/micro-clearfix-hack/ */ 
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { zoom: 1; }

/* =============================================================================
   PLACEHOLDER Media Queries for Responsive Design.
   These override the primary ('mobile first') styles
   Modify as content requires.
   ========================================================================== */

/* Style adjustments for viewports 480px or less 
*/

@media screen and (max-width: 480px) {
	
	html {-webkit-text-size-adjust: none;}
	p, a {font-size:1.1em;}
	h1 {font-size:2em;}
	h2 {font-size:1.3em;}
	h3 {font-size:1.1em;}
	header {float:left;width:100%;height:auto;}
	header .search {position:absolute;right:20px;top:30px;}
	header form input#goog-wm-qt {
		border:1px solid #45aac5 !important;
		-moz-box-shadow:inset 0 0 3px;
		-webkit-box-shadow:inset 0 0 3px;
		box-shadow:inset 0 0 3px;
		width:140px !important;
		padding:0 5px !important;
		background-position:120px center !important;
	}
	header h1 a {width:150px;height:150px;}
	.breadcrumb {font-size:11px;margin:10px 0;padding:0 5%;width:90%;}
	header h3.tagline {display:none;}
	header .header_quote {padding:0 0 0 2%;max-width:320px;}
	#slideshow {display:none;}
	.homepage #main {padding-top:20px;}
	.homepage #container .container_header {height:auto;}
	.homepage #container_quote {display:none;}
	nav#primary {float:left;width:100%;clear:both;position:relative;top:0;height:auto;}
	.homepage nav#primary {margin-bottom:20px;}
	.sf-menu li .access {
		border-bottom:4px solid #93aab3;
		padding:8px 5% 8px 25px;
		display:block;
		width:80%;
		margin:0 auto;
		font-size:1.3em;
		line-height:30px;
		background:url('../images/skip_arrow.png') center left no-repeat;
	}
	.featured-jobs, .jobs h2 {margin-left:0px;}
	.sf-menu {line-height:1.0;font-size:11px;height:auto;float:left;width:100%;margin-bottom:20px;position:static;}
	.sf-menu ul {position:relative;top:0;float:left;width:100%;}/* left offset of submenus need to match (see below) */
	.sf-menu ul li {width:100%;}
	.sf-menu li {
		float:left;
		width:100%;
		position:relative;
		-moz-transition: all 0.2s ease-out 0.15s;
		-webkit-transition: all 0.2s ease-out 0.15s;
		-o-transition: all 0.2s ease-out 0.15s;
		transition: all 0.2s ease-out 0.15s;
		overflow:hidden;
		height:auto;
	}
	.sf-menu a {display:block;position:relative;border-bottom:1px solid #93aab3;width:80%;margin:0 auto;}
	.sf-menu a:hover {border-bottom:1px solid transparent;}
	.sf-menu li:last-child a {border-bottom:0;}
	.sf-menu li:hover ul,
	.sf-menu li.sfHover ul {left:0;top:0;z-index:99;}/* match top ul list item height */
	ul.sf-menu li:hover li ul,
	ul.sf-menu li.sfHover li ul,
	ul.sf-menu li li:hover ul,
	ul.sf-menu li li.sfHover ul,
	ul.sf-menu li li:hover li ul,
	ul.sf-menu li li.sfHover li ul,
	ul.sf-menu li li li:hover ul,
	ul.sf-menu li li li.sfHover ul 	{left:0;top:0;}/* match ul width */
	.sf-menu li li, .sf-menu li li li {background:#93aab3;}
	.sf-menu li li li {background:#ddd;}
	.sf-menu li li a {padding:5%;}
	
	.sf-menu li.primary-link a, .sf-menu li a {
		background: url('../images/sf_menu_mobile_bg.png') 0 0 no-repeat;
		min-width:1px;
		padding:10px 10px 10px 35px;
	}
	.sf-menu li.primary-link a:hover {background: url('../images/sf_menu_mobile_bg.png') 0 -35px no-repeat;}
	.sf-menu li.primary-link a.active {background:none;}
	
	/* SF-MENU SHADOWS
	*/
	.sf-shadow ul {
		background:transparent;
		padding:0;
		-moz-border-radius-bottomleft: 0;
		-moz-border-radius-topright: 0;
		-webkit-border-top-right-radius: 0;
		-webkit-border-bottom-left-radius: 0;
	}
	#main {float:left;clear:both;width:90%;padding:5%;margin-bottom:0;}

	#container {width:auto;}
	#container .container_header {
		float:left;
		width:100%;
		height:auto;
		background:transparent url('../images/banner_small.jpg') top center no-repeat;
	}
	.globalwidth, .page, .border_bottom {width:100%;float:left;clear:both;}
	.content_left, .product_left {float:left;width:100%;margin:10px 0 0 0;padding:0 0 10px 0;}
	.content_right, .product_right {float:left;width:100%;margin:10px 0 0 0;}
	
	.sidebar_nav {float:left;width:100%;margin-left:0;padding-left:0;}
	
	#products {width:100%;}
	#products .slides_container {
		float:left;
		width: auto\9; /* ie8 */
		max-width: 95%;
		width:95%;
		height:280px;
		/*width:280px;height:250px;*/
	}
	/*#products .slides_container img {width:280px;}*/
	#products .slides_container img, #client-list li img {
		width: auto\9; /* ie8 */
		width: 80%;
		height: auto;
	}
	/*#products .pagination {width:100%;}*/
	
	.news-listing {float:left;width:100%;margin:10px 0;padding:5% 0 0 0;border:0;}
	.news-listing ul li, .popular-searches li {width: inherit; float: none; margin:0px 0px 10px 0px;}

	/* PAGE STYLES*/
	
	.page h2 {float:none;width:90%;margin:10px;}
	.border_bottom {float:left;width:100%;margin-bottom:30px;}
	
	hr {margin:10px 0;}

	footer {float:left;width:100%;background:none;}
	footer .footer-primary {
		height:259px;
		padding:140px 0 0 0;
		background:url('../images/footer_primary_bg.png') top center no-repeat, url('../images/footer_bg.png') bottom center;
		text-align:center;
	}
	
	footer .footer-primary .sub-nav {display:block;padding:30px 0 0 0;font-size:11px;line-height:18px;}
	footer .footer-primary .sub-nav li {line-height:16px;padding:2px 20px 2px 0;margin-left:5px;}
	header .sub-nav {display:none;}
	img {
			width: auto\9; /* ie8 */
			width: 80%;
			height: auto;
	}
	#clients li img {
		width:auto;	
	}
}

/* =============================================================================
   Print styles.
   Inlined to avoid required HTTP connection: www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */
 
@media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: sanbeiji.com/archives/953 */
  a, a:visited { color: #444 !important; text-decoration: underline; }
  a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* css-discuss.incutio.com/wiki/Printing_Tables */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3{ page-break-after: avoid; }
}
