/* Custom form
================*/
.form {
	position: relative;
}

.form::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: rgba(255,255,255,0.5);
	cursor: progress;
	z-index: 1;
	opacity: 0;
	visibility: hidden;
	transition: all 0.4s ease-in-out;
}

.form.loading::before {
	opacity: 1;
	visibility: visible;
}

	.form .label {
		margin: 0 0 0.75rem 0;
		color: var(--color-tertiary);
		font-weight: 400;
	}

	.form .input,
	.form .required {
		position: relative;
	}

	.form .required::before {
		content: "";
		position: absolute;
		top: 0.5rem;
		right: 0.5rem;
		width: 0.3125rem;
		height: 0.3125rem;
		border-radius: 50%;
		background-color: #b70e0c;
	}

		.form input[type="text"],
		.form input[type="email"],
		.form input[type="tel"],
		.form select,
		.form textarea {
			display: block;
			width: 100%;
			border: 1px solid #edeff3;
			padding: 0 0.75rem;
			background-color: var(--color-quaternary);
			color: inherit;
			font-size: inherit;
			font-weight: inherit;
		}

		.form input[type="text"],
		.form input[type="email"],
		.form input[type="tel"],
		.form select {
			height: 2.75rem;
		}

		.form select {
			-webkit-appearance: none;
			-moz-appearance: none;
			appearance: none;
		}

		.form select.placeholder {
			color: #89919a;
		}

		.form textarea {
			padding: 0.75rem;
		}

		.form input[type="text"]:focus,
		.form input[type="email"]:focus,
		.form input[type="tel"]:focus,
		.form select:focus,
		.form textarea:focus {
			outline: none;
			border-bottom: 1px solid var(--color-tertiary);
		}

		.form input[type="checkbox"] {
			position: absolute;
			opacity: 0;
			visibility: hidden;
		}

		.form input[type="checkbox"] ~ label {
			position: relative;
			cursor: pointer;
		}

			.form input[type="checkbox"] ~ label > span {
				display: inline-block;
				margin-left: 1.875rem;
				line-height: 1.25rem;
			}

			.form input[type="checkbox"] ~ label > span::before,
			.form input[type="checkbox"] ~ label > span::after {
				content: "";
				position: absolute;
				top: 0;
				left: 0;
				width: 1.25rem;
				height: 1.25rem;
			}

			.form input[type="checkbox"] ~ label > span::before {
				border: 1px solid #edeff3;
				background-color: var(--color-quaternary);
			}

			.form input[type="checkbox"] ~ label > span::after {
				content: "\ea02";
				display: inline-block;
				text-align: center;
				color: var(--color-tertiary);
				font-family: 'icomoon';
				font-size: 0.8125rem;
				line-height: 1.125rem;
				opacity: 0;
			}

			.form input[type="checkbox"]:checked ~ label > span::after {
				opacity: 1;
			}

		.form input:disabled,
		.form select:disabled,
		.form textarea:disabled {
			cursor: not-allowed;
		}

		.form input.error,
		.form select.error,
		.form textarea.error {
			border-bottom: 1px solid #b70e0c;
		}

		.form input[type="checkbox"].error ~ label > span::before {
			border: 1px solid #b70e0c;
		}

		.form input ~ label.error,
		.form select ~ label.error,
		.form textarea ~ label.error {
			position: absolute;
			right: 0;
			bottom: 100%;
			margin-bottom: 0;
			padding: 0.1rem 0.375rem;
			background-color: #b70e0c;
			color: #ffffff;
			font-size: 0.75rem;
		}

		.form input ~ label.error::before,
		.form select ~ label.error::before,
		.form textarea ~ label.error::before {
			content: "";
			position: absolute;
			top: 100%;
			right: 0;
			border-width: 0 0.25rem 0.3125rem 0;
			border-style: solid;
			border-color: transparent #b70e0c transparent #b70e0c;
		}

	.form .input-privacy {
		display: inline-block;
		font-size: 0.8125rem;
	}

	.form .input-privacy + .input-privacy {
		margin-top: 0.9375rem;
	}

	.form .input-button {
		text-align: center;
	}

		.form .input-button button {
			width: 100%;
		}

		.form .form-result {
			display: none;
			margin-top: 1.875rem;
		}
/*
================*/

/* Custom form tabs
================*/
.form-tabs-list-col > a {
	display: block;
	display: flex;
	height: 100%;
	border: 1px solid #edeff3;
	padding: 0.625rem;
	background-color: var(--color-quaternary);
	text-align: center;
	text-decoration: none;
	transition: background-color 0.3s ease, color 0.3s ease;
}

.form-tabs-list-col > a:focus {
	color: var(--color-link-primary);
}

.form-tabs-list-col > a:hover {
	background-color: var(--color-tertiary);
	color: #ffffff;
}

.form-tabs-list-col > a.active {
	background-color: var(--color-tertiary);
	color: #ffffff;
}

	.form-tabs-list-col > a > span {
		margin: auto;
	}

		.form-tabs-list-col > a > span > span {
			display: block;
			font-size: 0.6875rem
		}

.form-tabs-panel {
	display: none;
	border: 1px solid var(--color-tertiary);
	padding: 1.875rem 0.9375rem;
	font-size: 0.8125rem;
}

	.form-tabs-panel-wrap {
		position: relative;
		max-height: 400px;
		padding: 0 0.9375rem;
		overflow-y: auto;
	}

		.form-tabs-panel .select-all,
		.form-tabs-panel .clear-all {
			text-transform: uppercase;
			text-decoration: none;
		}

		.form-tabs-panel .select-all:focus,
		.form-tabs-panel .clear-all:focus {
			color: var(--color-tertiary);
		}

		.form .form-tabs-panel input[type="checkbox"] ~ label > span {
			word-break: break-word;
		}

		.form .form-tabs-panel input[type="checkbox"]:checked ~ label > span {
			color: var(--color-tertiary);
		}
/*
================*/

/* Recaptcha
================*/
.grecaptcha-badge {
	/*left: 0 !important;
	width: 70px !important;
	overflow: hidden !important;*/
	z-index: 500;
	/*transition: all 0.3s ease !important;*/
}

/*.grecaptcha-badge:hover {
	width: 256px !important;
}*/
/*
================*/