@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600&family=Raleway:wght@500;600;700&display=swap');

main {
  margin-top: -5vh;
}

section {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background-color: var(--title-color);
  z-index: 0;
}

section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  background: var(--text-color);
}

.container1 {
  position: relative;
  min-width: 68rem;
  min-height: 34rem;
  display: flex;
  z-index: 99;
}

/** ====== Entre em contacto ====== **/
.container1 .contactInfo {
  position: absolute;
  top: 2.5rem;
  width: 21rem;
  height: calc(100% - 5rem);
  background: var(--title-color);
  z-index: 1;
  padding: 2.5rem;
  display: flex;
  justify-content: center;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 20px 25px rgba(181, 100, 100, 0.15);
}

.container1 .contactInfo h2 {
  color: #fff;
  font-size: 24px;
  font-weight: 500;
}

.container1 .contactInfo ul.info {
  position: relative;
  margin: -15px 0;
  transform: translateY(-4rem);
}

.container1 .contactInfo ul.info li {
  position: relative;
  list-style: none;
  display: flex;
  margin: 20px 0;
  cursor: pointer;
  align-items: flex-start;
}

.container1 .contactInfo ul.info .headicon {
  color: rgb(255, 255, 255);
  font-weight: 700;
}
.container1 .contactInfo ul.info li span:nth-child(1) {
  width: 30px;
  min-width: 30px;
}

.container1 .contactInfo ul.info li span:nth-child(1) img {
  max-width: 100%;
  filter: invert(1);
}

.container1 .contactInfo ul.info li span:nth-child(2) {
  color: rgb(245, 245, 245);
  margin-left: 10px;
  font-weight: 200;
}

/** ====== Formulario ====== **/
.container1 .contactForm {
  position: absolute;
  padding: 4.2rem 3.12rem;
  padding-left: 15rem;
  margin-left: 9.3rem;
  width: calc(100% - 9.3rem);
  height: 100%;
  background: rgb(255, 255, 255);
  box-shadow: 0 50px 50px rgba(0, 0, 0, 0.25);
}

.container1 .contactForm h2 {
  color: var(--title-color);
  font-size: 24px;
  font-weight: var(--weight-medium);
}

.container1 .contactForm .formBox {
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding-top: 30px;
}

.container1 .contactForm .formBox .inpuBox {
  position: relative;
  margin-bottom: 35px;
}

.container1 .contactForm .formBox .inpuBox.w50 {
  width: 47%;
}

.container1 .contactForm .formBox .inpuBox.w100 {
  width: 100%;
}

.container1 .contactForm .formBox .inpuBox input,
.container1 .contactForm .formBox .inpuBox textarea {
  width: 100%;
  resize: none;
  padding: 5px 0;
  font-size: 18px;
  font-weight: 300;
  color: #333;
  border: none;
  outline: none;
  border-bottom: 1px solid #777;
}

.container1 .contactForm .formBox .inpuBox textarea {
  height: 120px;
}

.container1 .contactForm .formBox .inpuBox span {
  position: absolute;
  left: 0;
  padding: 5px 0;
  pointer-events: none;
  font-size: 18px;
  font-weight: 300;
  transition: 0.3s;
}

.container1 .contactForm .formBox .inpuBox input:focus ~ span,
.container1 .contactForm .formBox .inpuBox input:valid ~ span,
.container1 .contactForm .formBox .inpuBox textarea:focus ~ span,
.container1 .contactForm .formBox .inpuBox textarea:valid ~ span {
  transform: translateY(-20px);
  font-size: 12px;
  color: var(--title-color);
  font-weight: 500;
  letter-spacing: 1px;
}

.container1 .contactForm .formBox .inpuBox input[type='submit'] {
  position: relative;
  cursor: pointer;
  background-color: var(--title-color);
  color: #fff;
  max-width: 150px;
  transition: 0.5s;
}

