:root{
	--color-1: #065a5c;
	--color-2: #9eb269;
	--color-3: #193c4c;
	--color-4: #c8d9dd;
	--color-red: #ea5433;
	--color-amber: #fcc447;
	--color-green: var(--color-2);
	--color-text: var(--color-3);
	--color-background: #f0f0e8;
	--color-background-light-grey: #fbfbf9;
	--color-background-dark: #f0f0ea;
	--color-border-grey: var(--color-background-dark);
}

/****/

@font-face{
font-family: "Body"; font-style: normal; font-weight: 400;
src: url("../_lib/_media/fonts/archivo-regular.woff2") format("woff2");
}

@font-face{
font-family: "Body"; font-style: italic; font-weight: 400;
src: url("../_lib/_media/fonts/archivo-italic.woff2") format("woff2");
}

@font-face{
font-family: "Body"; font-style: normal; font-weight: 700;
src: url("../_lib/_media/fonts/archivo-semibold.woff2") format("woff2");
}

@font-face{
font-family: "Body"; font-style: italic; font-weight: 700;
src: url("../_lib/_media/fonts/archivo-semibolditalic.woff2") format("woff2");
}

@font-face{
font-family: "Header"; font-style: normal; font-weight: 700;
src: url("../_media/fonts/heuristica-bold.woff2") format("woff2");
}

@font-face{
font-family: "Header"; font-style: italic; font-weight: 700;
src: url("../_media/fonts/heuristica-bolditalic.woff2") format("woff2");
}

@font-face{
font-family: "Button"; font-style: normal; font-weight: 700;
src: url("../_lib/_media/fonts/archivo-bold.woff2") format("woff2");
}

/****/

#footerWrap{
    padding-top: 0;
}

footer{
    text-align: left;
}

/****/

.navMenu li a{
	font-size: 0.9em;
    text-transform: uppercase;
}

.navMenu li a.current, .navMenu li a:hover, .navMenu li a:focus{
    color: var(--color-2);
}

/****/

.module.socialShare{
	background: var(--color-3);
	color: #ffffff;
	padding: 2em;
	margin: 0 auto;
    border-radius: 3px;
}

.module.socialShare h1, .module.socialShare a{
	color: #ffffff;
}

.module.socialShare p{
	max-width: 750px; 
	margin: 20px auto;
}

.module .socialLinks{
    text-align: center;
	font-size: 2em;
}

.module .socialLinks a{
    display: inline-block;
    padding: 0.4em;
}

.module .hashtag{
    text-align: center;
	font-size: 2em;
}

.module .hashtag a{
	font-weight: inherit;
}

/****/

.logos{
	padding: 1em 0;
	border-bottom: 1px solid var(--color-border-grey);
	margin: 0 auto;
}

.logos ul{
    list-style: none;
    padding: 0;
    margin: 1em auto;
    display: flex;
    gap: 2em;
    align-items: center;
    flex-wrap: wrap;
}

.logos .flexibleImage{
    width: 120px;
    text-align: center;
}

.partnerLogos .flexibleImage{
    width: 90px;
}

/****/

.module{
    max-width: 999em;
}

.module h1{
	line-height: 1.2em;
	font-size: 1.8em;
	color: var(--color-1);
	margin: 0 0 1.5em 0;
}

.module ul.pointer{
    width: 90%;
    margin: 1em auto;
}

.module ul.pointer > li{
    position: relative;
    padding: 4px 0;
    list-style: none;
    font-size: 1em;
}

.module ul.pointer > li:before{
    font-family: "FontAwesome";
  	font-weight: 400;
    content: "\f0da";
    color: var(--color-2);
    padding: 0.1em 1em 0 0;
}

.module.introduction{
    text-align: center;
}

.module p.introduction{
    font-size: 1.3em;
}

.module .informationBox{
	background: var(--color-2);
	padding: 0.8em 1em;
	font-size: 1.2em;
	margin: 2em auto;
}

.module a:not(.uiButton):hover{
	text-decoration: none;
    color: var(--color-2);
    opacity: 1;
}

