/* RESET SCSS */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* TYPOGRAPHY AND BASE */
html {
  font-size: 16px; /* Set a base font size */
  box-sizing: border-box;
}

*, *::before, *::after {
  box-sizing: inherit;
}

body {
  font-family: "Arial", sans-serif;
  line-height: 1.6;
  color: #333;
  background-color: #fff;
}

/* IMAGES AND MEDIA */
img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

/* FORMS */
input, button, textarea, select {
  font: inherit;
  margin: 0;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

/* LINKS */
a {
  text-decoration: none;
  color: inherit;
}

/* UTILITIES */
.hidden {
  display: none !important;
}

:root {
  --light: white;
  --red: #CB5641;
  --primary: #4D6B6E;
  --bg: #EFE9E4;
  --bg-secondary: #4C6B6E;
}

p, a {
  font-size: 16px; /* Set a base font size */
  box-sizing: border-box;
  font-family: "Roboto", sans-serif;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Playfair Display", sans-serif;
  color: var(--primary);
  line-height: 1;
}

.button {
  border-radius: 25px;
  background-color: var(--bg-secondary);
  width: fit-content;
  color: var(--light);
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  min-width: fit-content;
}
.button-light {
  background-color: var(--light);
  color: var(--bg-secondary);
}

.text-red {
  color: var(--red);
}

.header_banner {
  background-color: #92ADAF;
  height: 40px;
  display: flex;
  align-items: center;
  padding: 0 20px;
  color: white;
  font-size: 14px;
}
.header_phone {
  position: absolute;
  bottom: -100%;
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  background-color: #3a9d3a;
  border-radius: 15px;
  padding: 5px 10px;
  border: 2px solid white;
  right: 0px;
}
.header_container {
  max-width: 1600px;
  width: 100%;
  margin: auto;
  position: relative;
}
.header_nav .header_container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
.header_nav img {
  height: 120px;
  width: auto;
  margin-top: 5px;
}
.header_menu {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 20px;
}
.header_menu li {
  position: relative;
}
.header_menu li.active {
  color: #2A5631;
}
.header_menu li.active:after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 65%;
  height: 2px;
  background-color: #BC5E49;
}

.banner {
  background-color: #EFE9E4;
  padding: 0 20px;
}
.banner_top {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
.banner_content {
  display: flex;
  flex-direction: row;
  gap: 100px;
}
.banner_container {
  max-width: 1500px;
  width: 100%;
  margin: auto;
  padding: 50px 0 0 0;
  display: flex;
  flex-direction: column;
  position: relative;
}
.banner_location {
  color: var(--red);
  font-size: 14px;
  font-weight: 500;
}
.banner h1 {
  font-size: 60px;
  font-weight: 500;
}
.banner_p {
  font-size: 20px;
  margin-top: 20px;
}
.banner_guys {
  object-fit: contain;
  height: 390px;
  position: relative;
  top: 70px;
}
.banner_certif {
  height: 110px;
  width: 110px;
}

.services {
  padding: 0 20px;
}
.services_container {
  max-width: 1600px;
  width: 100%;
  margin: 100px auto 0 auto;
  display: flex;
  flex-direction: row;
  gap: 10px;
}
.services_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.services_item h2 {
  font-size: 24px;
  font-weight: 500;
  margin-top: 20px;
}
.services_item span {
  font-size: 14px;
  color: var(--red);
  margin-top: 10px;
}
.services_item a {
  margin-top: 20px;
}

.experience {
  background-color: var(--bg);
  margin-top: 100px;
  padding: 0 20px;
}
.experience_container {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  gap: 100px;
  padding: 100px 0;
  align-items: flex-start;
}
.experience img {
  object-fit: contain;
}
.experience_infos {
  display: flex;
  flex-direction: column;
  width: 50%;
}
.experience_infos span {
  font-size: 14px;
  color: var(--red);
  font-weight: bold;
  margin-bottom: 10px;
}
.experience_infos h2 {
  font-size: 24px;
  font-weight: 500;
}
.experience_infos > p {
  margin-top: 20px;
}
.experience_infos ul li {
  padding-left: 20px;
  position: relative;
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.experience_infos ul li:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 3px;
  height: 100%;
  background-color: var(--light);
}
.experience_infos ul li h3 {
  margin-bottom: 10px;
  font-weight: 500;
}
.experience_infos a {
  margin-top: 50px;
}

.qualities {
  max-width: 1500px;
  width: 100%;
  margin: 100px auto 0;
  display: flex;
  flex-direction: row;
  gap: 100px;
  padding: 0 20px;
}
.qualities_item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  text-align: center;
  max-width: 450px;
}
.qualities_item img {
  height: 50px;
  width: 50px;
  object-fit: contain;
}
.qualities_item h3 {
  font-size: 20px;
  font-weight: 500;
  color: var(--red);
}
.qualities_item p {
  color: var(--primary);
  margin: 10px 0;
}
.qualities_item a {
  margin: auto 0 0 0;
}