.container1 .contactForm .formBox .inpuBox input[type='submit']:hover {
  background-color: var(--text-color);
}

/** ====== Mapa ====== **/

.map {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background-color: var(--title-color);
}

.mapa {
  box-shadow: 2px 2px 30px rgba(0, 0, 0, 0.25);
}

iframe {
  width: 850px;
  height: 500px;
}

/** ====== Tornando responsivel ====== **/

@media (max-width: 1200px) {
  .container1 {
    width: 90%;
    min-width: auto;
    margin: 20px;
  }

  .container1 .contactInfo {
    top: 0;
    height: 100%;
    position: relative;
    box-shadow: none;
  }

  .container1 .contactForm {
    position: relative;
    width: calc(100% - 350px);
    padding: 0;
    margin: 0px;
    padding: 40px;
    height: 550px;
  }

  .container1 .contactInfo ul.info {
    transform: translateY(0.2rem);
  }

}

@media (max-width: 991px) {
  section {
    margin-top: var(--header-height);
    background-color: var(--text-color);
  }

  section::before {
    display: none;
  }

  .container1 {
    display: flex;
    flex-direction: column-reverse;
  }

  .container1 .contactForm {
    width: 100%;
    height: auto;
  }

  .container1 .contactInfo {
    width: 100%;
    height: auto;
    padding: 25px;
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 600px) {
  .container1 .contactForm {
    padding: 25px;
  }

  .container1 .contactInfo {
    padding: 25px;
    flex-direction: column;
    align-items: flex-start;
  }

  .container1 .contactForm .formBox .inpuBox.w50 {
    width: 100%;
  }
}

.u-footer .u-sheet-1 {
  min-height: 244px;
}

.u-footer .u-social-icons-1 {
  height: 45px;
  min-height: 16px;
  width: 156px;
  min-width: 68px;
  white-space: nowrap;
  margin: 32px 60px 0 auto;
}

.u-footer .u-icon-1 {
  color: rgb(59, 89, 152) !important;
}

.u-footer .u-icon-2 {
  color: rgb(85, 172, 238) !important;
}

.u-footer .u-icon-3 {
  color: rgb(197, 54, 164) !important;
}

.u-footer .u-text-1 {
  width: 362px;
  margin: -51px auto 0;
}

.u-footer .u-image-1 {
  width: 189px;
  height: 77px;
  margin: -201px auto 60px 27px;
}

.u-footer .u-logo-image-1 {
  width: 100%;
  height: 100%;
}
@media (max-width: 1199px) {
  .u-footer .u-sheet-1 {
    min-height: 250px;
  }

  .u-footer .u-social-icons-1 {
    width: 156px;
    margin-top: 22px;
    margin-right: 75px;
  }

  .u-footer .u-text-1 {
    width: auto;
    margin-top: -45px;
    margin-right: 177px;
    margin-left: 132px;
  }

  .u-footer .u-image-1 {
    margin-top: -207px;
    margin-left: 38px;
  }
}
@media (max-width: 991px) {
  .u-footer .u-social-icons-1 {
    margin-right: 35px;
  }

  .u-footer .u-text-1 {
    margin-top: -45px;
    margin-left: 45px;
    margin-right: 45px;
  }

  .u-footer .u-image-1 {
    margin-left: 35px;
  }
}
@media (max-width: 767px) {
  .u-footer .u-sheet-1 {
    min-height: 468px;
  }

  .u-footer .u-social-icons-1 {
    margin-top: 134px;
    margin-right: auto;
  }

  .u-footer .u-text-1 {
    margin-top: 38px;
    margin-left: 0;
    margin-right: 0;
  }

  .u-footer .u-image-1 {
    margin-top: -411px;
    margin-left: auto;
  }
}
@media (max-width: 575px) {
  .u-footer .u-social-icons-1 {
    margin-right: 75px;
  }

  .u-footer .u-image-1 {
    margin-top: -411px;
  }
}
