@import url('/css/icomoon/style.css');
@import url('//fonts.googleapis.com/css?family=Rajdhani:400,700|t:400,500,700');
/*
	font-family: 't', sans-serif;
	font-family: 'Rajdhani', sans-serif;
*/

html,
body {
	height: 100%;
}

body {
	background: #F7F7F7;
	color: #333;
	display: flex;
	flex-direction: column;
	font-family: 'Lato', sans-serif;
	font-size: 14px;
	font-weight: 400;
	height: calc(100% - 70px);
	margin: 0;
	padding: 70px 0 0 0;
}

@media screen and (max-width: 1000px) {
	body {
		height: calc(100% - 50px);
		padding-top: 50px;
	}
}

h1, h2, h3, h4, h5, h6 {
	line-height: 100%;
	margin: 0 0 20px 0;
	padding: 0;
}

h1 {
	color: #1b70ba;
	font-size: 28px;
	font-weight: 700;
	margin: 0;
}

h1 span {
	margin-right: 10px;
}

h2 {
	color: #363A3C;
	font-size: 16px;
	font-weight: 700;
}

h3 {
	font-size: 14px;
	font-weight: 500;
}

h4 {
}

h5 {
}

h6 {
}

a {
	color: #1b70ba;
	outline: none;
	text-decoration: none;
}

a:hover { 
	color: #272727;
	text-decoration: none;
}

a img { border: 0; }

.blacklink { 
	color: #000000; 
	text-decoration: none;
}

.sublink {
	clear: left;
	color: #808080;
	float: left;
	font-size: 13px;
	line-height: 13px;
	text-decoration: none;
}

.blacklink:hover, .sublink:hover { text-decoration: underline; }

.print-logo {
	display: none;
}

p {
	line-height: 20px;
	margin: 0 0 10px 0;
}

#mobile-nav-toggle { display: none; }

iframe {
	max-width: 100%;
}