.module input.text, .module textarea, .module select{
    padding: 0.8em 1em;
}

@media screen and (max-width: 750px){

	.module input.text, .module textarea, .module select{
		width: 100%;
	}

}

.module.breakout{
    padding: 2em 5%;
    margin: -0.1% 0;
    max-width: none;
	font-size: 1em;
}

.module.blue{
    background: var(--color-3);
}

.module.blue{
    color: #ffffff;
}

.module.blue a{
    color: var(--color-2);
}

.module.breakout p{
	margin: 0.5em auto;
	font-weight: 700;
}

.module.breakout p.note{
	font-size: 0.9em;
}

.module.breakout a{
	font-weight: 700;
}

.module.breakout input.text{
    background: #ffffff;
    color: var(--color-3);
}

.module.breakout .informationBox{
    padding: 1em 4em;
}

@media only screen and (min-width: 900px){

	.module.breakout form{
		display: flex;
		flex-flow: row wrap;
		justify-content: center;
		align-items: center;
		align-content: center;
	}

	.module.breakout .formInput{
		flex: 1 1 200px;
		padding: 0.3em;
		margin: 0;
	}

	.module.breakout .formInput.submit{
		flex: 0 0 15em;
	}

	.module.breakout .formInput.submit .uiButton{
		width: 100%;
	}

}

.module.breakout h1{
    border: 0;
    padding: 0;
}

.module.breakout.mailingListModule{
	margin-bottom: -1.1%;
}

.mailingList input.text{
    padding: 1.1em;
    border-color: transparent;
}

.mailingListModule input.text{
	width: 100%;
}

/****/

.adminModule{
    background: #ffffff;
    border-color: transparent;
}

.adminModule h1{
	font-size: 1.5em;
	color: var(--color-1);
}

/****/

.heroBackgroundWrap{
    margin: 0;
    padding: 0;
    max-width: none;
    overflow: hidden;
}

.heroWrap{
	background: var(--color-1);
    background-image: url("../_media/images/hero.jpg");
    background-size: cover;
    background-position: bottom center;
    margin: 0;
    padding: 1em;
    height: 350px;
}

.hero{
    margin: 5em auto 0 auto;
    width: 86%;
    text-align: center;
    color: #ffffff;
    position: relative;
}

.heroTextWrap{
    width: 100%;
    height: 2.2em;
}

.heroText{
    display: none;
    font-size: 1.2em;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.3);
}

.hero h1{
    font-size: 2.5em;
    color: inherit;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.3);
}

.hero p{
    font-size: 1.2em;
    font-weight: 700;
}

.hero a{
    color: inherit;
}

.heroText.current{
    display: block;
}

.hero .buttons{
    position: relative;
    top: 1.5em;
}

.hero .uiButton{
    background: #ffffff;
    color: var(--color-1);
    font-weight: bold;
    font-size: 1.4em;
}

.hero .uiButton:hover{
    background: var(--color-2);
    color: #ffffff;
}

@media only screen and (max-width: 1000px){

	.hero h1{
		font-size: 1.8em;
	}

	.hero p{
		font-size: 1.2em;
	}

}

@media only screen and (max-width: 750px){

	.heroWrap{
		height: 300px;
	}

	.hero{
		margin-top: 3em;
	}

}

@media only screen and (max-width: 630px){

	.hero p{
		font-size: 1.1em;
	}

}

@media only screen and (max-width: 500px){

	.hero{
		margin-top: 2em;
	}

	.hero p{
		font-size: 0.9em;
	}

}

/****/

.responseDataWrap{
    background: var(--color-2);
    margin: 0;
    padding: 20px 0;
    max-width: none;
    overflow: hidden;
    color: #ffffff;
}

.responseData{
    margin: 0 auto 0 auto;
}

.responseData h1{
	font-size: 1.5em;
	color: #ffffff;
	margin: 0.5em auto;
	text-align: center;
}

.responseData .genderChart{
    max-width: 600px;
    margin: 2em auto;
    text-align: center;
}