.pro {
  max-width: 1600px;
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  margin: 50px auto 0;
  gap: 20px;
  background-color: var(--bg-secondary);
  color: var(--light);
  padding-right: 20px;
}
.pro span {
  font-size: 14px;
}
.pro > div {
  max-width: 550px;
}
.pro h2 {
  margin: 10px 0 20px;
  color: var(--light);
  font-size: 24px;
  font-weight: 500;
}

.agences {
  background-color: var(--bg);
  padding: 0 20px;
}
.agences_container {
  max-width: 1200px;
  width: 100%;
  margin: 100px auto 0;
  padding: 50px 0;
}
.agences_container h2 {
  font-size: 24px;
  text-align: center;
}
.agences_container > p {
  text-align: center;
  color: var(--red);
  margin: 20px auto 50px;
}
.agences_list {
  display: flex;
  flex-direction: row;
  gap: 20px;
  flex-wrap: wrap;
}
.agences_list_number {
  font-weight: 600;
}
.agences_list a {
  font-weight: bold;
  font-size: 14px;
}
.agences li {
  width: calc((100% - 60px) / 4);
  background-color: var(--light);
  padding: 20px 40px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 20px;
  color: var(--primary);
}
.agences li h3 {
  color: var(--red);
  font-weight: 500;
}

.footer {
  background-color: #92ADAF;
}
.footer_container {
  max-width: 1600px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  gap: 30px;
  padding: 0 20px;
}
.footer_phone {
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
  background-color: #3a9d3a;
  border-radius: 25px;
  padding: 5px 10px;
  border: 2px solid white;
  width: fit-content;
  color: var(--light);
}
.footer_col1 {
  margin-top: -65px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  color: var(--light);
  max-width: 400px;
}
.footer_col1 p {
  font-family: "Playfair Display", sans-serif;
}
.footer_col1 img {
  width: 120px;
  height: 120px;
}
.footer_col2 {
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 400px;
}
.footer_col2 p {
  color: var(--light);
  font-family: "Playfair Display", sans-serif;
}
.footer_col3 {
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 400px;
}
.footer_col3 p {
  font-family: "Playfair Display", sans-serif;
  color: var(--light);
}
.footer_col3 a {
  margin-top: -20px;
}
.footer_col3 img {
  margin-top: -60px;
}
.footer_banner {
  display: flex;
  justify-content: space-between;
  grid-column: span 3;
  padding: 30px 20px;
  background-color: var(--bg-secondary);
  color: var(--light);
  font-size: 14px;
}
.footer_banner .footer_container {
  align-items: center;
}
.footer_social {
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
}

.blog {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 20px;
  gap: 40px;
  margin: 100px auto 0;
}
.blog h2 {
  font-size: 24px;
  font-weight: 500;
  color: var(--primary);
}

.carousel {
  max-width: 1200px;
  width: 100%;
  overflow: hidden;
  position: relative;
}

.carousel-track {
  display: flex;
  transition: transform 0.5s ease;
}

.carousel-item {
  min-width: calc((100% - 90px) / 3);
  box-sizing: border-box;
  text-align: center;
  background-color: var(--bg);
  margin: 0 15px;
  border-radius: 5px;
}
.carousel-item img {
  max-height: 280px;
  width: 100%;
  object-fit: cover;
}
.carousel-item h3, .carousel-item p {
  padding: 20px 20px;
  text-align: left;
}
.carousel-item h3 {
  font-size: 20px;
  color: var(--red);
  font-weight: 500;
}
.carousel-item p {
  font-size: 14px;
}

.dots {
  display: flex;
  justify-content: center;
  margin-top: 15px;
}

.dot {
  width: 17px;
  height: 17px;
  margin: 0 5px;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.3s;
  background-color: #EFE9E4;
}

.dot.active {
  background: var(--bg-secondary);
}

.made { margin-top: 0;}

/*# sourceMappingURL=styles.css.map */
