/*===========================================
	FONTS
===========================================*/
@font-face {
	font-family: 'Helvetica-Regular';
		src: url('/wsm-fonts/Helvetica-Regular.ttf') format('truetype');
}
@font-face {
	font-family: 'Raleway-Regular';
		src: url('/wsm-fonts/Raleway-Regular.ttf') format('truetype');
}
@font-face {
	font-family: 'Montserrat-Bold';
		src: url('/wsm-fonts/Montserrat-Bold.ttf') format('truetype');
}
@font-face {
	font-family: 'Font-Awesome';
		src: url('/wsm-plugins/FontAwesomePro5.13.0/webfonts/fa-regular-400.ttf') format('truetype');
}


/*===========================================
	STANDARD ELEMENTS
===========================================*/
* {
	margin: 0; 
	padding: 0;
}

body {
	font-family: "Helvetica-Regular", Arial, "Lucida Grande", sans-serif; 
	font-weight: 300;
    font-size: 14px;
    text-transform: none;
	/*color: #222;*/
	color: #606060;
	background-color: #FFF;
	padding: 0;
	margin: 0;	
}

html, body {
	height: 100%;
}


/*===========================================
	HEADERS
===========================================*/
h1, h2, h3, h4, h5, h6 {
	color: #404040;
	margin: 0;
	padding: 0;
}
	h1 {
		font-size: 36px;
		padding-bottom: 10px;
		line-height: 1em;
		font-weight: 500;
	}

	h2 {
		font-size: 24px;
		font-weight: 600;
		line-height: 1.33;
	}

	h3 {
		font-size: 14px;
		font-weight: 400;
		line-height: 1.33;
		
	}
	h4 {
		font-size: 1.1em;
		line-height: 1.5em;
	}
	

/*===========================================
	PARAGRAPHS & TEXT
===========================================*/
p {
	text-align: left;
	font-size: 14px;
    font-weight: 300;
    line-height: 1.57;
    padding-bottom: 20px;	
}
	p:last-child {
		padding-bottom: 0;	
	}

ul, li {
	list-style: none;
	margin: 0;
	padding: 0;
}

	.BulletList ul {
		margin: 0 0 0 30px;
		padding: 0;
		
	}
		.BulletList ul li {
			font-size: 14px;
			font-weight: 300;
			line-height: 1.57;
			padding-bottom: 10px;
			list-style-type: disc;
		}
	
	.SmallText{
		font-size: 0.8em;
		line-height: 1.4em;
		text-align: left
	}
	.BoldText {
		font-weight: 700;
	}
	.ItalicText {
		font-style: italic;
	}
	.StrikeThrough {
		text-decoration: line-through;
	}
	
	
/*===========================================
	LIST ITEM BOX
===========================================*/
.ListItemBox {
	width: 100%;
	margin-bottom: 10px;
}
	.ListItemBox .Icon {
		float: left;
		width: 40px;
		Margin-right: 20px;
		font-size: 32px;
		text-align: center;
	}
		.ListItemBox .Icon i {
			padding: 5px 0;
		}
	.ListItemBox .Content {
		float: left;
		width: calc(100% - 60px);
	}
		.ListItemBox .Content h2 {
			font-size: 1.25em;
			margin-bottom: 0px;
		}
		.ListItemBox .Content p {
			font-size: 1em;
		}
	
/*===========================================
	MARGINS & DISPLAY
===========================================*/
.HideContiner, .HideItem {
    display: none;
}


/*===========================================
	HYPERLINKS
===========================================*/
a:link, a:active, a:visited {
	text-decoration: none;
	color: #222;
	transition: color 0.3s linear;
	-webkit-transition: color 0.3s linear;
	-moz-transition: color 0.3s linear;
}
	a:hover {
		text-decoration: underline;
	}


