.form-contatti {
  background-image: url(../img/bg-form-desk.jpg);
  background-size: cover;
  width: 100%;
}
.form-contatti__wrap {
  max-width: 144rem;
  margin: 0 auto;
  display: flex;
}
@media only screen and (max-width: 1000px) {
  .form-contatti__wrap {
    flex-direction: column;
  }
}
.form-contatti__text {
  flex: 1.2;
  padding: 6rem 2rem 6rem 6rem;
}
@media only screen and (max-width: 700px) {
  .form-contatti__text {
    padding: 2.5rem;
  }
}
.form-contatti__text .title-form {
  font-weight: 600;
  font-size: 3.6rem;
  line-height: 1.2;
  color: #fff;
  margin-bottom: 1.6rem;
}
.form-contatti__text p {
  font-weight: 400;
  font-size: 2rem;
  line-height: 1.4;
  color: #fff;
}
.form-contatti__form {
  flex: 2;
  padding: 6rem;
  background: url(../img/bg-form-desk_right.png) repeat-x;
  background-size: cover;
}
@media only screen and (max-width: 700px) {
  .form-contatti__form {
    padding: 2.5rem;
  }
}
.form-contatti__form .title-form {
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.2;
  color: #fff;
  margin: 1rem 0 1.6rem;
}
.form-contatti__form .cont {
  display: flex;
  flex-flow: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
.form-contatti__form .cont .cont-field {
  flex: 0 0 calc(50% - 1.5rem);
  margin-bottom: 1rem;
}
@media only screen and (max-width: 700px) {
  .form-contatti__form .cont .cont-field {
    flex: 0 0 100%;
  }
}
.form-contatti__form .cont .cont-field .msg-error {
  color: #fff;
  font-size: 1.4rem;
  display: block;
  margin-bottom: 1rem;
}
.form-contatti__form .cont .form-control {
  width: 100%;
  border: 1px solid #adb6c2;
  padding: 1.8rem 1.4rem;
  font-size: 1.6rem;
  border-radius: 4px;
  margin-bottom: 0.5rem;
  height: 6rem;
}
.form-contatti__form .cont__submit {
  align-self: flex-end;
  width: 29rem;
}
@media only screen and (max-width: 700px) {
  .form-contatti__form .cont__submit {
    width: 100%;
  }
}
.form-contatti__form .cont__submit button {
  font-weight: 600;
  width: 100%;
  height: 5rem;
  background-color: #fff;
  margin: 0;
  border: 0;
  border-radius: 0.4rem;
  font-size: 1.6rem;
  color: #818d9c;
}
.form-contatti__form .cont__privacy label {
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.4;
  color: #fff;
  position: relative;
}
@media only screen and (max-width: 1000px) {
  .form-contatti__form .cont__captcha {
    margin-bottom: 2rem;
  }
}
.form-contatti__form .cont-attach {
  display: flex;
  flex-flow: column;
  margin-bottom: 30px;
}
.form-contatti__form .cont-attach .cont-attach-title {
  margin-bottom: 16px;
}
.form-contatti__form .cont-attach .cont-attach-title p {
  font-weight: 600;
  font-size: 20px;
  line-height: 140%;
  color: #fff;
}
.form-contatti__form .cont-attach .cont-attach-title p span {
  font-weight: 400;
  font-size: 14px;
  line-height: 1.4;
}
.form-contatti__form .cont-attach .choose-file-button {
  background-color: white;
  padding: 1rem;
  border-radius: 0.3rem;
  cursor: pointer;
  width: 100%;
  text-align: center;
  margin-bottom: 1rem;
}
.form-contatti__form .cont-attach .choose-file-button p {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.4;
  color: #0057a7;
  margin-bottom: 0;
}
.form-contatti__form .cont-attach .choose-file-button p::after {
  content: url("../img/ico-attach.png");
  margin-left: 8px;
  top: 3px;
  position: relative;
}
.form-contatti__form .cont-attach .choose-file-text {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.4;
  color: #fff;
  width: 100%;
  text-align: center;
}
.form-contatti__form textarea {
  width: 100%;
  flex: 0 0 100%;
  height: 22.6rem;
  margin-bottom: 2rem;
  padding: 1.4rem;
  font-size: 1.6rem;
  line-height: 1.6;
}
.form-contatti__form .has-error .form-control {
  border: 2px solid #dc3545;
}

.privacy {
  display: block;
  position: relative;
  padding-left: 30px;
  margin-bottom: 12px;
  cursor: pointer;
  font-size: 22px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.privacy input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 2rem;
  width: 2rem;
  background-color: transparent;
  border: 0.15rem solid #fff;
  border-radius: 0.2rem;
}

.privacy:hover input ~ .checkmark {
  background-color: transparent;
}

.privacy input:checked ~ .checkmark {
  background-color: #2196f3;
}

.checkmark::after {
  content: "";
  position: absolute;
  display: none;
}

.privacy input:checked ~ .checkmark::after {
  display: block;
}

.privacy .checkmark::after {
  left: 6px;
  top: 3px;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}