.component-container {
	padding: 0 !important;
}

& section.campaign-hero {
	width: 100%;
	position: relative;
	margin-inline: auto;
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: #fff;
	padding: 6rem 0 0;
	width: 100%;

	& picture {
		max-width: 767px;

		@media (max-width: 979px) {
			max-width: 400px;
		}
	}

	& h3 {
		font-weight: 300;
		letter-spacing: 0;
		font-family: var(--body-font-family);
		display: flex;
		flex-direction: column;
		align-items: center;
		font-size: 3rem;
		text-align: center;

		@media (max-width: 767px) {
			font-size: 2rem;
		}

		@media (max-width: 500px) {
			font-size: 1.3rem;
		}

		& span {
			& span {
				color: var(--secondary-color);
			}
		}

		& b {
			font-weight: 700;
			color: var(--secondary-color);
		}
	}

	& p {
		max-width: 860px;
		margin: 0 auto;
		text-align: center;
		text-wrap: balance;
		margin: 1rem auto 3rem;
	}
}

.form-section {
	position: relative;
	background-color: #e0e0e0;
	color: #fff;
	text-align: center;
	padding: 6rem 2rem;
	margin: 0;
	isolation: isolate;

	&:after {
		z-index: -1;
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		opacity: 0.02;
		background-size: 10px 10px;
		background-image: repeating-linear-gradient(
			45deg,
			#fff 0,
			#fff 1px,
			var(--primary-color) 0,
			var(--primary-color) 50%
		);
	}

	.thanks-p {
		color: var(--body-color);
	}

	.rsform-submit-button.rsform-thankyou-button {
		background: var(--secondary-color);
		color: #fff;
		padding: 10px 20px !important;
		line-height: 26px;
		border-radius: 25px;
		text-align: center;
		font-size: 12px;
		font-weight: 700;
		text-transform: uppercase;
		display: block;
		border: none;
		width: 100%;
		margin: 0 auto;
		max-width: 200px;
		box-shadow: none;
	}

	& form {
		position: relative;
		z-index: 10;
		max-width: 979px;
		margin: 0 auto;
	}
}