/*===========================================
	BUTTONS
===========================================*/
a.ContentButton,
span.ContentButton {
	display: inline-block;
	margin-top: 20px;
	text-align: center;
	background: #050e35;
	border: 1px solid #050e35;
	padding: 8px 20px;
	color: #FFF;
	text-transform: uppercase;
	font-weight: 400;
	transition: all .3s;
	text-decoration: none;
	cursor: pointer;
}
	a.ContentButton:hover,
	span.ContentButton:hover {
		background: #1e3b27;
		border: 1px solid #1e3b27;
	}
	
	a.ContentButton.Alternate,
	span.ContentButton.Alternate {
		background: #720000;
		border: 1px solid #720000;
		color: #FFF;
		text-decoration: none;
	}
		a.ContentButton.Alternate:hover,
		span.ContentButton.Alternate:hover {
			background: #670101;
			border: 1px solid #670101;
		}


a.MoreInformationButton,
span.MoreInformationButton {
	display: inline-block;
	background: #050e35;
	border: none;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border-radius: 4px;
	padding: 15px 20px;
}

	
/*===========================================
	IMAGES
===========================================*/
img {
	max-width: 100%;
	height: auto;
}
div {
	outline: none;
}

/*===========================================
	CLEAR FIXES
===========================================*/
.ClearFix:before, .ClearFix:after { 
	content: ""; 
	display: table; 
}
.ClearFix:after {
	clear: both; 
}
.ClearFix { 
	*zoom: 1; 
}


/*===========================================
	TEXT STYLES
===========================================*/
.TextLeft {
	text-align: left;
}
.TextCenter {
	text-align: center;
}
.TextRight {
	text-align: right;
}
.TextJustify {
	text-align: justify;
}
.Uppercase {
	text-transform: uppercase;
}
.TextStrong {
	font-weight: bold;
}


/*===========================================
	MARGINS
===========================================*/
.MarginBottom_20 {
	margin-bottom: 20px;
}

.Padding_200 {
	padding: 200px 0;
}
.PaddingTopBottom_10 {
	padding: 10px 0;
}
.Padding_50 {
	padding: 50px;
}
.PaddingTop_50 {
	padding-top: 50px;
}
.PaddingBottom_50 {
	padding-bottom: 50px;
}
	.PaddingTopBottom_50 {
		padding: 50px 0;
	}
.PaddingBottom {
	padding: 0 0 20px 0;
}

.BorderTopBottom {
	border-top: 5px solid #fab73c;
	border-bottom: 5px solid #fab73c;
}

.BorderBottom {
	border-bottom: 5px solid #fab73c;
}


