/**********************************************************************/
/**********************************************************************/
.formarea {
	display: flex;
	flex-direction: column;
}

/**********************************************************************/
.formarea__input  {
	position: relative;
	margin-bottom: 20px;
}

/**********************************************************************/
.formarea__input input, .formarea__input textarea {
	display: block;
	width: 100%;
	padding: 12px 19px;
	border: 2px solid #007EFF;
	background-color: #FFFFFF;
	font: normal normal 18px / 24px "Open Sans", sans-serif;
	color: #000000;
	outline: none;
    appearance: none;
	transition: background-color 0.3s, border-color 0.3s;
}
body.dark .formarea__input input, body.dark .formarea__input textarea {
	background-color: #1C1D21;
	color: #FFFFFF;
}
.formarea__input input.empty:not(:focus), .formarea__input textarea.empty:not(:focus) {
	background-color: #F2F2F2;
	border-color: #D9D9D9;
}
body.dark .formarea__input input.empty:not(:focus),
body.dark .formarea__input textarea.empty:not(:focus) {
	background-color: #1C1D21;
}
.formarea__input textarea {
	height: 140px;
	resize: none;
}
.formarea__input .error {
	border-color: #F5362D !important;
}

/**********************************************************************/
.formarea__label {
	position: absolute;
	left: 20px;
	top: 0;
	transform: translateY(-50%);
	font: normal normal 14px / 20px "Open Sans", sans-serif;
	color: #007EFF;
	pointer-events: none;
	transition: all 0.3s;
}
.formarea__input input.empty:not(:focus) ~ .formarea__label,
.formarea__input textarea.empty:not(:focus) ~ .formarea__label {
	top: 15px;
	transform: none;
	font-size: 18px;
	color: #C2C2C2;
}
.formarea__input input.error ~ .formarea__label,
.formarea__input textarea.error ~ .formarea__label {
	color: #F5362D;
}
.formarea__label:before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: calc(100% + 10px);
	height: 100%;
	background-color: #FFFFFF;
	opacity: 1;
	transition: opacity 0.3s;
	z-index: -1;
}
body.dark .formarea__label:before {
	background-color: #1C1D21;
}
.formarea__input input.empty:not(:focus) ~ .formarea__label:before,
.formarea__input textarea.empty:not(:focus) ~ .formarea__label:before{
	opacity: 0;
}

/**********************************************************************/
.formarea label.error {
	display: block;
	margin: 5px 0 0;
	font: normal normal 12px / 16px "Open Sans", sans-serif;
	color: #F5362D;
}

/**********************************************************************/
.formarea__submit {
	position: relative;
	display: block;
	width: 100%;
	padding: 7px 20px 8px;
	border: none;
	background-color: rgb(0, 126, 255);
	font: normal 700 22px / 35px "Oswald", sans-serif;
	color: #FFFFFF;
	text-align: center;
	outline: none;
    appearance: none;
	cursor: pointer;
	transition: background-color 0.3s;
}
.formarea__submit:hover {
	background-color: rgba(0, 126, 255, 0.6);
}
.formarea__submit.disabled {
	pointer-events: none;
}

/**********************************************************************/
.formarea__note {
	font-size: 12px;
	line-height: 18px;
	color: #707070;
}
body.dark .formarea__note {
	color: #FFFFFF;
}
.formarea__note a {
	color: #007EFF;
	text-decoration: underline;
}
.formarea__note a:hover {
	text-decoration: none;
}

/**********************************************************************/
.formarea__response {
	display: none;
	margin-top: 20px;
    font-size: 14px;
    line-height: 20px;
	color: #328d1d;
}
.formarea__response.error {
	color: #F5362D;
}
.formarea__response.show {
	display: block;
}


/**********************************************************************/
/**********************************************************************/
.formarea-blue .formarea__input input,
.formarea-blue .formarea__input textarea {
	border-color: #FFFFFF;
	background-color: #007EFF !important;
	color: #FFFFFF;
}
.formarea-blue .formarea__input input.empty:not(:focus),
.formarea-blue .formarea__input textarea.empty:not(:focus) {
	border-color: transparent;
	background-color: rgba(0, 0, 0, 0.1) !important;
}

/**********************************************************************/
.formarea-blue .formarea__label {
	color: #FFFFFF;
}
.formarea-blue .formarea__input input.empty:not(:focus) ~ .formarea__label,
.formarea-blue .formarea__input textarea.empty:not(:focus) ~ .formarea__label {
	color: rgba(0, 0, 0, 0.5) !important;
}
.formarea-blue .formarea__label:before {
	background-color: #007EFF !important;
}

/**********************************************************************/
.formarea-blue .formarea__submit {
	width: 250px;
	max-width: 100%;
	margin: 20px auto 20px 0;
	background-color: #FFFFFF;
	color: #000000;
	text-transform: uppercase;
}
.formarea-blue .formarea__submit:hover {
	background-color: rgba(255, 255, 255, 0.6);
}

/**********************************************************************/
.formarea-blue .formarea__note {
	color: #FFFFFF;
}
.formarea-blue .formarea__note a {
	color: #FFFFFF;
}

/**********************************************************************/
.formarea-blue .formarea__response {
	color: #FFFFFF;
}




/**********************************************************************/
/*********************         RESPONSIVE         *********************/
/**********************************************************************/
@media screen and (max-width: 767px) {
	/******************************************************************/
	/******************************************************************/
	.formarea__note {
		max-width: 280px;
		margin: 25px auto 0;
		text-align: center;
	}

	/******************************************************************/
	.formarea__response {
		text-align: center;
	}
	
	
	/******************************************************************/
	/******************************************************************/
	.formarea-blue .formarea__submit {
		margin: 20px auto -5px;
	}
}