/*	GLOBAL
--------------------------------*/
body {
	background: #fff url('../images/backgrounds/palms.jpg') no-repeat center top;
	background-attachment: fixed;
	background-size: cover;
	color: #646464;
	font: 100%/1.72em 'Myriad Pro', Verdana, Arial, sans-serif;
}

.touch body {
	background-attachment: scroll;
	background-repeat: repeat;
}

.wrapper {
	margin: 0 auto;
	max-width: 1600px;
	width: 96.25%;
}

.clr:after{
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

.clr{
	zoom: 1;
}

.alignRight {
	float: right;
}

.alignLeft {
	float: left;
}

nav ul {
	margin: 0;
}

nav ul li{
	list-style: none;
}

a {
	color: #0063be;
}


/*	HEADER
--------------------------------*/
header {
	background-color: rgba(0,0,0,.3);
	border-bottom: 1px solid rgba(255,255,255,.4);
	height: 180px;
}

.lt-ie9 header {
	background: url('../images/backgrounds/blk-30.png') repeat left top;
	border-bottom: 1px solid #fff;
}

.topBar {
	background-color: rgba(0,0,0,.4);
	height: 60px;
}

.lt-ie9 .topBar {
	background: url('../images/backgrounds/blk-40.png') repeat left top;
}

h1 {
	margin: 0;
}

#logo {
	margin: 0;
}

#logo img {
	display: block;
	width: 220px;
}

.topBar .alignRight p,
.topBar nav {
	float: left;
}

.topBar .alignRight p {
	color: #fff;
	font-size: 1.375em;
	margin: 17px 16px 0 0;
}

.topBar nav {
	font-size: .875em;
	margin-top: 19px;
}

.topBar li {
	float: left;
	margin-left: 30px;
	position: relative;
}

.topBar a {
	color: #fff;
	display: block;
	text-decoration: none;
}

.topBar a:hover {
	text-decoration: underline;
}

.topBar a.theme {
	background: url('../images/icons/gear.png') no-repeat left center;
	background-size: 15px 15px;
	padding: 0 0 0 22px; 
	text-decoration: none;
}

.topBar a.mail {
	background: url('../images/icons/envelope.png') no-repeat left center;
	background-size: 21px 15px;
	padding-left: 28px; 
}

.topBar .themeSelector {
	padding-bottom: 10px;
}

.topBar .themeSelector ul {
	background-color: #fff;
	box-shadow: 0 5px 10px rgba(0,0,0,.25);
	display: none;
	left: 50%;
	margin-left: -110px;
	padding: 18px 13px 0;
	position: absolute;
	top: 36px;
	width: 194px;
	z-index: 10;
}

.topBar .themeSelector:hover ul,
.topBar .themeSelector:hover .arrow {
	display: block;
}

.lt-ie9 .topBar .themeSelector:hover .arrow {
	display: none;
}

.topBar .themeSelector ul li { 
	margin: 0 5px 10px;
	width: 87px;
}

.topBar .themeSelector ul li p {
	color: #0063be;
	font-size: .875em;
	margin: 0;
} 

.topBar .themeSelector img {
	display: block;
}

.themeSelector .arrow {
	background-color: #fff;
	display: none;
	height: 27px;
	left: 50%;
	margin-left: -13px;
	position: absolute;
	top: 26px; 
	width: 27px;
	transform:rotate(45deg);
	-ms-transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
}

.navBar {
	height: 120px;
}

.navBar .wrapper {
	position: relative;
}

/* Top Level Navigation */
.navBar nav {
	font-size: 1.375em;
	margin-top: 14px;
}

.navBar nav li {
	float: left;
}

.navBar nav li a {
	background-color: #4a6a8d;
	color: #fff;
	display: block;
	height: 54px;
	line-height: 56px;
	padding: 2px 24px 0;
	text-decoration: none;
}

.navBar nav li.active a, 
.no-js .navBar nav li a:hover,
.no-touch .navBar nav li a:hover {
	background-color: #0063be;
}

/* Second Level Navigation */
.navBar nav li ul {
	display: none;
	font-size: .818em;
	left: 0;
	position: absolute;
	top: 84px;
}

.navBar nav li.active ul {
	display: block;
}

.navBar nav li.active ul li a {
	background-color: transparent;
	height: 34px;
	line-height: 36px;
	padding: 2px 14px 0;
}

.navBar nav li.active ul li.active a,
.no-js .navBar nav li.active ul li a:hover,
.no-touch .navBar nav li.active ul li a:hover {
	background-color: #0063be;
}

/* Search */
#search {
	padding-top: 24px;
}

#search input {
	float: left;
	border-radius: 0;
}

#search input[type='text'] {
	background: rgba(255,255,255,.25);
	border: none;
	color: #fff;
	font-family: 'Myriad Pro', Verdana, Arial, sans-serif;
	height: 40px;
	line-height: 40px;
	padding: 0 0 0 10px;
	width: 358px;
}

::-webkit-input-placeholder { 
	color:#fff; 
}

::-moz-placeholder { 
	color:#fff;
} 

:-ms-input-placeholder { 
	color:#fff; 
}
 