.responseData .genderChart .genderBar{
    border-radius: 5px;
    width: 80%;
    display: inline-block;
    padding: 0.2em 0.8em;
    background: rgba(255, 255, 255, 0.8);
    color: var(--color-2);
    position: relative;
    text-align: left;
}

.responseData .genderChart .genderMarker{
    border-right: var(--color-2) solid 2px;
    position: absolute;
    top:0;
    left: 0;
    height: 100%;
}

.responseData .genderChart .svg-icon.svg-male, .responseData .genderChart .svg-icon.svg-female{
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.5em;
    padding: 0.2em;
}

.responseData .genderChart .malePercentage, .responseData .genderChart .femalePercentage{
    font-weight: 700;
}

.responseData .genderChart .femalePercentage{
    float: right;
}

.responseData .worldMap{
    width: 100%;
    max-width: 600px;
    margin: auto;
}

.responseData .worldMap .flexibleImage{
    position: relative;
}

.responseData .worldMap .flexibleImage .mapValue{
    position: absolute;
    padding: 3px 5px;
	background: rgba(255, 255, 255, 0.2);
    border-radius: 3px;
    font-size: 0.8em;
    font-weight: 700;
    cursor: default;
}

/****/

.socialBarWrap{
    background: var(--color-1);
    margin: 0;
    padding: 20px 5%;
    max-width: none;
    overflow: hidden;
}

.socialBar{
    margin: 0 auto;
    color: #ffffff;
    position: relative;
    font-weight: 700;
}

.socialBar .socialLinks{
    position: absolute;
    top: -0.4em;
    right: 0;
    margin: 0;
    padding: 0;
}

.socialBar .socialLinks a{
    font-size: 0.8em;
    padding-left: 0.3em;
    color: #ffffff;
}

.socialBar .socialLinks a:hover{
	text-decoration: none;
    color: var(--color-2);
    opacity: 1;
}

/****/

.questionnaire{
    margin: 0 auto 40px auto;
    width: 100%;
}

.questionnaire .pageStatus{
    margin: 2em auto 2em auto;
    font-size: 0.8em;
    font-weight: 700;
	width: 100%;
	overflow-x: auto;
}

.questionnaire .pageStatus a{
    color: var(--color-text);
}

.questionnaire .pageStatus a:hover{
    text-decoration: none;
}

.questionnaire .pageStatus .pageStatusBoxes{
    width: 100%;
    display: flex;
	justify-content: space-between;
	align-items: center;
	align-content: center;
}

.questionnaire .pageStatusBox{
    color: var(--color-text);
    background: var(--color-background);
    width: 2.3em;
    padding: 0.6em 0 0.6em 0;
    position: relative;
    display: inline-block;
    text-align: center;
    z-index: 2;
    border-radius: 50px;
}

.questionnaire .pageStatusBox.current{
  	font-weight: 700;
  	font-size: 1.6em;
}

.questionnaire .pageStatusBox.passed{
    background: var(--color-red);
    color: var(--color-red-overlay);
}

.questionnaire .pageStatusBox.complete{
    background: var(--color-2);
    color: var(--color-2-overlay);
}

.questionnaire .pageStatus .line{
    border-bottom: 3px solid var(--color-1);
    position: relative;
    top: -1.8em;
    z-index: 1;
    margin: 0 2%;
}

.questionnaireContent{
    padding: 0.5em;
    position: relative;
}

.questionnaire h1{
	margin: 1.5em  0 1em 0;
}

.questionnaire a{
	color: var(--color-1);
}

.questionnaire div.submit{
    border-top: 1px solid var(--color-border-grey);
    position: relative;
    padding: 1em 0 1em 0;
}

.questionnaire .uiButton{
    margin-top: 1em;
}

.questionnaire .uiButton{
    color: #ffffff;
    padding: 0.7em 2em;
    font-size: 0.9em;
    display: inline-block;
    margin-top: 1em;
}

.questionnaire label{
    font-size: 0.9em;
    font-family: "Button";
}