#prenotaCambioGommeForm.formResponsive {
	.formRed {
		display: flex;
		flex-direction: column;
		align-items: center;
		background-color: red;
		color: #fff;
		padding: 0.5rem;
		gap: 0.5rem;

		& i {
			font-size: 1.8rem;
		}
	}

	.formHorizontal {
		color: #fff;

		& input,
		& select {
			margin: 0 !important;
			padding: 15px;
		}

		& select option {
			text-transform: uppercase;
		}

		.rsform-block > label {
			width: auto;
			position: relative;
			top: 0;
			left: 0;
			max-width: none;
			color: var(--body-color);
			padding: 5px 0px 5px 20px;
			font-size: 0.8rem;
			text-align: left;
		}

		& p.align-center {
			color: #fff;
		}

		.formValidation {
			.formError {
				color: #fff !important;
				margin: 0px 5px 3px 0 !important;
				text-align: center;
				font-weight: 700;
				background: #000;
			}
		}

		.formSpan12 {
			flex-direction: row !important;
			flex-wrap: wrap;
			gap: 1rem !important;
			align-items: flex-start;

			.rsform-block {
				flex: 1 1 40%;
				margin: 0;
			}
		}

		.rsform-block.rsform-block-cvupload {
			flex: 1 1 100%;
			text-align: center;
			margin: 3rem auto;

			& > label {
				position: relative;
				top: 0;
				left: 0;
				color: #fff;
				margin-bottom: 0.6rem;
				cursor: pointer;
				background-color: var(--secondary-color);
				max-width: max-content;
				padding: 0.5rem 1rem;
				border-radius: 10px;
				margin: 0 auto 0.5rem;
				width: 100%;

				&:before {
					content: "\f574";
					font-family: "FontAwesome";
					margin-right: 0.5rem;
				}

				&:hover {
					background-color: var(--dsecondary-color);
					transition: all 300ms linear;
				}
			}

			.formControls {
				.formBody {
					display: flex;
					flex-direction: column;
					align-items: center;
					gap: 0 3rem;

					.formDescription {
						font-size: 0.7rem;
						display: block;
						text-align: center;
						margin-top: 0.5rem;
						font-style: italic;
					}

					.formValidation {
						font-size: 0.8rem;
					}

					& input[type="file"] {
						display: none;
					}
				}
			}
		}

		.rsform-block.rsform-block-faqform {
			order: -1;
			flex: 1 1 100%;
			color: #fff;

			margin: 1rem 0;

			& > label {
				color: var(--secondary-color);
				position: relative;
				top: 0;
				left: 0;
				margin-bottom: 2rem;
				text-align: center;
				max-width: none;
				width: 100%;
				font-size: 1.6rem;
				line-height: 1.2;
			}

			.formControls {
				.formBody {
					display: flex;
					flex-wrap: wrap;
					gap: 2rem;
					justify-content: center;
					align-items: flex-start;

					@media (max-width: 979px) {
						flex-direction: column;
						align-items: center;
						gap: 1rem;
					}

					& > label {
						margin: 0;
						padding: 0.2rem 0.5rem;
						background-color: var(--secondary-color);
					}

					.formDescription {
						font-size: 0.9rem;
						display: block;
						text-align: center;
						margin-top: 0.5rem;
						padding: 1rem 0;
					}
				}
			}
		}

		.rsform-block.rsform-block-submit {
			& button {
				max-width: max-content;
				margin: 0 auto;
				min-width: 200px;
			}
		}

		#venditaForm {
			.rsform-block-message {
				width: 100%;
				flex: 1 1 100%;
				margin: 0;

				& textarea {
					field-sizing: content;
					min-height: 200px;
					width: 100%;
				}
			}
		}

		.rsform-block-name,
		.rsform-block-surname {
			flex: 1 1 40% !important;
		}

		.rsform-block-informativa {
			& a {
				color: var(--secondary-color) !important;
				text-decoration: underline;
			}
		}

		.rsform-block-kmannuo,
		.rsform-block-anticipo {
			flex: 1 1 40% !important;

			& > label {
				position: relative;
				text-align: center;
				color: #fff;
				width: 100%;
				top: 0;
				left: 0;
				margin: 30px auto 10px;
			}

			.formControls {
				.formBody {
					display: flex;
					flex-wrap: wrap;
					justify-content: center;
					gap: 20px;

					& label {
						color: #fff;
						display: flex;
						justify-content: center;
						gap: 5px;
						margin: 0;
						padding: 0;

						& input {
							width: auto;
						}
					}

					& select {
						border-radius: 15px;
						border: none;
						width: 100%;
						padding: 10px;
					}

					& span {
						flex: 1 1 100%;
					}

					& p.formDescription {
						display: none;
					}
				}
			}
		}

		.rsform-block-customertype,
		.rsform-block-duratanoleggio {
			flex: 1 1 40%;

			& > label {
				position: relative;
				text-align: center;
				color: #fff;
				width: 100%;
				top: 0;
				left: 0;
				margin: 30px auto 10px;
			}

			.formControls {
				.formBody {
					display: flex;
					flex-wrap: wrap;
					justify-content: center;
					gap: 20px;

					& label {
						color: #fff;
						display: flex;
						justify-content: center;
						gap: 5px;
						margin: 0;
						padding: 0;

						& input {
							width: auto;
						}
					}

					& span {
						flex: 1 1 100%;
					}

					& p.formDescription {
						display: none;
					}
				}
			}
		}

		.rsform-block-duratanoleggio {
			flex: 0 1 50%;
		}

		.rsform-block-posizionelavorativa {
			display: none !important;
		}

		.rsform-block-posizionelavorativa,
		.rsform-block-sede,
		.rsform-block-address,
		.rsform-block-message,
		.rsform-block-informativa,
		.rsform-block-submit {
			flex: 1 1 100% !important;
		}

		.rsform-block-message {
			margin-top: 2rem !important;

			& > label {
				position: relative;
				max-width: none;
				width: 100%;
				text-align: center;
				text-wrap: balance;
				padding: 0px 0.5rem;
				left: 0;
				color: var(--secondary-color);
				margin-bottom: 1rem;
			}

			& textarea {
				padding: 15px;
			}
		}

		.rsform-block-birthday {
			& > label {
			}

			.formControls {
				background-color: #fff;
				border-radius: 15px;
				padding: 13px;

				display: flex;
				box-sizing: border-box;

				.formBody {
					color: var(--body-color);
					display: flex;
					align-items: center;
				}
			}

			.formValidation {
				position: absolute;
				bottom: 0;
				left: 0;
			}

			& select {
				color: var(--body-color);
				background-color: transparent;
				border: none;
				height: auto;
				padding: 0;
				margin: 0;

				&:focus {
					box-shadow: none;
				}

				& option {
					color: var(--body-color);
				}
			}
		}

		.rsform-block-informativa {
			margin: 2rem auto !important;

			& > label {
				position: relative;
				max-width: none;
				width: 100%;
				text-align: center;
				text-wrap: balance;
				padding: 0px 0.5rem;
				left: 0;

				text-align: center !important;
				margin-bottom: 0.5rem !important;
			}

			.formControls {
				.formBody {
					display: flex;
					flex-direction: column;

					& label {
						display: block;
						position: relative;
						margin: 0 auto;
						padding: 0;
						padding-left: 30px;
						max-width: 480px;
						text-align: left;
						color: var(--body-color);

						& input {
							position: absolute;
							top: 50%;
							left: 0;
							z-index: 10;
							margin: -10px 0 0 !important;
							width: 20px !important;
							height: 20px !important;
						}
					}
				}
			}
		}

		@media (max-width: 768px) {
			.rsform-block {
				flex: 1 1 100% !important;
			}
		}
	}
}