input:-moz-placeholder {
	color:#fff; 
}


/*	MAIN CONTENT
--------------------------------*/
#mainContent {
	padding: 34px 0 80px;
}

.columns-1,
.columns-2,
.columns-3 {
	clear: left;
}

.column {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	float: left;
	padding-left: 40px;
}

.column:first-child {
	padding-left: 0;
}

.columns-1 .column {
	width: 100%;
}

.columns-2 .column {
	width: 50%;
}

.columns-2 .narrow {
	width: 30%;
}

.columns-2 .wide {
	width: 70%;
}

.columns-3 .column {
	width: 33.333%;
}

/* Portlets */
.portlet {
	background-color: #fff;
	border-top: 2px solid #002663;
	margin: 0 0 20px;
}

.portlet h2, .portletContent {
	font-size: 1em;
	padding: 0 18px;
}

.portlet h2 {
	color: #002663;
	font-weight: 100;
	font-size: 1.625em;
	margin: 0;
	padding-top: 8px;
	padding-bottom: 10px;
}

.portletContent {
	line-height: 1.71em;
	padding-bottom: 30px;
}

.portletContent h3 {
	font-size: 1.285em;
	font-weight: normal;
	margin: 0 0 1em 0;
}

.portletContent a {
	text-decoration: none;
}

.portletContent a:hover {
	text-decoration: underline;
}

.portletContent a.btn {
	background-color: #0063be;
	color: #fff;
	display: inline-block;
	font-size: 1.25em;
	height: 50px;
	line-height: 50px;
	padding: 0 38px;
	text-decoration: none;
}

.portletContent a.btn:hover {
	background-color: #4a6a8d;
}


/*	SMALL SCREEN OVERRIDES
--------------------------------*/
@media only screen and (max-width: 1200px) {
	.navBar nav li ul {
		font-size: .7272em;
	}
}

@media only screen and (max-width: 1100px) {
	.navBar nav li ul {
		font-size: .5909em;
		padding-left: 10px;
		padding-right: 10px;
	}
}

@media only screen and (max-width: 1023px) {
	.topBar .alignRight p {
		font-size: .875em;
		margin-top: 19px;
		margin-right: 0px;
	}
	.topBar li {
		margin-left: 20px;
	}
	.navBar nav li.active ul li a {
		padding: 2px 8px 0;
	}
	#search input[type='text'] {
		width: 258px;
	}
}

@media only screen and (max-width: 860px) {
	.navBar nav li ul {
		font-size: .5em;
		padding: 2px 0px 0;
	}
}

@media only screen and (max-width: 767px) {
	header,
	.topBar,
	.navBar {
		height: auto;
	}
	header .wrapper {
		width: 100%;
	}
	#logo {
		float: none;
		margin: 0 0 16px;
		text-align: center;
		width: 100%;
	}
	.topBar .alignRight p {
		display: none;
	}
	.topBar .alignRight {
		float: none;
	}
	.topBar nav {
		clear: both;
		float: none;
		overflow: hidden;
		padding-bottom: 20px;
		position: relative;
		width: 100%;
	}
	.topBar ul {
		float: left;
		left: 50%;
		position: relative;
		text-align: center;
	}
	.topBar li {
		display: block;
		margin: 0px 8px;
		position: relative;
		right: 50%;
	}
	.topBar a.theme,
	.topBar a.mail {
		background-image: none;
		padding: 0;
	}
	.topBar .themeSelector:hover ul,
	.topBar .themeSelector:hover .arrow {
		display: none;
	}
	.topBar .themeSelector a:hover {
		text-decoration: underline;
	}
	.navBar .wrapper {
		width: 100%;
	}
	.navBar .alignRight,
	.navBar .alignLeft,
	.navBar nav li {
		float: none;
		position: relative;
	}
	.navBar nav {
		font-size: 1.125em;
		margin-top: 0;
	}
	.navBar nav li a {
		height: 44px;
		line-height: 46px;
	}
	.navBar nav li ul {
		font-size: .818em;
	}
	.navBar nav li.active ul,
	.navBar nav li ul {
		background-color: #fff;
		display: none;
		top: 46px;
		width: 100%;
		z-index: 10;
	}
	.no-touch .navBar nav li:hover ul,
	.no-js .navBar nav li:hover ul,
	.navBar nav li ul.active {
		display: block;
	}
	.navBar nav li ul li {
		background-color: #fff;
		border-bottom: 1px solid #ccc;
	}
	.navBar nav li ul li a,
	.navBar nav li.active ul li.active a {
		background-color: #fff;
		color: #646464;
		height: 34px;
		line-height: 36px;
	}
	.no-touch .navBar nav li.active ul li a:hover,
	.no-touch .navBar nav li ul li a:hover {
		background-color: #e5eff8;
	}
	.navBar nav li.active ul li a {
		padding-left: 24px;
		padding-right: 24px;
	}
	#search {
		padding-top: 0;
		margin: 20px auto 0;
		width: 311px;
	}
	#search input {
		margin-bottom: 20px;
	}
	.columns-1 .column, 
	.columns-2 .column,
	.columns-3 .column {
		padding-left: 0;
		width: 100%;
	}
}