/*===========================================
	COLOR CHART
===========================================*/
.GreenText {color: #050e35}
.GreyText {color: #DEDEDE;}
.RedText {color: #720000;}
.WhiteText {color: #FFF;}
.YellowText {color: #FFBA00;}
.BlueText {color: #28406D;}
.LightGreenText {color: #B4DF6A;}


.WhiteBackground {background: #FFFFFF;}
.LightGreyBackground {background: #eeeeee;}
.GreyBackground {background: #F7F8FA;}
.GreenBackground {background: #050e35;}
.DarkGreyBackground {background: #233038;}


/*===========================================
	UNDER CONSTRUCTION
===========================================*/
.UnderConstruction {
	margin: 0 auto;
	margin-top: 100px;
	width: 500px;
	color: #000;
	position: relative;
	text-align: left;
	overflow: auto;
	z-index: 2;	
}
.UnderConstruction img{
	margin-bottom: 50px;
}
.UnderConstruction h2 {
	text-align: center;
	margin-bottom: 10px;
}
.UnderConstruction p {
	text-align: center;
	margin-bottom: 10px;
}
	.UnderConstruction a:link, .UnderConstruction a:active, .UnderConstruction a:visited {
		text-decoration: none;
		color: #000;
	}
	.UnderConstruction a:hover {
		text-decoration: underline;
	}


/*===========================================
	FRAME CONTAINERS
===========================================*/
.FullWidthContainer {
	position: relative;
	max-width: 100%;
}
.CenterMaxContainer {
	position: relative;
	margin: 0 auto;
	max-width: calc(100% - 100px);
	padding: 0 50px;
}
.CenterContainer {
	position: relative;
	margin: 0 auto;
	max-width:580px;
	padding: 0 10px;
}

.ContentContainer_VMiddle {
	margin: auto;
	display: flex;
	justify-content: center;
	flex-direction: column;			
	height: 100%;
	text-align: left;
	width: 100%;
}
	.ContentContainer_VMiddle.CenterContent {
		align-items: center;
	}

.HiddenSection {
	display: none;
}


/*===========================================
	CONTENT CONTAINERS
===========================================*/
.ContentHolder {
	width: 100%;
}
	.ContentHolder .ContentContainer_ContentLeft {
		float: right;
		max-width: 568px;
		padding-right: 20px;
	}
	.ContentHolder .ContentContainer_ContentRight {
		float: left;
		max-width: 568px;
		padding-left: 20px;
	}
	
	.ContentHolder .DisplayLogos {
		text-align: center;
	}
		.ContentHolder .DisplayLogos img {
			max-width: 200px;
			margin-right: 10px;
		}
			.ContentHolder .DisplayLogos img:last-child {
				margin-right: 0;
			}
	
	
/*===========================================
	SECTION BANNER DISPLAY
===========================================*/
.SectionBannerDisplay {
	background: #050e35 url(/wsm-images/images/backgrounds/gold_background.jpg) no-repeat; 
	background-position: center; 
	background-size: cover;
	padding: 20px 0;
}
	.SectionBannerDisplay h2 {
		color: #FFF;
	}
	.SectionBannerDisplay p {
		color: #FFF;
	}
	
/*===========================================
	ADMIN CONTROL
===========================================*/
.AdminControl .AdminNavigation {
	margin:0 20px 0 0;
	flex-basis: 230px;
}
	.AdminControl .AdminNavigation .Header {
		background: #050e35;
		color: #FFF;
		padding: 15px 10px;
	}
.AdminControl .AdminMainContent {
	flex-grow: 1;
	margin: 0;
}


/*===========================================
	ADMIN NAVIGATION
===========================================*/
.AdminControl .AdminNavigation ul {
	margin: 0 50px 0 10px;;
}
	.AdminControl .AdminNavigation li {
		padding: 15px 0;
		border-bottom: 1px solid #DEDEDE;
	}		
		.AdminControl .AdminNavigation li a {
			text-decoration: none;
		}					
			.AdminControl .AdminNavigation li a:before {
				font-family: Font-Awesome;
				content: "\f054";
				margin-right: 10px;
				font-size: 0.8em;
				color: #050e35;
			}
			
		.AdminControl .AdminNavigation li a:hover {
			color: #004281;
		}	
	
		.AdminControl .AdminNavigation li.current a {
			color: #050e35;
			margin-left: 20px;
		}
			.AdminControl .AdminNavigation li.current a:before {
				content: "\f324";
			}
	

/*===========================================
	FIXED SIZED CONTAINERS
===========================================*/
.OneHalf_Margin {
	float: left;
	width: 49%;
	margin-right: 2%;
}
	.OneHalf_Margin:nth-child(2n), .OneHalf_Margin:last-child {
		margin-right: 0%;
	}
.OneHalf_NoMargin {
	float: left;
	width: 50%;
}


.OneThird_Margin {
	float: left;
	width: 32%;
	margin-right: 2%;
	margin-bottom: 10px;
}
	.OneThird_Margin:nth-child(3n) {
		float: left;
		margin-right: 0%;
	}
	
.OneQuarter_Margin {
	float: left;
	width: 24.25%;
	margin: 0 1% 0 0;
}
	.OneQuarter_Margin:nth-child(4n), .OneQuarter_Margin:last-child {
		margin: 0;
	}
	
.OneFifth_Margin {
	float: left;
	width: 19.2%;
	margin: 0 1% 10px 0;
}
	.OneFifth_Margin:nth-child(5n), .OneFifth_Margin:last-child {
		margin: 0 0 10px 0;
	}


/*===========================================
	FLEX CONTAINERS
===========================================*/
.FlexContainer {
	display: flex;
	flex-wrap: wrap;
}	
	
	/*	HALFS 	*/
	.FlexContainer .FullWidth_FlexItem {
		width: 100%;
	}
	
	/*	HALFS 	*/
	.FlexContainer .OneHalf_FlexItem {
		width: 50%;
	}
	
	.FlexContainer .OneHalfWideMargin_FlexItem {
		width: 49%;
		margin-right: 2%;
	}
		.FlexContainer .OneHalfWideMargin_FlexItem:nth-child(2n), 
		.FlexContainer .OneHalfWideMargin_FlexItem:last-child {
			margin-right: 0%;
		}


	/*	THIRDS 	*/	
	.FlexContainer .OneThird_FlexItem {
		width: 33.33%;
	}
		.FlexContainer .OneThird_FlexItem:nth-child(3n),
		.FlexContainer .OneThird_FlexItem:last-child {
			width: 33.34%;
		}
	
	.FlexContainer .OneThirdMargin_FlexItem {
		width: 32.66%;
		margin: 0 1% 10px 0;
	}
		.FlexContainer .OneThirdMargin_FlexItem:nth-child(3n),
		.FlexContainer .OneThirdMargin_FlexItem:last-child {
			width: 32.68%;
			margin: 0 0 10px 0;
		}
		
		
	/*	QUARTERS 	*/
	.FlexContainer .OneQuarter_FlexItem {
		width: 25%;
	}
	
	.FlexContainer .OneQuarterMargin_FlexItem {
		width: 24.25%;
		margin: 0 1% 10px 0;
	}
		.FlexContainer .OneQuarterMargin_FlexItem:nth-child(4n),
		.FlexContainer .OneQuarterMargin_FlexItem:last-child {
			margin: 0 0 10px 0;
		}
		
		
	/*	FIFTHS 	*/
	.FlexContainer .OneFifthMargin_FlexItem {
		width: 19.2%;
		margin: 0 1% 10px 0;
	}
		.FlexContainer .OneFifthMargin_FlexItem:nth-child(5n),
		.FlexContainer .OneFifthMargin_FlexItem:last-child {
			margin: 0 0 10px 0;
		}
		
	.FlexContainer .OneFifthNoMargin_FlexItem {
		width: 20%;
		margin: 0;
	}
			
		
/*===========================================
	PAGE HEADER
===========================================*/
.PageContentManagementContainer {

}
	.PageContentManagementContainer .PageContentManagement {
		background: #222222;
	}
		.PageContentManagementContainer .PageContentManagement ul {
			float: right
		}
			.PageContentManagementContainer .PageContentManagement ul li {
				float: left;
				padding: 5px 10px;
			}
				.PageContentManagementContainer .PageContentManagement ul li a {
					font-size: 0.9em;
					color: #FFF;
				}
				.PageContentManagementContainer .PageContentManagement ul li a:hover {
					text-decoration: none;
				}
					.PageContentManagementContainer .PageContentManagement ul li a i {
						margin-right: 8px;
					}
					
					
/*===========================================
	PAGE HEADER
===========================================*/
.PageHeaderContainer {
	background: #FFF;	
}
	
	.PageHeaderContainer .HeaderBar {
		background: #00aff0;
		height: 28px
	}
		.PageHeaderContainer .HeaderBar .ContentLeft {
			float: left;	
		}
		.PageHeaderContainer .HeaderBar .ContentRight {
			float: right;
		}
		
		.PageHeaderContainer .HeaderBar p {
			color: #FFF;
			padding: 4px 0;			
			font-size: 0.9em;
		}
			.PageHeaderContainer .HeaderBar a {
				color: #FFF;
			}
		.PageHeaderContainer .HeaderBar ul {
			float: right
		}
			.PageHeaderContainer .HeaderBar ul li {
				float: left;
				padding: 5px 10px;
			}
				.PageHeaderContainer .HeaderBar ul li a {
					font-size: 0.9em;
					color: #FFF;
				}
				.PageHeaderContainer .HeaderBar ul li a:hover {
					text-decoration: none;
				}
					.PageHeaderContainer .HeaderBar ul li a i {
						margin-right: 8px;
					}
		
	
	.PageHeaderContainer .CompanyLogo {
		float: left;
		max-height: 90px;
		padding: 20px 0;
	}
		.PageHeaderContainer .CompanyLogo img {
			max-height: 70px;
		}
		
		.PageHeaderContainer .ContentRight {
			float: right;
		}
		
		.PageHeaderContainer .Locations {
			width: 100%;
		}
			.PageHeaderContainer .Locations ul {
				float: right;
			}
				.PageHeaderContainer .Locations ul li {
					float: left;
					line-height: 30px;
					padding-right: 10px;
				}
					.PageHeaderContainer .Locations ul li:last-child {
						padding-right: 0;
					}
				

/*===========================================
	HEADER CONTROLS
===========================================*/
.HeaderControl {
	margin-bottom: 50px;
}

	.HeaderControl .HeaderTitle_FlexItem {
		height: 50px;
		line-height: 50px;
		flex-grow: 1;
	}
		.HeaderControl .HeaderTitle_FlexItem h2 {
			color: #050e35;
		}
		
	.HeaderControl .HeaderControl_FlexItem {
		margin: 0 0 0 20px;
		text-align: right;
	}
		.HeaderControl .HeaderControl_FlexItem ul {
			border-left: 1px solid #DEDEDE;
		}
			.HeaderControl .HeaderControl_FlexItem ul li {
				border-top: 1px solid #DEDEDE;
				border-right: 1px solid #DEDEDE;
				border-bottom: 1px solid #DEDEDE;
				height: 48px;
				width: 48px;
				text-align: center;
			}
				.HeaderControl .HeaderControl_FlexItem ul li a i {
					line-height: 48px;
					font-size: 2em;
					color: #050e35;
				}


/*=========================================== 
	RESPONSE MESSAGES
===========================================*/
.ResponseMessage {
	margin-top: 50px;
}
	.ResponseMessage h1 {
		padding-bottom: 25px;
	}
	.ResponseMessage a {
		color: #606060;
	}
	.ResponseMessage .SupportFooter {
		/*background: yellow;*/
	}


/*=========================================== 
	FORM SELECTION
===========================================*/
.FormSelection {
	background: #FFF;
}
	.FormSelection h1 {
		margin-top: 50px;
	}
	.FormSelection h2 {
		font-size: 1.5em;
	}
	.FormSelection h3 {
		font-size: 1em;
		padding-bottom: 0;
		line-height: 1.5em;
		font-weight: 500;
	}
	
	/*	One Third	*/
	.FormSelection .FlexContainer .OneHalfMargin_FlexItem {
		text-align: center;
		width: 48.25%;
		margin: 0 3.5% 20px 0;
	}
		.FormSelection .FlexContainer .OneHalfMargin_FlexItem:nth-child(2n),
		.FormSelection .FlexContainer .OneHalfMargin_FlexItem:last-child {
			margin: 0 0 20px 0;
		}
	
	/*	One Third	*/
	.FormSelection .FlexContainer .OneThirdMargin_FlexItem {
		text-align: center;
		width: 31%;
		margin: 0 3.5% 20px 0;
	}
		.FormSelection .FlexContainer .OneThirdMargin_FlexItem:nth-child(3n),
		.FormSelection .FlexContainer .OneThirdMargin_FlexItem:last-child {
			margin: 0 0 20px 0;
		}
		
		.FormSelection .OneHalfMargin_FlexItem a,
		.FormSelection .OneThirdMargin_FlexItem a {
			display: block;
			padding: 10px;
			text-decoration: none;
			border: 1px solid #DEDEDE;
			background: #FFF;
			color: #606060;
		}
			.FormSelection .OneHalfMargin_FlexItem a:hover,
			.FormSelection .OneThirdMargin_FlexItem a:hover {
				border: 1px solid #F1F1F1;
				background: #F1F1F1;
			}
		
		.FormSelection .FormIconDisplay {
			font-size: 48px;
			color: #7ab251;
			padding: 10px 0;
		}
		.FormSelection .FormDisplayName {
			padding: 10px 0;
			line-height: 1.5em;
		}
		.FormSelection .FormDisplayDescription p {
			font-size: 0.8em;
			padding: 0;
			text-align: center;
		}
		
		
/*=========================================== 
	REFERRAL FORM
===========================================*/		
.ReferralForm {
	margin-bottom: 50px;
	padding-bottom: 50px;
}
	.ReferralForm h1 {
		font-size: 1.5em;
	}

.ReferralForm .SectionForm {
	background: #FFF;
	margin-bottom: 15px;
}
	.ReferralForm .SectionForm .SectionHeader {
		line-height: 1.4em;
		padding: 7px 10px;
		color: #FFF;
		background: #00aff0;
		margin-bottom: 10px;
	}