.questionnaire label:before{
    font-family: "FontAwesome";
  	font-weight: 400;
    content: "\f0da";
    color: var(--color-2);
    padding: 0.1em 0.8em 0 0;
}

.questionnaire .additional label:before{
    content: "";
    padding: 0;
}

.questionnaire .formInput .labelSpan{
    padding: 1em 1em 0.2em 0;
    font-size: 1em;
}

.questionnaire form{
    display: block;
}

.questionnaire .formInput .inputSpan{
    padding: 1em 0 0.2em 0;
}

.questionnaire .formInput input.text:not([size]), .questionnaire .formInput select, .questionnaire .formInput textarea:not(.fullWidth){
	width: auto;
	max-width: 100%;
}

.createParticipant .formInput textarea{
	width: 100%;
}

.questionnaire .formInput input.text, .questionnaire .formInput select, .questionnaire .formInput textarea, .questionnaire .responseRow select{
    background-color: var(--color-background);
    border-color: transparent;
    padding: 0.8em 1em;
}

.questionnaire .formInput input.text:focus, .questionnaire .formInput textarea:focus, .questionnaire .formInput select:focus{
	border-color: transparent;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}

.questionnaire .formInput.hasValue input.text, .questionnaire .formInput.hasValue select, .questionnaire .formInput.hasValue textarea, .questionnaire .keywords .dataTable.sortable tr{
    background-color: var(--color-2);
    color: var(--color-2-overlay);
}

.questionnaire .formSpecify:not(.hasValue) input.text, .questionnaire .formSpecify:not(.hasValue) textarea{
    background-color: var(--color-background);
    color: var(--color-text);
}

.questionnaire .currency:not(.hasValue) select{
    background-color: var(--color-background);
    color: var(--color-text);
}

.questionnaire.passed .formInput:not(.hasValue) input.text, .questionnaire.passed .formInput:not(.hasValue) select, .questionnaire.passed .formInput:not(.hasValue) textarea{
    background-color: var(--color-red);
    color: var(--color-red-overlay);
}

.questionnaire.passed .formSpecify:not(.hasValue) input.text, .questionnaire.passed .formSpecify:not(.hasValue) textarea{
    background-color: var(--color-red);
    color: var(--color-red-overlay);
}

.questionnaire.passed .currency:not(.hasValue) select{
    background-color: var(--color-red);
    color: var(--color-red-overlay);
}

.questionnaire .formInput.invalid input.text, .questionnaire .formInput.invalid select, .questionnaire .formInput.invalid textarea{
    background-color: var(--color-red);
    color: var(--color-red-overlay);
}

.questionnaire .keywords .dataTable td{
    font-family: "Body";
    font-weight: 400;
	font-size: 1.2em;
}

.questionnaire .keywords .dataTable.sortable tr .uiButton{
	margin-top: 0.2em;
}

.questionnaire .linkedListInput .inputSpan{
	max-width: 100%;
}

.questionnaire .linkedListInput .keywords{
	margin: auto;
}

.questionnaire .linkedListInput .tableWrap{
	margin: auto;
	text-align: right;
}

.questionnaire .linkedListInput table{
	font-size: inherit;
}

.questionnaire .formInput.linkedListInput td{
	border-bottom-color: transparent;
	padding: 0;
}

.questionnaire .formInput.linkedListInput tr:hover td{
	background: transparent;
}

.questionnaire .additional .formInput .labelSpan, .questionnaire .additional .formInput .inputSpan{
    padding-top: 0;
}

.questionnaire .formInput .note{
	margin: 1em 0 0 2em;
	opacity: 0.5;
	font-size: 0.9em;
}

.questionnaire .formInput  .inputSpan .note{
    margin: 0.5em 0 0 0;
}

/****/

.coachingTip{
	color: var(--color-2);
}

.centeredButtons .currencyFilter select{
    padding: 0.6em;
    margin: 1em 0;
    width: 100%;
}

.saveLink{
	font-weight: 700;
	font-size: 1.2em;
	text-align: center;
	margin-top: 2em;
}

