/* GLOBAL */
body h1,
body h2,
body p,
body li,
body a {
  font-family: "Proxima Nova", sans-serif;
}

.l1200 {
  max-width: 1200px;
  width: 95%;
  margin: auto;
}

.l1100 {
  max-width: 100%;
  width: 100%;
  margin: auto;
}

.l1000 {
  max-width: 1000px;
  width: 95%;
  margin: auto;
}

:root {
  --green: #9cc21f;
  --dark-blue: #0c3f62;
  --clear-blue: #009ee3;
}

.text-green,
div p.text-green {
  color: var(--green);
}

div p.text-clear-blue {
  color: var(--clear-blue);
}

.text-white,
.text-white p,
.text-white li {
  color: #fff;
}

.text-dark,
.text-dark p,
.text-dark li {
  color: var(--dark-blue);
}

.text-std,
.text-std p,
.text-std li {
  font-size: 25px;
  line-height: 120%;
  font-weight: 400;
}

p.text-large-semi-bold {
  font-size: 36px;
  line-height: 95%;
  font-weight: 600;
}

.bg-green {
  background: var(--green);
}

.bg-clear-blue {
  background: var(--clear-blue);
}

.bg-gradient-blue {
  background: linear-gradient(to right, #0c3f62 0%, #0c3f62 50%, transparent 50%, transparent 100%);
}

.bg-dark-blue {
  background: var(--dark-blue);
}

.font-regular {
  font-weight: 400;
}

.font-semi-bold {
  font-weight: 600;
}

.font-bold {
  font-weight: 800;
}

.btn-green img,
.link-connect img {
  display: flex;
}

.btn-green,
.btn-clear-blue,
.link-connect {
  display: flex;
  align-items: start;
  gap: 8px;
  text-decoration: none;
  color: var(--dark-blue);
  font-size: 28px;
  font-weight: 700;
}

.btn-green,
.btn-clear-blue {
  line-height: 115%;
  padding: 22px 75px;
  width: max-content;
}

.btn-green {
  background: var(--green);
  border: 2px solid transparent;
}
.btn-clear-blue {
  background: var(--clear-blue);
}

.link-connect {
  margin-top: 7px;
  margin-bottom: 7px;
  line-height: 1;
  padding-left: 40px;
  width: max-content;
  gap: 0;
}

.link-connect strong {
  position: relative;
}

.link-connect strong::after {
  position: absolute;
  content: "";
  bottom: -3px;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--dark-blue);
  transform: translateX(-50%);
  transition: width 0.2s;
  transform-origin: center;
}

.link-connect .arrow {
  margin-right: 7px;
  margin-left: -37px;
}

.btn-green,
.btn-clear-blue,
.link-connect .btn-green img,
.link-connect img,
.btn-green img,
.link-connect img,
.btn-green img,
.link-connect img {
  transition: 0.2s ease;
}

.btn-green:hover img,
.btn-green:active img,
.btn-green:focus img {
  transform: translatex(5px);
}

.btn-green:hover,
.btn-green:active,
.btn-green:focus {
  border-radius: 20px;
  border: 2px solid var(--dark-blue);
}

.link-connect:hover strong::after,
.link-connect:active::after,
.link-connect:focus::after {
  width: 100%;
}

.light-blue-list ul {
  margin: 0 0 0 15px;
  padding: 0;
}

.light-blue-list li,
.white-list li {
  list-style: none;
}

.light-blue-list li::before,
.white-list li::before {
  content: "•";
  font-weight: bold;
  display: inline-block;
  width: 1rem;
  margin-left: -1rem;
}

.light-blue-list li::before {
  color: var(--clear-blue);
}

.white-list li::before {
  color: var(--white);
}

.light-blue-list p {
  margin-top: 2rem;
}

strong {
  font-family: "Proxima Nova", sans-serif;
  font-weight: 700;
}

.title2-dark-blue {
  font-size: 50px;
  font-weight: 700;
  line-height: 95%;
  color: var(--dark-blue);
}
/*
CUSTOM CSS
*/

/* HOME */
.header-banner {
  background-position: center top;
  background-size: 100% auto;
  background-repeat: no-repeat;
  box-shadow: 6px -30px 25px white inset;
}

.header-banner .logo img {
  width: 384px;
  height: 100%;
  object-fit: contain;
}

.header-banner .bg-blue-white {
  padding-bottom: 8rem;
}

.header-banner nav .bg-green {
  min-width: 300px;
  max-height: 135px;
  display: flex;
  justify-content: center;
  align-items: start;
  flex-direction: column;
}

.header-banner h1 {
  font-size: 72px;
  line-height: 86%;
  font-family: "Proxima Nova", sans-serif;
  font-weight: 700;
}

.header-banner p {
  font-size: 35px;
  line-height: 110%;
  font-weight: 400;
  margin-bottom: 0;
}

.header-banner .wrapper-btn {
  margin-top: -95px;
  padding: 0;
}

.header-banner .bg-gradient-blue .wrapper-text {
  padding-bottom: 80px;
}

.header-banner .btn-green {
  width: 100%;
}

#block-steps {
  margin-top: 110px;
}

.wrapper-steps h2,
.wrapper-steps h3 {
  color: var(--green);
  font-weight: 600;
  line-height: 95%;
}

.wrapper-steps h2 {
  text-align: center;
  width: 70px;
  font-size: 35px;
  background: var(--dark-blue);
  z-index: 2;
  position: relative;
}