.dashboard table,
.record-list-record table {
	table-layout: fixed;
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Header and Nav ------------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.header {
	background: #fff;
	border-bottom: 3px solid #1b70ba;
	height: 70px;
	left: 0;
	padding: 0 40px 0 320px;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 8;
}

.header .logo {
	color: #fff;
	left: 40px;
	margin: 9px 0 0 0;
	position: absolute;
	text-decoration: none;
	width: 221px;
}

.header .logo img {
	max-width: 100%;
}

.header .logo img.custom-logo {
	display: block;
	margin: 0 auto;
	max-height: 50px;
}

.header .login-info {
	border-left: 1px solid #707070;
	float: right;
	height: 70px;
	padding-left: 40px;
}

.header .login-info ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.header .login-info > ul {
	margin-top: 25px;
}

.header .login-info > ul > li {
	position: relative;
}

.header .login-info > ul > li > a {
	color: #1b70ba;
	position: relative;
	z-index: 4;
}

.header .login-info > ul > li > a span:first-child {
	margin-right: 5px;
	font-size: 16px;
}

.header .login-info > ul > li > a span:last-child {
	margin-left: 5px;
}

.header .login-info > ul ul {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	left: -20px;
	right: -20px;
	opacity: 0;
	padding: 50px 0 10px 0;
	position: absolute;
	top: -12px;
	-webkit-transition: all 0.2s linear;
	transition: all 0.2s linear;
	visibility: hidden;
	z-index: 3;
}

@media screen and (min-width: 1000px) {
	.header .login-info > ul > li:hover > a {
		color: #363A3C;
	}

	.header .login-info > ul > li:hover > ul {
		opacity: 1;
		visibility: visible;
	}
}

.header .login-info > ul ul a {
	color: #1b70ba;
	display: block;
	font-size: 12px;
	margin: 0 0 5px 0;
	padding: 4px 30px;
}

.header .login-info > ul ul a:hover {
	background: #EDF0F5;
}

@media screen and (max-width: 1200px) {
	.header {
		padding: 0 20px 0 180px;
	}
	
	.header .logo {
		left: 20px;
	}
}

@media screen and (max-width: 1000px) {
	.header {
		padding: 0 15px;
		height: 50px;
	}
	
	.header .login-info {
	}
		
	.header .logo {
		left: 15px;
		margin-top: 10px;
		width: 144px;
	}
	
	.header .login-info {
		border: 0;
		border-top: 1px solid #ccc;
		float: none;
		font-size: 13px;
		margin: 20px 0 0 0;
		padding: 20px;
	}
	
	.header .login-info > ul {
		margin: 0;
	}
	
	.header .login-info > ul ul {
		opacity: 1;
		margin-top: 15px;
		padding: 15px 0 10px 0;
		left: auto;
		right: auto;
		position: static;
		top: auto;
		visibility: visible;
	}
	
	.header .login-info > ul ul a {
		font-size: 13px;
	}
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Nav Toggle ----------------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.nav-toggle {
	cursor: pointer;
	display: none;
	height: 20px;
	right: 15px;
	top: 15px;
	position: absolute;
	width: 30px;
	z-index: 1000;
}

.show-nav .nav-toggle {
	width: 25px;
}

.nav-toggle .hamburger-first {
	top: 0;
}

.nav-toggle .hamburger-second {
	top: 8px;
}

.nav-toggle .hamburger-third {
	top: 16px;
}

.nav-toggle .hamburger-first, 
.nav-toggle .hamburger-second, 
.nav-toggle .hamburger-third {	
	background: #1b70ba;
	height: 3px;
	position: absolute;
	right: 0;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
	width: 30px;
}

.show-nav .hamburger-first,
.show-nav .hamburger-third {
	background: #fff;
	transform: rotate(45deg);
	width: 25px;
	top: 8px;
}

.show-nav .hamburger-second {
	opacity: 0;
}

.show-nav .hamburger-third {
	transform: rotate(-45deg);
}

@media screen and (max-width: 1000px) {
	.nav-toggle {
		display: block;
	}
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Primary Navigation --------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.primary-navigation-wrap {
	border-left: 1px solid #1b70ba;
	font-size: 14px;
	position: relative;
}

.primary-navigation-wrap a,
.primary-navigation-wrap a:hover {
	display: block;
	text-decoration: none;
}

.primary-navigation-wrap > ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-navigation-wrap > ul > li {
	border-right: 1px solid #1b70ba;
	float: left;
	position: relative;
}

.primary-navigation-wrap > ul > li > a {
	color: #1b70ba;
	display: block;
	height: 70px;
	line-height: 70px;
	padding: 0 20px;
	position: relative;
	text-decoration: none;
	transition: background .10s linear, color .10s linear;
	-webkit-transition: background .10s linear, color .10s linear;
	z-index: 21;
}

.primary-navigation-wrap > ul > li:hover,
.primary-navigation-wrap > ul > li.selected {
}

.primary-navigation-wrap > ul > li:hover > a,
.primary-navigation-wrap > ul > li.selected > a {
	background: #1b70ba;
	color: #fff;
}

/* drop level 1 */
.primary-navigation-wrap > ul > li > ul {
	background-color: rgba(255,255,255,0.98);
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	list-style: none;
	display: none;
	padding: 4px 0;
}

@media screen and (min-width: 1000px) {
	.primary-navigation-wrap > ul > li > ul {
		box-shadow: 0 5px 7px rgba(0,0,0,0.25);
		display: block;
		margin: 0;
		max-height: 0;
		min-width: 180px;
		opacity: 0;
		overflow: hidden;
		position: absolute;
		top: 70px;
		-webkit-transition: all .25s ease;
		-ms-transition: all .25s ease;
		transition: all .25s ease;
		width: 100%;
		z-index: 20;
	}

	.primary-navigation-wrap > ul > li:last-child > ul,
	.primary-navigation-wrap > ul > li.last > ul {
		right: 0;
	}

	.primary-navigation-wrap > ul > li:focus > ul,
	.primary-navigation-wrap > ul > li:hover > ul {
		max-height: 500px;
		opacity: 1;
		visibility: visible;
	}
}

.primary-navigation-wrap > ul > li > ul li a {
	background-color: #ffffff;
	font-family: 'Rajdhani', sans-serif;
	color: #2d2d2d;
	display: block;
	font-size: 13px;
	font-weight: 400;
	line-height: 14px;
	padding: 10px 9px;
	text-decoration: none;
	transition: all .10s linear;
	-webkit-transition: all .10s linear;
	-moz-transition: all .10s linear;
	-o-transition: all .10s linear;
}

.primary-navigation-wrap > ul > li > ul li > a:hover,
.primary-navigation-wrap > ul > li > ul li.selected > a {
	background: #dbdbdb;
}

/* drop level 2+ */
.primary-navigation-wrap > ul > li > ul ul {
	display: none;
}

.primary-navigation-wrap .employer-selector {
	float: right;
	margin-top: 18px;
}

.primary-navigation-wrap .employer-selector label {
	float: left;
	font-weight: 300;
	margin: 4px 10px 0 0;
}

@media screen and (max-width: 1200px) {
	.primary-navigation-wrap > ul > li > a {
		padding: 0 13px;
		font-size: 13px;
	}
}

@media screen and (max-width: 1000px) {
	.primary-navigation-wrap {
		background: #1b70ba;
		bottom: 0;
		box-shadow: 0 0 30px rgba(0,0,0,0.25);
		box-sizing: border-box;
		height: auto;
		margin: 0;
		max-width: 300px;
		padding: 50px 10px 10px 10px;
		position: fixed;
		right: -100%;
		top: 0;
		transition: right 0.3s ease;
		-webkit-transition: right 0.3s ease;
		width: 100%;
		z-index: 999;
	}
	
	.primary-navigation-wrap .wrapper {
		margin: 0;
	}
	
	.primary-navigation-wrap > ul {
		display: block;
	}
	
	.primary-navigation-wrap > ul > li {
		float: none;
	}
	
	.primary-navigation-wrap > ul > li > a {
		color: #fff;
		float: none;
		height: auto;
		line-height: 100%;
		padding: 15px 20px;
	}
	
	body.show-nav .primary-navigation-wrap {
		right: 0;
	}

	.header .login-info > ul > li > a {
		color: #fff;
	}
}

/* ---------------------------------------------------------------------------------------------------------------------- */
/* Middle Area ---------------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.middle-area {
	margin: 0 40px;
	flex: 1 0 auto;
}

@media screen and (max-width: 1200px) {
	.middle-area {
		margin: 0 20px;
	}
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Secondary Navigation ------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.secondary-navigation-wrap {
	background: #ffffff;
	background: url(/images/template/light-gray-background.png);
	border-bottom: 1px solid #8f9297;
	clear: both;
	top: -10px;
	margin-bottom: -10px;
	padding-bottom: 5px;
	position: relative;
	z-index: 1;
}

.secondary-navigation-wrap ul.secondary-navigation {
	list-style: none;
	margin: 0;
	padding: 15px 10px 0 10px;
}

.secondary-navigation-wrap ul.secondary-navigation li {
	float: left;
	margin-right: 5px;
	margin-bottom: 5px;
}

.secondary-navigation-wrap ul.secondary-navigation li a {
	background: #efefef;
	color: #000000;
	display: block;
	float: left;
	font-size: 11px;
	height: 25px;
	line-height: 25px;
	padding: 1px 10px;
	text-decoration: none;
}

.secondary-navigation-wrap ul.secondary-navigation li a:hover,
.secondary-navigation-wrap ul.secondary-navigation li.selected a {
	background: #585858;
	color: #ffffff;
	opacity: 1;
	filter: alpha(opacity=100);
	padding: 1px 10px;
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Heading Area/Pager/Search Bar ---------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.heading-area-wrap {
	clear: both;
    padding: 30px 0;
}

.heading-area .sub-heading {
	font-weight: bold;
	margin: 0 0 20px 41px;
}

.heading-area-wrap .button {
	border-color: #ffffff;
	color: #ffffff;
}

h1 .heading-image {
	background-position: 50% 50%;
	background-repeat: no-repeat;
	background-size: cover;
	border-radius: 50%;
	box-shadow: 0 1px 2px rgba(0,0,0,0.25);
	border: 1px solid rgba(0,0,0,0.15);
	float: left;
	margin: -10px 12px 0 0;
	height: 75px;
	overflow: hidden;
	width: 75px;
}

h1 .heading-image img {
	visibility: hidden;
	width: 100%;
}


.pager-bar {
    border-bottom: 1px solid #c1c1c1;
	padding: 0 0 10px 0;
	margin-bottom: 10px;
}

.pager-bar input.search-input {
	border-right: 0;
	-webkit-border-top-left-radius: 15px;
	-webkit-border-bottom-left-radius: 15px;
	-moz-border-radius-topleft: 15px;
	-moz-border-radius-bottomleft: 15px;
	border-top-left-radius: 15px;
	border-bottom-left-radius: 15px;
	float: left;
	height: 16px;
	padding: 4px 4px 4px 10px;
}

.pager-bar input.search-input.standalone {
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-right: 1px solid #c1c1c1;
	margin-right: 6px;
}

.pager-bar input.search-submit {
	background: #ffffff;
	background: -moz-linear-gradient(top, #ffffff 0%, #d8d8d8 100%);
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#d8d8d8));
	background: -webkit-linear-gradient(top, #ffffff 0%,#d8d8d8 100%);
	background: -o-linear-gradient(top, #ffffff 0%,#d8d8d8 100%);
	background: -ms-linear-gradient(top, #ffffff 0%,#d8d8d8 100%);
	background: linear-gradient(top, #ffffff 0%,#d8d8d8 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#d8d8d8',GradientType=0 );
	-webkit-border-top-right-radius: 10px;
	-webkit-border-bottom-right-radius: 10px;
	-moz-border-radius-topright: 10px;
	-moz-border-radius-bottomright: 10px;
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	cursor: pointer;
	float: left;
	font-size: 11px;
	font-weight: bold;
	height: 26px;
}

.pager-bar input.search-submit.standalone {
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
}

.pager-bar input.search-submit:hover {
	background: #d8d8d8;
}

@media (max-width: 600px) {
	.heading-area .fr {
		float: none;
		margin-bottom: 15px;
		text-align: center;
	}

	.heading-area .fr .button {
		display: block;
		margin: 0 0 8px;
	}

	h1 {
		font-size: 22px;
		text-align: center;
	}

	.heading-area .sub-heading {
		margin: 10px 0 20px 0;
		text-align: center;
	}
}

/* ---------------------------------------------------------------------------------------------------------------------- */
/* Filters Form --------------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.filters-form {

}

.filters-form:after {
	clear: both;
	content: '';
	display: table;
}

.filters-form .filter {
	float: left;
	margin-bottom: 10px;
	position: relative;
	padding-left: 10px;
	padding-right: 10px;
}

.filters-form .filter:first-of-type {
	padding-left: 0;
}

.filters-form .filter:last-of-type {
	padding-right: 0;
}

.filters-form .filter:after {
	background: #D9DADB;
	content: '';
	height: 33px;
	bottom: 0;
	position: absolute;
	right: 0;
	width: 1px;
}

.filters-form .filter:last-of-type:after {
	display: none;
}

.filters-form .filter-label {
	color: #1b70ba;
	display: block;
	font-size: 12px;
	font-weight: 500;
	margin-bottom: 5px;
}

input,
select {
	border-radius: 6px;
}

.chosen-container-single .chosen-single {
	background: #fff;
	border: 1px solid #D0D0D0;
	box-shadow: none;
	height: 33px;
	line-height: 33px;
}

.chosen-container-single .chosen-single div b {
	background-position: 0px 7px;
}

.chosen-container-active.chosen-with-drop .chosen-single div b {
	background-position: -18px 7px;
}

.search-input {
	background: #fff url(/images/icons/search-gray.svg) calc(100% - 10px) 50% no-repeat;
	background-size: 12px 12px;
	padding-right: 25px;
}

@media screen and (max-width: 800px) {
	.filters-form.fl {
		float: none;
		text-align: center;
	}
	
	.filters-form .filter {
		display: inline-block;
		float: none;
		vertical-align: top;
		text-align: left;
	}
	
	.plan-dashboard-button-wrap.fr.smt {
		float: none;
		margin-bottom: 20px;
		text-align: center;
	}
}


/* ---------------------------------------------------------------------------------------------------------------------- */
/* Content Container ---------------------------------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------------------------------------------------- */
.footer {
	background: #f0f0f0;
	color: #808080;
	flex-shrink: 0;
	margin: 50px 0 0 0;
	font-size: 10px;
	padding: 5px 10px;
	text-align: center;
}

.highlight {
	background: #fffae0;
	border: 1px solid #ffe153;
	margin: 0 0 10px 0;
	padding: 10px;
}

.wrapper.narrow {
	max-width: 1100px;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Login Screen ---------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
body.public-page .header {
	background: none;
	border: none;
	height: auto;
	padding: 0 20px;
	position: static;
	text-align: center;
}

body.public-page .header .logo {
	display: inline-block;
	float: none;
	margin-top: 25px;
	position: static;
	width: 292px;
}

body.public-page .middle-area {
	padding-top: 30px;
}

@media screen and (max-width: 550px) {
	body.public-page .header {
		height: 65px;
	}

	body.public-page .header .logo {
		margin-top: 10px;
		width: 255px;
	}

	body.public-page .middle-area {
		padding-top: 32px;
	}
}

.login-box {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	margin: 20px auto 0 auto;
	overflow: hidden;
	padding: 30px 0 0 0;
	position: relative;
	max-width: 420px;
}

body.public-page h1 {
	text-align: center;
}

.login-box .field-wrap {
	margin-bottom: 15px;
	padding: 0 30px;
}

.login-box .field-wrap label {
	display: block;
	margin-bottom: 5px;
}

.login-box .field-wrap input {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	border-radius: 3px;
	padding: 8px;
	width: 100%;
}

.login-box .submit-wrap {
	background: #F7F8FA;
	padding: 30px;
	text-align: center;
}

.login-box .submit {
	background: #1b70ba;
	border: 0;
	border-radius: 5px;
	color: #ffffff;
	display: inline-block;
	font-size: 12px;
	font-weight: 500;
	padding: 10px 40px;
	text-transform: none;
}

.back-create-an-account-button-wrap {
	margin-top: 30px;
	text-align: center;
}

.back-create-an-account-button-wrap .button {
	margin: 0 20px 15px;
}



/* ----------------------------------------------------------------------------------------------------------------------- */
/* Success Checkmark ------------------------------------------------------------------------------------------------------ */
/* ----------------------------------------------------------------------------------------------------------------------- */
.discount-code-message {
	font-weight: bold;
	margin-top: 5px;
}

.discount-code-message svg {
	display: inline-block;
	margin-right: 5px;
	width: 20px;
	vertical-align: middle;
}

.discount-code-message > div > div {
	display: inline-block;
	vertical-align: middle;
}

.discount-code-message .valid {
	color: #73AF55;
}

.discount-code-message .invalid {
	color: #D06079;
}

.discount-code-message .path {
	stroke-dasharray: 1000;
	stroke-dashoffset: 0;
}
.discount-code-message .path.circle {
	-webkit-animation: dash 0.9s ease-in-out;
	animation: dash 0.9s ease-in-out;
}
.discount-code-message .path.line {
  stroke-dashoffset: 1000;
  -webkit-animation: dash 0.9s 0.35s ease-in-out forwards;
  animation: dash 0.9s 0.35s ease-in-out forwards;
}
.discount-code-message .path.check {
	stroke-dashoffset: -100;
	-webkit-animation: dash-check 0.9s 0.35s ease-in-out forwards;
	animation: dash-check 0.9s 0.35s ease-in-out forwards;
}
@-webkit-keyframes dash {
  0% {
    stroke-dashoffset: 1000;
  }
  100% {
    stroke-dashoffset: 0;
  }
}
@keyframes dash {
  0% {
    stroke-dashoffset: 1000;
  }
  100% {
    stroke-dashoffset: 0;
  }
}
@-webkit-keyframes dash-check {
  0% {
    stroke-dashoffset: -100;
  }
  100% {
    stroke-dashoffset: 900;
  }
}
@keyframes dash-check {
  0% {
    stroke-dashoffset: -100;
  }
  100% {
    stroke-dashoffset: 900;
  }
}



/* ----------------------------------------------------------------------------------------------------------------------- */
/* Miscellaneous --------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.hr { 
	border-bottom: 1px solid #cccccc;
	height: 1px;
	overflow: hidden;
	margin: 15px 0;
	position: relative;
}

.hr.small-margin {
	margin: 3px 0;
}

.hr hr { display: none; }

.smr { margin-right: 6px; }
.mr { margin-right: 20px; }

.vsmt { margin-top: 4px; }
.smt { margin-top: 10px; }
.mt { margin-top: 20px; }
.bmt { margin-top: 30px; }
.negmt { margin-top: -10px; }

.vsmb { margin-bottom: 4px; }
.smb { margin-bottom: 10px; }
.mb { margin-bottom: 20px; }
.bmb { margin-bottom: 30px; }

.ml { margin-left: 20px; }
.sml { margin-left: 10px; }
.bml { margin-left: 30px; }

.cb { clear: both; }
.clear:after {
	clear: both;
	content: '';
	display: table;
}
.cr { clear: right; }
.cl { clear: left; }
.fr { float: right; }
.fl { float: left; }
.cn { clear: none; }

.tar { text-align: right; }
.tac,th.tac { text-align: center; }
.tal { text-align: left; }
.spt { padding-top: 5px; }
.spr { padding-right: 5px; }
.pt { padding-top: 15px; }
.g { color: #808080; }
.red { color: red; }
.green { color: green; }
.nmr { margin-right: 0; }
.nbg { background: none; }
.gbr { border-right: 1px solid #e8e8e8; }
.dn { display: none; }
.gr { color: green; }
.w { color: #ffffff; }

.small { font-size: 80%; }

.di { display: inline; width: auto; float: none; }
.dib { display: inline-block; }
.vam { vertical-align: middle; }
.db { display: block; }

.uc { text-transform: uppercase; }

.checkbox {	vertical-align: middle; }

.drag-class td {
	background: #d9ecff;
	border-bottom: 1px solid #000000;
	border-top: 1px solid #000000;
	opacity: .5;
}

.drag-handle { cursor: move; }

.all-caps {	text-transform: uppercase; }

.status-icon {
	background: url(/images/icons/status-icon.png) 0 0 no-repeat;
	display: inline-block;
	height: 8px;
	width: 8px;
}

.status-icon.offline { background-position: 0 -8px; }

.status-icon span { display: none; }

.long-link {
	overflow-wrap: break-word;
	word-wrap: break-word;

	-ms-word-break: break-all;
	/* This is the dangerous one in WebKit, as it breaks things wherever */
	word-break: break-all;
	/* Instead use this non-standard one: */
	word-break: break-word;

	/* Adds a hyphen where the word breaks, if supported (No Blink) */
	-ms-hyphens: auto;
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
}

.orange {
	color: #ED2121;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* CT Overlay ------------------------------------------------------------------------------------------------------------ */
/* ----------------------------------------------------------------------------------------------------------------------- */
.ct-underlay {
	background: #000000;
	display: none;
	bottom: 0;
	left: 0;
	opacity: .7;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 200;
}

.ct-overlay {
	background: #ffffff;
	box-shadow: 0 0 20px rgba(0,0,0,.50);
	-moz-box-shadow: 0 0 20px rgba(0,0,0,.50);
	-webkit-box-shadow: 0 0 20px rgba(0,0,0,.50);
	display: none;
	left: 50%;
	margin: 0 0 0 -200px;
	padding: 15px;
	position: absolute;
	top: 100px;
	min-width: 100px;
	z-index: 201;
}

.ct-overlay .ct-overlay-close,
.overlay-close {
	background: url(/images/icons/x-close.png);
	position: absolute;
	top: 18px;
	right: 18px;
	width: 25px;
	height: 26px;
	cursor: pointer;
	z-index: 201;
}

.ct-overlay h1 {
	margin-bottom: 20px;
	padding-right: 80px;
}

.page-buttons .pager {
	margin-right: 5px;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Alerts ---------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.alert,
.good-alert, 
.bad-alert {
	background: #e7ffe6;
	border: 1px solid #beffbb;
	color: #000000;
	margin: 10px 0;
	position: relative;
	z-index: 0;
}

.alert.neutral {
	background: #fffae0;
	border: 1px solid #ffe153;
	margin: 0 0 10px 0;
}

.alert .inside,
.alert-inside {
	margin: 0 auto;
	font-size: 18px;
	padding: 20px 25px 20px 10px;
}

.alert.neutral .inside {
	font-size: 12px;
	padding: 10px;
}

.bad-alert {
	background: #ffe6e6;
	border: 1px solid #ffbbbb;
}

.close-it {
	background: url(/images/icons/hide.png) 0 0 no-repeat;
	height: 20px;
	position: absolute;
	right: 5px;
	top: 5px;
	width: 56px;
}

.close-it span {
	display: none;
}

.good-alert.fixed, 
.bad-alert.fixed {
	border-top: 0;
	border-left: 0;
	border-right: 0;
	display: none;
	left: 0;
	margin: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 9999;
}

.good-alert.fixed .alert-inside, 
.bad-alert.fixed .alert-inside {
	margin: 0 auto;
	position: relative;
	max-width: 960px;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Buttons --------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.submit,
.button {
	background: #1b70ba;
	border: 0;
	border-radius: 4px;
	box-sizing: border-box;
	color: #ffffff;
	cursor: pointer;
	display: inline-block;
	font-family: 'Roboto', sans-serif;
	font-size: 13px;
	font-weight: 500;
	height: auto;
	line-height: 16px;	
	max-width: 100%;
	padding: 9px 25px;
	text-align: center;
	transition: background .10s linear;
	-webkit-transition: background .10s linear;
}

.submit.cancel,
.submit[type=button] {
	background: #878787;
}

.submit.cancel {
	margin-left: 10px;
}

.button.white {
	background: #fff;
	border: 1px solid #1b70ba;
	color: #1b70ba;
}

.button.black {
	background: #333333;
}

.button.gray {
	background: #808080;
}
a
.button.blue {
	background: #3985FF;
}

.button.big {
	font-size: 14px;
	font-weight: bold;
	padding: 13px 30px;
}

.submit:hover,
.submit:active,
.submit.active,
.submit.disabled,
.submit[disabled], 
.button:hover,
.button:active,
.button.active,
.button.disabled,
.button[disabled] {  
	background: #0cf;
	color: #ffffff;
}

.button.disabled,
.button.disabled:active,
.button[disabled] {  
	background: #D9DADB;
	color: #ffffff;
	cursor: not-allowed;
}

.submit:active,
.submit.active,
.button:active,
.button.active {
	background: #333333;
	color: #ffffff;
}

.submit:first-child,
.button:first-child {

}

.button.small,
.submit.small {
	font-size: 12px;
	padding: 4px 10px;
}

.submit.small {
	font-size: 14px;
}

.button.tiny,
.submit.tiny {
	font-size: 11px;
	padding: 2px 5px;
}

.button .print { margin-top: 2px; }


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Pager ----------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.pager,
.pager:active {
	background: #fff;
	-webkit-appearance: none;
	border-radius: 2px;
	border: 1px solid #C4C4C4;
	color: #363A3C;
	display: inline-block;
	font-size: 12px;
	height: 20px;
	line-height: 20px;
	padding: 0 7px;
	text-align: center;
	text-decoration: none;
}

.pager:hover,
.pager.on {
	background: #1b70ba;
	border-color: #1b70ba;
	color: #fff;
	text-decoration: none;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Display Table --------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.display-table {
	background: #fff;
	border-radius: 4px;
	border-collapse: collapse;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	border: 0;
	font-size: 14px;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.display-table tr {
}

.display-table th {
	background: #1b70ba;
	border-right: 1px solid #363A3C;
	box-shadow: 0 3px 6px rgba(0,0,0,.08);
	color: #fff;
	padding: 10px;
	text-align: left;
}

.display-table th:last-child {
	border: 0;
}

.display-table tr th.sort a {
	background-image: url(/images/icons/sort.svg);
	background-position: 100% 50%;
	background-repeat: no-repeat;
	color: #ffffff;
	display: block;
	padding: 4px 0;
	text-decoration: none;
}

.display-table tr th.sort.asc a {
	background-image: url(/images/icons/sort-asc.svg);
}

.display-table tr th.sort.desc a {
	background-image: url(/images/icons/sort-desc.svg);
}

.display-table tr th.sort:hover,
.display-table tr th.sort.current {
	background-color: rgba(0,0,0,0.85);
}

.display-table th.tar {
	text-align: right;
}

.display-table th.tac {
	text-align: center;
}

.display-table th.table-header { cursor: pointer; }
.display-table th.table-header:hover { 
	background-color: #45484b;
}

.display-table th.table-header.headerSortUp {
	background-color: #45484b;
}

.display-table th.table-header.headerSortDown {
	background-color: #45484b;
}

.display-table th.headerSortUp:hover,
.display-table th.headerSortUp:hover {
}

.display-table tbody tr:nth-child(2n) {
	background: #F7F8FA;
}

.display-table td {
	border-right: 1px solid #D9DADB;
	padding: 10px;
}

.display-table td:last-child {
	border: 0;
}

.display-table tr:hover td {
	background: #eefaff;
}

.display-table tr td img.shadow {
	padding: 3px;
	box-shadow: 0 0 3px rgba(0,0,0,.25);
	-moz-box-shadow: 0 0 3px rgba(0,0,0,.25);
	-webkit-box-shadow: 0 0 3px rgba(0,0,0,.25);
}

.display-table tr.totals {
}

.display-table tr.totals td {
	border-top: 3px double #333333;
	font-weight: bold;
	text-align: right;
}

.display-table tr.totals td.tac { text-align: center; }

.display-table tr.inactive td {
	color: #cccccc;
}

.display-table tr.inactive td img {
	opacity: .50;
	filter: alpha(opacity=50);
}

.dragClass td {
	background: #d9ecff;
	border-bottom: 1px solid #000000;
	border-top: 1px solid #000000;
	opacity: .5;
}

.dragHandle {
	cursor: move;
}

.display-table td span.checkbox {
	background: url(/images/icons/checkbox.png) 0 100% no-repeat;
	display: inline-block;
	height: 22px;
	text-indent: -9999px;
	width: 20px;
}

.display-table td span.checkbox.checked {
	background: url(/images/icons/checkbox-checked.png) 0 0 no-repeat;
	text-indent: -9999px;
}

.calendar-controls {
	text-align: center;
}

.display-table.calendar {

}

.display-table.calendar th {
	text-align: center;
	width: 14.28571428571429%;
}

.display-table.calendar td {
	vertical-align: top;
}

.display-table.calendar tr td.Today {
	background: #fff7dd;
}

.display-table.calendar tr td.weekend {
	background: #eaeaea;
}

.display-table.calendar tr td.empty-cell {
    background: #808080;
}

.display-table.calendar td .number {
	float: right;
	font-size: 10px;
}

.display-table.calendar td .inner {
	min-height: 50px;
	padding-right: 18px;
}

.display-table.calendar td .inner ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.display-table.calendar td .inner ul li {

}

.display-table.calendar td .inner ul li a {
	border-radius: 4px;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border: 1px solid #cccccc;
	display: block;
	margin: 0 0 2px 0;
	padding: 2px 5px;
}

.display-table.calendar td .inner ul li a:hover {

}

.active-icon {
	color: #3985FF;
	font-size: 20px;
}

.display-table .actions {
	white-space: nowrap;
}

.actions a {
	color: #A3A3A3;
	display: inline-block;
	font-size: 13px;
	margin-right: 14px;
}

.actions a:last-child {
	margin-right: 0;
}

.actions a span {
	margin-right: 2px;
}

.actions a:hover {
	color: #1b70ba;
}

.actions a .icon-view {
	font-size: 12px;
}

.actions a .icon-edit {
	font-size: 12px;
}

.actions a .icon-impersonate {
	font-size: 8px;
}

.status-color-orb {
	padding-left: 18px;
	height: 16px;
	line-height: 16px;
	position: relative;
}

.status-color-orb:before {
	background-color: #3985FF;
	border-radius: 100%;
	content: '';
	left: 0;
	display: block;
	height: 10px;
	position: absolute;
	top: calc(50% - 5px);
	width: 10px;	
}

.status-color-orb.ready-to-sign:before {
	background-color: #13D398;
}

.status-color-orb.under-review:before {
	background-color: #3985FF;
}

.status-color-orb.in-progress:before {
	background-color: #F18A00;
}

.status-color-orb.complete:before {
	background-color: #000;
}

.display-table .faux-column-label {
	display: none;
}

@media screen and (max-width: 800px) {
	.display-table {
		display: none;
	}
	
	.display-table.no-mobile,
	.display-table.details-table,
	.display-table.mobile-handling {
		display: table;
	}

	.display-table.mobile-handling thead,
	.display-table.mobile-handling th,
	.display-table.mobile-handling tfoot {
		display: none;
	}
	
	.display-table.mobile-handling {
		background: none;
		border: 0;
		box-shadow: none;
	}

	.display-table.mobile-handling tr {
		background: #ffffff !important;
		border-radius: 5px;
		box-shadow: 0 2px 3px rgba(0,0,0,0.25);
		display: block;
		margin: 0 0 15px 0;
	}

	
	.display-table.mobile-handling td {
		background: none !important;
		border: 0;
		border-bottom: 1px solid rgba(0,0,0,0.1);
		box-sizing: border-box;
		display: block;
		text-align: center;
		width: 100%;
	}
	
	.display-table.mobile-handling td.mobile-hide,
	.display-table.mobile-handling td.tablet-hide {
		display: none; 
	}
	
	.display-table.mobile-handling .faux-column-label {
		display: inline-block;
		padding-right: 10px;
		color: #808080;
		font-size: 90%;
		text-transform: uppercase;
	}
	
	.display-table td img {
		border: 1px solid rgba(0,0,0,0.1);
	}
	
	.button.table-action {
		display: inline-block;
	}
	
	.mobile-horz-scroll-wrap {
		max-width: 100%;
		overflow: auto;
	}

	.mobile-horz-scroll-wrap fieldset {
		min-width: 600px;
	}
	
	.table-wrap {
		max-height: 300px;
	}

	.display-table .button.small {
		margin-bottom: 5px;
	}
}

/* ----------------------------------------------------------------------------------------------------------------------- */
/* Split Record Table (e.g. Announcements) ------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.split-record-table {
    border-spacing: 0;
    border-collapse: collapse;	
	width: 100%;
}

.split-record-table tr {
	background: #fff;
	box-shadow: 0 3px 6px rgba(0,0,0,0.08);
	border-radius: 4px;
	display: table;
	margin-bottom: 20px;
	width: 100%;
}

.split-record-table td img {
	box-shadow: 0 1px 8px rgba(0,0,0,0.08);
	border-radius: 4px;
	display: block;
}

.split-record-table td:nth-child(2) {
	padding: 20px 20px 20px 10px;
}

.split-record-table td {
	padding: 10px;
	vertical-align: top;
}

@media screen and (max-width: 768px) {
	.split-record-table td {
		box-sizing: border-box;
		display: block;
		width: 100%;
	}
	
	.split-record-table td img {
		width: 100%;
	}
	
	.split-record-table td:last-child {
		padding: 20px;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Split Record Table (e.g. Announcements) ------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.card {
	background: #fff;
	box-shadow: 0 3px 6px rgba(0,0,0,0.08);
	border-radius: 4px;
}

.card.padding {
	padding: 10px;
}

.card h3 {
	color: #1b70ba;
	font-size: 18px;
}

.card.detail-page {
	padding: 30px 50px;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Dashboard ------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
@media screen and (min-width: 880px) {
	.dashboard .col {
		border: 0;
		float: left;
		margin: 0;
		padding: 0;
		width: 48.5%;
	}

	.dashboard .col.last {
		float: right;
	}
}

/*
.dashboard .gray-box {
	background: none;
	box-shadow: none;
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	border: 0;
	margin-bottom: 80px;
	padding: 0;
}
*/

.dashboard .gray-box {
	margin-bottom: 30px;
	overflow: hidden;
	position: relative;
}

@media screen and (max-width: 880px) {
	.dashboard .gray-box {
		border-bottom: 1px solid #ccc;
		margin-bottom: 30px;
		padding-bottom: 30px;
	}
}

.dashboard .gray-box h3 {
	color: #333333;
	margin: 0 0 10px 0;
}


.dashboard .gray-box p,
.dashboard .gray-box .display-table-wrap {
	background: #ffffff;
	margin: 0 -15px -10px -15px;
}

.dashboard .gray-box p {
	padding: 15px;
}

.dashboard .button {
	background: none;
	color: #ec7c76;
	letter-spacing: 0;
	margin: 3px;
	padding: 0;
	text-transform: uppercase;
}

.dashboard .button.mr {
	margin-right: 15px;
}

.dashboard .button:hover {
	background: none;
	color: #333333;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Responsive Layout/Detail Page ----------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.responsive-layout .col-2 {
	display: inline-block;
	margin: 0;
	vertical-align: top;
	width: calc(50% - 40px);
}

.responsive-layout .col-2:nth-child(1) {
	margin-right: 80px;
}

.hr {
	margin: 40px 0;
}

.hr hr {	
	display: none;
}

@media screen and (min-width: 1180px) {
	.detail {
		display: flex;
	}

	.detail .col {
		display: inline-block;
		margin: 0 40px 0 0;
		vertical-align: top;
		width: calc(50% - 20px);
	}

	.detail .col:last-child {
		margin: 0;
	}

	.detail .col.narrow {
		max-width: 500px;
		width: calc(100% / 3);
	}

	.detail .col.wide {
		max-width: 800px;
		width: calc((100% / 3) * 2);
	}

	.detail .col.wide:nth-child(2) {
		margin-left: 80px;
		width: calc(((100% / 3) * 2) - 80px);
	}
}

@media screen and (max-width: 1180px) {
	.detail .col { 
		margin-bottom: 35px;
	}
}

@media screen and (max-width: 800px) {
	.responsive-layout .col-2,
	.responsive-layout .col-2:nth-child(1) { 
		display: block;
		margin: 0 0 30px 0;
		width: auto;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* FileDrop Styling ------------------------------------------------------------------------------------------------------ */
/* ----------------------------------------------------------------------------------------------------------------------- */
/* Essential FileDrop zone element configuration: */
.fd-zone {
  position: relative;
  overflow: hidden;
  /* The following are not required but create a pretty box: */
  text-align: center;
}

/* Hides <input type="file"> while simulating "Browse" button: */
.fd-file {
  opacity: 0;
  font-size: 118px;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  padding: 0;
  margin: 0;
  cursor: pointer;
  filter: alpha(opacity=0);
  font-family: sans-serif;
}

/* Provides visible feedback when user drags a file over the drop zone: */
.fd-zone.over { border-color: maroon; background: #eee; }


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Training -------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.page-training iframe {
	width: 100%;
}

.training-card {
	display: inline-block;
	max-width: 420px;
}

.training-card .icon-check {
	color: #1b70ba;
	font-size: 23px;
}

.training-card .upper-training-card {
	padding: 20px;
}

.training-card .upper-training-card p:last-child {
	margin: 0;
}

.training-card .lower-training-card {
	background: #F7F8FA;
	padding: 20px;
}

.training-card .lower-training-card .ltc-left {
	border-right: 1px solid #C4C4C4;
	display: inline-block;
	margin-right: 30px;
	padding-right: 30px;
	vertical-align: middle;
}

.training-card .lower-training-card .ltc-right {
	display: inline-block;
	vertical-align: middle;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Announcements --------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.announcements-box {
	margin: 80px auto 0 auto;
	max-width: 1100px;
}

.announcements-box h2 {
	border-bottom: 1px solid #D9DADB;
	padding: 0 0 10px 0;
}

.horizontal-card-carousel {
	margin-left: -40px;
	margin-right: -40px;
	overflow: hidden;
}

@media screen and (max-width: 1180px) {
	.horizontal-card-carousel {
		margin-left: 0;
		margin-right: 0;
	}
}

.horizontal-card-carousel .card {
	background: none;
	box-shadow: none;
	outline: none;
	padding: 0 40px;
	position: relative;
}

@media screen and (min-width: 768px) {
	.horizontal-card-carousel:before,
	.horizontal-card-carousel:after {
		background: url(/images/icons/triple-vertical-dots.svg) 50% 50% no-repeat;
		content: '';
		left: calc(100% / 3);
		height: 26px;
		position: absolute;
		top: calc(50% - 13px);
		-webkit-transition: opacity 0.2s linear;
		transition: opacity 0.2s linear;
		width: 6px;
	}

	.horizontal-card-carousel:after {
		left: calc((100% / 3) * 2);
	}

	.horizontal-card-carousel.animating:before,
	.horizontal-card-carousel.animating:after {
		opacity: 0;
		-webkit-transition: opacity 0s linear;
		transition: opacity 0s linear;
	}
}

.horizontal-card-carousel .slick-arrow {
	background: url(/images/icons/orange-arrow-left.svg) 50% 50% no-repeat;
	background-size: 100% auto;
	border: 0;
	cursor: pointer;
	height: 24px;
	left: 0;
	outline: none;
	position: absolute;
	text-indent: -9999px;
	top: calc(50% - 12px);
	width: 14px;
	z-index: 10;
}

.horizontal-card-carousel .slick-arrow.slick-next {
	background-image: url(/images/icons/orange-arrow-right.svg);
	left: auto;
	right: 0;
}
.horizontal-card-carousel .card h3 {

}

.horizontal-card-carousel .card h3 a {
	color: #333;
}

.horizontal-card-carousel .card h3 a:hover {
	color: #3985FF;
}

.horizontal-card-carousel p:last-of-type {
	margin: 0;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Forms ----------------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
form, fieldset, form fieldset ol, form fieldset li {
	margin: 0;
	padding: 0;
}

form { margin: 0; }

form, input, textarea, option, select {
	font-family: 'Roboto', sans-serif;
	font-size: 14px;
}

input, textarea, select, .chosen-container .chosen-choices {
	border: 1px solid #D0D0D0;
	padding: 8px;
}

input.error, 
textarea.error, 
select.error,
.chosen-container.error .chosen-single {
	border-color: red;
}

label.error {
	color: red;
}

input.readonly {
	background: #e5e5e5;
}

fieldset {
	border: 0;
	padding: 0;
	margin: 0 0 20px 0;
	max-width: 1100px;
}

legend {
	border: 0;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	color: #4b4b4b;
	float: left;
	display: table;
	font-weight: bold;
	padding: 5px 0;
	text-indent: 0px;
	text-transform: uppercase;
	width: 100%;
}

form fieldset ol {
	list-style: none;
}

.form,
.view-table {
	background: #ffffff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	border-collapse: collapse;
	width: 100%; 
}

.form td,
.view-table td,
.view-table th {
	padding: 20px 30px;
}

.form td:first-child,
.view-table td:first-child,
.view-table th:first-child {
	border-right: 1px solid #D9DADB;
	width: 135px;
}

@media screen and (max-width: 550px) {
	.form td, 
	.view-table td, 
	.view-table th {
		font-size: 13px;
		padding: 10px;
	}
	
	.form td:first-child,
	.view-table td:first-child,
	.view-table th:first-child {
		width: auto;
	}	
}

.form tr:nth-child(2n),
.view-table tr:nth-child(2n) {
	background: #F7F8FA;
}

.form label,
.view-table th {
	font-weight: bold;
	text-align: left;
}

fieldset label.block {
	display: block;
	width: auto;
}

form em {
	color: red;
	font-style: normal;
	padding: 0 0 0 2px;
}

form select {
	width: 200px;
}

form select.default {
	width: auto;
}

textarea { 
	border: 1px solid #D0D0D0;
	line-height: 15px;
}

input.datepicker,
fieldset .field-wrap.normal input[type=text].datepicker {
	background: #ffffff url(/images/icons/calendar.gif) 108px 48% no-repeat;
	cursor: pointer;
	min-width: 0;
	padding-right: 20px;
	width: 105px;
}

input.datetimepicker {
	background: #ffffff url(/images/icons/calendar.gif) 153px 48% no-repeat;
	padding-right: 20px;
	width: 155px;
	cursor: pointer;
}

form .padding {
	padding: 10px;
}

span.checkbox-wrap,
span.radio-wrap {
	margin: 5px 20px 5px 0;
	min-height: 16px;
	line-height: 16px;
	display: inline-block;
	position: relative;
}

span.checkbox-wrap:last-child,
span.radio-wrap:last-child {
	margin-right: 0;
}

span.radio-wrap label {
	display: inline-block;
	padding-left: 21px;	
}

.radio-wrap label:before {
	border: 1px solid #A3A3A3;
	border-radius: 100%;
	box-sizing: border-box;
	content: '';
	height: 16px;
	left: 0;
	position: absolute;
	top: -1px;
	width: 16px;
}

.radio-wrap label.checked:after {
	background: #1b70ba;
	border-radius: 100%;
	box-sizing: border-box;
	content: '';
	height: 8px;
	left: 4px;
	position: absolute;
	top: 3px;
	width: 8px;	
}

.radio-wrap label.checked {

}

span.checkbox-wrap input {
}

span.checkbox-wrap img {
	margin: -1px 4px 0 0;
	float: left; 
	padding: 3px;
	box-shadow: 0 0 3px rgba(0,0,0,.25);
	-moz-box-shadow: 0 0 3px rgba(0,0,0,.25);
	-webkit-box-shadow: 0 0 3px rgba(0,0,0,.25);
	width: 20px;
}

.checkbox-wrap label.unchecked,
.checkbox-wrap label.checked {
	background: url(/images/icons/checkbox.png) 0 50% no-repeat;
	cursor: pointer;
	display: block;
	padding-left: 27px;
	line-height: 25px;
	min-height: 25px;
	opacity: 1;
}

span.checkbox-wrap label.checked {
	background: url(/images/icons/checkbox-checked.png) 0 50% no-repeat;
}

span.checkbox-wrap label.unchecked:hover,
span.checkbox-wrap label.checked:hover {
	opacity: .60;
	filter: alpha(opacity=60);
}

.address-last-row td {
	border-bottom: 4px solid #cccccc;
}

.content-box-item,
.ui-sortable-placeholder {
	background-color: #e9e9e9;
	border: 1px solid #cccccc;
	border-radius: 3px;
	-moz-border-radius: 3px;
	-webkit-border-radius: 3px;
	min-height: 15px;
	display: block;
	margin: 0 0 4px 0;
	padding: 10px 5px;
}

.content-box-item.ui-sortable-helper {
	border: 1px solid #808080;
}

.content-box-item .handle {
	background: #e9e9e9 url(/images/icons/icon_drag.gif) 4px 50% no-repeat;
	cursor: move;
	display: block;
	float: left;
	height: 15px;
	margin: 0 8px 0 0;
	width: 15px;
}

.ui-sortable-placeholder {
	border: 1px dashed #000000;
	background: #ffffff;
	height: 20px;
	opacity: .4;
	filter: alpha(opacity=40);
}

.chosen-container-multi .chosen-choices li.search-choice {
	float: none;
	margin: 3px 5px;
}

.readonly {
	background: rgba(0,0,0,0.01);
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Plans Dashboard ------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.plans-dashboard {
	
}

.current-credits {
	border: 1px solid #1b70ba;
	background: #fff;
	margin-bottom: 30px;
	font-size: 12px;
	padding: 15px;
}

.current-credits h2 {
	margin-bottom: 10px;
}

@media screen and (min-width: 1200px) {
	.plans-dashboard .table-col,
	.plans-dashboard .announcements-col {
		box-sizing: border-box;
		display: inline-block;
		vertical-align: top;
		width: 80%;
	}

	.plans-dashboard .table-col {
		border-right: 1px solid #D9DADB;
		padding-right: 25px;
	}

	.plans-dashboard .announcements-col {
		padding-left: 25px;
		width: 20%;
	}
}

.announcements-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.announcements-list li {
	border-top: 1px solid #D9DADB;
	padding: 15px 0;
}

@media screen and (max-width: 1200px) {
	.plans-dashboard .announcements-col {
		margin-top: 50px;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Plan Detail ----------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.plan-detail {
	
}

.plan-detail .col {
	box-sizing: border-box;
	padding: 30px 40px;
}

.plan-detail .col.last {
	margin-top: 30px;
}

@media screen and (min-width: 900px) {
	.plan-detail .col {
		display: inline-block;
		vertical-align: top;
	}
	
	.plan-detail .col.first {
		width: 70%;
	}

	.plan-detail .col.last {
		margin-left: 30px;
		margin-top: 0;
		width: calc(30% - 30px);
	}
}

.button-bar {
}

.button-bar .button {
	margin-right: 20px;
}

.hr.thick {
	border-bottom: 10px solid #EDF0F5;
}

@media screen and (max-width: 550px) {
	.button-bar .button {
		display: block;
		margin: 0 0 5px 0;
		text-align: center;
	}
	
	.plan-detail .fr {
		float: none;
	}
}

.mark-estate-plan-as-signed-link-wrap {
	margin-top: 20px;
	text-align: right;
}

.mark-estate-plan-as-signed-link {
	color: inherit;
	background: url(/images/icons/checkbox.png) 100% 50% no-repeat;
	display: inline-block;
	height: 35px;
	line-height: 35px;
	padding-right: 30px;
}

.mark-estate-plan-as-signed-link.checked {
	background-image: url(/images/icons/checkbox-checked.png);
	font-weight: bold;
}

.mark-estate-plan-as-signed-link.disabled {
	color: #808080;
	cursor: not-allowed;
}

a.mark-estate-plan-as-signed-link:hover {
	opacity: 0.7;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Send Secure Link Overlay ---------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.send-secure-link-wrap {
	opacity: 0;
	transition: all 0.5s ease;
	visibility: hidden;
}

.send-secure-link-wrap.visible {
	opacity: 1;
	visibility: visible;
}

.send-secure-link-overlay {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	left: 50%;
	max-width: 90%;
	overflow: hidden;
	position: absolute;
	text-align: center;
	top: 115px;
	transform: translateX(-50%);
	width: 750px;
	z-index: 1001;
}

.send-secure-link-underlay {
	background: #363A3C;
	bottom: 0;
	left: 0;
	opacity: .5;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1000;
}

.send-secure-link-overlay-top {
	padding: 15px 20px;
}

.send-secure-link-overlay-top .close {
	color: #C4C4C4;
	font-size: 17px;
	position: absolute;
	right: 15px;
	top: 15px;
}

.send-secure-link-overlay-top .close:hover {
	color: #333;
}

.send-secure-link-overlay-top .icon-link {
	color: #1b70ba;
	font-size: 30px;
}

.send-secure-link-overlay-top h3 {
	font-size: 16px;
	font-weight: 500;
	margin: 15px 0;
}

.send-secure-link-overlay-top p {
	font-size: 12px;
	margin: 0 0 20px 0;
}

.send-secure-link-overlay-top .field-wrap {

}

.send-secure-link-overlay-top .field-wrap input {
	width: 280px;
}

.send-secure-link-overlay-bottom {
	background: #F7F8FA;
	padding: 20px;
}

.send-secure-link-overlay-bottom .submit {

}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Create a Plan --------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.orange-alert {
	background: url(/images/icons/small-alert-icon.svg) 0 50% no-repeat;
	background-size: 26px 26px;
	color: #1b70ba;
	margin-bottom: 20px;
	padding: 10px 0 10px 35px;
}

.plan-create-page .col.first {
	max-width: 1160px;
	margin-left: calc(((100% - 1160px) / 2) - 200px);
}

.plan-create-page .col.last {
	background: #fff;
	box-shadow: 0 0 5px rgba(0,0,0,0.1);
	box-sizing: border-box;
	padding: 30px;
	position: fixed;
	overflow: auto;
	top: 70px;
	right: 0;
	bottom: 0;
	width: 400px;
}

@media screen and (max-width: 1640px) {
	.plan-create-page .col.first {
		margin: 0;
	}
}

@media screen and (max-width: 1550px) {
	.plan-create-page .col.first {
		margin-right: 300px;
		max-width: 100%;
	}
	
	.plan-create-page .col.last {
		width: 300px;
	}
}

.view-notes-mobile-link,
.hide-notes-mobile-link-wrap {
	display: none;
}

@media screen and (max-width: 1200px) {
	.view-notes-mobile-link {
		display: inline-block;
		margin-left: 20px;
	}
	
	.plan-create-page .col.first {	
		margin-right: auto;
	}
	
	.plan-create-page .col.last {
		right: -270px;
		-webkit-transition: right 0.3s ease;
		transition: right 0.3s ease;
		width: 270px;
	}
	
	.hide-notes-mobile-link-wrap {
		border-bottom: 1px solid #ccc;
		display: block;
		margin-bottom: 20px;
		padding-bottom: 20px;
		text-align: right
	}
	
	.show-notes .plan-create-page .col.last {
		right: 0;
	}
}

@media screen and (max-width: 1000px) {
	.plan-create-page .col.last {
		top: 50px;
	}
}


.step-selector {
	list-style: none;
	margin: 0 -5px 30px -5px;
	padding: 0;
}

.step-selector li {
	display: inline-block;
	margin: 0 5px;
	width: calc((100% / 6) - 10px);
	vertical-align: top;
}

.step-selector li a {
	background: #949ba0;
	border-radius: 2px;
	color: #fff;
	display: block;
	font-size: 12px;
	padding: 13px 0;
	position: relative;
	text-align: center;
}

.step-selector li a div {
	font-size: 10px;
	text-transform: uppercase;
}

.step-selector li.selected a {
	background: #1b70ba;
}

.step-selector li.selected a:after {
	background: #1b70ba;
	content: '';
	height: 14px;
	width: 14px;
	transform: rotate(45deg);
	bottom: -7px;
	position: absolute;
	left: calc(50% - 7px);
}

.step-selector li.passed a {
	background: #F18A00;
	color: #fff;
}

.step-selector li.passed a:after {
	background: #F18A00;
	box-sizing: border-box;
	bottom: -11px;
	border: 2px solid #fff;
	border-radius: 100%;
	content: "\e903";
	font-size: 8px;
	color: #fff;
	font-family: 'icomoon' !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	height: 22px;
	left: calc(50% - 11px);
	line-height: 18px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	position: absolute;
	text-transform: none;
	width: 22px;
}

.step-selector li.disabled a {
	background: #EDF0F5;
	color: #A3A3A3;
	cursor: not-allowed;
}

.plan-create-page .card {
}

.plans-form {
	padding-left: 50px;
	padding-right: 50px;
}

.plans-form h2 {
	font-size: 24px;
	margin: 0 0 60px 0;
	padding-top: 30px;
}

.plans-form .hr {
	border-color: #EDF0F5;
}

.plans-form fieldset {
	max-width: none;
}

.field-wrap {
	margin-bottom: 20px;
}

.field-wrap:after {
	clear: both;
	content: '';
	display: table;
}

.field-wrap:last-child {
	margin-bottom: 0;
}

.striped-bg-field-wraps .field-wrap {
	background: #F7F8FA;
	margin: 0;
	padding: 15px 30px 15px 65px;
}

.striped-bg-field-wraps .field-wrap:nth-child(2n) {
	background: none;
}

.striped-bg-field-wraps .field-wrap label.fl {
	margin-top: 10px;
}

.striped-bg-field-wraps .field-wrap .field-tip-wrap {
	margin-top: 7px;
}

.field-wrap.attention {
	position: relative;
}

.field-wrap.attention:before {
	background: url(/images/icons/small-alert-icon.svg) 50% 50% no-repeat;
	content: '';
	height: 26px;
	left: 10px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 26px;
}

.field-wrap.attention > label {
	color: #1b70ba;
}

.plans-form label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	margin: 0 0 8px 0;
}

.plans-form label.inline {
	display: inline-block;
	margin: 0 30px 0 0;
	vertical-align: middle;
}

.plans-form label.inline.bml {
	margin: 0 15px 0 30px;
}

.plans-form .conditional-parent label {
	font-size: 14px;
}

.plans-form .locked-out {
	position: relative;
}

.plans-form .locked-out:before {
	background: rgba(255,255,255,0.75);
	bottom: 0;
	content: '';
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 5;
}

.first-name-field {
	box-sizing: border-box;
	margin-right: 15px;
	width: calc((100% / 3) - 30px);
	vertical-align: top;
}

.last-name-field {
	box-sizing: border-box;
	width: calc((100% / 3) + 30px);
	vertical-align: top;
}

input.full-width {	
	box-sizing: border-box;
	width: 100%;
}

.half-width {
	box-sizing: border-box;
	width: calc(50% - 7.5px);
	vertical-align: top;
}

.half-width:last-child {
	margin-left: 15px;
}

.field-wrap.state,
.field-wrap.zip,
.field-wrap.county {
	display: inline-block;
	margin-right: 15px;
	min-width: 100px;
	width: calc(30% - 30px);
	vertical-align: top;
}

.field-wrap.zip {
	min-width: 65px
}

.field-wrap.state select,
.field-wrap.zip input,
.field-wrap.county input {
	box-sizing: border-box;
	width: 100%;
}

.field-wrap.county {
	margin: 0;
	width: calc(40% + 30px);
}

.bold {
	font-weight: bold;
}

.g {

}

.gray-bg {
	background: #EDF0F5;
}

.conditional-child.gray-bg {
	padding: 30px;
}

.multiple-add-field {
	box-shadow: 0 1px 4px rgba(0,0,0,0.3);
	border-radius: 3px;
	margin-bottom: 30px;
	padding: 20px 30px;
	position: relative;
}

.multiple-add-field .main-label {
	font-size: 16px;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.multiple-add-field .delete-multi-field-link {
	float: right;
}

.multiple-add-field:first-child > .delete-multi-field-link {
	display: none;
}

.conditional-child {
	display: none;
	padding-left: 30px;
}

.checkbox-stack {
	padding: 5px;
}

.checkbox-stack span.checkbox-wrap,
.checkbox-stack span.radio-wrap {
	display: block;
}

.checkbox-stack span.checkbox-wrap label,
.checkbox-stack span.radio-wrap label {
	display: inline-block;
}

.plans-form .form-step-status {
	background: url(/images/icons/form-step-status.svg) 50% 50% no-repeat;
	background-size: 43px 42px;
	height: 50px;
	margin-top: 30px;
}

.plans-form .form-step-status.submittable {
	background-image: url(/images/icons/form-step-status-complete.svg);
}

.plans-form .submit-wrap {
	border-top: 1px solid #C4C4C4;
	margin: 20px -30px 0 -30px;
	padding-top: 25px;
	padding-bottom: 20px;
	text-align: center;
}

.plans-form .submit-wrap .submit.back {
	background-image: url(/images/icons/white-chevron-left.svg);
	background-position: 20px 50%;
	background-repeat: no-repeat;
	background-size: 5px auto;
	padding-left: 33px;
	float: left;
}

.submit.save-for-later {
	background-image: url(/images/icons/white-clock.svg);
	background-position: 20px 50%;
	background-repeat: no-repeat;
	background-size: 12px 12px;
	padding-left: 40px;
}

.plans-form .submit-wrap .submit.next {
	background-image: url(/images/icons/white-chevron-right.svg);
	background-position: calc(100% - 20px) 50%;
	background-repeat: no-repeat;
	background-size: 5px auto;
	padding-right: 33px;
	float: right;
}

.plans-form .submit-wrap .submit.disabled {
	background-color: #D9DADB;
	cursor: not-allowed;
}

.plans-form .submit-wrap .submit.save-and-complete {
	font-size: 14px;
	margin-top: -5px;
	padding: 15px 30px;
}

.marital-status {
	text-align: center;
}

.marital-status .radio-wrap label {
	box-sizing: border-box;
	border: 1px solid #C4C4C4;
	cursor: pointer;
	padding: 0;
	line-height: 310px;
	height: 200px;
	width: 200px;
	vertical-align: middle;
}

.marital-status.is-client-driven .radio-wrap label {
	line-height: 340px;
}

.marital-status .radio-wrap label:after,
.marital-status .radio-wrap label:before {
	display: none;
}

.marital-status .radio-wrap label img {
	max-height: 70px;
	position: absolute;
	left: 50%;
	top: 40%;
	transform: translateY(-50%) translateX(-50%);
}

.marital-status .radio-wrap label .text {
	display: inline-block;
	line-height: 110%;
}

.marital-status.is-client-driven .radio-wrap label .text small {
	display: block;
	font-weight: 400;
	margin-top: 5px;
	padding: 0 10px;
	font-size: 12px;
}

.marital-status .radio-wrap label.checked {
	background: #F7F8FA;
	border-color: #1b70ba;
}

.notes-list {
	list-style: none;
	margin: 10px 0 0 0;
	padding: 0;
}

.notes-list li {
	border-top: 1px solid #D9DADB;
	font-size: 12px;
	line-height: 22px;
	padding: 10px 0;
}

.notes-list li .delete-plan-note {
	float: right;
	color: #A3A3A3;
	font-size: 10px;
}

.notes-list li .delete-plan-note:hover {
	color: red;
}

.notes-list li h3 {
	color: #1b70ba;
	font-size: 12px;
	font-weight: bold;
	margin: 0 0 5px 0;
}

.fancybox-wrap {
	box-shadow: 0 1px 6px rgba(0,0,0,0.2);
}

span.seperator {
	background: #D9DADB;
	display: inline-block;
	height: 20px;
	margin: 0 15px;
	vertical-align: middle;
	width: 1px;
}

.red-line-issue-overlay {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	left: calc(50% - 210px);
	overflow: hidden;
	position: fixed;
	text-align: center;
	top: 150px;
	width: 420px;
	z-index: 1001;
}

.red-line-issue-overlay-top {
	background: url(/images/icons/orange-circle-alert.svg) 50% 15px no-repeat;
	background-size: 26px 26px;
	padding: 55px 20px 20px 20px;
}

.red-line-issue-overlay h3 {
	font-size: 14px;
	font-weight: bold;
	margin: 0 0 8px 0;
}

.red-line-issue-overlay p {
	font-size: 12px;
	margin: 0;
}

.red-line-issue-overlay-bottom {
	background: #F7F8FA;
	padding: 20px;
}

.red-line-issue-underlay {
	background: rgba(54,58,60,0.5);
	bottom: 0;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1000;
}

@media screen and (max-width: 800px) {
	.step-selector li {
		margin: 0 5px 15px 5px;
		width: calc((100% / 3) - 10px);
	}
	
	.marital-status .radio-wrap label {
		height: 130px;
		line-height: 198px;
		width: 130px;
	}
	
	.marital-status .radio-wrap label img {
		height: 45px;
		top: 35%;
	}
}

@media screen and (max-width: 550px) {
	.plan-create-page .tar.smb .submit,
	.submit-wrap .submit,
	.plans-form .submit-wrap .submit.next {
		display: block;
		float: none;
		margin: 0 0 5px 0;
		text-align: center;
		width: 100%;
	}
	
	.plans-form h2 {
		font-size: 18px;
		margin-bottom: 20px;
		padding-top: 0;
	}
	
	.plans-form {
		padding-left: 10px;
		padding-right: 10px;
	}
	
	.plans-form .submit-wrap {
		margin-left: 0;
		margin-right: 0;
	}
	
	.step-selector li {
		width: calc(50% - 10px);
	}
	
	input[type=text], 
	input[type=password], 
	textarea, 
	select, 
	.chosen-container,
	input.half-width:last-child,
	.field-wrap.state,
	.field-wrap.zip,
	.field-wrap.county {
		box-sizing: border-box;
		margin: 0 0 5px;
		width: 100%;
	}
	
	input[type=text], 
	textarea, 
	select, 
	.chosen-container,
	input.half-width:last-child {
		margin: 0 0 5px;	
	}	
	
	.plans-form label.inline {
		display: block;
		margin: 0 0 5px 0;
	}
	
	.field-wrap {
		margin-bottom: 10px;
	}
	
	.plans-form .hr {
		margin: 20px 0;
	}
	
	.conditional-child {
		padding-left: 0;
	}
	
	.multiple-add-field {
		padding: 10px;
	}
	
	.plans-form label.inline.bml {
		margin: 5px 0;
	}
	
	.plans-form .submit-wrap .submit.save-and-complete {
		margin-top: 0;
	}

	.dragHandle {
		display: none !important;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Plan Summary ---------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.plan-summary-wrap {
	font-size: 14px;
}

.plan-summary-wrap label {
	color: #A3A3A3;
	display: inline-block;
	font-weight: bold;
	margin: 0;
}

.plan-summary-wrap label.bml {
	margin-left: 20px;
}

.plan-summary-wrap h2 {
	font-size: 20px;
	margin: 0 0 20px 0;
	padding: 0;
}

.plan-summary-wrap .edit-link {
	color: #3985FF;
	font-size: 10px;
}

.plan-summary-wrap h4,
.plan-summary-wrap strong {
	font-size: 14px;
	text-transform: uppercase;
	margin: 0 0 3px 0;
	padding: 0;
}

.plan-summary-wrap .indent {
	padding-left: 20px;
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Plan Field Tips ------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.field-tip-wrap {
	height: 18px;
	margin: -2px 0 0 -23px;
	position: absolute;
}

.field-tip-tooltip {
	display: block;
	position: relative;
}

.field-tip-tooltip .icon {
	background: url(/images/icons/field-tip-gray.svg) calc(100% - 3px) 50% no-repeat;;
	background-size: 12px 12px;
	display: block;
	height: 18px;
	position: relative;
	width: 18px;
	z-index: 2;
}

.field-tip-tooltip .text {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.16);
	color: #fff;
	font-size: 9px;
	font-weight: bold;
	height: 18px;
	line-height: 18px;
	max-width: 0px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	text-align: right;
	transition: all 0.1s ease;
	right: calc(100% - 18px);
	z-index: 1;
}

.field-tip-tooltip:hover {
}

.field-tip-tooltip:hover .icon,
.field-tip-wrap.show-tip .field-tip-tooltip .icon {
	background-image: url(/images/icons/field-tip-blue.svg);
}

.field-tip-tooltip:hover .text {
	color: #3985FF;
	padding: 0 20px 0 6px;
	max-width: 150px;
}

.field-tip-wrap.show-tip .field-tip-tooltip:hover .text {
	color: #fff;
	padding: 0;
	max-width: 0px;
}

.field-tip-overlay {
	bottom: 31px;
	border-radius: 4px;
	box-shadow: 0 13px 30px rgba(0,0,0,0.20);
	left: -37px;
	opacity: 0;
	position: absolute;
	text-align: center;
	transition: all 0.3s ease;
	visibility: hidden;
	width: 550px;
	z-index: 2;
}

.field-tip-overlay:after {
	background: #F7F8FA;
	bottom: -10px;
	content: '';
	left: 35px;
	height: 20px;
	position: absolute;
	transform: rotate(45deg);
	width: 20px;
}

.field-tip-wrap.show-tip .field-tip-overlay {
	background: #fff;
	bottom: 31px;
	opacity: 1;
	visibility: visible;
	z-index: 5;
}

.field-tip-overlay-heading {
	background: url(/images/icons/field-tip-blue.svg) 50% 15px no-repeat;
	background-size: 26px 26px;
	border-bottom: 1px solid #EDF0F5;
	color: #3985FF;
	font-size: 20px;
	font-weight: bold;
	padding: 50px 20px 20px 20px;
	text-transform: uppercase;
}

.field-tip-overlay-middle {
	padding: 15px 50px;
}

.field-tip-overlay-bottom {
	background: #F7F8FA;
	padding: 20px;
}

.field-tip-overlay-bottom .button {

}

@media screen and (max-width: 550px) {
	.field-tip-wrap {
		margin-left: -20px;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Training Overlay ------------------------------------------------------------------------------------------------------ */
/* ----------------------------------------------------------------------------------------------------------------------- */
.training-overlay {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16);
	left: calc(50% - 210px);
	overflow: hidden;
	position: absolute;
	text-align: center;
	top: 100px;
	width: 420px;
	z-index: 1001;
}

.training-overlay-upper {
	background: url(/images/icons/orange-circle-alert.svg) 50% 15px no-repeat;
	background-size: 26px 26px;
	padding: 55px 20px 20px 20px;
}

.training-overlay-upper h3 {
	font-size: 14px;
	font-weight: bold;
	margin: 0 0 8px 0;
}

.training-overlay-upper p {
	font-size: 12px;
	margin: 0;
}

.training-overlay-lower {
	background: #F7F8FA;
	padding: 20px;
}

.training-overlay-lower .button {

}

.training-underlay {
	background: rgba(54,58,60,0.5);
	bottom: 0;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1000;
}



/* ----------------------------------------------------------------------------------------------------------------------- */
/* Registration ---------------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.registration-page-wrap {
	max-width: 1100px;
	margin: 0 auto;
}

.registration-page-wrap > h1 {
	margin-bottom: 20px;
	text-align: center;
}

.registration-page-wrap > p {
	text-align: center;
}

.registration-page-wrap form {
	margin-top: 60px;
}

.registration-page-wrap form .field-wrap {
	margin-bottom: 12px;
}

.registration-page-wrap form label {
	display: block;
	font-size: 12px;
	font-weight: 500;
	margin: 0 0 4px 0;
}

.registration-page-wrap form input[type=text],
.registration-page-wrap form input[type=password] {
	box-sizing: border-box;
	width: 100%;
}

.registration-page-wrap .row {
	border-bottom: 1px solid #D9DADB;
	margin-bottom: 30px;
	padding-bottom: 20px;
}

.registration-page-wrap .row.first {

}

.registration-page-wrap .row.last {
}

@media screen and (min-width: 768px) {
	.registration-page-wrap .col {
		box-sizing: border-box;
		border-right: 1px solid #D9DADB;
		display: inline-block;
		padding: 0 30px;
		vertical-align: top;
		width: calc(100% / 3);
	}

	.registration-page-wrap .col.first {
	}

	.registration-page-wrap .col.last {
		border-right: 0;
	}

	.registration-page-wrap .row.last .col.last {
		width: calc((100% / 3) * 2);
	}
}

.registration-page-wrap .row.last .col.last > .field-wrap > p {
	font-size: 12px;
}

.registration-page-wrap .submit-wrap {
	text-align: right;
}

.registration-page-wrap .required-field-note {
	float: left;
}

.registration-page-wrap .field-wrap.city {
	display: inline-block;
	margin-right: 15px;
	width: calc(40% + 30px);
}

.registration-page-wrap .field-wrap.zip {
	margin-right: 0;
}

.registration-page-wrap  .field-wrap.discount-code input[type=text] {
	width: calc(100% - 150px);
	margin-right: 10px;
}


.field-wrap.cc-exp-date,
.field-wrap.cc-cvv {
	box-sizing: border-box;
	display: inline-block;
	width: 70%;
}

.field-wrap.cc-cvv {
	padding-left: 15px;
	width: 30%;
}

.radio-wrap.account-type {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0px 3px 6px rgba(0,0,0,0.16);
	cursor: pointer;
	display: inline-block;
	min-height: 240px;
	overflow: hidden;
	position: relative;
	width: 280px;
	vertical-align: top;
}

.radio-wrap.account-type:hover {
	opacity: .9;
}

.radio-wrap.account-type label {
	cursor: pointer;
	padding: 0;
}

.radio-wrap.account-type label:before {
	background: #fff;
	top: auto;
	bottom: 20px;
	left: calc(50% - 8px);
	z-index: 2;
}

.radio-wrap.account-type label:after {
	top: auto;
	bottom: 24px;
	left: calc(50% - 4px);
	z-index: 2;
}

.radio-wrap.account-type label h3 {
	color: #1b70ba;
	font-size: 24px;
	font-weight: bold;
	margin: 0;
	padding: 15px 0 5px 0;
	text-align: center;
}

.radio-wrap.account-type label p {
	color: #A3A3A3;
	font-size: 11px;
	line-height: 15px;
	margin: 0 0 16px 0;
	padding: 0 15px;
	text-align: center;
}

.radio-wrap.account-type label ul {
	font-size: 12px;
	list-style: none;
	margin: 0;
	padding: 0 20px;
}

.radio-wrap.account-type label ul li {
	margin-bottom: 3px;
}

.radio-wrap.account-type label ul li:last-of-type {
	margin: 0;
}

.radio-wrap.account-type label ul li strong {
	font-size: 16px;
}

.radio-wrap-footer {
	background: #F7F8FA;
	height: 50px;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
}

#card-errors {
	color: red;
	margin-top: 5px;
}

@media screen and (max-width: 768px) {
	.radio-wrap.account-type {
		display: block;
		margin: 0 0 10px 0;
		width: auto;
	}
}


/* ----------------------------------------------------------------------------------------------------------------------- */
/* Credit Card Element/Field for Add/Edit Advisor Form ------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------------------------- */
.StripeElement {
	background-color: white;
	border-radius: 4px;
	border: 1px solid rgba(0,0,0,0.5);
	box-shadow: 0 1px 3px 0 #e6ebf1;
	box-sizing: border-box;
	height: 40px;
	max-width: 100%;
	padding: 10px 12px;
	transition: box-shadow 150ms ease;
	width: 400px;
}

.StripeElement--focus {
	box-shadow: 0 1px 3px 0 #cfd7df;
}

.StripeElement--invalid {
	border-color: #fa755a;
}

.StripeElement--webkit-autofill {
	background-color: #fefde5 !important;
}