:root {
	/* client colors */
	--client-light-green: #00d37d;
	--client-dark-green: #02a860;
	--client-dark-blue: #003f5c;

	--client-support-red: #018048;
	--client-support-tan: #9fe895;
	--client-support-purple: #33657d;
	--client-support-orange: #febe3c;
	--client-support-yellow: #fce53d;
	--client-support-black: #2b2b2b;
	--client-support-gray: #dddddd;

	--client-font-body: "Quicksand", sans-serif;
	--client-font-head: "Familjen Grotesk", sans-serif;
	--font-size: 16px;
	--font-family-label: var(--client-font-body);
	--font-family: var(--client-font-body);
}

html,
body {
	font-family: var(--client-font-body);
	line-height: 150%;
}

h1,
h2,
h3,
h4,
.h1,
.h2,
.h3,
.h4 {
	color: var(--client-dark-green);
	font-family: var(--client-font-head);
	letter-spacing: 1;
}

h1,
.h1 {
	color: var(--client-dark-blue);
}

a {
	color: var(--client-dark-blue);
	font-weight: 500;
	text-decoration: underline;

	&:hover {
		color: var(--client-dark-green);
	}
}

.layout {
	background-color: white;
}

/*
    3.2 Header Styling
*/

header {
	border-bottom: 2px solid var(--color-gray-dark);
	& .header-logo {
		width: 300px;
	}
}

@media (max-device-width: 836px), (max-width: 836px) {
	header {
		& > .layout-container {
			flex-direction: column;
			justify-content: center;
			gap: var(--gap-horizontal-50);
		}
	}
}

@media all and (max-device-width: 475px), all and (max-width: 475px) {
	header {
		& .header-logo {
			width: 200px;
		}
	}
}

header {
	padding: 50px;
	& > .layout-container {
		position: relative;
		& > .chat-icon {
			position: absolute;
			right: -40px;
			top: -40px;
		}
	}
}

@media (max-device-width: 875px), (max-width: 875px) {
	header {
		padding-bottom: 15px;
		& > .layout-container {
			flex-direction: column;
			justify-content: center;
			gap: 50px;
			& > .chat-icon {
				display: none;
			}
		}
	}
}

@media (max-device-width: 475px), (max-width: 475px) {
	header {
		& .header-logo {
			width: 300px;
		}
		& > .layout-container {
			min-height: auto;
		}
	}
}

@media (max-device-width: 400px), (max-width: 400px) {
	header {
		padding-left: 10px;
		padding-right: 10px;
	}
}

main > .layout-container {
	/*outline: none;*/
}

/*
    3.4 Footer Styling
*/

footer {
	flex-direction: column;
	& a,
	& a:hover,
	& a:visited {
		color: var(--color-tertiary-normal);
	}
	& .h1,
	& .h2,
	& .h3,
	& .h4 {
		color: var(--color-white-normal);
		font-weight: 500;
	}
	& .h2:after {
		content: "";
		display: block;
		width: var(--column-width-2);
		height: 2px;
		background-color: var(--color-tertiary-normal);
		align-self: flex-start;
		margin-top: var(--gap-vertical-50);
	}
	& .page-text {
		color: var(--color-white-normal);
	}
	& > .layout-container {
		font-size: var(--font-size);
		& > div {
			max-width: var(--column-width-4);
			width: 100%;
		}
		& > .h2 {
			max-width: 100%;
			font-family: var(--font-family-alt);
		}
		& > .routing-links,
		& > .institution-info {
			display: flex;
			flex-wrap: wrap;
			color: var(--color-white-normal);
			& .flex-row {
				gap: 5px;
			}
		}
	}
	& > .footer-application-number {
		color: var(--color-white-normal);
		text-align: right;
		opacity: 0.15;
	}
}

@media all and (max-device-width: 1106px), all and (max-width: 1106px) {
	footer {
		& > .layout-container {
			& > .institution-info {
				max-width: var(--column-width-3);
				width: 100%;
			}
			& > .routing-links {
				max-width: var(--column-width-4);
				width: 100%;
			}
		}
	}
}

@media all and (max-device-width: 836px), all and (max-width: 836px) {
	footer {
		& > .layout-container {
			justify-content: flex-start;
			& > .institution-info {
				max-width: var(--column-width-3);
				width: 100%;
			}
		}
	}
}

@media all and (max-device-width: 656px), all and (max-width: 656px) {
	footer {
		& > .layout-container {
			flex-direction: column;
			& > .institution-info,
			& > .routing-links {
				max-width: var(--column-width-4);
				width: 100%;
			}
		}
	}
}

footer {
	background: #003f5c;
}

.divider::before {
	background-color: var(--client-light-green);
}

.horizontal-divider {
	border-color: var(--client-light-green);
}

.vertical-divider {
	border-color: var(--client-light-green);
}

.page-navigation-container {
	margin-top: 0;
	padding-top: var(--gap-vertical-200);
	border-top: solid 1px var(--client-light-green);
}

.section-header {
	font-size: 20px;
	&:after {
		background-color: var(--client-light-green);
	}
}