.wrapper-steps .number-separator,
.wrapper-steps .number-separator-right,
.number-separator-left {
  position: relative;
}

.wrapper-steps .number-separator::after,
.wrapper-steps .number-separator-right::after,
.wrapper-steps .number-separator-left::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translatey(-50%);
  height: 2px;
  background: var(--green);
  padding: 0;
}

.wrapper-steps .number-separator::after {
  right: 0;
  width: 100%;
}

.wrapper-steps .number-separator-right::after {
  right: 0;
  width: 50%;
}

.wrapper-steps .number-separator-left::after {
  left: 0;
  width: 50%;
}

.wrapper-steps h3 {
  font-size: 25px;
  color: var(--green);
  line-height: 120%;
}

.wrapper-steps p {
  font-size: 18px;
  color: white;
  padding: 0 25px;
}

.wrapper-steps .wrapper-img {
  height: 65px;
}

.wrapper-steps div {
  text-align: center;
}

.wrapper-steps .wrapper-img img {
  height: 100%;
  object-fit: contain;
}

.container-signalement {
  margin-top: 50px;
  margin-bottom: -270px;
}

.container-signalement .wrapper-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#block-signaler-probleme .wrapper-img img,
#block-defis-citoyens .wrapper-img img,
#block-services-municipaux .wrapper-img img {
  width: 515px;
  height: 515px;
  object-fit: contain;
  margin-left: -85px;
}

#block-signaler-probleme .block-text {
  margin-top: -40px;
  padding-left: 100px;
}

#block-defis-citoyens {
  margin-top: 235px;
}

#block-defis-citoyens .light-blue-list :not(:last-child) {
  margin-bottom: 2rem;
}

#block-defis-citoyens .light-blue-list p {
  margin: 2.5rem 0;
}

#block-services-municipaux h2 {
  font-size: 30px;
  font-weight: 600;
}

#block-collectivite .wrapper-list-services {
  margin-bottom: 2rem;
  padding-bottom: 3rem;
}

.wrapper-list-services img {
  margin-right: 10px;
  vertical-align: baseline;
  width: 100%;
  max-width: 35px;
  height: 100%;
  object-fit: contain;
}

.wrapper-list-services p {
  padding: 0;
  line-height: 100%;
  margin-bottom: 2rem;
}

#block-collectivite {
  margin-bottom: 110px;
}

#block-collectivite .wrapper-btn {
  margin-bottom: -55px;
}

#block-collectivite {
  padding-bottom: 250px;
  background-position: 60% bottom;
  background-size: 870px auto;
  background-repeat: no-repeat;
}

/* MOBILE */
@media (max-width: 1600px) {
  section#block-collectivite {
    background-position: 100% bottom;
  }

  .l1100 {
    width: 95%;
    max-width: 1100px;
  }
}

@media (max-width: 1200px) {
  body {
    overflow-x: hidden;
  }

  body .header-banner .logo img {
    width: 100%;
  }

  .header-banner nav .bg-green {
    min-width: auto;
  }

  .bg-gradient-blue {
    background: var(--dark-blue);
  }

  .header-banner .container-text {
    max-width: 100%;
  }

  .header-banner nav {
    flex-direction: column;
    gap: 10px;
  }

  .header-banner nav {
    margin-bottom: 20%;
  }

  .wrapper-steps .number-separator-right::after,
  .wrapper-steps .number-separator-left::after {
    width: 100%;
  }
}

@media (max-width: 992px) {
  .header-banner h1 {
    font-size: 45px;
  }

  .header-banner p {
    font-size: 28px;
  }

  .header-banner {
    background-position: top center;
  }

  .header-banner .wrapper-btn {
    margin-top: -20px;
  }

  .btn-green,
  .btn-clear-blue,
  .link-connect {
    padding: 10px 20px;
    font-size: 25px;
  }

  #block-collectivite {
    padding-bottom: 300px;
  }

  #block-signaler-probleme .wrapper-img img,
  #block-defis-citoyens .wrapper-img img,
  #block-services-municipaux .wrapper-img img {
    width: 350px;
    height: 350px;
    margin-left: auto;
  }

  #block-signaler-probleme .block-text {
    margin-top: 10px;
    padding-left: 10px;
  }
}
@media (max-width: 768px) {
  .btn-green,
  .btn-clear-blue {
    font-size: 18px;
    padding: 12px 20px;
  }

  .link-connect {
    font-size: 18px;
    padding: 8px 25px 10px 25px;
  }

  .link-connect br {
    display: none;
  }

  .link-connect .arrow {
    margin-left: 10px;
  }

  .btn-green img,
  .link-connect img {
    width: 18px;
    height: 18px;
  }

  .text-std,
  .text-std p,
  .text-std li {
    font-size: 20px;
  }

  .title2-dark-blue {
    font-size: 35px;
  }

  p.text-large-semi-bold {
    font-size: 28px;
  }

  #block-collectivite {
    background-position: center bottom;
  }

  #block-signaler-probleme .wrapper-img img,
  #block-defis-citoyens .wrapper-img img,
  #block-services-municipaux .wrapper-img img {
    width: 310px;
  }

  #block-steps {
    margin-top: 40px;
  }

  #block-collectivite .wrapper-btn {
    margin-bottom: 31px;
    margin-top: -20px;
  }
}
