body {
  font-family: 'Roboto', 'Trebuchet MS', Arial;
  margin: 0;
}
strong {
  font-weight: normal;
}
header {
  color: white;
  left: 0;
  right: 0;
  z-index: 10000;
  top: 0;
  display: flex;
  justify-content: space-between;
  width: 100%;
  background: none;
  box-shadow: none;
  height: 7rem;
  line-height: 7rem;
  position: absolute;
}
header a {
  text-decoration: none;
  color: white;
  font-weight: bold;
}
header:before {
  background-color: #0f46bb;
  background-image: url(img/overlay.png), linear-gradient(90deg, rgba(245, 74, 111, 0), #5b9aec 90%);
  background-size: auto, auto;
  background-repeat: repeat, no-repeat;
  content: '';
  display: block;
  height: 0.75rem;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
header .logo {
  padding-left: 20px;
  text-transform: uppercase;
  font-weight: bold;
}
nav {
  flex-shrink: 0;
  flex-grow: 0;
  margin-right: 20px;
  text-transform: uppercase;
}
nav > ul {
  display: -moz-flex;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  list-style: none;
  margin: 0;
  padding-left: 0;
}
nav li {
  padding: 0 10px;
}
.no-webp #banner {
  background-image: linear-gradient(90deg, rgba(58, 58, 58, 0.6), rgba(58, 58, 58, 0.6)), url(img/roofer-2.jpg);
}
.webp #banner {
  background-image: linear-gradient(90deg, rgba(58, 58, 58, 0.6), rgba(58, 58, 58, 0.6)), url(img/roofer-2.jpg);
}
#banner {
  background-color: #3a3a3a;
  color: white;
  padding: 15px 0 15px 0;
  background-attachment: fixed, fixed;
  background-position: right, bottom;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  -webkit-background-size: auto, cover;
  min-height: calc(75vh + 7rem);
  position: relative;
  text-align: center;
  display: grid;
}
#banner::before {
  pointer-events: none;
  -moz-transition: opacity 2s ease-in-out 0.75s;
  -webkit-transition: opacity 2s ease-in-out 0.75s;
  -ms-transition: opacity 2s ease-in-out 0.75s;
  transition: opacity 2s ease-in-out 0.75s;
  background: #333333;
  content: '';
  height: 100%;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