.button-primary,
.status-center-page .button-primary {
	background-color: var(--client-dark-green);
	border-color: var(--client-dark-green);
	&:hover:not(:disabled),
	&:active:not(:disabled),
	&:focus:not(:disabled) {
		background-color: var(--client-light-green);
		border-color: var(--client-light-green);
		color: white;
		font-weight: normal;
	}
}

.button-other,
.status-center-page .button-other,
.status-center-page .btn-primary,
.status-center-page .btn-default {
	background-color: white !important;
	border-color: var(--client-dark-blue) !important;
	color: var(--client-dark-blue) !important;
	&:hover:not(:disabled),
	&:active:not(:disabled),
	&:focus:not(:disabled) {
		border-color: var(--client-dark-green) !important;
		color: var(--client-dark-green) !important;
		background-color: white !important;
	}
}

.status-center-page .btn-primary {
	box-shadow: none;
	text-shadow: none;
}

.button-link,
.status-center-page .button-link {
	color: var(--client-dark-blue);
	&:hover:not(:disabled),
	&:active:not(:disabled),
	&:focus:not(:disabled) {
		color: var(--client-dark-green);
	}
}

input.DefaultCBControlClassV3,
input.DefaultRBControlClassV3 {
	accent-color: var(--client-dark-green);
	&:hover {
		accent-color: var(--client-dark-green);
	}
}

input.form-control,
select.form-control {
	color: var(--client-dark-blue);
	border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
	font-family: var(--client-font-body);
	&:focus,
	&:active {
		border-color: var(--client-light-green);
	}
	&:disabled {
		background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
	}
}

.page-Default-Content {
	& .flex-row:has(> .lets-get-started-container) {
		height: 100%;
	}
	& .lets-get-started-container {
		height: auto;
		border-color: var(--client-light-green);
	}
	& .default-thumbnail-container {
		flex-direction: column;
		/*width: 100%;
		max-width: var(--column-width-10);*/
		& > .thumbnail {
			background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
			border-color: var(--client-light-green);
		}
	}
	& .thumbnail-call-to-action {
		& .fiviBtnContainer:after,
		& .arrow-right:after {
			color: var(--client-dark-blue);
		}
		&:hover {
			& .fiviBtnContainer:after,
			& .arrow-right:after {
				color: var(--client-dark-green);
			}
		}
	}
}

.product-services-container {
	& > .product-service-container {
		outline-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
		&:hover {
			background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
		}
		& > .product-service-heading {
			font-size: 20px;
			color: var(--client-dark-blue);
			&:after {
				color: var(--client-dark-green);
			}
		}
		& > .product-service-content {

		}
	}
}

.fiviProdServControl {
	& .fiviProdGroup,
	& .fiviServGroup {
		& > .fiviProductDisplay.fiviProdServ {
			border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
			&:has(> .fiviRadioButton input:checked) {
				background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
			}
		}
	}
}

.fiviControl.fiviTextBox {
	& label.DefaultLabelClass {
		font-weight: 500;
	}
	& .fiviWriteOnlyEditButton,
	& .fiviControlActionsContainer .fiviLinkButton {
		font-weight: 600;
		&:hover,
		&:active,
		&:focus {
			color: var(--client-dark-green);
		}
	}
	& > .fiviValueLabelContainer {
		font-family: var(--client-font-body);
	}
}

.fiviAddressControl .fiviBtnContainer {
	& button {
		font-weight: 600;
		&:active,
		&:hover,
		&:focus {
			color: var(--client-dark-green);
		}
	}
}

.fiviControl.fiviDropDown {
	&:has(option[value=""]:checked) {
		& label.DefaultLabelClass {
			font-weight: 500;
		}
	}
}

.fiviEmploymentHistory .fiviRemoveBtn {
	& > button,
	&:before,
	&:after {
		color: var(--client-dark-green);
	}
}

.fiviEmploymentHistory .fiviRemoveBtn {
	&:hover {
		& > button,
		&:after,
		&:before {
			color: var(--client-dark-green);
		}
	}
}

.fiviEmpHistInputContainer {
	& .fiviEmpHistIncomeContainer {
		order: unset;
		max-width: fit-content;
	}
}

.fiviDisclosureList {
	& .DisclosureLinkV3 {
		color: var(--client-dark-blue);
		&:hover {
			color: var(--client-dark-green);
		}
	}
}

.fiviIDAuthentication {
	& .fiviIDAuthSubmitAnswerContainer {
		margin-top: 0;
		padding-top: var(--gap-vertical-200);
		border-top: solid 1px var(--client-light-green);
	}
}

.funding-method-container {
	& > .fiviPanel {
		& .fiviRadioButton {
			& input {
				& + label {
					border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
					&:hover,
					&:active,
					&:focus {
						border-color: var(--client-dark-blue);
						color: var(--client-dark-blue);
					}
				}
				&:checked + label {
					border-color: var(--client-dark-blue);
					color: var(--client-dark-blue);
					background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
				}
			}
		}
	}
}

.funding-detail {
	border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
}

.fiviCCInfo > span:nth-of-type(2) {
	&:before {
		color: var(--client-dark-blue);
	}
}

.fiviOTPButtonContainer {
	margin-top: 0;
	padding-top: var(--gap-vertical-200);
	border-top: solid 1px var(--client-light-green);
}

.journey-bar {
	& .journey-bar-group.current-group:after {
		background-color: var(--client-dark-green);
	}
	& .journey-bar-group.future-group:after {
		background-color: color-mix(in srgb, var(--client-light-green) 33%, transparent);
	}
	& .journey-bar-group.previous-group:after {
		background-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
	}
}

@media (max-device-width: 875px), (max-width: 875px) {
	.journey-bar-group > span {
		display: none;
	}
}

.fiviDocumentList table > tbody > tr,
.fiviDocumentList table > thead > tr {
	border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
}

.fiviFundingInput input::placeholder {
	color: var(--color-gray-dark) !important;
}

.existing-list-container {
	gap: var(--gap-horizontal-75);
	justify-content: flex-start;
	align-items: flex-start;
	& .fiviLinkButton {
		color: var(--client-dark-blue);
		text-decoration: underline;
		&:hover,
		&:active,
		&:hover {
			color: var(--color-primary-dark);
		}
	}
	& > div.flex-column {
		align-items: center;
	}
	& .h3 {
		width: fit-content;
	}
	& .fiviIndividualHyperlinkList {
		width: fit-content;
	}
}

.existing-list-container {
	gap: var(--gap-horizontal);
	flex-direction: row;
	flex-wrap: wrap;
}

.fiviIndividualIncome > div {
	& .fiviIndividualIncomeRemoveButtonContainer:has(> button) {
		& > button,
		&:before,
		&:after {
			color: var(--client-dark-green);
		}
	}
}

.fiviIndividualIncome > div {
	& .fiviIndividualIncomeRemoveButtonContainer:has(> button) {
		&:hover {
			& > button,
			&:after,
			&:before {
				color: var(--client-dark-green);
			}
		}
	}
}

.fiviProductFundingItem,
.fiviFundingAmount {
	border: none;
}

.fiviFundingInput,
.fiviFundingAmount {
	& > label {
		border-right: none;
	}
}

.fiviProductFundingItem > .fiviFundingInput > label::after {
	color: var(--client-dark-green);
}

.fiviProductFundingItem > .fiviFundingInput > label:has(+ .funding-required):after {
	color: red;
}

/*
    tooltips
*/

/*.DefaultTooltipClass:focus:after {
    content: attr(title);
    position: absolute;
    font-size: 14px;
    background-color: black;
    border-radius: 3px;
    color: white;
    opacity: .9;
    padding: 10px;
    width: fit-content;
    min-width: 200px;
    z-index: 5000;
    right: -30px;
    top: 25px;
}*/

.fivi-popover {
	padding: 10px;
	max-width: 300px;
	border: 2px solid color-mix(in srgb, var(--client-light-green) 66%, transparent);
	border-radius: 5px;
	font-size: calc(var(--font-size) + 2px);
	line-height: var(--font-lineheight);
	font-weight: 400;
	color: var(--font-color);
	width: fit-content;
	background-color: color-mix(in srgb, var(--client-light-green) 15%, white);
    opacity: 0;
	&::backdrop {
		background-color: transparent;
	}
}

@media (pointer: coarse), (hover: none), (max-device-width: 875px), (max-width: 875px) {
	.fivi-popover {
		max-width: 90vw;
        opacity: 1;
		&::backdrop {
			background-color: black;
			opacity: 0.75;
            pointer-events: none;
		}
	}
}

/*
    Status Center Overrides
*/

.status-center-page {
	& input.form-control,
	& select.form-control {
		color: var(--client-dark-blue);
		border-color: color-mix(in srgb, var(--client-light-green) 66%, transparent);
		font-family: var(--client-font-body);
	}
	& .DefaultLabelClassV3 {
		font-family: var(--client-font-body) !important;
		color: var(--client-dark-blue) !important;
		margin-left: 0 !important;
	}
	& .V3SummaryHeader > #topNav > ul > .nav-item > a {
		color: var(--client-dark-blue) !important;
		fill: var(--client-dark-blue) !important;
	}
	& .V3SummaryHeader > #topNav > ul > .nav-item.active {
		border-color: var(--client-dark-green);
		& > a {
			color: var(--client-dark-green) !important;
			fill: var(--client-dark-green) !important;
		}
	}
	& .V3SummaryHeader > #topNav > ul > .nav-item .badge {
		background-color: var(--client-dark-green);
	}
	& .h1,
	& .h2,
	& .h3,
	& .h4,
	& h1,
	& h2,
	& h3,
	& h4 {
		color: var(--client-dark-green);
		font-family: var(--client-font-head);
		letter-spacing: 1;
	}
	& .V3SummaryControl .container-fluid > div > .task {
		border-color: var(--client-light-green);
	}
	& article .task:hover {
		background-color: color-mix(in srgb, var(--client-light-green) 10%, transparent);
	}
	& .V3SummaryControl .container-fluid > div > .task .task-title {
		color: var(--client-dark-blue);
	}
	& .V3SummaryControl .container-fluid > div > .task > .task-icon {
		fill: var(--client-light-green);
	}
}