#banner::after {
  background-image: url(img/courbe-1-2.svg);
  background-size: 100% 100%;
  background-position: center;
  bottom: -1px;
  content: '';
  height: 6rem;
  left: 0;
  position: absolute;
  width: 100%;
  box-shadow: inset 0 -1px 0 0 #ffffff;
  pointer-events: none;
}
#banner .content {
  align-self: end;
}
h1,
h2 {
  font-size: 30px;
}
h3 {
  font-size: 25px;
}
.down {
  font-size: 70px;
  align-self: end;
}
.down a {
  text-decoration: none;
}
.down a i {
  background: -webkit-gradient(linear, left top, left bottom, from(#0f46bb), to(#5b9aec));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.section h2,
.section h1,
.section h3 {
  text-transform: uppercase;
}
.section h2 {
  text-align: center;
}
.section h2::after {
  margin: 0 auto;
}
.section h3::after,
.section h2::after {
  position: relative;
  top: 0.75em;
  content: '';
  height: 2px;
  display: block;
  width: 5rem;
  background-color: #0f46bb;
  background-image: url(img/overlay.png), linear-gradient(90deg, rgba(245, 74, 111, 0), #5b9aec 90%);
  background-size: auto, auto;
  background-repeat: repeat, no-repeat;
}
#services {
  padding: 6rem 0;
}
#services p {
  margin-top: 45px;
  font-size: 20px;
  line-height: 29px;
}
#services p.desc {
  text-align: center;
  width: 70%;
  margin: 50px auto;
  font-size: 22px;
}
#services .description {
  display: flex;
  margin: 130px 150px 0 150px;
  align-items: center;
}
#services .description .image {
  flex-shrink: 0;
  border-radius: 100%;
  box-shadow: 0 1rem 3rem 0 rgba(0, 0, 0, 0.25);
  margin: 0 6rem 0 0;
  width: 35rem;
}
#services .description .image img {
  border-radius: 100%;
  display: block;
  width: 100%;
}
#services .description .texte ul {
  margin-top: 40px;
  font-size: 18px;
}
#services .description.pair {
  justify-content: flex-end;
}
#services .description.pair .image {
  margin: 0 0 0 6rem;
}
#realisations {
  background-color: #0f46bb;
  background-image: url(img/overlay.png), linear-gradient(45deg, rgba(245, 74, 111, 0), #5b9aec 90%);
  background-size: auto, auto;
  background-repeat: repeat, no-repeat;
  padding: 8rem 0 10rem 0;
  position: relative;
  top: 0;
  color: white;
  text-align: center;
}
#realisations::before {
  background-image: url(img/courbe.svg);
  background-size: 100% 100%;
  background-position: center;
  content: '';
  height: 8rem;
  left: 0;
  top: 0;
  position: absolute;
  width: 100%;
}
#realisations::after {
  background-image: url(img/courbe-1.svg);
  background-size: 100% 100%;
  background-position: center;
  bottom: -1px;
  content: '';
  height: 8rem;
  left: 0;
  position: absolute;
  width: 100%;
  box-shadow: inset 0 -1px 0 0 #fff;
}
#realisations h3::after,
#realisations h2::after {
  background-color: white!important;
  background-image: none;
  margin: 0 auto;
}
#realisations h2 {
  margin-top: 70px;
}
#contact {
  padding: 70px 20px 8rem 20px;
}
#contact .contact-content {
  flex-direction: column;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  text-align: center;
  align-content: center;
  gap: 50px;
  margin-top: 70px;
  font-size: 20px;
}
#contact .contact-content .contact-devis {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap-reverse;
}
#contact .contact-content .bulle-devis {
  align-self: center;
}
#contact .contact-content .bulle-devis img {
  width: 170px;
  transform: rotate(12deg);
}
#contact .contact-infos {
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: left;
}
#contact .contact-infos .name {
  text-transform: uppercase;
  font-size: 23px;
  font-weight: bold;
}
#contact .contact-infos .contact-item {
  display: flex;
  gap: 10px;
  justify-content: left;
}
#contact .contact-infos .contact-item i {
  background: -webkit-gradient(linear, left top, left bottom, from(#0f46bb), to(#5b9aec));
  background-clip: text;
  font-size: x-large;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: 30px;
}
footer {
  background-color: black;
  background-color: #3a3a3a;
  color: #ffffff;
  padding-top: 14.75rem;
  padding: 5rem 0 3rem 0;
  background-attachment: fixed, fixed;
  background-image: linear-gradient(90deg, rgba(58, 58, 58, 0.6), rgba(58, 58, 58, 0.6)), url(img/roofer-2.jpg);
  background-position: center, center;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  position: relative;
  text-align: center;
}
footer::before {
  pointer-events: none;
  transform: scaleY(-1);
  background-image: url(img/courbe-footer.svg);
  background-size: 100% 100%;
  background-position: center;
  content: '';
  height: 8rem;
  left: 0;
  position: absolute;
  top: -1px;
  width: 100%;
  box-shadow: inset 0 -1px 0 0 #ffffff;
}
footer p {
  padding: 0 1px;
}
footer a {
  text-decoration: none;
  color: white;
}
.fa-ul > li {
  line-height: 1.5rem;
}
.fa-ul > li:not(:last-child) {
  margin-bottom: 1rem;
}
.fa-ul i {
  background: -webkit-gradient(linear, left top, left bottom, from(#0f46bb), to(#5b9aec));
  background-clip: text;
  font-size: x-large;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: 30px;
  font-size: 17px;
}
.topnav .menu-burger {
  display: none;
}
@media all and (max-width: 1440px) {
  #services .description {
    margin: 130px 50px 0 50px;
  }
  #services .description .image {
    width: 28rem;
    margin: 0 3rem 0 0;
  }
}
@media all and (max-width: 1150px) {
  #services .description {
    flex-wrap: wrap;
  }
  #services .description .image {
    margin: 0 auto;
  }
  #services .description.pair .image {
    order: -1;
    margin: 0 auto;
  }
}
@media all and (max-width: 768px) {
  #banner,
  footer {
    background-attachment: initial;
  }
  .topnav ul li:not(.menu-burger) {
    display: none;
  }
  .topnav li.menu-burger {
    float: right;
    display: list-item;
  }
  .topnav.responsive {
    flex-direction: column;
  }
  .topnav.responsive .logo {
    background-color: #0f46bb;
    background-image: url(img/overlay.png), linear-gradient(45deg, rgba(245, 74, 111, 0), #5b9aec 90%);
    background-size: auto, auto;
    background-repeat: repeat, no-repeat;
  }
  .topnav.responsive ul {
    flex-direction: column;
  }
  .topnav.responsive li:not(.menu-burger) {
    display: list-item;
    position: relative;
    line-height: 3rem;
    background-color: rgba(0, 0, 0, 0.8);
    width: 100%;
  }
  .topnav.responsive li.menu-burger {
    position: absolute;
    right: 20px;
    top: 0;
  }
}
@media all and (max-width: 550px) {
  h1,
  h2 {
    font-size: 25px;
  }
  #services {
    padding: 3rem 0 1rem 0;
  }
  #services p.desc {
    width: 100%;
  }
  #services .description {
    margin: 80px 20px 0 20px;
  }
  #services .description .image {
    width: 17rem;
    margin: auto;
  }
  #realisations {
    padding: 5rem 0 8rem 0;
  }
  #contact {
    padding: 30px 20px 3rem 20px;
  }
  #contact .contact-content {
    gap: 20px;
  }
  #contact .contact-devis {
    justify-content: center!important;
    gap: 15px;
  }
}
#contact-form {
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
  padding: 1rem;
  border-radius: 1rem;
  text-align: left;
  display: flex;
  flex-direction: column;
  max-width: 39rem;
}
#contact-form > div:not(.msg-send):not(.note):not(.consent) {
  display: flex;
  flex-direction: column;
  padding: 1rem;
  gap: 0.5rem;
}
#contact-form input,
#contact-form textarea {
  border: 1px solid #ccc !important;
  border-radius: 8px;
  padding: 8px;
  font-size: 1rem;
  font-family: inherit;
}
#contact-form button {
  align-self: flex-end;
  background: -webkit-gradient(linear, left top, left bottom, from(#0f46bb), to(#5b9aec));
  color: white;
  text-transform: uppercase;
  border-radius: 5px;
  border-color: transparent;
  padding: 0.5rem;
}
#contact-form .fa-check {
  color: green;
}
#contact-form .fa-xmark {
  color: red;
}
#contact-form .msg-send {
  display: flex;
}
.grecaptcha-badge {
  visibility: hidden;
}
.note {
  font-size: 0.8rem;
  color: grey;
  font-style: italic;
  padding: 0.5rem 1rem;
}
.note a {
  text-decoration: underline;
  color: grey;
  font-weight: bold;
}
.consent {
  padding: 0.2rem 1rem;
  font-size: 1rem;
}
