html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  font-family: sans-serif;
}

body {
  margin: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

audio, canvas, progress, video {
  vertical-align: baseline;
  display: inline-block;
}

audio:not([controls]) {
  height: 0;
  display: none;
}

[hidden], template {
  display: none;
}

a {
  background-color: #0000;
}

a:active, a:hover {
  outline: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b, strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

h1 {
  margin: .67em 0;
  font-size: 2em;
}

mark {
  color: #000;
  background: #ff0;
}

small {
  font-size: 80%;
}

sub, sup {
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
  position: relative;
}

sup {
  top: -.5em;
}

sub {
  bottom: -.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

hr {
  box-sizing: content-box;
  height: 0;
}

pre {
  overflow: auto;
}

code, kbd, pre, samp {
  font-family: monospace;
  font-size: 1em;
}

button, input, optgroup, select, textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button, select {
  text-transform: none;
}

button, html input[type="button"], input[type="reset"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled], html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"], input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"] {
  -webkit-appearance: none;
}

input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

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

td, th {
  padding: 0;
}

@font-face {
  font-family: webflow-icons;
  src: url("data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SBiUAAAC8AAAAYGNtYXDpP+a4AAABHAAAAFxnYXNwAAAAEAAAAXgAAAAIZ2x5ZmhS2XEAAAGAAAADHGhlYWQTFw3HAAAEnAAAADZoaGVhCXYFgQAABNQAAAAkaG10eCe4A1oAAAT4AAAAMGxvY2EDtALGAAAFKAAAABptYXhwABAAPgAABUQAAAAgbmFtZSoCsMsAAAVkAAABznBvc3QAAwAAAAAHNAAAACAAAwP4AZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADpAwPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAADAAAAAwAAABwAAQADAAAAHAADAAEAAAAcAAQAQAAAAAwACAACAAQAAQAg5gPpA//9//8AAAAAACDmAOkA//3//wAB/+MaBBcIAAMAAQAAAAAAAAAAAAAAAAABAAH//wAPAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAEBIAAAAyADgAAFAAAJAQcJARcDIP5AQAGA/oBAAcABwED+gP6AQAABAOAAAALgA4AABQAAEwEXCQEH4AHAQP6AAYBAAcABwED+gP6AQAAAAwDAAOADQALAAA8AHwAvAAABISIGHQEUFjMhMjY9ATQmByEiBh0BFBYzITI2PQE0JgchIgYdARQWMyEyNj0BNCYDIP3ADRMTDQJADRMTDf3ADRMTDQJADRMTDf3ADRMTDQJADRMTAsATDSANExMNIA0TwBMNIA0TEw0gDRPAEw0gDRMTDSANEwAAAAABAJ0AtAOBApUABQAACQIHCQEDJP7r/upcAXEBcgKU/usBFVz+fAGEAAAAAAL//f+9BAMDwwAEAAkAABcBJwEXAwE3AQdpA5ps/GZsbAOabPxmbEMDmmz8ZmwDmvxmbAOabAAAAgAA/8AEAAPAAB0AOwAABSInLgEnJjU0Nz4BNzYzMTIXHgEXFhUUBw4BBwYjNTI3PgE3NjU0Jy4BJyYjMSIHDgEHBhUUFx4BFxYzAgBqXV6LKCgoKIteXWpqXV6LKCgoKIteXWpVSktvICEhIG9LSlVVSktvICEhIG9LSlVAKCiLXl1qal1eiygoKCiLXl1qal1eiygoZiEgb0tKVVVKS28gISEgb0tKVVVKS28gIQABAAABwAIAA8AAEgAAEzQ3PgE3NjMxFSIHDgEHBhUxIwAoKIteXWpVSktvICFmAcBqXV6LKChmISBvS0pVAAAAAgAA/8AFtgPAADIAOgAAARYXHgEXFhUUBw4BBwYHIxUhIicuAScmNTQ3PgE3NjMxOAExNDc+ATc2MzIXHgEXFhcVATMJATMVMzUEjD83NlAXFxYXTjU1PQL8kz01Nk8XFxcXTzY1PSIjd1BQWlJJSXInJw3+mdv+2/7c25MCUQYcHFg5OUA/ODlXHBwIAhcXTzY1PTw1Nk8XF1tQUHcjIhwcYUNDTgL+3QFt/pOTkwABAAAAAQAAmM7nP18PPPUACwQAAAAAANciZKUAAAAA1yJkpf/9/70FtgPDAAAACAACAAAAAAAAAAEAAAPA/8AAAAW3//3//QW2AAEAAAAAAAAAAAAAAAAAAAAMBAAAAAAAAAAAAAAAAgAAAAQAASAEAADgBAAAwAQAAJ0EAP/9BAAAAAQAAAAFtwAAAAAAAAAKABQAHgAyAEYAjACiAL4BFgE2AY4AAAABAAAADAA8AAMAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAADgCuAAEAAAAAAAEADQAAAAEAAAAAAAIABwCWAAEAAAAAAAMADQBIAAEAAAAAAAQADQCrAAEAAAAAAAUACwAnAAEAAAAAAAYADQBvAAEAAAAAAAoAGgDSAAMAAQQJAAEAGgANAAMAAQQJAAIADgCdAAMAAQQJAAMAGgBVAAMAAQQJAAQAGgC4AAMAAQQJAAUAFgAyAAMAAQQJAAYAGgB8AAMAAQQJAAoANADsd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzVmVyc2lvbiAxLjAAVgBlAHIAcwBpAG8AbgAgADEALgAwd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzUmVndWxhcgBSAGUAZwB1AGwAYQByd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzRm9udCBnZW5lcmF0ZWQgYnkgSWNvTW9vbi4ARgBvAG4AdAAgAGcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAuAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==") format("truetype");
  font-weight: normal;
  font-style: normal;
}

[class^="w-icon-"], [class*=" w-icon-"] {
  speak: none;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  font-family: webflow-icons !important;
}

.w-icon-slider-right:before {
  content: "";
}

.w-icon-slider-left:before {
  content: "";
}

.w-icon-nav-menu:before {
  content: "";
}

.w-icon-arrow-down:before, .w-icon-dropdown-toggle:before {
  content: "";
}

.w-icon-file-upload-remove:before {
  content: "";
}

.w-icon-file-upload-icon:before {
  content: "";
}

* {
  box-sizing: border-box;
}

html {
  height: 100%;
}

body {
  color: #333;
  background-color: #fff;
  min-height: 100%;
  margin: 0;
  font-family: Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

img {
  vertical-align: middle;
  max-width: 100%;
  display: inline-block;
}

html.w-mod-touch * {
  background-attachment: scroll !important;
}

.w-block {
  display: block;
}

.w-inline-block {
  max-width: 100%;
  display: inline-block;
}

.w-clearfix:before, .w-clearfix:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-clearfix:after {
  clear: both;
}

.w-hidden {
  display: none;
}

.w-button {
  color: #fff;
  line-height: inherit;
  cursor: pointer;
  background-color: #3898ec;
  border: 0;
  border-radius: 0;
  padding: 9px 15px;
  text-decoration: none;
  display: inline-block;
}

input.w-button {
  -webkit-appearance: button;
}

html[data-w-dynpage] [data-w-cloak] {
  color: #0000 !important;
}

.w-code-block {
  margin: unset;
}

pre.w-code-block code {
  all: inherit;
}

.w-optimization {
  display: contents;
}

.w-webflow-badge, .w-webflow-badge > img {
  box-sizing: unset;
  width: unset;
  height: unset;
  max-height: unset;
  max-width: unset;
  min-height: unset;
  min-width: unset;
  margin: unset;
  padding: unset;
  float: unset;
  clear: unset;
  border: unset;
  border-radius: unset;
  background: unset;
  background-image: unset;
  background-position: unset;
  background-size: unset;
  background-repeat: unset;
  background-origin: unset;
  background-clip: unset;
  background-attachment: unset;
  background-color: unset;
  box-shadow: unset;
  transform: unset;
  direction: unset;
  font-family: unset;
  font-weight: unset;
  color: unset;
  font-size: unset;
  line-height: unset;
  font-style: unset;
  font-variant: unset;
  text-align: unset;
  letter-spacing: unset;
  -webkit-text-decoration: unset;
  text-decoration: unset;
  text-indent: unset;
  text-transform: unset;
  list-style-type: unset;
  text-shadow: unset;
  vertical-align: unset;
  cursor: unset;
  white-space: unset;
  word-break: unset;
  word-spacing: unset;
  word-wrap: unset;
  transition: unset;
}

.w-webflow-badge {
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 0 0 1px #0000001a, 0 1px 3px #0000001a;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 2147483647 !important;
  color: #aaadb0 !important;
  overflow: unset !important;
  background-color: #fff !important;
  border-radius: 3px !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 6px !important;
  font-size: 12px !important;
  line-height: 14px !important;
  text-decoration: none !important;
  display: inline-block !important;
  position: fixed !important;
  inset: auto 12px 12px auto !important;
  transform: none !important;
}

.w-webflow-badge > img {
  position: unset;
  visibility: unset !important;
  opacity: 1 !important;
  vertical-align: middle !important;
  display: inline-block !important;
}

h1, h2, h3, h4, h5, h6 {
  margin-bottom: 10px;
  font-weight: bold;
}

h1 {
  margin-top: 20px;
  font-size: 38px;
  line-height: 44px;
}

h2 {
  margin-top: 20px;
  font-size: 32px;
  line-height: 36px;
}

h3 {
  margin-top: 20px;
  font-size: 24px;
  line-height: 30px;
}

h4 {
  margin-top: 10px;
  font-size: 18px;
  line-height: 24px;
}

h5 {
  margin-top: 10px;
  font-size: 14px;
  line-height: 20px;
}

h6 {
  margin-top: 10px;
  font-size: 12px;
  line-height: 18px;
}

p {
  margin-top: 0;
  margin-bottom: 10px;
}

blockquote {
  border-left: 5px solid #e2e2e2;
  margin: 0 0 10px;
  padding: 10px 20px;
  font-size: 18px;
  line-height: 22px;
}

figure {
  margin: 0 0 10px;
}

figcaption {
  text-align: center;
  margin-top: 5px;
}

ul, ol {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

.w-list-unstyled {
  padding-left: 0;
  list-style: none;
}

.w-embed:before, .w-embed:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-embed:after {
  clear: both;
}

.w-video {
  width: 100%;
  padding: 0;
  position: relative;
}

.w-video iframe, .w-video object, .w-video embed {
  border: none;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

button, [type="button"], [type="reset"] {
  cursor: pointer;
  -webkit-appearance: button;
  border: 0;
}

.w-form {
  margin: 0 0 15px;
}

.w-form-done {
  text-align: center;
  background-color: #ddd;
  padding: 20px;
  display: none;
}

.w-form-fail {
  background-color: #ffdede;
  margin-top: 10px;
  padding: 10px;
  display: none;
}

label {
  margin-bottom: 5px;
  font-weight: bold;
  display: block;
}

.w-input, .w-select {
  color: #333;
  vertical-align: middle;
  background-color: #fff;
  border: 1px solid #ccc;
  width: 100%;
  height: 38px;
  margin-bottom: 10px;
  padding: 8px 12px;
  font-size: 14px;
  line-height: 1.42857;
  display: block;
}

.w-input::placeholder, .w-select::placeholder {
  color: #999;
}

.w-input:focus, .w-select:focus {
  border-color: #3898ec;
  outline: 0;
}

.w-input[disabled], .w-select[disabled], .w-input[readonly], .w-select[readonly], fieldset[disabled] .w-input, fieldset[disabled] .w-select {
  cursor: not-allowed;
}

.w-input[disabled]:not(.w-input-disabled), .w-select[disabled]:not(.w-input-disabled), .w-input[readonly], .w-select[readonly], fieldset[disabled]:not(.w-input-disabled) .w-input, fieldset[disabled]:not(.w-input-disabled) .w-select {
  background-color: #eee;
}

textarea.w-input, textarea.w-select {
  height: auto;
}

.w-select {
  background-color: #f3f3f3;
}

.w-select[multiple] {
  height: auto;
}

.w-form-label {
  cursor: pointer;
  margin-bottom: 0;
  font-weight: normal;
  display: inline-block;
}

.w-radio {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-radio:before, .w-radio:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-radio:after {
  clear: both;
}

.w-radio-input {
  float: left;
  margin: 3px 0 0 -20px;
  line-height: normal;
}

.w-file-upload {
  margin-bottom: 10px;
  display: block;
}

.w-file-upload-input {
  opacity: 0;
  z-index: -100;
  width: .1px;
  height: .1px;
  position: absolute;
  overflow: hidden;
}

.w-file-upload-default, .w-file-upload-uploading, .w-file-upload-success {
  color: #333;
  display: inline-block;
}

.w-file-upload-error {
  margin-top: 10px;
  display: block;
}

.w-file-upload-default.w-hidden, .w-file-upload-uploading.w-hidden, .w-file-upload-error.w-hidden, .w-file-upload-success.w-hidden {
  display: none;
}

.w-file-upload-uploading-btn {
  cursor: pointer;
  background-color: #fafafa;
  border: 1px solid #ccc;
  margin: 0;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: normal;
  display: flex;
}

.w-file-upload-file {
  background-color: #fafafa;
  border: 1px solid #ccc;
  flex-grow: 1;
  justify-content: space-between;
  margin: 0;
  padding: 8px 9px 8px 11px;
  display: flex;
}

.w-file-upload-file-name {
  font-size: 14px;
  font-weight: normal;
  display: block;
}

.w-file-remove-link {
  cursor: pointer;
  width: auto;
  height: auto;
  margin-top: 3px;
  margin-left: 10px;
  padding: 3px;
  display: block;
}

.w-icon-file-upload-remove {
  margin: auto;
  font-size: 10px;
}

.w-file-upload-error-msg {
  color: #ea384c;
  padding: 2px 0;
  display: inline-block;
}

.w-file-upload-info {
  padding: 0 12px;
  line-height: 38px;
  display: inline-block;
}

.w-file-upload-label {
  cursor: pointer;
  background-color: #fafafa;
  border: 1px solid #ccc;
  margin: 0;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: normal;
  display: inline-block;
}

.w-icon-file-upload-icon, .w-icon-file-upload-uploading {
  width: 20px;
  margin-right: 8px;
  display: inline-block;
}

.w-icon-file-upload-uploading {
  height: 20px;
}

.w-container {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
}

.w-container:before, .w-container:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-container:after {
  clear: both;
}

.w-container .w-row {
  margin-left: -10px;
  margin-right: -10px;
}

.w-row:before, .w-row:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-row:after {
  clear: both;
}

.w-row .w-row {
  margin-left: 0;
  margin-right: 0;
}

.w-col {
  float: left;
  width: 100%;
  min-height: 1px;
  padding-left: 10px;
  padding-right: 10px;
  position: relative;
}

.w-col .w-col {
  padding-left: 0;
  padding-right: 0;
}

.w-col-1 {
  width: 8.33333%;
}

.w-col-2 {
  width: 16.6667%;
}

.w-col-3 {
  width: 25%;
}

.w-col-4 {
  width: 33.3333%;
}

.w-col-5 {
  width: 41.6667%;
}

.w-col-6 {
  width: 50%;
}

.w-col-7 {
  width: 58.3333%;
}

.w-col-8 {
  width: 66.6667%;
}

.w-col-9 {
  width: 75%;
}

.w-col-10 {
  width: 83.3333%;
}

.w-col-11 {
  width: 91.6667%;
}

.w-col-12 {
  width: 100%;
}

.w-hidden-main {
  display: none !important;
}

@media screen and (max-width: 991px) {
  .w-container {
    max-width: 728px;
  }

  .w-hidden-main {
    display: inherit !important;
  }

  .w-hidden-medium {
    display: none !important;
  }

  .w-col-medium-1 {
    width: 8.33333%;
  }

  .w-col-medium-2 {
    width: 16.6667%;
  }

  .w-col-medium-3 {
    width: 25%;
  }

  .w-col-medium-4 {
    width: 33.3333%;
  }

  .w-col-medium-5 {
    width: 41.6667%;
  }

  .w-col-medium-6 {
    width: 50%;
  }

  .w-col-medium-7 {
    width: 58.3333%;
  }

  .w-col-medium-8 {
    width: 66.6667%;
  }

  .w-col-medium-9 {
    width: 75%;
  }

  .w-col-medium-10 {
    width: 83.3333%;
  }

  .w-col-medium-11 {
    width: 91.6667%;
  }

  .w-col-medium-12 {
    width: 100%;
  }

  .w-col-stack {
    width: 100%;
    left: auto;
    right: auto;
  }
}

@media screen and (max-width: 767px) {
  .w-hidden-main, .w-hidden-medium {
    display: inherit !important;
  }

  .w-hidden-small {
    display: none !important;
  }

  .w-row, .w-container .w-row {
    margin-left: 0;
    margin-right: 0;
  }

  .w-col {
    width: 100%;
    left: auto;
    right: auto;
  }

  .w-col-small-1 {
    width: 8.33333%;
  }

  .w-col-small-2 {
    width: 16.6667%;
  }

  .w-col-small-3 {
    width: 25%;
  }

  .w-col-small-4 {
    width: 33.3333%;
  }

  .w-col-small-5 {
    width: 41.6667%;
  }

  .w-col-small-6 {
    width: 50%;
  }

  .w-col-small-7 {
    width: 58.3333%;
  }

  .w-col-small-8 {
    width: 66.6667%;
  }

  .w-col-small-9 {
    width: 75%;
  }

  .w-col-small-10 {
    width: 83.3333%;
  }

  .w-col-small-11 {
    width: 91.6667%;
  }

  .w-col-small-12 {
    width: 100%;
  }
}

@media screen and (max-width: 479px) {
  .w-container {
    max-width: none;
  }

  .w-hidden-main, .w-hidden-medium, .w-hidden-small {
    display: inherit !important;
  }

  .w-hidden-tiny {
    display: none !important;
  }

  .w-col {
    width: 100%;
  }

  .w-col-tiny-1 {
    width: 8.33333%;
  }

  .w-col-tiny-2 {
    width: 16.6667%;
  }

  .w-col-tiny-3 {
    width: 25%;
  }

  .w-col-tiny-4 {
    width: 33.3333%;
  }

  .w-col-tiny-5 {
    width: 41.6667%;
  }

  .w-col-tiny-6 {
    width: 50%;
  }

  .w-col-tiny-7 {
    width: 58.3333%;
  }

  .w-col-tiny-8 {
    width: 66.6667%;
  }

  .w-col-tiny-9 {
    width: 75%;
  }

  .w-col-tiny-10 {
    width: 83.3333%;
  }

  .w-col-tiny-11 {
    width: 91.6667%;
  }

  .w-col-tiny-12 {
    width: 100%;
  }
}

.w-widget {
  position: relative;
}

.w-widget-map {
  width: 100%;
  height: 400px;
}

.w-widget-map label {
  width: auto;
  display: inline;
}

.w-widget-map img {
  max-width: inherit;
}

.w-widget-map .gm-style-iw {
  text-align: center;
}

.w-widget-map .gm-style-iw > button {
  display: none !important;
}

.w-widget-twitter {
  overflow: hidden;
}

.w-widget-twitter-count-shim {
  vertical-align: top;
  text-align: center;
  background: #fff;
  border: 1px solid #758696;
  border-radius: 3px;
  width: 28px;
  height: 20px;
  display: inline-block;
  position: relative;
}

.w-widget-twitter-count-shim * {
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
}

.w-widget-twitter-count-shim .w-widget-twitter-count-inner {
  text-align: center;
  color: #999;
  font-family: serif;
  font-size: 15px;
  line-height: 12px;
  position: relative;
}

.w-widget-twitter-count-shim .w-widget-twitter-count-clear {
  display: block;
  position: relative;
}

.w-widget-twitter-count-shim.w--large {
  width: 36px;
  height: 28px;
}

.w-widget-twitter-count-shim.w--large .w-widget-twitter-count-inner {
  font-size: 18px;
  line-height: 18px;
}

.w-widget-twitter-count-shim:not(.w--vertical) {
  margin-left: 5px;
  margin-right: 8px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large {
  margin-left: 6px;
}

.w-widget-twitter-count-shim:not(.w--vertical):before, .w-widget-twitter-count-shim:not(.w--vertical):after {
  content: " ";
  pointer-events: none;
  border: solid #0000;
  width: 0;
  height: 0;
  position: absolute;
  top: 50%;
  left: 0;
}

.w-widget-twitter-count-shim:not(.w--vertical):before {
  border-width: 4px;
  border-color: #75869600 #5d6c7b #75869600 #75869600;
  margin-top: -4px;
  margin-left: -9px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large:before {
  border-width: 5px;
  margin-top: -5px;
  margin-left: -10px;
}

.w-widget-twitter-count-shim:not(.w--vertical):after {
  border-width: 4px;
  border-color: #fff0 #fff #fff0 #fff0;
  margin-top: -4px;
  margin-left: -8px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large:after {
  border-width: 5px;
  margin-top: -5px;
  margin-left: -9px;
}

.w-widget-twitter-count-shim.w--vertical {
  width: 61px;
  height: 33px;
  margin-bottom: 8px;
}

.w-widget-twitter-count-shim.w--vertical:before, .w-widget-twitter-count-shim.w--vertical:after {
  content: " ";
  pointer-events: none;
  border: solid #0000;
  width: 0;
  height: 0;
  position: absolute;
  top: 100%;
  left: 50%;
}

.w-widget-twitter-count-shim.w--vertical:before {
  border-width: 5px;
  border-color: #5d6c7b #75869600 #75869600;
  margin-left: -5px;
}

.w-widget-twitter-count-shim.w--vertical:after {
  border-width: 4px;
  border-color: #fff #fff0 #fff0;
  margin-left: -4px;
}

.w-widget-twitter-count-shim.w--vertical .w-widget-twitter-count-inner {
  font-size: 18px;
  line-height: 22px;
}

.w-widget-twitter-count-shim.w--vertical.w--large {
  width: 76px;
}

.w-background-video {
  color: #fff;
  height: 500px;
  position: relative;
  overflow: hidden;
}

.w-background-video > video {
  object-fit: cover;
  z-index: -100;
  background-position: 50%;
  background-size: cover;
  width: 100%;
  height: 100%;
  margin: auto;
  position: absolute;
  inset: -100%;
}

.w-background-video > video::-webkit-media-controls-start-playback-button {
  -webkit-appearance: none;
  display: none !important;
}

.w-background-video--control {
  background-color: #0000;
  padding: 0;
  position: absolute;
  bottom: 1em;
  right: 1em;
}

.w-background-video--control > [hidden] {
  display: none !important;
}

.w-slider {
  text-align: center;
  clear: both;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  background: #ddd;
  height: 300px;
  position: relative;
}

.w-slider-mask {
  z-index: 1;
  white-space: nowrap;
  height: 100%;
  display: block;
  position: relative;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-slide {
  vertical-align: top;
  white-space: normal;
  text-align: left;
  width: 100%;
  height: 100%;
  display: inline-block;
  position: relative;
}

.w-slider-nav {
  z-index: 2;
  text-align: center;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  height: 40px;
  margin: auto;
  padding-top: 10px;
  position: absolute;
  inset: auto 0 0;
}

.w-slider-nav.w-round > div {
  border-radius: 100%;
}

.w-slider-nav.w-num > div {
  font-size: inherit;
  line-height: inherit;
  width: auto;
  height: auto;
  padding: .2em .5em;
}

.w-slider-nav.w-shadow > div {
  box-shadow: 0 0 3px #3336;
}

.w-slider-nav-invert {
  color: #fff;
}

.w-slider-nav-invert > div {
  background-color: #2226;
}

.w-slider-nav-invert > div.w-active {
  background-color: #222;
}

.w-slider-dot {
  cursor: pointer;
  background-color: #fff6;
  width: 1em;
  height: 1em;
  margin: 0 3px .5em;
  transition: background-color .1s, color .1s;
  display: inline-block;
  position: relative;
}

.w-slider-dot.w-active {
  background-color: #fff;
}

.w-slider-dot:focus {
  outline: none;
  box-shadow: 0 0 0 2px #fff;
}

.w-slider-dot:focus.w-active {
  box-shadow: none;
}

.w-slider-arrow-left, .w-slider-arrow-right {
  cursor: pointer;
  color: #fff;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  -webkit-user-select: none;
  user-select: none;
  width: 80px;
  margin: auto;
  font-size: 40px;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.w-slider-arrow-left [class^="w-icon-"], .w-slider-arrow-right [class^="w-icon-"], .w-slider-arrow-left [class*=" w-icon-"], .w-slider-arrow-right [class*=" w-icon-"] {
  position: absolute;
}

.w-slider-arrow-left:focus, .w-slider-arrow-right:focus {
  outline: 0;
}

.w-slider-arrow-left {
  z-index: 3;
  right: auto;
}

.w-slider-arrow-right {
  z-index: 4;
  left: auto;
}

.w-icon-slider-left, .w-icon-slider-right {
  width: 1em;
  height: 1em;
  margin: auto;
  inset: 0;
}

.w-slider-aria-label {
  clip: rect(0 0 0 0);
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  position: absolute;
  overflow: hidden;
}

.w-slider-force-show {
  display: block !important;
}

.w-dropdown {
  text-align: left;
  z-index: 900;
  margin-left: auto;
  margin-right: auto;
  display: inline-block;
  position: relative;
}

.w-dropdown-btn, .w-dropdown-toggle, .w-dropdown-link {
  vertical-align: top;
  color: #222;
  text-align: left;
  white-space: nowrap;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  text-decoration: none;
  position: relative;
}

.w-dropdown-toggle {
  -webkit-user-select: none;
  user-select: none;
  cursor: pointer;
  padding-right: 40px;
  display: inline-block;
}

.w-dropdown-toggle:focus {
  outline: 0;
}

.w-icon-dropdown-toggle {
  width: 1em;
  height: 1em;
  margin: auto 20px auto auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
}

.w-dropdown-list {
  background: #ddd;
  min-width: 100%;
  display: none;
  position: absolute;
}

.w-dropdown-list.w--open {
  display: block;
}

.w-dropdown-link {
  color: #222;
  padding: 10px 20px;
  display: block;
}

.w-dropdown-link.w--current {
  color: #0082f3;
}

.w-dropdown-link:focus {
  outline: 0;
}

@media screen and (max-width: 767px) {
  .w-nav-brand {
    padding-left: 10px;
  }
}

.w-lightbox-backdrop {
  cursor: auto;
  letter-spacing: normal;
  text-indent: 0;
  text-shadow: none;
  text-transform: none;
  visibility: visible;
  white-space: normal;
  word-break: normal;
  word-spacing: normal;
  word-wrap: normal;
  color: #fff;
  text-align: center;
  z-index: 2000;
  opacity: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -webkit-tap-highlight-color: transparent;
  background: #000000e6;
  outline: 0;
  font-family: Helvetica Neue, Helvetica, Ubuntu, Segoe UI, Verdana, sans-serif;
  font-size: 17px;
  font-style: normal;
  font-weight: 300;
  line-height: 1.2;
  list-style: disc;
  position: fixed;
  inset: 0;
  -webkit-transform: translate(0);
}

.w-lightbox-backdrop, .w-lightbox-container {
  -webkit-overflow-scrolling: touch;
  height: 100%;
  overflow: auto;
}

.w-lightbox-content {
  height: 100vh;
  position: relative;
  overflow: hidden;
}

.w-lightbox-view {
  opacity: 0;
  width: 100vw;
  height: 100vh;
  position: absolute;
}

.w-lightbox-view:before {
  content: "";
  height: 100vh;
}

.w-lightbox-group, .w-lightbox-group .w-lightbox-view, .w-lightbox-group .w-lightbox-view:before {
  height: 86vh;
}

.w-lightbox-frame, .w-lightbox-view:before {
  vertical-align: middle;
  display: inline-block;
}

.w-lightbox-figure {
  margin: 0;
  position: relative;
}

.w-lightbox-group .w-lightbox-figure {
  cursor: pointer;
}

.w-lightbox-img {
  width: auto;
  max-width: none;
  height: auto;
}

.w-lightbox-image {
  float: none;
  max-width: 100vw;
  max-height: 100vh;
  display: block;
}

.w-lightbox-group .w-lightbox-image {
  max-height: 86vh;
}

.w-lightbox-caption {
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  background: #0006;
  padding: .5em 1em;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-lightbox-embed {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.w-lightbox-control {
  cursor: pointer;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 24px;
  width: 4em;
  transition: all .3s;
  position: absolute;
  top: 0;
}

.w-lightbox-left {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yMCAwIDI0IDQwIiB3aWR0aD0iMjQiIGhlaWdodD0iNDAiPjxnIHRyYW5zZm9ybT0icm90YXRlKDQ1KSI+PHBhdGggZD0ibTAgMGg1djIzaDIzdjVoLTI4eiIgb3BhY2l0eT0iLjQiLz48cGF0aCBkPSJtMSAxaDN2MjNoMjN2M2gtMjZ6IiBmaWxsPSIjZmZmIi8+PC9nPjwvc3ZnPg==");
  display: none;
  bottom: 0;
  left: 0;
}

.w-lightbox-right {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii00IDAgMjQgNDAiIHdpZHRoPSIyNCIgaGVpZ2h0PSI0MCI+PGcgdHJhbnNmb3JtPSJyb3RhdGUoNDUpIj48cGF0aCBkPSJtMC0waDI4djI4aC01di0yM2gtMjN6IiBvcGFjaXR5PSIuNCIvPjxwYXRoIGQ9Im0xIDFoMjZ2MjZoLTN2LTIzaC0yM3oiIGZpbGw9IiNmZmYiLz48L2c+PC9zdmc+");
  display: none;
  bottom: 0;
  right: 0;
}

.w-lightbox-close {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii00IDAgMTggMTciIHdpZHRoPSIxOCIgaGVpZ2h0PSIxNyI+PGcgdHJhbnNmb3JtPSJyb3RhdGUoNDUpIj48cGF0aCBkPSJtMCAwaDd2LTdoNXY3aDd2NWgtN3Y3aC01di03aC03eiIgb3BhY2l0eT0iLjQiLz48cGF0aCBkPSJtMSAxaDd2LTdoM3Y3aDd2M2gtN3Y3aC0zdi03aC03eiIgZmlsbD0iI2ZmZiIvPjwvZz48L3N2Zz4=");
  background-size: 18px;
  height: 2.6em;
  right: 0;
}

.w-lightbox-strip {
  white-space: nowrap;
  padding: 0 1vh;
  line-height: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: auto hidden;
}

.w-lightbox-item {
  box-sizing: content-box;
  cursor: pointer;
  width: 10vh;
  padding: 2vh 1vh;
  display: inline-block;
  -webkit-transform: translate3d(0, 0, 0);
}

.w-lightbox-active {
  opacity: .3;
}

.w-lightbox-thumbnail {
  background: #222;
  height: 10vh;
  position: relative;
  overflow: hidden;
}

.w-lightbox-thumbnail-image {
  position: absolute;
  top: 0;
  left: 0;
}

.w-lightbox-thumbnail .w-lightbox-tall {
  width: 100%;
  top: 50%;
  transform: translate(0, -50%);
}

.w-lightbox-thumbnail .w-lightbox-wide {
  height: 100%;
  left: 50%;
  transform: translate(-50%);
}

.w-lightbox-spinner {
  box-sizing: border-box;
  border: 5px solid #0006;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  margin-left: -20px;
  animation: .8s linear infinite spin;
  position: absolute;
  top: 50%;
  left: 50%;
}

.w-lightbox-spinner:after {
  content: "";
  border: 3px solid #0000;
  border-bottom-color: #fff;
  border-radius: 50%;
  position: absolute;
  inset: -4px;
}

.w-lightbox-hide {
  display: none;
}

.w-lightbox-noscroll {
  overflow: hidden;
}

@media (min-width: 768px) {
  .w-lightbox-content {
    height: 96vh;
    margin-top: 2vh;
  }

  .w-lightbox-view, .w-lightbox-view:before {
    height: 96vh;
  }

  .w-lightbox-group, .w-lightbox-group .w-lightbox-view, .w-lightbox-group .w-lightbox-view:before {
    height: 84vh;
  }

  .w-lightbox-image {
    max-width: 96vw;
    max-height: 96vh;
  }

  .w-lightbox-group .w-lightbox-image {
    max-width: 82.3vw;
    max-height: 84vh;
  }

  .w-lightbox-left, .w-lightbox-right {
    opacity: .5;
    display: block;
  }

  .w-lightbox-close {
    opacity: .8;
  }

  .w-lightbox-control:hover {
    opacity: 1;
  }
}

.w-lightbox-inactive, .w-lightbox-inactive:hover {
  opacity: 0;
}

.w-richtext:before, .w-richtext:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-richtext:after {
  clear: both;
}

.w-richtext[contenteditable="true"]:before, .w-richtext[contenteditable="true"]:after {
  white-space: initial;
}

.w-richtext ol, .w-richtext ul {
  overflow: hidden;
}

.w-richtext .w-richtext-figure-selected.w-richtext-figure-type-video div:after, .w-richtext .w-richtext-figure-selected[data-rt-type="video"] div:after, .w-richtext .w-richtext-figure-selected.w-richtext-figure-type-image div, .w-richtext .w-richtext-figure-selected[data-rt-type="image"] div {
  outline: 2px solid #2895f7;
}

.w-richtext figure.w-richtext-figure-type-video > div:after, .w-richtext figure[data-rt-type="video"] > div:after {
  content: "";
  display: none;
  position: absolute;
  inset: 0;
}

.w-richtext figure {
  max-width: 60%;
  position: relative;
}

.w-richtext figure > div:before {
  cursor: default !important;
}

.w-richtext figure img {
  width: 100%;
}

.w-richtext figure figcaption.w-richtext-figcaption-placeholder {
  opacity: .6;
}

.w-richtext figure div {
  color: #0000;
  font-size: 0;
}

.w-richtext figure.w-richtext-figure-type-image, .w-richtext figure[data-rt-type="image"] {
  display: table;
}

.w-richtext figure.w-richtext-figure-type-image > div, .w-richtext figure[data-rt-type="image"] > div {
  display: inline-block;
}

.w-richtext figure.w-richtext-figure-type-image > figcaption, .w-richtext figure[data-rt-type="image"] > figcaption {
  caption-side: bottom;
  display: table-caption;
}

.w-richtext figure.w-richtext-figure-type-video, .w-richtext figure[data-rt-type="video"] {
  width: 60%;
  height: 0;
}

.w-richtext figure.w-richtext-figure-type-video iframe, .w-richtext figure[data-rt-type="video"] iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.w-richtext figure.w-richtext-figure-type-video > div, .w-richtext figure[data-rt-type="video"] > div {
  width: 100%;
}

.w-richtext figure.w-richtext-align-center {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}

.w-richtext figure.w-richtext-align-center.w-richtext-figure-type-image > div, .w-richtext figure.w-richtext-align-center[data-rt-type="image"] > div {
  max-width: 100%;
}

.w-richtext figure.w-richtext-align-normal {
  clear: both;
}

.w-richtext figure.w-richtext-align-fullwidth {
  text-align: center;
  clear: both;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.w-richtext figure.w-richtext-align-fullwidth > div {
  padding-bottom: inherit;
  display: inline-block;
}

.w-richtext figure.w-richtext-align-fullwidth > figcaption {
  display: block;
}

.w-richtext figure.w-richtext-align-floatleft {
  float: left;
  clear: none;
  margin-right: 15px;
}

.w-richtext figure.w-richtext-align-floatright {
  float: right;
  clear: none;
  margin-left: 15px;
}

.w-nav {
  z-index: 1000;
  background: #ddd;
  position: relative;
}

.w-nav:before, .w-nav:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-nav:after {
  clear: both;
}

.w-nav-brand {
  float: left;
  color: #333;
  text-decoration: none;
  position: relative;
}

.w-nav-link {
  vertical-align: top;
  color: #222;
  text-align: left;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.w-nav-link.w--current {
  color: #0082f3;
}

.w-nav-menu {
  float: right;
  position: relative;
}

[data-nav-menu-open] {
  text-align: center;
  background: #c8c8c8;
  min-width: 200px;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  overflow: visible;
  display: block !important;
}

.w--nav-link-open {
  display: block;
  position: relative;
}

.w-nav-overlay {
  width: 100%;
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-nav-overlay [data-nav-menu-open] {
  top: 0;
}

.w-nav[data-animation="over-left"] .w-nav-overlay {
  width: auto;
}

.w-nav[data-animation="over-left"] .w-nav-overlay, .w-nav[data-animation="over-left"] [data-nav-menu-open] {
  z-index: 1;
  top: 0;
  right: auto;
}

.w-nav[data-animation="over-right"] .w-nav-overlay {
  width: auto;
}

.w-nav[data-animation="over-right"] .w-nav-overlay, .w-nav[data-animation="over-right"] [data-nav-menu-open] {
  z-index: 1;
  top: 0;
  left: auto;
}

.w-nav-button {
  float: right;
  cursor: pointer;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  -webkit-user-select: none;
  user-select: none;
  padding: 18px;
  font-size: 24px;
  display: none;
  position: relative;
}

.w-nav-button:focus {
  outline: 0;
}

.w-nav-button.w--open {
  color: #fff;
  background-color: #c8c8c8;
}

.w-nav[data-collapse="all"] .w-nav-menu {
  display: none;
}

.w-nav[data-collapse="all"] .w-nav-button, .w--nav-dropdown-open, .w--nav-dropdown-toggle-open {
  display: block;
}

.w--nav-dropdown-list-open {
  position: static;
}

@media screen and (max-width: 991px) {
  .w-nav[data-collapse="medium"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="medium"] .w-nav-button {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .w-nav[data-collapse="small"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="small"] .w-nav-button {
    display: block;
  }

  .w-nav-brand {
    padding-left: 10px;
  }
}

@media screen and (max-width: 479px) {
  .w-nav[data-collapse="tiny"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="tiny"] .w-nav-button {
    display: block;
  }
}

.w-tabs {
  position: relative;
}

.w-tabs:before, .w-tabs:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-tabs:after {
  clear: both;
}

.w-tab-menu {
  position: relative;
}

.w-tab-link {
  vertical-align: top;
  text-align: left;
  cursor: pointer;
  color: #222;
  background-color: #ddd;
  padding: 9px 30px;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.w-tab-link.w--current {
  background-color: #c8c8c8;
}

.w-tab-link:focus {
  outline: 0;
}

.w-tab-content {
  display: block;
  position: relative;
  overflow: hidden;
}

.w-tab-pane {
  display: none;
  position: relative;
}

.w--tab-active {
  display: block;
}

@media screen and (max-width: 479px) {
  .w-tab-link {
    display: block;
  }
}

.w-ix-emptyfix:after {
  content: "";
}

@keyframes spin {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

.w-dyn-empty {
  background-color: #ddd;
  padding: 10px;
}

.w-dyn-hide, .w-dyn-bind-empty, .w-condition-invisible {
  display: none !important;
}

.wf-layout-layout {
  display: grid;
}

@font-face {
  font-family: "PP Neue Montreal 700";
  src: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/65c4f0295252d1d5065ad109_PPNeueMontreal-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "PP Neue Montreal 500";
  src: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/65c4f1dfc880aeeee42ecccd_900670c46c3a80efc0c7992ffd214f6c.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "PP Neue Montreal 300-400";
  src: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/65c4f204e338b0c256004684_PPNeueMontreal-Thin.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --vert-principale-foncé: #339949;
  --vert-principale: #2bb34c;
  --blanc: #fff;
  --noir: black;
  --gris-principale: #111b2b;
  --anthracite: #040404;
  --gris: #999;
  --gris-clair: #dfdfdf;
  --maf-pink: #e97a92;
  --voyant-rouge: #ff543e;
  --bourgogne: #a31c39;
  --bleu-facebook: #1277f2;
}

.w-layout-blockcontainer {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.w-form-formrecaptcha {
  margin-bottom: 8px;
}

.w-embed-youtubevideo {
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/static/youtube-placeholder.2b05e7d68d.svg");
  background-position: 50%;
  background-size: cover;
  width: 100%;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  position: relative;
}

.w-embed-youtubevideo:empty {
  min-height: 75px;
  padding-bottom: 56.25%;
}

.w-backgroundvideo-backgroundvideoplaypausebutton:focus-visible {
  outline-offset: 2px;
  border-radius: 50%;
  outline: 2px solid #3b79c3;
}

@media screen and (max-width: 991px) {
  .w-layout-blockcontainer {
    max-width: 728px;
  }
}

@media screen and (max-width: 767px) {
  .w-layout-blockcontainer {
    max-width: none;
  }
}

body {
  color: #1a1b1f;
  background-color: #efefef;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 28px;
}

h1 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 44px;
  font-weight: 400;
  line-height: 62px;
}

h2 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 36px;
  font-weight: 400;
  line-height: 50px;
}

h3 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 30px;
  font-weight: 400;
  line-height: 46px;
}

h4 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 24px;
  font-weight: 400;
  line-height: 38px;
}

h5 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 20px;
  font-weight: 500;
  line-height: 34px;
}

h6 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: 500;
  line-height: 28px;
}

p {
  margin-bottom: 10px;
}

a {
  color: #1a1b1f;
  text-decoration: none;
  display: block;
}

a:hover {
  color: #32343a;
}

a:active {
  color: #43464d;
}

ul {
  margin-top: 20px;
  margin-bottom: 10px;
  padding-left: 40px;
  list-style-type: disc;
}

li {
  margin-bottom: 10px;
}

img {
  display: block;
}

label {
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 500;
  line-height: 20px;
}

blockquote {
  border-left: 5px solid #e2e2e2;
  margin-top: 25px;
  margin-bottom: 25px;
  padding: 15px 30px;
  font-size: 20px;
  line-height: 34px;
}

figcaption {
  opacity: 1;
  text-align: center;
  margin-top: 5px;
  font-size: 14px;
  line-height: 26px;
}

.divider {
  background-color: #eee;
  height: 1px;
}

.styleguide-content-wrap {
  text-align: center;
}

.section {
  min-height: 100px;
}

.styleguide-block {
  text-align: left;
  flex-direction: column;
  align-items: center;
  margin-top: 80px;
  margin-bottom: 80px;
  display: block;
}

.container {
  width: 100%;
  max-width: 1140px;
  margin-left: auto;
  margin-right: auto;
}

.paragraph-tiny {
  font-size: 12px;
  line-height: 20px;
}

.paragraph-bigger {
  opacity: 1;
  margin-bottom: 10px;
  font-size: 20px;
  font-weight: 400;
  line-height: 34px;
}

.paragraph-bigger.cc-bigger-light {
  opacity: .6;
}

.bouton {
  text-align: center;
  letter-spacing: .5px;
  text-transform: none;
  border-radius: 5px;
  padding: 12px 25px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 20px;
  text-decoration: none;
  transition: background-color .4s, opacity .4s, color .4s;
}

.bouton:hover {
  background-color: var(--vert-principale-foncé);
  color: #fff;
  box-shadow: 0 2px 5px #0003;
}

.bouton:active {
  background-color: var(--vert-principale-foncé);
  box-shadow: 0 2px 8px #0003;
}

.bouton.bouton---vert {
  background-color: var(--vert-principale);
  color: #fff;
}

.bouton.bouton---vert:hover {
  background-color: var(--vert-principale-foncé);
}

.bouton.bouton---vert.w--current {
  color: #fff;
}

.bouton.bouton---vert.bouton-passer-a-l-action {
  display: none;
}

.bouton.bouton-blanc {
  color: #202020;
  background-color: #fff;
  padding: 16px 35px;
  font-size: 14px;
  line-height: 26px;
}

.bouton.bouton-blanc:hover {
  background-color: #fffc;
}

.bouton.bouton-blanc:active {
  background-color: #ffffffe6;
}

.bouton.pied-de-page---bouton-blanc {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  color: var(--vert-principale);
  background-color: #fff;
  border-radius: 6px;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  height: 48px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 16px;
  font-size: 14px;
  line-height: 26px;
  transition: box-shadow .3s, transform .3s;
  display: flex;
}

.bouton.pied-de-page---bouton-blanc:hover {
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 5px #0000004d;
}

.bouton.pied-de-page---bouton-blanc:active {
  background-color: #ffffffe6;
}

.bouton.pied-de-page---bouton-blanc.pied-de-page---bouton-infolettre {
  height: 42px;
  padding: 8px 20px;
  font-size: 16px;
  line-height: 18px;
}

.label {
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 500;
  line-height: 20px;
}

.label.cc-styleguide-label {
  margin-bottom: 25px;
}

.heading-jumbo-tiny {
  text-transform: uppercase;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 500;
  line-height: 32px;
}

.rich-text {
  width: 70%;
  margin-bottom: 100px;
  margin-left: auto;
  margin-right: auto;
}

.rich-text p {
  opacity: .6;
  margin-top: 15px;
  margin-bottom: 25px;
}

.rich-text figcaption {
  opacity: .6;
}

.rich-text figure {
  margin-top: 25px;
  padding-bottom: 20px;
}

.paragraph-light {
  opacity: .6;
}

.heading-jumbo {
  color: #2bb34c;
  text-align: center;
  text-transform: none;
  margin-top: 10px;
  margin-bottom: 10px;
  font-family: "Neue Montreal 700";
  font-size: 208px;
  font-weight: 700;
  line-height: 120%;
}

.heading-jumbo-small {
  text-transform: none;
  margin-top: 10px;
  margin-bottom: 15px;
  font-size: 36px;
  font-weight: 400;
  line-height: 50px;
}

.styleguide-button-wrap {
  margin-top: 10px;
  margin-bottom: 10px;
}

.styleguide-header-wrap {
  color: #fff;
  text-align: center;
  background-color: #1a1b1f;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 460px;
  padding: 30px;
  display: flex;
}

.paragraph-small {
  font-size: 14px;
  line-height: 26px;
}

.logo-link {
  z-index: 1;
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  color: var(--noir);
  cursor: pointer;
  flex: none;
  align-items: center;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 25px;
  transition: opacity .3s ease-in-out, transform .3s ease-in-out;
  display: flex;
}

.logo-link:hover {
  opacity: .9;
  transform: scale(1.1);
}

.logo-link:active {
  opacity: .7;
}

.logo-link.w--current {
  transition: opacity .3s ease-in-out, transform .3s ease-in-out;
}

.logo-link.w--current:hover {
  transform: scale(1.1);
}

.navigation-wrap {
  flex: none;
  justify-content: space-between;
  align-items: center;
  display: flex;
  position: relative;
}

.navigation-item {
  opacity: .6;
  color: var(--gris-principale);
  text-align: center;
  letter-spacing: .5px;
  text-transform: none;
  padding: 9px 20px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 20px;
  transition: opacity .4s;
}

.navigation-item:hover {
  opacity: 1;
}

.navigation-item:active {
  opacity: .8;
}

.navigation-item:lang(en) {
  color: var(--noir);
}

.navigation-item.w--current {
  opacity: 1;
  color: var(--gris-principale);
  letter-spacing: .5px;
  font-weight: 600;
}

.navigation-item.w--current:hover {
  opacity: .8;
}

.navigation-item.w--current:active {
  opacity: .7;
  color: #32343a;
}

.navigation-item.dropdown {
  padding-right: 6px;
}

.status-message {
  color: #fff;
  text-align: center;
  background-color: #202020;
  padding: 9px 30px;
  font-size: 14px;
  line-height: 26px;
}

.status-message.cc-error-message {
  background-color: #db4b68;
}

.text-field {
  border: 1px solid #e4e4e4;
  border-radius: 0;
  margin-bottom: 18px;
  padding: 21px 20px;
  font-size: 14px;
  line-height: 26px;
  transition: border-color .4s;
}

.text-field:hover {
  border-color: #e3e6eb;
}

.text-field:active, .text-field:focus {
  border-color: #43464d;
}

.text-field::placeholder {
  color: #32343a66;
}

.protected-wrap {
  justify-content: center;
  padding-top: 90px;
  padding-bottom: 100px;
  display: flex;
}

.protected-heading {
  margin-bottom: 30px;
}

.utility-page-wrap {
  color: #fff;
  text-align: center;
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  padding: 30px;
  display: flex;
}

._404-wrap {
  background-color: #1a1b1f;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 30px;
  display: flex;
}

._404-content-wrap {
  margin-bottom: 20px;
}

.titre-principal {
  background-color: var(--blanc);
  color: var(--noir);
  text-align: center;
  z-index: 1;
  max-width: 75vw;
  margin-top: 60px;
  margin-bottom: 60px;
  padding: 10px 30px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 60px;
  position: relative;
}

.titre-principal.sombre {
  max-width: 80vw;
}

.titre-principal.sombre.histoire {
  z-index: 2;
  margin-bottom: 60px;
}

.titre-principal.titre-notre-symbole {
  z-index: 2;
  margin-top: 0;
  margin-bottom: 20px;
}

.titre-principal.variante {
  background-color: var(--vert-principale);
  color: var(--blanc);
  max-width: none;
  margin-top: 30px;
  margin-bottom: 20px;
}

.contenant.centr {
  text-align: center;
}

.navigation---logo---image {
  text-align: left;
  object-fit: fill;
  width: 80px;
  height: 78.9px;
}

.navigation---menu-fond-blanc {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: #fff;
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  padding-top: 12px;
  padding-bottom: 8px;
  padding-right: 0;
  display: flex;
}

.pied-de-page---principale {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  margin-bottom: 60px;
  display: flex;
}

.pied-de-page---contenant---logo-titre {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 20px;
  display: flex;
}

.image-2 {
  background-color: #fff;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/65aa7be3deb6c02fc7067804_logo-coeur-meres-au-front.svg");
  background-position: 0 0;
  background-size: auto;
}

.pdp---logo-blanc {
  width: 81px;
  height: 76px;
}

.pdp---titre {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 36px;
  line-height: 46px;
}

.pdp---menu-gauche {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.pdp---lien {
  color: #fff;
  font-family: "PP Neue Montreal 500", sans-serif;
  text-decoration: none;
  display: block;
}

.pdp---lien:hover {
  color: #fff;
  text-decoration: underline;
}

.pdp---contenant---contribuer-la-cause {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.pdp---lien-blanc {
  color: #fff;
  font-family: "PP Neue Montreal 700", sans-serif;
  text-decoration: none;
  display: block;
}

.pdp---lien-blanc:hover {
  color: #fff;
  text-decoration: underline;
}

.pdp---lien-blanc.pdp---contribuer-la-cause---lien {
  font-size: 24px;
}

.pdp---lien-blanc.pdp---contribuer-la-cause---lien:hover {
  text-decoration: none;
}

.pdp---contribuer-la-cause---contentant-du-bouton {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  flex-flow: column;
  align-items: flex-start;
  display: flex;
}

.champdeformualire {
  background-color: #fff0;
  border: 1px solid #000;
  border-radius: 5px;
}

.champdeformualire.pdp-champdeformulaire {
  border-color: var(--blanc);
  color: var(--blanc);
  padding-top: 20px;
  padding-bottom: 20px;
  font-size: 16px;
}

.champdeformualire.pdp-champdeformulaire::placeholder {
  color: var(--blanc);
  font-family: "PP Neue Montreal 300-400", sans-serif;
}

.pied-de-page---contenant---formulaire {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-direction: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
}

.pied-de-page---formulaire {
  grid-column-gap: 20px;
  grid-row-gap: 0px;
  padding-top: 5px;
  display: flex;
}

.section---accueil---nos-actions {
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/65c50f297395ad0e40dc4b78_logo-meresaufront-blanc.png");
  background-position: 100% 0;
  background-repeat: no-repeat;
  background-size: auto;
  padding-top: 100px;
  padding-bottom: 100px;
  display: block;
}

.collection-cartes-actions {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  text-align: left;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-items: stretch;
  margin-bottom: 40px;
  display: grid;
}

.carte-action-en-cours {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  color: var(--blanc);
  border-radius: 5px;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 360px;
  max-width: 95vw;
  height: 571px;
  padding: 32px;
  font-size: 18px;
  line-height: 21.6px;
  display: flex;
  position: relative;
}

.formulaire---message-aprs-soumission {
  color: var(--vert-principale);
  background-color: #fff;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 400;
}

.collection-cartes-actions---pas-d-actions {
  background-color: var(--blanc);
  color: var(--vert-principale);
  border-radius: 10px;
  margin-bottom: 40px;
}

.carte-d-action---nom-de-l-action {
  color: var(--blanc);
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 23px;
  line-height: 23.5px;
}

.carte-d-action---cat-gorie {
  color: var(--blanc);
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 28.8px;
}

.carte-d-action---block-informations-en-bas {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  flex-direction: column;
  justify-content: space-between;
  align-self: flex-start;
  align-items: flex-start;
  display: flex;
}

.paragraphe {
  text-align: left;
  margin-bottom: 10px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 32px;
  font-weight: 400;
  line-height: 1.2;
}

.paragraphe.centre {
  text-align: center;
  width: 60%;
  line-height: 38.4px;
}

.paragraphe.sous-titre-nos-actions {
  text-align: left;
}

.paragraphe.cdg {
  width: auto;
}

.paragraphe.court {
  text-align: center;
  width: 100%;
}

.paragraphe.court.portevoix {
  text-align: center;
  padding-left: 0;
  padding-right: 0;
}

.paragraphe.section-grand-titre {
  width: 100%;
}

.paragraphe.blogue.date-blogue {
  color: var(--vert-principale);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 15px;
}

.paragraphe.campagne-cdg-hero {
  color: var(--blanc);
  text-shadow: 0 1px 2px var(--anthracite);
  margin-bottom: 0;
  font-size: 22px;
}

.paragraphe.campagne-cdg {
  font-size: 28px;
}

.paragraphe.remerciements-bdf {
  margin-bottom: 0;
  font-size: 1.375rem;
}

.inscription-newsletter {
  background-color: var(--vert-principale);
  text-align: center;
  border-radius: 5px;
  justify-content: space-around;
  align-items: center;
  width: 267px;
  height: 45px;
  padding: 0 15px;
  transition: right .3s, box-shadow .3s;
  display: flex;
  position: absolute;
  top: 300px;
  right: -92px;
  transform: rotate(-90deg);
}

.inscription-newsletter:hover {
  box-shadow: -5px 5px 10px 2px var(--gris);
  right: -82px;
}

.inscription-newsletter.sombre {
  cursor: pointer;
  right: -95px;
}

.inscription-newsletter.sombre:hover {
  right: -90px;
  box-shadow: -5px 5px 10px 2px #2bb34c80;
}

.image-3 {
  background-color: var(--vert-principale);
  color: var(--blanc);
}

.icone-newsletter {
  width: 20px;
  height: 20px;
}

.section-titre-vert {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 1138px;
  max-width: 90vw;
  margin-top: 60px;
  margin-bottom: 60px;
  display: flex;
}

.section-titre-vert.nos-groupes {
  justify-content: space-between;
  align-items: center;
  height: 80vh;
  position: relative;
}

.contenant-bandeau-de-liens {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  background-color: var(--vert-principale);
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 90px;
  margin-top: 80px;
  display: flex;
}

.contenant-bandeau-de-liens.bandeau-liens-page-nous-connaitre {
  margin-top: 0;
}

.contenant-bandeau-de-liens.campagne-cdg {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  background-color: #135935;
  margin-top: 0;
}

.contenant-bandeau-de-liens.test {
  z-index: 9999;
  margin-top: 0;
  position: sticky;
  top: 0;
}

.contenant-bandeau-de-liens.avec-margin {
  margin-bottom: 80px;
}

.lien-blanc {
  opacity: .5;
  color: var(--blanc);
  text-align: center;
  cursor: pointer;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 19px;
  font-weight: 500;
  line-height: 19.2px;
  text-decoration: none;
  transition: opacity .3s ease-in-out;
}

.lien-blanc:hover {
  opacity: 1;
  color: var(--blanc);
}

.lien-blanc.invisible {
  display: none;
}

.section-principale {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  max-width: 95vw;
  margin: 60px auto;
  display: flex;
  position: relative;
}

.section-principale.sombre {
  background-color: var(--anthracite);
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.section-principale.sombre.p-100 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.section-principale.sombre.pt-50 {
  padding-top: 50px;
}

.section-principale.sombre.lien-nous-connaitre {
  width: 100vw;
  max-width: none;
  padding-top: 70px;
  padding-bottom: 70px;
}

.section-principale.sombre.notre-histoire {
  width: 100%;
  padding-top: 40px;
  padding-bottom: 40px;
}

.section-principale.sombre.ressources-externes {
  width: 100vw;
  max-width: none;
  margin-top: 40px;
  margin-bottom: 40px;
}

.section-principale.sombre.invisible {
  display: none;
}

.section-principale.sombre.avec-margin {
  margin-top: 40px;
  margin-bottom: 40px;
}

.section-principale.portrait {
  margin-top: 40px;
}

.section-principale.page-groupe {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  margin-top: 100px;
}

.section-principale.carte {
  width: 100%;
}

.section-principale.texte-equite {
  margin-top: 40px;
  margin-bottom: 100px;
}

.section-principale.page-action {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  margin-top: 20px;
  margin-bottom: 20px;
}

.section-principale.page-action.comment-participer {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  padding-bottom: 20px;
}

.section-principale.actions-en-cours {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

.section-principale.retour-sur-le-passe {
  margin-top: 20px;
  margin-bottom: 20px;
}

.section-principale.section-polygones-acceuil {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  margin-top: 110vh;
  padding-top: 60px;
}

.section-principale.inondez-vos-elus {
  width: 100vw;
  max-width: none;
  margin-bottom: 0;
  overflow: visible;
}

.section-principale.commentaires {
  width: 40%;
}

.section-principale.hidden {
  display: none;
}

.section-principale.blogue {
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  margin-top: 0;
  margin-bottom: 60px;
}

.section-principale.blogue.avant-footer {
  margin-bottom: 60px;
}

.section-principale.gauche {
  justify-content: flex-start;
  align-items: center;
}

.section-principale.special-shorts {
  background-color: var(--vert-principale);
  -webkit-clip-path: polygon(0 10%, 66% 0, 100% 15%, 100% 90%, 25% 100%, 0 95%);
  clip-path: polygon(0 10%, 66% 0, 100% 15%, 100% 90%, 25% 100%, 0 95%);
  width: 100%;
  max-width: none;
  margin: 2rem 0;
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.section-principale.cpv {
  z-index: 5;
  margin-top: 2rem;
}

.image-carte-agir {
  aspect-ratio: auto;
  object-fit: cover;
  border-radius: 5px;
  width: 100%;
  height: 465px;
}

.titre-carte-agir {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 30px;
}

.texte-carte-agir {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 18px;
  line-height: 21.6px;
}

.reseaux-sociaux-fond-vert {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.lien-reseau-social {
  background-color: var(--vert-principale);
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 52px;
  height: 48px;
  padding-left: 16px;
  padding-right: 16px;
  transition: box-shadow .3s ease-in-out, transform .3s ease-in-out;
  display: flex;
}

.lien-reseau-social:hover {
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.lien-reseau-social.fond-blanc {
  background-color: var(--blanc);
  padding-left: 0;
  padding-right: 0;
  transition: box-shadow .3s, transform .3s;
}

.lien-reseau-social.fond-blanc:hover {
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 5px #0000004d;
}

.carte-avec-badge-et-bouton {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  z-index: 2;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 360px;
  max-width: 95vw;
  height: 571px;
  padding: 32px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 18px;
  line-height: 21.6px;
  display: flex;
  position: relative;
}

.carte-avec-badge-et-bouton.sans-badge {
  justify-content: flex-end;
  align-items: flex-start;
}

.badge-vert {
  background-color: var(--vert-principale);
  -webkit-clip-path: polygon(0 0, 97% 0, 100% 59%, 96% 98%, 0 100%, 1% 65%);
  clip-path: polygon(0 0, 97% 0, 100% 59%, 96% 98%, 0 100%, 1% 65%);
  justify-content: center;
  align-items: center;
  height: 51px;
  padding-left: 35px;
  padding-right: 35px;
  display: flex;
}

.badge-vert.voyant-rouge {
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  width: auto;
  height: 34px;
  padding: 25px;
}

.badge-vert.avec-date {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: auto;
  min-height: 51px;
  padding-top: 8px;
  padding-bottom: 8px;
}

.badge-texte {
  color: var(--blanc);
  text-align: center;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 20px;
}

.badge-texte.article {
  margin-left: 10px;
}

.section-agir-physiquement {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  justify-content: center;
  align-items: flex-start;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
}

.section-devenir-membre {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: space-between;
  align-items: center;
  width: 1138px;
  max-width: 90vw;
  margin-left: 0;
  margin-right: 0;
  font-weight: 400;
  display: flex;
}

.contenant-bloc-texte-avec-bouton {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 60%;
  display: flex;
}

.titre-gris-principale {
  color: var(--gris-principale);
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
  line-height: 48px;
}

.paragraphe-gris-principale {
  color: var(--gris-principale);
}

.lien {
  display: inline-block;
}

.lien.vert {
  transition: color .3s ease-in-out;
}

.lien.vert:hover {
  color: var(--blanc);
  text-decoration: underline;
}

.lien.vert.variante:hover {
  color: var(--vert-principale);
}

.lien.blanc {
  transition: opacity .2s, color .3s;
}

.lien.blanc:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.btn {
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 240px;
  height: 48px;
  padding: 0 16px;
  display: flex;
}

.btn.bouton-vert {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--vert-principale);
  color: var(--blanc);
}

.btn.bouton-vert._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  text-decoration: none;
}

.btn.bouton-blanc {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--blanc);
  color: var(--vert-principale);
  text-decoration: none;
}

.btn.bouton-blanc._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
}

.btn.bouton-blanc._500.largeur-auto {
  width: auto;
}

.btn.bouton-blanc._500.largeur-auto._24px.moins {
  display: none;
}

.btn.bouton-blanc._500._24px {
  font-size: 24px;
  line-height: 28.8px;
}

.gros-bouton {
  text-align: center;
  border-radius: 5px;
  padding: 20px 60px;
}

.gros-bouton.bouton-vert {
  background-color: var(--vert-principale);
}

.gros-bouton.bouton-vert._700 {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 17.2px;
}

.blanc {
  color: var(--blanc);
}

.blanc._700 {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 28.8px;
}

.blanc._700._40px {
  font-size: 40px;
  line-height: 48px;
}

.blanc._700._32px {
  font-size: 32px;
  line-height: 38.4px;
}

.blanc._700._32px._44lh {
  line-height: 44px;
}

.blanc._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 15.48px;
}

.blanc._500._24px {
  font-size: 24px;
  line-height: 24px;
}

.blanc._500._24px.lh34px {
  line-height: 34px;
}

.blanc._500.texte-faire-un-don {
  margin-bottom: 0;
  line-height: 26px;
}

.blanc.tag-offre-emploi {
  border: 1px solid var(--blanc);
  border-radius: 70px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: 14px;
  line-height: 48px;
}

.blanc.action-passee {
  max-width: 100%;
}

.vert {
  color: var(--vert-principale);
}

.vert._700._80px {
  font-size: 80px;
  line-height: 96px;
}

.vert._700.titre-devenir-membre {
  font-size: 80px;
  line-height: 68.8px;
}

.vert._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
}

.tres-grand-titre {
  color: var(--gris-clair);
  z-index: -1;
  margin-top: 140px;
  margin-bottom: 80px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 220px;
  font-weight: 700;
  line-height: 189.2px;
}

.tres-grand-titre.impliquez {
  margin-bottom: 0;
}

.tres-grand-titre.vous {
  margin-top: 0;
}

.section-flex-c {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.flex-c {
  flex-flow: column;
  display: flex;
}

.flex-c.gap40 {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

.flex-c.gap40.margin-negatif {
  margin-top: -100px;
}

.flex-c.gap20 {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  align-items: flex-start;
}

.flex-c.gap20.contenu-faire-un-don {
  width: 50%;
}

.flex-c.center {
  justify-content: flex-start;
  align-items: center;
}

.flex-c.center.gap10 {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
}

.grande-carte-sans-badge {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 940px;
  max-width: 95vw;
  min-height: 450px;
  padding: 40px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 24px;
  display: flex;
  position: relative;
}

.carte-apercu-emploi {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 360px;
  height: 360px;
  padding: 32px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 14px;
  line-height: 48px;
  display: flex;
}

.page-principale {
  color: var(--noir);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100vw;
  max-width: none;
  display: flex;
  position: relative;
}

.page-principale.cdg {
  width: 100%;
}

.flex {
  display: flex;
}

.flex.space-between {
  justify-content: space-between;
}

.flex.center {
  justify-content: center;
  align-items: center;
}

.flex.center.gap40 {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

.flex.center.gap40.margin-negatif {
  margin-top: -160px;
}

.flex.gap20 {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: flex-start;
  align-items: center;
}

.contenant-inondez-vos-lus {
  z-index: 5;
  width: 100vw;
  height: 614px;
  position: absolute;
}

.inondez-vos-lus {
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  width: 50%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 60px;
  padding-bottom: 60px;
  display: flex;
}

.logo-emploi {
  position: absolute;
  inset: 25% 0 0 30%;
}

.position-relative {
  position: relative;
}

.logo-coeur-rose {
  position: absolute;
  inset: 35% auto auto 40%;
}

.contenant-fil-d-ariane {
  color: var(--noir);
  justify-content: flex-start;
  align-items: center;
  max-width: 1251px;
  margin: 20px auto 0;
  padding-left: 20px;
  line-height: 19.2px;
  display: flex;
}

.mosaic-de-photo {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  grid-template-rows: auto auto auto auto auto;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.texte-mosaic {
  text-align: center;
  margin-bottom: 0;
  padding: 10px;
  font-size: 30px;
  line-height: 1.3;
}

.mosaic-bloc-vert {
  background-color: var(--vert-principale);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  margin-top: 100px;
  margin-bottom: 100px;
  display: flex;
}

.coeur-mosaic {
  width: 6.5625rem;
  height: 6.125rem;
}

.grand-polygone-vert {
  color: var(--blanc);
  justify-content: center;
  align-items: center;
  margin-top: 140px;
  margin-bottom: 140px;
  font-size: 24px;
  line-height: 28.8px;
  display: flex;
}

.contenant-polygone-vert {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/662275a526326e3cce8a486d_GrandPolygoneVert.svg");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  justify-content: center;
  align-items: center;
  width: 650px;
  height: 140px;
  display: flex;
}

.contenant-polygone-vert.participer {
  background-position: 50%;
  background-size: contain;
  width: auto;
  max-width: 90vw;
  padding: 80px 140px;
}

.contenant-polygone-vert.impaire {
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/662275a526326e3cce8a486d_GrandPolygoneVert.svg");
}

.contenant-polygone-vert.paire {
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/662275a526326e3cce8a486d_GrandPolygoneVert.svg");
  background-position: 50%;
  background-size: contain;
  height: 150px;
}

.contenant-polygone-vert.page-devenir-membre {
  background-size: contain;
  width: 910px;
  height: 193px;
}

.contenant-polygone-vert.infolettre {
  width: 1138px;
  max-width: 90vw;
  height: 242px;
}

.contenant-polygone-vert.page-cdg {
  background-position: 50%;
  background-size: 1000px 400px;
  width: 1000px;
  max-width: 90vw;
  height: 300px;
  margin-top: 40px;
  margin-bottom: 40px;
}

.contenant-polygone-vert.avec-lien {
  cursor: pointer;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/662275a526326e3cce8a486d_GrandPolygoneVert.svg");
  transition: transform .3s ease-in-out;
}

.contenant-polygone-vert.avec-lien:hover {
  transform: translate(0, -4px);
}

.contenu-polygone-vert {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  color: var(--blanc);
  text-align: center;
  justify-content: flex-start;
  align-items: center;
  width: 85%;
  margin-left: auto;
  margin-right: auto;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 62px;
  font-weight: 500;
  line-height: 74.4px;
  display: flex;
}

.contenu-polygone-vert.infolettre {
  justify-content: space-between;
  align-items: center;
  height: 90%;
  padding: 0 20px 20px;
}

.contenu-polygone-vert.participer {
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  justify-content: space-between;
  width: 100%;
}

.contenu-polygone-vert.page-devenir-membre {
  height: 100%;
}

.notre-mission {
  color: var(--blanc);
  text-align: center;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/66227a593db028da88728dee_Notre%20Mission.png");
  background-position: 0 0;
  background-size: cover;
  border-radius: 5px;
  width: 1138px;
  height: 600px;
  font-size: 32px;
  line-height: 46px;
}

.notre-mission.flex-c.center {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: flex-end;
  align-items: center;
  max-width: 95vw;
  padding-bottom: 100px;
}

.coeur-notre-mission {
  width: 101px;
  height: 93.65px;
}

.sous-titre-section-sombre {
  color: var(--blanc);
  text-align: center;
  z-index: 1;
  width: 75%;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 25px;
  font-weight: 400;
  line-height: 1.4;
}

._700 {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
}

._700.titre-notre-mission {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 50px;
  line-height: 60px;
}

._700._50px {
  font-size: 50px;
  line-height: 48px;
}

._700._50px.titre-comment-devenir-membre {
  margin-bottom: 40px;
}

._700._24px {
  font-size: 24px;
  line-height: 28.8px;
}

._700._24px._44lh {
  line-height: 44px;
}

.element-principe-fondateur {
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 910px;
  height: 390px;
  font-size: 18px;
  line-height: 32px;
  display: flex;
}

.texte-principe-fondateur {
  margin-bottom: 0;
  padding-left: 40px;
  padding-right: 40px;
}

.nos-valeurs {
  color: var(--gris-principale);
  text-align: center;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/6622889de723853d42b820e2_GrandCoeurPointilleVert.svg");
  background-position: 0 0;
  background-size: contain;
  justify-content: center;
  align-items: center;
  width: 692.84px;
  height: 649.4px;
  font-size: 30px;
  line-height: 46px;
  display: flex;
  position: relative;
}

.nos-valeurs.nos-raisons {
  margin-top: 140px;
  margin-bottom: 140px;
}

.texte-nos-valeurs {
  width: 60%;
}

.texte-nos-valeurs.nos-raisons {
  color: var(--blanc);
}

.valeur {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  background-color: var(--blanc);
  color: var(--vert-principale);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  padding: 20px 40px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 28.8px;
  display: flex;
}

.titre-valeur {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 24px;
  line-height: 28.8px;
}

.respect {
  position: absolute;
  inset: 0% auto auto 0%;
  box-shadow: 2px 5px 10px 4px #0003;
}

.solidarit {
  position: absolute;
  top: 10%;
  bottom: auto;
  right: -20%;
  box-shadow: 2px 5px 10px 4px #0003;
}

.bienveillance {
  position: absolute;
  inset: auto auto 0% 25%;
  box-shadow: 2px 5px 10px 4px #0003;
}

.comment-devenir-membre {
  color: var(--gris-principale);
  width: 1145px;
  margin-top: 100px;
  margin-bottom: 100px;
  font-size: 32px;
  line-height: 50px;
}

.sous-titre-dates-importantes {
  color: var(--gris-principale);
  text-align: center;
  width: 50%;
  font-size: 24px;
}

.badge-rose {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  background-color: var(--maf-pink);
  color: var(--blanc);
  text-align: center;
  -webkit-clip-path: polygon(0 0, 97% 0, 100% 59%, 96% 98%, 0 100%, 1% 65%);
  clip-path: polygon(0 0, 97% 0, 100% 59%, 96% 98%, 0 100%, 1% 65%);
  justify-content: center;
  align-items: center;
  width: 180px;
  height: 34px;
  padding: 30px 20px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 20px;
  display: flex;
}

.affichage-dates-importantes {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: center;
  align-items: flex-start;
  margin-top: 60px;
  margin-bottom: 60px;
  display: flex;
}

.section-faq {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  text-align: center;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 1138px;
  margin-bottom: 140px;
  padding: 30px;
  font-size: 24px;
  line-height: 28.8px;
  display: flex;
}

.coeur-faq {
  width: 81px;
  height: 76px;
  position: relative;
}

.point-interrogation {
  position: absolute;
  inset: 20% auto auto 30%;
}

.titre-faq {
  margin: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 60px;
}

.lien-courriel {
  color: var(--blanc);
  padding-left: 8px;
  font-style: italic;
  transition: opacity .2s;
  display: block;
}

.lien-courriel:hover {
  color: var(--blanc);
  text-decoration: underline;
}

.contenant-faq {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  width: 100%;
  margin-top: 10px;
  margin-bottom: 10px;
  display: flex;
}

.contenant-fleche-faq {
  border: 1px solid var(--gris);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  display: flex;
}

.liste-faq {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: row;
  height: 100%;
  display: grid;
}

.enveloppe-faq {
  background-color: var(--blanc);
  color: var(--gris);
  text-align: left;
  cursor: pointer;
  border-radius: 5px;
  flex-flow: column;
  width: 100%;
  font-size: 18px;
  line-height: 21.6px;
  display: flex;
  overflow: hidden;
}

.question-faq {
  justify-content: space-between;
  align-items: center;
  padding: 20px 40px;
  display: flex;
}

.reponse-faq {
  padding-bottom: 20px;
  padding-left: 40px;
  padding-right: 40px;
}

.reponse {
  color: var(--noir);
  font-size: 16px;
  line-height: 19.2px;
}

.titre-vert {
  color: var(--vert-principale);
  text-align: left;
  margin-bottom: 60px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 100px;
  font-weight: 700;
  line-height: 1.1;
}

.titre-vert.devenir-mere-au-front {
  text-align: center;
  width: 90%;
}

.titre-vert.nos-actions {
  text-align: left;
  font-size: 208px;
}

.titre-vert.titre-nos-groupes {
  text-align: center;
}

.titre-vert.nous-contacter {
  text-align: center;
  font-size: 160px;
}

.titre-vert.inondez-vos-elus {
  text-align: center;
  font-size: 100px;
  line-height: 120px;
}

.titre-vert.blogue {
  margin-top: 20px;
  font-size: 80px;
}

.titre-vert.campagne-cdg {
  color: var(--blanc);
  text-shadow: 0 1px 3px var(--anthracite);
  margin-bottom: 0;
  font-size: 75px;
  line-height: 1.1;
}

.contenant-titre-vert {
  width: 100%;
  max-width: 90vw;
}

.contenant-titre-vert.inondez-vos-elus {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.image-devenir-membre {
  width: 525px;
}

.arri-re-plan-principe-fondateur {
  -webkit-text-fill-color: inherit;
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/img/background-image.svg");
  background-position: 50%;
  background-size: contain;
  background-clip: border-box;
  flex-flow: row;
  width: 35%;
  height: 100%;
  display: flex;
}

.contenant-texte-principe-fondateur {
  justify-content: center;
  align-items: center;
  width: 65%;
  height: 100%;
  display: flex;
}

.collection-list-dates-importantes {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: row;
  place-content: center;
  place-items: stretch stretch;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  display: grid;
}

.num-rotation-devenir-membre {
  color: var(--vert-principale);
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  line-height: 38.4px;
}

._32px {
  font-size: 32px;
}

.tapes {
  grid-column-gap: 90px;
  grid-row-gap: 90px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.contenant-comment-devenir-membre {
  display: flex;
}

.div-block-12 {
  border: 1px solid var(--vert-principale);
  background-color: var(--vert-principale);
  opacity: .5;
  flex-flow: row;
  justify-content: center;
  align-items: flex-start;
  margin-right: 20px;
}

.images-devenir-membre {
  grid-column-gap: 100px;
  grid-row-gap: 100px;
  text-align: center;
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  width: 50%;
  display: flex;
}

.contenant-swiper {
  width: 1200px;
  max-width: 80vw;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}

.contenant-swiper.shorts {
  width: 100%;
}

.swiper.agir-en-1-clic {
  overflow: hidden;
}

.swiper.principes-fondateurs {
  width: 100%;
  overflow: hidden;
}

.swiper.agir-au-quotidien {
  width: 1138px;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

.swiper.action-rouyn {
  justify-content: center;
  align-items: stretch;
  width: 100%;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  overflow: hidden;
}

.swiper.carrousel-de-cartes {
  justify-content: center;
  align-items: stretch;
  overflow: hidden;
}

.swiper.actions-porte-voix, .swiper.shorts {
  overflow: hidden;
}

.swiper.shorts {
  padding-top: 1rem;
  padding-bottom: 1.75rem;
  overflow: hidden;
}

.swiper-wrapper {
  display: flex;
}

.swiper-wrapper.principes-fondateurs {
  flex-flow: row;
  justify-content: flex-start;
  align-items: center;
  margin-top: 20px;
  display: flex;
}

.swiper-wrapper.carrousel-actions {
  grid-column-gap: 0rem;
  grid-row-gap: 0rem;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.swiper-wrapper.carrousel-actions.agir-en-1-clic {
  display: block;
}

.swiper-wrapper.agir-en-1-clic {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  display: flex;
}

.swiper-wrapper.actions-porte-voix {
  justify-content: center;
  align-items: flex-start;
}

.swiper-slide {
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.swiper-slide.principes-fondateurs {
  flex-flow: row;
  flex: none;
  justify-content: flex-start;
  align-items: center;
  width: 910px;
}

.swiper-slide.agir-en-1-clic {
  flex: none;
  width: 362px;
}

.swiper-slide.action-rouyn {
  flex: none;
}

.swiper-slide.carrousel-de-cartes {
  width: 33.3333%;
}

.swiper-slide.actions-porte-voix {
  display: flex;
}

.swiper-slide.shorts {
  flex: none;
  width: 290px;
  height: 430px;
}

.info-carte-agir {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  padding-bottom: 20px;
  display: flex;
}

.principes-fondateurs {
  flex-flow: row;
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  width: 1138px;
  max-width: 95vw;
  display: flex;
  position: relative;
  overflow: visible;
}

.contenant-impliquez-vous {
  max-width: 95vw;
  margin-top: -30px;
  position: relative;
  overflow: visible;
}

.grand-coeur-blanc {
  z-index: -2;
  width: 581px;
  height: 544px;
  position: absolute;
  inset: -20% 0% 0% -25%;
  overflow: clip;
}

.grand-coeur-blanc.droite {
  flex: none;
  top: -25%;
  left: 75%;
}

.carte-rejoingnez-un-groupe {
  cursor: pointer;
  background-image: linear-gradient(#0000001a, #0000001a), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/66350317becced010f175b73_carteMAF.jpg");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 544px;
  height: 544px;
  margin-bottom: -100px;
  padding: 40px;
  transition: box-shadow .3s ease-in-out;
  display: flex;
}

.carte-rejoingnez-un-groupe:hover {
  box-shadow: 5px 5px 15px 5px #0006;
}

.tiquette-s-impliquer {
  background-color: var(--vert-principale);
  color: var(--blanc);
  text-align: center;
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 139px;
  height: 40px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  line-height: 26px;
  display: flex;
}

.texte-tiquette-s-impliquer {
  margin-bottom: 0;
}

.faire-un-don {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: var(--blanc);
  cursor: pointer;
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 544px;
  height: 196px;
  padding: 20px;
  transition: box-shadow .3s ease-in-out;
  display: flex;
}

.faire-un-don:hover {
  box-shadow: 5px 5px 15px 5px #0006;
}

.carte-s-impliquer {
  background-image: linear-gradient(#0006, #0006), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/663506a7a70cef749d54fb00_MAF_s-impliquer.png");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 544px;
  height: 371px;
  padding: 30px;
  display: flex;
}

.nous-connaitre {
  color: var(--blanc);
  cursor: pointer;
  background-image: linear-gradient(#0000004d, #0000004d), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/66350d7443c62407c0cb0ce5_MAF_nous_connaitre.png");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 1137px;
  height: 600px;
  margin-top: 40px;
  padding: 40px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 120px;
  font-weight: 700;
  line-height: 120px;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
  display: flex;
}

.nous-connaitre:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 15px 5px #0000004d;
}

.carte-besoin-de-vous {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  background-color: var(--vert-principale);
  cursor: pointer;
  -webkit-clip-path: polygon(2% 5%, 95% 8%, 100% 70%, 85% 95%, 0% 100%, 3% 40%);
  clip-path: polygon(2% 5%, 95% 8%, 100% 70%, 85% 95%, 0% 100%, 3% 40%);
  flex-flow: column;
  justify-content: space-between;
  width: 500px;
  max-width: 95vw;
  min-height: 267px;
  padding: 3rem;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 38.4px;
  transition-property: transform;
  transition-duration: .3s;
  transition-timing-function: ease;
  display: flex;
}

.carte-besoin-de-vous:hover {
  transform: translate(0, -2px);
}

.badge-blanc {
  color: var(--vert-principale);
  text-align: center;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/663520dd5ad218e35b4b052e_badgeBlanc.png");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 90% 50px;
  justify-content: center;
  align-items: center;
  padding: 15px 35px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 14px;
  display: flex;
}

.badge-blanc.mini-portrait {
  background-position: 100%;
  background-size: cover;
  padding-left: 25px;
  padding-right: 25px;
}

.icon-on-a-besoin-de-vous {
  width: 55px;
  height: 56px;
  margin-right: 20px;
}

.collection-on-a-besoin-de-vous {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: row;
  justify-content: space-between;
  align-items: stretch;
  margin-top: 40px;
  margin-bottom: 40px;
  font-size: 16px;
  display: flex;
}

.contenant-image-faire-un-don {
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  height: 408px;
  display: flex;
  position: relative;
}

.contenant-faire-un-don {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: row;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

._50 {
  width: 50%;
}

.titre-faire-un-don {
  color: var(--blanc);
  text-align: center;
  z-index: 5;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 76px;
  font-weight: 700;
  line-height: 91.2px;
}

.fond-vert {
  background-color: var(--vert-principale);
  border-radius: 5px;
  width: 100%;
  padding: 20px;
}

.formulaire-faire-un-don {
  background-color: var(--vert-principale);
  text-align: center;
  border-radius: 5px;
  width: 50%;
  padding: 20px;
}

.en-tete-formulaire-adhesion {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--gris-principale);
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  max-width: 95vw;
  font-size: 18px;
  line-height: 28.8px;
  display: flex;
}

.noir {
  color: var(--noir);
}

.noir._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
}

.texte-formulaire-adh-sion {
  letter-spacing: -.32px;
  font-size: 21px;
}

.contenant-groupe-portrait {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 95vw;
  margin-top: 40px;
  margin-bottom: 60px;
  display: flex;
}

.carte-rejoindre-un-groupe {
  color: var(--blanc);
  cursor: pointer;
  background-image: linear-gradient(#00000080, #00000080), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/663bbee771be4ae78cf8f730_MAF_groupe.jpg");
  background-position: 0 0, 50%;
  background-size: auto, cover;
  border-radius: 5px;
  width: 545px;
  height: 641px;
  padding: 30px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
}

.carte-rejoindre-un-groupe:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 15px 5px #0000004d;
}

.contenu-carte-rejoindre-un-groupe {
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  height: 100%;
  font-size: 18px;
  line-height: 21.6px;
  display: flex;
}

.portraits {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-flow: column;
  justify-content: space-between;
  display: flex;
}

.carte-mini-portrait {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  justify-content: space-between;
  align-items: stretch;
  width: 544px;
  max-width: 95vw;
  height: 225.6px;
  padding: 30px 50px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 21.6px;
  display: flex;
}

.carte-mini-portrait.variante {
  background-color: #0000;
  height: 250px;
  padding-left: 30px;
  padding-right: 30px;
  position: relative;
}

.partie-gauche {
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 60%;
  display: flex;
}

.partie-droite {
  -webkit-text-fill-color: transparent;
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/img/background-image.svg");
  background-position: 0 0;
  background-size: auto;
  -webkit-background-clip: text;
  background-clip: text;
  border-radius: 5px;
  width: 40%;
}

.image-portrait {
  width: 100%;
}

.link {
  color: var(--vert-principale);
  display: inline-block;
}

.link:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.contenant-formulaire-devenir-membre {
  background-color: var(--vert-principale);
  text-align: center;
  border-radius: 10px;
  width: 1138px;
  max-width: 95vw;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  padding: 40px;
}

.code-embed {
  width: 100%;
  height: 1042px;
}

.formulaire-devenir-membre {
  border-radius: 10px;
}

.pied-de-page {
  background-color: var(--vert-principale);
  color: var(--blanc);
  z-index: 100;
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  width: 100vw;
  padding: 50px 100px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 24px;
  position: relative;
}

.archives {
  background-color: var(--vert-principale);
}

.archive-flow-infolettre-pdp {
  width: 500px;
  padding: 40px;
}

.pdp-colonne-gauche {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.pdp-colonne-droite {
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.formulaire-infolettre {
  flex-flow: row;
  width: 500px;
  min-width: 400px;
  min-height: 220px;
  margin-left: -15px;
  padding-left: 0;
}

.groupe-liens-pdp {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  align-items: center;
  display: flex;
}

.lien-balado {
  background-color: var(--blanc);
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 52px;
  height: 48px;
  padding-bottom: 0;
  padding-left: 16px;
  padding-right: 16px;
  transition: transform .3s, box-shadow .3s;
  display: flex;
}

.lien-balado:hover {
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 5px #0003;
}

.lien-balado.vert {
  background-color: var(--vert-principale);
}

.contenant-groupe-liens-pdp {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  display: flex;
}

.fil-d-ariane {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  display: flex;
}

.image-principe-fondateur {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.soulignement-nav-item {
  background-color: var(--vert-principale);
  width: 0%;
  height: 3px;
}

.titre-impliquez-vous {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.swiper-btn-prev {
  cursor: pointer;
  transition: transform .3s ease-in;
}

.swiper-btn-prev:hover {
  transform: translate(-10px);
}

.swiper-button-cercle {
  border: 1px solid var(--vert-principale);
  border-radius: 50%;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 116px;
  height: 116px;
  display: flex;
}

.swiper-button-cercle.prev.shorts, .swiper-button-cercle.next.shorts {
  border-color: var(--blanc);
}

.contenant-swiper-button {
  z-index: 10;
  flex: none;
  justify-content: space-between;
  align-items: stretch;
  width: 116%;
  display: flex;
  position: absolute;
  top: 50%;
  left: -8%;
}

.contenant-swiper-button.agir-en-1-clic, .contenant-swiper-button.actions-porte-voix {
  width: 116%;
  left: -8%;
}

.contenant-swiper-button.shorts {
  width: 116%;
  left: -8%;
  transform: translate(0, -50%);
}

.swiper-btn-next {
  cursor: pointer;
  transition: transform .3s ease-in;
}

.swiper-btn-next:hover {
  transform: translate(10px);
}

.titre-navigation {
  display: none;
}

.list {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  z-index: 500;
  justify-content: center;
  align-items: center;
  margin-top: 0;
  margin-bottom: 0;
  padding: 10px 20px;
  line-height: 20px;
  list-style-type: none;
  display: flex;
  position: relative;
}

.list-item {
  margin-bottom: 3px;
}

.list-item.bouton-passer-a-l-action {
  margin-left: 15px;
}

.list-item.dropdown-wrapper {
  position: relative;
}

.section-navigation {
  z-index: 500;
  width: 100vw;
}

.section-navigation.vert {
  background-color: var(--vert-principale);
}

.navbar-logo-left-container {
  z-index: 5;
  background-color: #0000;
  max-width: 1520px;
  margin-left: auto;
  margin-right: auto;
  padding: 15px 60px;
}

.navbar-wrapper {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.swiper-pagination {
  justify-content: center;
  align-items: center;
  width: auto;
  height: auto;
}

.swiper-pagination.agir-en-1-clic {
  margin-right: 0;
  position: absolute;
  inset: 0% 0% auto auto;
}

.swiper-pagination.agir-au-quotidien {
  width: 300px;
  margin-bottom: 20px;
  margin-right: 0;
  position: absolute;
  top: 0%;
  bottom: auto;
  right: 0%;
}

.swiper-pagination.carrousel-de-cartes {
  margin-right: 0;
  position: absolute;
  inset: 0% 0% auto auto;
}

.swiper-pagination.actions-porte-voix {
  position: absolute;
}

.swiper-pagination.shorts {
  margin-right: 0;
  position: absolute;
  inset: 0% 0% auto auto;
}

.agir-au-quotidien {
  align-items: center;
  width: 100%;
  display: flex;
  position: relative;
}

.carte-caroussel-agir {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  text-align: center;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  width: 362px;
  max-width: 95vw;
  height: auto;
  display: flex;
  overflow: hidden;
}

.titre-principe-fondateur {
  margin-bottom: 35px;
  margin-left: 60px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 48px;
}

.contenant-principe-fondateur {
  border-radius: 5px;
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: flex-start;
  width: 910px;
  max-width: 95vw;
  display: flex;
  overflow: hidden;
}

.bouton-vert {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--vert-principale);
  opacity: 1;
  color: var(--blanc);
  text-align: center;
  letter-spacing: -.15px;
  cursor: pointer;
  z-index: 2;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  min-height: 48px;
  padding: 1rem 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition-property: box-shadow, transform, border-color, color, background-color;
  transition-duration: .3s, .3s, .2s, .2s, .2s;
  transition-timing-function: ease, ease, ease, ease, ease;
  display: flex;
}

.bouton-vert:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-vert:active {
  border: 1px solid var(--vert-principale);
  background-color: var(--blanc);
  opacity: 1;
  color: var(--vert-principale);
}

.bouton-vert.long {
  letter-spacing: 0;
}

.bouton-vert.grand {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  letter-spacing: 0;
  border-radius: 5px;
  padding: 20px 60px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 17.2px;
}

.bouton-vert.grand._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 15.482px;
}

.bouton-vert.pos-relative {
  cursor: pointer;
  padding-left: 1rem;
  padding-right: 1rem;
}

.bouton-vert.pos-relative.next:hover {
  transform: translate(3px);
}

.bouton-vert.avec-margin {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.bouton-blanc {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--blanc);
  color: var(--vert-principale);
  text-align: center;
  letter-spacing: -.15px;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  min-height: 48px;
  padding-left: 16px;
  padding-right: 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition: color .2s, border-color .2s, background-color .2s, transform .3s, box-shadow .3s;
  display: flex;
}

.bouton-blanc:hover {
  color: var(--vert-principale);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-blanc:active {
  border: 1px solid var(--blanc);
  background-color: var(--vert-principale);
  color: var(--blanc);
}

.bouton-blanc.long {
  letter-spacing: 0;
}

.bouton-blanc.long.rose, .bouton-blanc.long.rose:hover {
  color: var(--maf-pink);
}

.bouton-blanc.long.rose:active {
  background-color: var(--maf-pink);
  color: var(--blanc);
}

.bouton-rose {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--maf-pink);
  color: var(--blanc);
  text-align: center;
  letter-spacing: -.15px;
  cursor: pointer;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  height: 48px;
  padding-left: 16px;
  padding-right: 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition: color .2s, border-color .2s, background-color .2s, box-shadow .3s, transform .3s;
  display: flex;
}

.bouton-rose:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-rose:active {
  border: 1px solid var(--maf-pink);
  background-color: var(--blanc);
  color: var(--maf-pink);
}

.bouton-rose.long {
  letter-spacing: 0;
  width: 240px;
}

.carte-video {
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 545px;
  max-width: 95vw;
  height: 640px;
  margin-left: auto;
  margin-right: auto;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 48px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.carte-video.video-integree {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  max-width: 545px;
  display: block;
}

.contenant-carte-video {
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  padding: 40px;
  display: flex;
  position: absolute;
}

.image-carte-video {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.titre-carte-video {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 40px;
  font-weight: 700;
  line-height: 48px;
}

.bouton-lecture {
  border-top-style: solid;
  border-top-width: 3px;
  border-top-color: var(--blanc);
  border-right-style: solid;
  border-right-width: 3px;
  border-right-color: var(--blanc);
  border-bottom-style: solid;
  border-bottom-width: 3px;
  border-bottom-color: var(--blanc);
  border-left-style: solid;
  border-left-width: 3px;
  border-left-color: var(--blanc);
  cursor: pointer;
  z-index: 2;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 150px;
  height: 150px;
  transition-property: transform;
  transition-duration: .3s;
  transition-timing-function: ease-in-out;
  display: flex;
}

.bouton-lecture:hover {
  transform: scale(1.1);
}

.overlay {
  background-color: var(--noir);
  opacity: .3;
  pointer-events: none;
  z-index: 0;
  border-radius: 5px;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.overlay._50 {
  opacity: .5;
}

.overlay.histoire {
  opacity: .6;
}

.overlay.animation {
  opacity: 0;
  transition: opacity .4s ease-in-out;
}

.overlay._60 {
  opacity: .6;
}

.overlay._40 {
  opacity: .4;
}

.overlay.blanc {
  background-color: var(--blanc);
  opacity: .4;
}

.contenant-image {
  z-index: -1;
  border-radius: 5px;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.contenant-image.notre-histoire {
  z-index: 1;
}

.contenant-image.index-positif {
  z-index: 0;
}

.contenant-decouvrez-nos-actions {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  width: 1138px;
  max-width: 95vw;
  margin-top: 40px;
  margin-bottom: 60px;
  display: flex;
}

.carte-avec-nombre {
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 545px;
  max-width: 95vw;
  height: 640px;
  padding: 40px;
  display: flex;
  position: relative;
}

.carte-avec-nombre.page-acceuil {
  cursor: pointer;
  transition: box-shadow .3s ease-in-out, transform .3s ease-in-out;
}

.carte-avec-nombre.page-acceuil:hover {
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.image-carte-nombre {
  object-fit: cover;
  border-radius: 5px;
  width: 100%;
  height: 100%;
}

.contenant-carte-nombre {
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.grand-nombre {
  color: var(--blanc);
  text-align: center;
  align-self: center;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 200px;
  font-weight: 700;
  line-height: 240px;
}

.titre-carte-nombre {
  color: var(--blanc);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 48px;
}

.sous-titre-carte-nombre {
  color: var(--blanc);
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 24px;
}

.texte-carte-nombre {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  display: flex;
}

.element-centre {
  cursor: pointer;
  align-self: center;
  transition: transform .3s ease-in-out;
  position: absolute;
}

.element-centre:hover {
  transform: scale(1.1);
}

.image-arriere-plan {
  aspect-ratio: auto;
  object-fit: cover;
  object-position: 50% 50%;
  border-radius: 5px;
  width: 100%;
  height: 100%;
}

.image-arriere-plan.album-photo-actions-passees {
  object-fit: contain;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 100%;
  margin-left: auto;
  margin-right: auto;
}

.image-arriere-plan.mini-portrait {
  object-position: 50% 0%;
}

.image-arriere-plan.cdg-jappuie {
  border-radius: 0;
}

.cercle {
  border: 1px solid var(--voyant-rouge);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 17px;
  height: 17px;
  display: flex;
}

.voyant {
  background-color: var(--voyant-rouge);
  border-radius: 50%;
  width: 11px;
  height: 11px;
}

.contenant-texte-carte-action {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.carte-moyenne-badge-et-bouton {
  width: 545px;
  max-width: 95vw;
  height: 640px;
  display: flex;
  position: relative;
}

.contenant-carte-moyenne {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  padding: 32px;
  display: flex;
}

.info-carte-moyenne {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.texte-carte-moyenne {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  color: var(--blanc);
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 32px;
  line-height: 38.4px;
  display: flex;
}

.carte-moyenne-texte-superieur {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 28.8px;
}

.collection-list-actions-passees {
  grid-column-gap: 35px;
  grid-row-gap: 0px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: row;
  max-width: 95vw;
  margin-bottom: 2rem;
  margin-left: 0;
  margin-right: 0;
  display: grid;
}

.rapport-activite {
  justify-content: space-between;
  align-items: center;
  width: 1139px;
  height: 604.51px;
  margin-top: 60px;
  display: flex;
}

.rapport-activite-gauche {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 50%;
  height: 100%;
  display: flex;
}

.texte-rapport-activite {
  margin-bottom: 0;
  font-size: 32px;
  line-height: 48px;
}

.rapport-activite-droite {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 50%;
  height: 100%;
  display: flex;
}

.carte-rapport-activitees {
  border-radius: 5px;
  width: 360px;
  max-width: 95vw;
  height: 571px;
  transition: transform .3s, box-shadow .3s;
  display: flex;
  position: relative;
}

.carte-rapport-activitees:hover {
  box-shadow: 3px 5px 11px 5px var(--gris);
  transform: translate(-2px, -2px);
}

.contenant-carte-rapport-activitees {
  z-index: 1;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  padding: 32px;
  display: flex;
}

.annee-rapport-activite {
  color: var(--blanc);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 38.4px;
}

.texte-etapes {
  font-size: 32px;
  line-height: 50px;
}

.texte-grand-polygone-verte.page-devenir-membre {
  font-size: 24px;
  line-height: 28.8px;
}

.sous-titre {
  text-align: center;
  width: 60%;
  font-size: 24px;
  line-height: 28.8px;
}

.sous-titre.gris-principale {
  color: var(--gris-principale);
  margin-bottom: 60px;
}

.sous-titre.inondez-vos-elus {
  line-height: 36px;
}

.sous-titre.campagne-cdg {
  color: var(--blanc);
  text-align: left;
  text-shadow: 0 1px 3px var(--anthracite);
  width: auto;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 32px;
  font-weight: 500;
  line-height: 1.1;
}

.bouton-blanc-texte-rose {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--blanc);
  color: var(--maf-pink);
  text-align: center;
  letter-spacing: -.15px;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  height: 48px;
  padding-left: 16px;
  padding-right: 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition: color .2s, border-color .2s, background-color .2s, transform .3s, box-shadow .3s;
  display: flex;
}

.bouton-blanc-texte-rose:hover {
  color: var(--maf-pink);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-blanc-texte-rose:active {
  border: 1px solid var(--blanc);
  background-color: var(--vert-principale);
  color: var(--blanc);
}

.collection-offres-emplois {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: wrap;
  align-items: center;
  max-width: 1200px;
  margin-top: 20px;
}

.liste-offres-emplois {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  display: flex;
}

.carte-emploi {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 360px;
  height: 360px;
  padding: 32px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 14px;
  line-height: 48px;
  transition: box-shadow .3s, transform .3s;
  display: flex;
}

.carte-emploi:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.carte-emploi.benevolat {
  background-color: var(--maf-pink);
}

.contenu-offre-emploi {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.tag-offre-emploi {
  border: .5px solid var(--blanc);
  border-radius: 70px;
  padding-left: 12px;
  padding-right: 12px;
}

.tag-offre-emploi:hover {
  color: var(--blanc);
}

.tag-offre-emploi.blanc {
  background-color: var(--blanc);
  color: var(--maf-pink);
  border-style: none;
  border-width: 0;
}

.contenant-tag {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.demi-contenant {
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 50%;
  display: flex;
}

.demi-contenant.gauche {
  width: 65%;
}

.demi-contenant.gauche.infolettre {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  font-size: 24px;
  line-height: 28.8px;
}

.demi-contenant.droite {
  width: 35%;
}

.texte-carte {
  color: var(--blanc);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
}

.contenant-texte {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.contenant-texte.grande-carte {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  width: 70%;
  line-height: 26.4px;
}

.en-tete-carte {
  color: var(--blanc);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 38px;
  font-weight: 700;
  line-height: 33px;
}

.carte-apercu-benevolat {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: var(--maf-pink);
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 360px;
  height: 360px;
  padding: 32px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 14px;
  line-height: 48px;
  display: flex;
}

.texte-nous-connaitre {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 120px;
  line-height: 120px;
}

.titre-carte-besoin-de-vous {
  color: var(--blanc);
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.75rem;
  line-height: 1.2;
}

.chevron-navigation {
  opacity: .7;
}

.dropdown-nous-connaitre {
  background-color: var(--blanc);
  z-index: 1;
  border-radius: 5px;
  width: 230px;
  position: absolute;
  top: 75px;
  left: -50px;
  overflow: hidden;
}

.liste-dropdown-nous-connaitre {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 10px;
  display: flex;
}

.list-item-2 {
  margin-bottom: 0;
}

.dropdown-trigger {
  cursor: pointer;
  justify-content: center;
  align-items: center;
  display: flex;
}

.contenant-hero {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: none;
  height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.contenant-hero.cdg {
  width: 100%;
  height: auto;
  min-height: 100vh;
  padding-top: 6rem;
}

.section-barre-de-navigation {
  width: 100%;
  position: absolute;
  top: 0;
}

.contenant-texte-hero {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  color: var(--blanc);
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 90%;
  font-size: 32px;
  line-height: 38.4px;
  display: flex;
}

.titre-hero {
  width: 60%;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 100px;
  font-weight: 700;
  line-height: 1.2;
}

.coeur-echo {
  z-index: 4;
  position: absolute;
}

.elements-centrales {
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.elements-du-bas {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  color: var(--blanc);
  text-align: center;
  flex-flow: column;
  justify-content: flex-end;
  align-items: center;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 28.8px;
  display: flex;
  position: absolute;
  bottom: 50px;
  left: 50%;
  transform: translate(-50%);
}

.section-bandeau-de-lien {
  width: 100%;
  height: 90px;
  position: static;
  left: 50%;
}

.page-principale-sombre {
  background-color: var(--anthracite);
  flex-flow: column;
  align-items: center;
  width: 100vw;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  display: flex;
  position: relative;
}

.span-500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
}

.image-flottante {
  z-index: 0;
  background-image: linear-gradient(#00000080, #00000080);
  border-radius: 5px;
  width: 300px;
  height: 300px;
  position: absolute;
}

.image-flottante.image-1 {
  background-image: linear-gradient(#00000080, #00000080), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/665a21c62aeb2385c243076e_MAF_Image.jpg");
  background-position: 0 0, 50%;
  background-size: auto, cover;
  top: 15%;
  left: 15%;
}

.image-flottante.image-2 {
  background-image: linear-gradient(#00000080, #00000080), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/6622902646ccb8ed1768a2ad_Image-date.jpg");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  right: 15%;
}

.image-flottante.image-3 {
  background-image: linear-gradient(#00000080, #00000080), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/674a27052f0ecdbe239cff1d_MathieuBMorin_MAF_20240512_143339.jpg");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  bottom: 0%;
}

.grande-carte-long-texte {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  color: var(--blanc);
  flex-flow: column;
  width: 1138px;
  max-width: 95vw;
  height: 600px;
  padding: 120px 60px 60px;
  font-size: 24px;
  line-height: 36px;
  display: flex;
  position: relative;
}

.titre-grande-carte-long-texte {
  z-index: 2;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 32px;
  line-height: 44px;
}

.lien-vert {
  color: var(--vert-principale);
  display: inline-block;
}

.lien-vert:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.texte-nos-demandes {
  color: var(--blanc);
  text-align: center;
  margin-top: 80px;
  margin-bottom: 80px;
  line-height: 52px;
}

.contenant-liens-nous-connaitre {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  justify-content: center;
  width: 80%;
  height: 680px;
  margin-top: 15px;
  display: flex;
}

.grande-carte-lien {
  justify-content: space-between;
  align-items: flex-end;
  width: 643px;
  height: 100%;
  padding: 30px;
  display: flex;
  position: relative;
}

.grande-carte-lien.gauche {
  transition: transform .3s ease-in-out;
}

.grande-carte-lien.gauche:hover {
  transform: translate(-3px);
}

.grande-carte-lien.droite {
  transition: transform .3s ease-in-out;
}

.grande-carte-lien.droite:hover {
  transform: translate(3px);
}

.titre-du-lien {
  color: var(--blanc);
  text-align: right;
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 72px;
  font-weight: 700;
  line-height: 86.4px;
}

.titre-du-lien.gauche {
  text-align: left;
}

.fleche-blanche {
  border: 1px solid var(--blanc);
  border-radius: 50%;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  padding: 30px;
  display: flex;
}

.paragraph-hero {
  width: 30%;
  line-height: 1.4;
}

.photo-portrait {
  object-fit: cover;
  border-radius: 5px;
  width: 539px;
}

.texte-portrait {
  color: var(--noir);
  width: 90%;
  margin-top: 20px;
  margin-bottom: 0;
  font-size: 24px;
  line-height: 36px;
}

.mini-carte-portrait {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 221px;
  height: 184px;
  padding: 15px;
  font-size: 14px;
  line-height: 16.8px;
  transition: color .3s ease-in-out;
  display: flex;
  position: relative;
}

.mini-carte-portrait:hover {
  color: var(--vert-principale);
}

.mini-carte-prenom {
  margin-top: 0;
  margin-bottom: 5px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 28.8px;
}

.contenant-texte-notre-histoire {
  z-index: 2;
  width: 80vw;
  max-width: 1138px;
  height: 820px;
  padding-bottom: 180px;
  position: relative;
  overflow: auto;
}

.notre-fonctionnement {
  color: var(--blanc);
  padding-left: 20px;
  padding-right: 20px;
  font-size: 32px;
  line-height: 50px;
}

.introduction {
  margin-bottom: 20px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 50px;
}

.lien-texte-notre-histoire {
  color: var(--vert-principale);
  transition-property: none;
  display: inline-block;
}

.lien-texte-notre-histoire:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.overlay-radial {
  pointer-events: none;
  z-index: 1;
  background-image: radial-gradient(circle, #0000, #040404 93%);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.overlay-radial.histoire {
  background-image: radial-gradient(circle, #0000, #040404 95%), radial-gradient(circle, #0000 40%, #040404);
}

.overlay-linear {
  pointer-events: none;
  z-index: 10;
  background-image: linear-gradient(#0000 70%, #040404 93%);
  border-radius: 5px;
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
}

.overlay-linear.blanc {
  background-image: linear-gradient(180deg, #0000 70%, var(--blanc) 93%);
}

.overlay-linear.vert {
  background-image: linear-gradient(180deg, #0000 27%, var(--vert-principale) 93%);
}

.overlay-linear.vert.inondez-vos-elus {
  z-index: 4;
  -webkit-text-fill-color: inherit;
  background-image: linear-gradient(#fff0, #2bb34cc4 56%);
  background-clip: content-box;
  height: 100%;
  margin-bottom: -10px;
}

.overlay-linear.cri-du-coeur {
  z-index: 10;
  background-image: linear-gradient(#0000 70%, #010101a1 74%, #040404 95%);
}

.mini-carte-conseil {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  background-color: var(--vert-principale-foncé);
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 221px;
  height: 184px;
  padding: 10px;
  font-size: 14px;
  line-height: 16.8px;
  display: flex;
}

.texte-mini-carte-conseil {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  display: flex;
}

.nom {
  width: 80%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 28.8px;
}

.mb140 {
  margin-bottom: 140px;
}

.div-block-16, .div-block-17 {
  width: 643px;
}

.div-block-18, .div-block-19 {
  height: 680px;
}

.div-block-20, .div-block-21 {
  width: 643px;
}

.div-block-22, .div-block-23 {
  z-index: 2;
}

.notre-cri-du-coeur {
  background-image: linear-gradient(180deg, #000000d9 52%, var(--anthracite) 94%), url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/666374144f85b4fe3d90c444_MAF_cri_du_coeur.jpg");
  background-position: 0 0, 50%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  width: 100vw;
  height: 100vh;
  padding-top: 80px;
  padding-bottom: 80px;
  position: relative;
}

.notre-symbole {
  color: var(--blanc);
  text-align: center;
  background-color: #040404;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: 800px;
  font-size: 20px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.nos-balados {
  background-color: var(--anthracite);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100vw;
  height: 870px;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
  position: relative;
}

.texte-cri-du-coeur {
  color: var(--blanc);
  text-align: center;
  z-index: 999;
  width: 60%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 220px;
  font-size: 30px;
  line-height: 50px;
  overflow: auto;
}

.texte-notre-symbole {
  z-index: 2;
  width: 30%;
  margin-bottom: 0;
}

.notre-symbole-btn-pdf {
  z-index: 10;
  margin-bottom: 60px;
  position: absolute;
  bottom: 0%;
  left: 50%;
  transform: translate(-50%);
}

.collection-carte-avec-badge {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  width: 1200px;
  max-width: 95vw;
  display: flex;
}

.collection-carte-avec-badge.action-en-cours-et-a-venir {
  grid-row-gap: 0px;
}

.collection-carte-avec-badge.action-en-cours-et-a-venir.page-groupe {
  grid-row-gap: 30px;
}

.collection-carte-avec-badge.ressources {
  margin-bottom: 40px;
}

.collection-carte-avec-badge.on-parle-de-nous {
  margin-bottom: 60px;
}

.collection-carte-avec-badge.articles-accueil {
  grid-column-gap: 30px;
  grid-row-gap: 0px;
  margin-bottom: 1rem;
}

.collection-carte-avec-badge.liste-rapports {
  margin-bottom: 1.5rem;
}

.grande-carte-avec-badge-et-bouton {
  color: var(--blanc);
  z-index: 2;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 1137px;
  max-width: 95vw;
  height: 600px;
  padding: 40px;
  display: flex;
  position: relative;
}

.bas-de-carte {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

.contenant-textes {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 55%;
  display: flex;
}

.contenant-textes.carte-photo {
  width: 85%;
}

.texte-secondaire {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 18px;
}

.texte-principal {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
  line-height: 44px;
}

.faq-autres {
  overflow: hidden;
}

.contenant-collections-ressources {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.grande-carte-titre {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 60px;
}

.sous-titre-nos-groupes {
  text-align: center;
  width: 75%;
  margin-left: auto;
  margin-right: auto;
  font-size: 32px;
  line-height: 38.4px;
}

.contenant-carte-groupe-hors-quebec {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  display: flex;
}

.contenant-citation {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 545px;
  max-width: 95vw;
  height: 641px;
  margin-top: 60px;
  margin-bottom: 60px;
  padding: 40px 30px 60px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 44px;
  font-weight: 700;
  line-height: 52.8px;
  display: flex;
  position: relative;
}

.citation {
  font-size: 42px;
}

.citation-auteur {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 32px;
  font-weight: 500;
  line-height: 38.4px;
}

.image-citation {
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  width: 150px;
  position: absolute;
  inset: auto 30px 30px auto;
}

.titre-nos-groupes-bas {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  color: var(--vert-principale);
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 20px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 28.8px;
  display: flex;
}

.lien-voir-la-carte {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  text-align: center;
  cursor: pointer;
  border-radius: 5px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 202px;
  height: 85px;
  padding: 20px;
  font-size: 24px;
  line-height: 20.64px;
  transition: box-shadow .3s ease-in-out, transform .3s ease-in-out;
  display: flex;
}

.lien-voir-la-carte:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.contenu-voir-la-carte {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.contenant-lien-voir-la-carte {
  position: absolute;
  inset: auto 10% 0% auto;
}

.etapes-rejoindre-un-groupe {
  grid-column-gap: 200px;
  grid-row-gap: 200px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  margin-top: 60px;
  margin-bottom: 60px;
  padding-top: 100px;
  display: flex;
  overflow: hidden;
}

.contenant-etape {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  text-align: center;
  border-radius: 5px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 480px;
  max-width: 95vw;
  height: 486px;
  padding: 20px;
  display: flex;
}

.contenant-etape.intro-etapes {
  background-color: var(--maf-pink);
  box-shadow: none;
  justify-content: center;
  transform: rotate(-15deg);
}

.contenant-etape.intro-etapes.temporaire {
  z-index: 1;
  position: absolute;
}

.contenant-etape.carte-de-dessous {
  position: absolute;
  inset: 0% auto auto 0%;
}

.contenant-etape.carte-de-dessous._20degres {
  z-index: -1;
  background-color: #ecb4c1;
  transform: rotate(-20deg);
}

.contenant-etape.carte-de-dessous._20degres.etape-1 {
  position: static;
  transform: rotate(-10deg);
}

.contenant-etape.carte-de-dessous._20degres.etape-1.temporaire {
  z-index: 1;
  position: absolute;
}

.contenant-etape.carte-de-dessous._20degres.etape2 {
  background-color: #edd2d8;
  position: static;
  transform: rotate(-5deg);
}

.contenant-etape.carte-de-dessous._20degres.etape2.temporaire {
  z-index: 1;
  position: absolute;
}

.contenant-etape.carte-de-dessous._20degres.etape3 {
  background-color: #eadcdf;
  position: static;
  transform: none;
}

.contenant-etape.carte-de-dessous._25degres {
  z-index: -2;
  background-color: #edd2d8;
  transform: rotate(-25deg);
}

.contenant-etape.carte-de-dessous._25degres.etape1 {
  transform: rotate(-15deg);
}

.contenant-etape.carte-de-dessous._25degres.etape2 {
  background-color: #eadcdf;
  transform: rotate(-10deg);
}

.contenant-etape.carte-de-dessous._30degres {
  z-index: -3;
  background-color: #eadcdf;
  transform: rotate(-30deg);
}

.contenant-etape.carte-de-dessous._30degres.etape1 {
  transform: rotate(-20deg);
}

.contenant-etape.cdg {
  margin: 20px;
  font-size: 21px;
}

.contenant-etape.cdg.etape-1 {
  background-color: #ecb4c1;
}

.contenant-etape.cdg.etape-2 {
  background-color: #edd2d8;
}

.etape {
  position: relative;
}

.titre-etape {
  color: var(--bourgogne);
  width: 80%;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 38.4px;
}

.texte-etape {
  color: var(--bourgogne);
  font-size: 24px;
  line-height: 28.8px;
}

.contenant-coeur {
  position: relative;
}

.coeur-etape {
  width: 132px;
}

.nombre-etape {
  color: var(--bourgogne);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 70px;
  font-weight: 500;
  line-height: 84px;
  position: absolute;
  inset: 50% 0% 0% 50%;
  transform: translate(-50%, -75%);
}

.etape-bouton {
  background-color: var(--blanc);
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  height: 48px;
  transition-property: none;
  display: flex;
}

.texte-etape-bouton {
  color: var(--bourgogne);
  padding-left: 16px;
  padding-right: 16px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 21.6px;
}

.boutons {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  display: flex;
}

.presentation-bouton {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.presentation-carte {
  grid-column-gap: 53px;
  grid-row-gap: 53px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.bas-carte-avec-badge-et-bouton {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.contenant-portrait {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  border-radius: 5px;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 95vw;
  height: 700px;
  display: flex;
  overflow: hidden;
}

.contenant-portrait.scientifiques {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  width: 1450px;
  height: 700px;
}

.photo-portrait {
  aspect-ratio: 2 / 3;
  object-fit: cover;
  height: 100%;
}

.photo-portrait.scientifiques {
  object-fit: contain;
  width: auto;
  min-width: 330px;
  height: auto;
  max-height: 50%;
}

.contenu-portrait {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  background-color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 782px;
  height: 100%;
  padding: 20px;
  font-size: 24px;
  line-height: 36px;
  display: flex;
  position: relative;
}

.contenu-portrait.scientifiques {
  width: 70%;
}

.nom-portrait {
  color: var(--vert-principale);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 70px;
  font-weight: 700;
  line-height: 90px;
}

.etiquettes-portrait {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  align-items: center;
  display: flex;
}

.etiquette-portrait {
  border-style: solid;
  border-width: 1px;
  border-radius: 50px;
  padding: 10px 20px;
  font-size: 18px;
  line-height: 21.6px;
}

.etiquette-portrait.role {
  border-color: var(--vert-principale);
  color: var(--vert-principale);
}

.etiquette-portrait.etiquette-groupe {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  border: 0 #000;
  justify-content: center;
  align-items: center;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
  display: flex;
}

.etiquette-portrait.etiquette-groupe:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.etiquette-groupe {
  background-color: var(--vert-principale);
  color: var(--blanc);
  font-size: 18px;
  line-height: 21.6px;
}

.texte-portrait {
  width: 100%;
  padding-bottom: 140px;
  overflow: auto;
}

.texte-portrait.scientifiques {
  height: auto;
  padding-bottom: 0;
  font-size: 18px;
  line-height: 26px;
}

.onglets-demandes {
  width: 100%;
  max-width: 1366px;
  overflow: hidden;
}

.contenant-onglet-demande {
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 40px;
  display: flex;
}

.contenant-onglet-demande.federal {
  background-color: var(--vert-principale);
}

.contenant-onglet-demande.provincial {
  background-color: var(--maf-pink);
}

.contenant-onglet-demande.municipal {
  background-color: var(--blanc);
}

.image-onglet-demande {
  object-fit: cover;
  object-position: 50% 50%;
  border-radius: 5px;
  flex: none;
  width: 342px;
  height: 600px;
}

.onglet-demande-droite {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 70%;
  height: 600px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 30px;
  font-weight: 700;
  line-height: 52px;
  display: flex;
}

.onglet-demande-droite.federal, .onglet-demande-droite.provincial {
  color: var(--blanc);
}

.onglet-demande-droite.municipal {
  color: var(--vert-principale);
}

.titre-onglet-demande {
  margin-top: 10px;
  margin-bottom: 0;
  font-size: 30px;
  line-height: 52px;
}

.onglet {
  opacity: .7;
  color: var(--noir);
  text-align: center;
  justify-content: center;
  align-items: center;
  width: 455px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 24px;
  font-weight: 400;
  line-height: 52px;
}

.onglet.federal {
  background-color: var(--vert-principale);
}

.onglet.federal.w--current {
  opacity: 1;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
}

.onglet.provincial {
  background-color: var(--maf-pink);
}

.onglet.provincial.w--current {
  opacity: 1;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
}

.onglet.municipal {
  background-color: var(--blanc);
}

.onglet.municipal.w--current {
  opacity: 1;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
}

.demande {
  box-sizing: border-box;
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-weight: 400;
  line-height: 46px;
  display: flex;
  overflow: auto;
}

.titre-demande {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 52px;
}

.texte-demande {
  max-width: 100%;
  overflow: hidden;
}

.splide {
  width: 100%;
  max-width: 95vw;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}

.splide.splide-balados {
  z-index: 5;
  justify-content: center;
  align-items: center;
  width: 1137px;
  max-height: 80%;
  display: flex;
  overflow: hidden;
}

.splide.commentaire {
  flex-flow: column;
  justify-content: center;
  align-items: center;
}

.splide.splide-album-photos {
  z-index: 10;
  margin-top: 20px;
}

.splide.splide-inondez {
  opacity: 0;
  width: 75%;
}

.splide.splide-porte-voix {
  max-width: 95vw;
  padding-bottom: 2rem;
  padding-left: 2rem;
  padding-right: 2rem;
}

.splide.agir-en-1-clic, .splide.actions-porte-voix {
  width: 1200px;
  padding-left: 3rem;
  padding-right: 3rem;
}

.splide__track {
  margin-top: 1rem;
}

.splide__list.gallerie-photos {
  padding: 2.5rem;
}

.splide__list.agir-en-1-clic, .splide__list.actions-porte-voix {
  display: flex;
}

.splide__slide.splide-balado {
  justify-content: center;
  align-items: center;
  display: flex;
}

.splide__slide.commentaire {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: center;
  align-items: center;
  padding-bottom: 60px;
  display: flex;
}

.splide__slide.porte-voix {
  justify-content: center;
  align-items: center;
  display: flex;
}

.splide__slide.scientifiques {
  justify-content: center;
  align-items: flex-start;
  max-height: 700px;
  display: flex;
}

.splide__slide.gallerie-photos {
  justify-content: center;
  align-items: center;
  max-height: 650px;
  padding: 2.5rem;
  display: flex;
}

.my-splider-progress {
  justify-content: center;
  align-items: center;
  width: 75%;
  margin-top: 20px;
  margin-bottom: 20px;
  display: inline-block;
}

.my-slider-progress-bar-federal {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  display: flex;
}

.section-nos-demandes {
  background-color: var(--anthracite);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100vw;
  display: flex;
  position: relative;
}

.my-slider-progress-bar-provincial, .my-slider-progress-bar-municipal, .pdp-contenant {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  display: flex;
}

.contenant-sliders {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 95vw;
  margin-bottom: 60px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  overflow: hidden;
}

.carte-conseil {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--blanc);
  color: var(--noir);
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 910px;
  max-width: 95vw;
  height: 454px;
  margin-left: auto;
  margin-right: auto;
  padding: 40px 100px;
  font-size: 18px;
  line-height: 30px;
  display: flex;
  overflow: hidden;
}

.carte-conseil-nom {
  color: var(--vert-principale);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 72px;
}

.carte-conseil-texte {
  overflow: auto;
}

.onglet-demandes {
  width: 100%;
}

.splide-extras {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  justify-content: flex-start;
  align-items: center;
  width: 70%;
  display: flex;
}

.splide-extras.grandes-fleches-vertes {
  width: 110%;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  right: 0;
  transform: translate(-50%, -50%);
}

.splide__arrows.nos-demandes {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.splide__arrows.grandes-fleches-vertes {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.splide__arrow {
  border: 1px solid var(--blanc);
  border-radius: 50%;
  padding: 10px;
}

.splide__arrow.splide__arrow--prev.grande-fleche-verte {
  border-color: var(--vert-principale);
  justify-content: center;
  align-items: center;
  width: 116px;
  height: 116px;
  display: flex;
}

.splide__arrow.splide__arrow--next.nos-demande {
  transform: rotate(180deg);
}

.splide__arrow.splide__arrow--next.grande-fleche-verte {
  border-color: var(--vert-principale);
  justify-content: center;
  align-items: center;
  width: 116px;
  height: 116px;
  display: flex;
}

.groupe-en-tete {
  color: var(--blanc);
  border-radius: 5px;
  justify-content: flex-start;
  align-items: flex-end;
  height: 654px;
  padding: 30px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 120px;
  font-weight: 700;
  line-height: 144px;
  display: flex;
  position: relative;
}

.groupe-titre {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 120px;
  font-weight: 700;
  line-height: 144px;
}

.groupe-description {
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  justify-content: flex-start;
  align-items: center;
  min-height: 420px;
  padding: 20px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 24px;
  line-height: 36px;
  display: flex;
}

.contenant-page-groupe {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 1138px;
  max-width: 100%;
  margin-bottom: 60px;
  display: grid;
}

.groupe-info-geo {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  border: 3px solid var(--vert-principale);
  color: var(--vert-principale);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  min-height: 90px;
  font-size: 24px;
  line-height: 20.64px;
  display: flex;
}

.groupe-contact {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--maf-pink);
  color: var(--blanc);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  min-height: 90px;
  font-size: 24px;
  line-height: 20.63px;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
  display: flex;
}

.groupe-contact:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.groupe-contact.facebook {
  background-color: var(--bleu-facebook);
}

.groupe-lien:hover {
  color: var(--blanc);
}

.collection-portraits-de-groupe {
  grid-column-gap: 35px;
  grid-row-gap: 35px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  place-items: center;
  max-width: 100%;
  display: grid;
}

.collection-petite-carte-portrait {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-flow: column;
  display: flex;
}

.collection-list-wrapper {
  height: 100%;
}

.contenant-boutons-faq {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.carte-principale {
  width: 100%;
  height: 100vh;
  position: relative;
}

.carte-pied-de-page {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--vert-principale);
  z-index: 1000;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  height: 50px;
  display: flex;
  position: absolute;
  inset: auto 0% 0%;
}

.texte-carte-pied-de-page {
  color: var(--blanc);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 24px;
}

.fleche-carte-pied-de-page {
  border: 1px solid var(--blanc);
  border-radius: 50%;
  padding: 8px;
}

.fleche-bas {
  transform: rotate(-90deg);
}

.contenant-liste-villes {
  background-color: var(--blanc);
  z-index: 1000;
  border-radius: 5px;
  position: absolute;
  top: 25px;
  left: 40px;
}

.contenant-liste-villes.cdg {
  max-width: 350px;
}

.titre-liste-villes {
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 28.8px;
}

.en-tete-liste-villes {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  border-radius: 5px;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  display: flex;
}

.separateur-liste-ville {
  background-color: var(--gris);
  opacity: .65;
  border-radius: 2px;
  width: 100%;
  height: 2px;
}

.ville {
  cursor: pointer;
  padding: 10px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  transition: color .3s ease-in-out;
}

.ville:hover {
  color: var(--vert-principale);
}

.liste-villes {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.map {
  width: 100%;
  height: 100%;
  padding: 20px;
}

.icone-aggrandir {
  display: none;
}

.icones-changement-de-taille {
  cursor: pointer;
  padding: 10px;
}

.liste-des-villes.groupes {
  max-height: 70vh;
  overflow: auto;
}

.collection-list {
  padding: 10px;
}

.en-tete {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 60px;
  margin-bottom: 60px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.offre-emploi-titre-en-tete {
  color: var(--vert-principale);
  text-transform: uppercase;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
  line-height: 52.8px;
}

.offre-emploi-contenant-presentation {
  border: 2px solid var(--vert-principale);
  border-radius: 5px;
  width: 1138px;
  max-width: 100%;
  padding: 20px 30px;
}

.offre-emploi-presentation-en-tete {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  border-bottom: 2px solid var(--gris);
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 10px;
  display: flex;
}

.offre-emploi-presentation-texte {
  font-size: 18px;
  line-height: 26px;
}

.offre-emploi-coeur-vert {
  width: 80px;
}

.offre-emploi-icone {
  position: relative;
}

.offre-emploi-icone-valise {
  position: absolute;
  inset: 50% 0% 0% 50%;
  transform: translate(-50%, -50%);
}

.offre-emploi-titre-emploi {
  color: var(--vert-principale);
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 48px;
}

.offre-emploi-liste-infos {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.offre-emploi-info {
  border: 1px solid var(--gris);
  color: var(--gris);
  border-radius: 70px;
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
  padding-left: 12px;
  padding-right: 12px;
  font-size: 14px;
  line-height: 48px;
  display: flex;
}

.offre-emploi-ce-que-nous-offrons {
  color: var(--blanc);
  justify-content: space-between;
  align-items: center;
  line-height: 26px;
  display: flex;
}

.ce-que-nous-offrons-titre {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 48px;
}

.signe-plus-ou-moins {
  cursor: pointer;
  padding: 10px 20px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 72px;
  font-weight: 700;
  line-height: 48px;
}

.signe-plus-ou-moins.portrait-scientifiques {
  color: var(--vert-principale);
  padding: 5px 10px;
  font-size: 40px;
  line-height: 40px;
}

.ce-que-nous-offrons-contenu {
  color: var(--blanc);
  position: relative;
  top: 20px;
}

.offre-emploi-competences {
  color: var(--blanc);
  justify-content: space-between;
  align-items: center;
  line-height: 26px;
  display: flex;
}

.competences-contenu {
  color: var(--blanc);
  position: relative;
  top: 20px;
}

.offre-emploi-processus {
  color: var(--vert-principale);
  justify-content: space-between;
  align-items: center;
  line-height: 26px;
  display: flex;
}

.processus-embauche-contenu {
  line-height: 26px;
  position: relative;
  top: 20px;
}

.offre-emploi-texte-equite {
  text-align: center;
  width: 50%;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 30px;
}

.offre-emploi-textes-riches {
  border-top: 1px solid var(--blanc);
}

.declencheur-ouverture-section {
  cursor: pointer;
  z-index: 2;
}

.offre-emploi-logo-coeur {
  flex: none;
}

.tabs-menu {
  display: flex;
}

.contenant-balado {
  grid-column-gap: 150px;
  grid-row-gap: 150px;
  z-index: 2;
  justify-content: center;
  align-items: center;
  width: 85%;
  height: 100%;
  margin-bottom: 40px;
  display: flex;
}

.balado-infos {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 50%;
  max-height: 75%;
  display: flex;
  overflow: auto;
}

.balado-titre {
  color: var(--vert-principale);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 52px;
}

.balado-temps {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.balado-duree {
  color: var(--blanc);
  line-height: 52px;
}

.balado-description {
  color: var(--blanc);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 30px;
}

.balado-liens {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.balado-intro-liens {
  color: var(--blanc);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  line-height: 30px;
}

.balado-vignette {
  border-radius: 5px;
  width: 100%;
  height: 100%;
}

.vignette-balado {
  width: 300px;
  height: 300px;
  position: relative;
}

.contenant-lecteur-balado {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  z-index: 10;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
  inset: 50% 0% 0% 50%;
  transform: translate(-50%, -50%);
}

.contenant-lecteur-balado.cach {
  display: none;
}

.icone-lecture {
  border: 1px solid var(--blanc);
  cursor: pointer;
  border-radius: 50%;
  padding: 15px;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
}

.icone-lecture:hover {
  transform: scale(1.2);
  box-shadow: 5px 5px 10px 5px #0003;
}

.balado-texte-extrait {
  color: var(--blanc);
  font-family: "PP Neue Montreal 300-400", sans-serif;
  line-height: 30px;
}

.contenant-page-action {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 1138px;
  max-width: 100%;
  display: grid;
}

.action-en-tete {
  color: var(--blanc);
  border-radius: 5px;
  justify-content: flex-start;
  align-items: flex-end;
  min-height: 475px;
  padding: 30px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 120px;
  font-weight: 700;
  line-height: 144px;
  display: flex;
  position: relative;
}

.action-description {
  background-color: var(--vert-principale);
  color: var(--blanc);
  border-radius: 5px;
  justify-content: flex-start;
  align-items: center;
  min-height: 420px;
  padding: 20px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 24px;
  line-height: 36px;
  display: flex;
}

.action-titre {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 100px;
  font-weight: 700;
  line-height: 1.1;
}

.action-info {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  border: 3px solid var(--vert-principale);
  color: var(--vert-principale);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  max-height: 100px;
  margin-top: .75rem;
  margin-bottom: .75rem;
  padding: 1.5rem;
  font-size: 24px;
  line-height: 20.64px;
  display: flex;
}

.action-info.lieu {
  border-color: var(--maf-pink);
  color: var(--maf-pink);
}

.action-info.lien-groupe {
  cursor: pointer;
  transition: background-color .3s ease-in-out, transform .3s ease-in-out, box-shadow .3s ease-in-out;
}

.action-info.lien-groupe:hover {
  color: var(--vert-principale);
  background-color: #2bb34c40;
  transform: translate(0, -2px);
  box-shadow: 0 5px 15px #0000004d;
}

.info-heure {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  display: flex;
}

.section-informations-pratiques {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  background-color: var(--vert-principale);
  color: var(--blanc);
  text-align: center;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 1138px;
  margin-top: 20px;
  margin-bottom: 20px;
  padding: 30px;
  font-size: 24px;
  line-height: 28.8px;
  display: flex;
}

.titre-informations-pratiques {
  margin: 20px 0 0;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 60px;
}

.titre-informations-pratiques.cdg {
  margin-top: 0;
}

.contenant-informations-pratiques {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  width: 100%;
  margin-top: 10px;
  margin-bottom: 10px;
  display: flex;
}

.action-infos {
  flex-flow: column;
  display: flex;
}

.formulaire-label {
  background-color: var(--blanc);
  text-transform: none;
  padding: 10px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.5rem;
}

.formulaire-nous-contacter {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.formulaire-input {
  color: var(--noir);
  background-color: #fff0;
  border-radius: 2px;
  padding: 1.5rem 1rem 1.25rem;
  font-size: 1.5rem;
}

.formulaire-input:focus {
  background-color: #0000000d;
  border: 1px #000;
}

.formulaire-input::placeholder {
  color: var(--gris);
  font-size: 1.5rem;
  line-height: 35px;
}

.formulaire-input.textarea {
  padding-top: .5rem;
}

.bouton-de-soumission {
  background-color: var(--gris);
  color: var(--blanc);
  text-align: center;
  letter-spacing: -.15px;
  border-radius: 5px;
  width: 228px;
  padding: 5px 80px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 48px;
  transition: background-color .3s ease-in-out, transform .3s ease-in-out, box-shadow .3s ease-in-out;
}

.bouton-de-soumission:hover {
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.bouton-de-soumission:active {
  background-color: var(--vert-principale);
}

.success-message {
  background-color: #ddd0;
}

.separateur-vert {
  background-color: var(--vert-principale);
  width: 50%;
  height: 1px;
}

.contenant-success-message {
  grid-column-gap: 35px;
  grid-row-gap: 35px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.lien-nous-contacter {
  color: var(--vert-principale);
  text-align: center;
  font-size: 32px;
}

.lien-nous-contacter:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.page-inondez-vos-elus {
  color: var(--noir);
  flex-flow: column;
  align-items: center;
  width: 100vw;
  max-width: none;
  display: flex;
  overflow: hidden;
}

.cercle-animation-accueil {
  cursor: pointer;
  z-index: 2;
  border-radius: 50%;
  width: 600px;
  height: 600px;
  position: absolute;
  top: 50%;
  overflow: hidden;
}

.cercle-animation-accueil:hover {
  width: 600px;
  height: 600px;
}

.image-animation-accueil {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.section-animation {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100vw;
  height: 100vh;
  padding-top: 140px;
  display: flex;
  position: absolute;
  inset: 0% auto auto 0%;
}

.texte-animation-accueil {
  opacity: 0;
  color: var(--blanc);
  text-align: center;
  z-index: 10;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 60px;
  transition-property: color;
  transition-duration: .3s;
  transition-timing-function: ease-in-out;
  display: none;
  position: absolute;
  top: 50%;
  transform: scale(.6);
}

.texte-animation-accueil:hover {
  color: var(--vert-principale);
}

.coeurs-animation-accueil {
  z-index: 3;
  justify-content: center;
  align-items: center;
  width: 800px;
  height: 800px;
  display: none;
  position: absolute;
  top: 20%;
}

.icone-polygone-vert {
  flex: none;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  display: flex;
  position: relative;
}

.textes-polygone-vert {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  text-align: left;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  display: flex;
}

.icone-sauver-la-planete {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.titre-polygone-vert {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 25px;
}

.textes-carte-rejoindre-un-groupe {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.coeur-notre-symbole {
  position: absolute;
}

.contenant-images-animation {
  z-index: 2;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/669ab59dd2779e5efeeb99d9_Fond_Innondez_vos_elus.png");
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 65vh;
  position: relative;
}

.image-animation-inondez-vos-elus {
  object-fit: cover;
  width: 100%;
  min-width: 1137px;
  position: absolute;
  overflow: hidden;
}

.image-animation-inondez-vos-elus.bas {
  z-index: 4;
  inset: auto 0% 0%;
}

.image-animation-inondez-vos-elus.centre {
  z-index: 3;
  inset: auto 0% 10%;
}

.rester-informe {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-weight: 700;
}

.contenant-commentaire {
  color: var(--blanc);
  text-align: center;
  background-image: url("https://cdn.prod.website-files.com/65a94a24e22128a97476dd69/66a2b26436fb21f8a2a922dc_Polygone_commentaires.png");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  justify-content: center;
  align-items: center;
  min-width: 454px;
  max-width: 500px;
  min-height: 167px;
  padding: 10px 30px 20px;
  font-size: 20px;
  line-height: 25px;
  display: flex;
  position: relative;
}

.coeur-commentaire {
  z-index: 5;
  position: absolute;
  top: auto;
  bottom: -25%;
}

.contenant-infos-action-passee {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  color: var(--blanc);
  justify-content: space-between;
  align-items: flex-start;
  width: 1137px;
  max-width: 100%;
  font-size: 24px;
  line-height: 36px;
  display: flex;
}

.action-passe-description {
  width: 70%;
  margin-bottom: 0;
}

.action-passee-infos-details {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 30%;
  display: flex;
}

.action-passee-detail {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  justify-content: flex-start;
  align-items: center;
  font-size: 18px;
  line-height: 15.5px;
  display: flex;
}

.action-passee-detail.lien {
  color: var(--blanc);
  cursor: pointer;
  transition: color .3s ease-in-out;
}

.action-passee-detail.lien:hover {
  color: var(--vert-principale);
  text-decoration: underline;
}

.action-passee-detail-date {
  grid-column-gap: 6px;
  grid-row-gap: 6px;
  display: flex;
}

.contenant-chiffres {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: wrap;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  place-items: center;
  width: 1338px;
  max-width: 95vw;
  display: flex;
}

.carte-chiffre-action-passee {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  background-color: var(--blanc);
  color: var(--vert-principale);
  text-align: center;
  border-radius: 5px;
  flex-flow: column;
  flex: none;
  justify-content: flex-start;
  align-items: center;
  width: 259px;
  height: auto;
  min-height: 397px;
  padding-top: 30px;
  padding-bottom: 30px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 30px;
  display: flex;
}

.chiffre {
  padding-left: 5px;
  padding-right: 5px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 44px;
  font-weight: 700;
  line-height: .9;
}

.carte-chiffre-icone {
  justify-content: center;
  align-items: center;
  min-height: 100px;
  display: flex;
}

.carte-chiffre-texte {
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.bouton-vert-album-photo {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  background-color: var(--vert-principale);
  opacity: 1;
  color: var(--blanc);
  text-align: center;
  letter-spacing: -.15px;
  z-index: 2;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  margin-top: 40px;
  margin-bottom: 40px;
  padding: 20px 60px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition-property: box-shadow, transform, border-color, color, background-color;
  transition-duration: .3s, .3s, .2s, .2s, .2s;
  transition-timing-function: ease, ease, ease, ease, ease;
  display: flex;
}

.bouton-vert-album-photo:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-vert-album-photo:active {
  border: 1px solid var(--vert-principale);
  background-color: var(--blanc);
  opacity: 1;
  color: var(--vert-principale);
}

.texte-grande-carte-long-texte {
  z-index: 2;
  overflow: auto;
}

.contenant-retour-en-image {
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 1138px;
  height: 640px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.etes-vous-pret {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  background-color: var(--blanc);
  color: var(--noir);
  justify-content: center;
  align-items: center;
  padding: 10px 20px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 25px;
  font-weight: 700;
  display: flex;
  position: absolute;
  top: 15%;
  left: 50%;
  transform: translate(-50%);
}

.section-inondez-vos-elus {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  margin-top: 60px;
  display: flex;
  position: relative;
}

.cercle-animation-inondez {
  cursor: pointer;
  border-radius: 50%;
  width: 600px;
  height: 600px;
  position: absolute;
  top: 0;
  overflow: hidden;
}

.cercle-animation-inondez:hover {
  width: 600px;
  height: 600px;
}

.image-animation-inondez {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.element-inondez-vos-elus {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  color: var(--blanc);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 740px;
  height: 596px;
  margin-left: auto;
  margin-right: auto;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
  display: flex;
}

.numero-etape {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 120px;
  font-weight: 700;
  line-height: 144px;
}

.texte-etape, .texte-etape-inondez {
  text-align: center;
}

.lien.blanc.special {
  cursor: pointer;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  transition-property: none;
}

.lien.blanc.special:hover {
  color: var(--blanc);
}

.lien.porte-voix {
  color: var(--blanc);
  text-align: center;
  cursor: pointer;
  background-color: #2db24abf;
  border-radius: 50px;
  padding: 10px 20px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 20px;
  font-weight: 500;
  transition: background-color .3s ease-in-out;
}

.lien.porte-voix:hover {
  color: var(--blanc);
  background-color: #2db24a;
}

.lien.cdg {
  opacity: 1;
  color: var(--bourgogne);
  cursor: pointer;
  background-color: #ffffffb3;
  border-radius: 50px;
  padding: 10px 20px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  transition: background-color .3s ease-in-out;
}

.lien.cdg:hover {
  background-color: #fff;
}

.derniere-etape-inondez {
  grid-column-gap: 60px;
  grid-row-gap: 60px;
  color: var(--vert-principale);
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 649px;
  height: 608px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 40px;
  padding-right: 40px;
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 42px;
  display: flex;
  position: relative;
}

.auteur-citation-inondez {
  color: var(--noir);
  text-transform: uppercase;
  font-size: 18px;
}

.photo-margaret-mead {
  object-fit: cover;
  border-radius: 50%;
  width: 124px;
  height: 124px;
  position: absolute;
  bottom: 0;
}

.progress-bar-inondez {
  justify-content: center;
  align-items: center;
  width: 50%;
  margin: 20px auto;
}

.my-slider-progress-bar-inondez {
  background-color: var(--vert-principale);
  justify-content: flex-start;
  align-items: center;
  height: 3px;
  display: flex;
}

.polygone-vert-texte {
  text-align: left;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 19px;
  font-weight: 400;
}

.contenant-recherche-villes {
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 15px;
  margin-right: 10px;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
  position: relative;
}

.icone-champs-recherche {
  padding: 10px;
  position: absolute;
  right: 10px;
}

.icone-effacer {
  cursor: pointer;
  width: 20px;
  height: 20px;
  transition: transform .3s ease-in-out;
}

.icone-effacer:hover {
  transform: translate(0, -2px);
}

.input-recherche {
  width: 100%;
}

.empty-state {
  background-color: #ddd0;
  display: none;
}

.fond-vert-inondez-vos-elus {
  background-color: var(--vert-principale);
  z-index: 50;
  height: 500px;
  position: absolute;
  inset: auto 0% -500px;
  overflow: hidden;
}

.collection-vide {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.logo-en-tete-projet {
  color: var(--blanc);
  border-radius: 10px;
  width: 100%;
}

.en-tete-projet {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  justify-content: center;
  align-items: flex-start;
  width: 1137px;
  margin-top: 40px;
  margin-bottom: 40px;
  font-size: 16px;
  display: flex;
}

.en-tete-projet.special {
  justify-content: flex-end;
  align-items: flex-end;
}

.contenant-polygones {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-flow: column;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
}

.contenant-bloc-de-texte {
  justify-content: center;
  align-items: center;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
}

.contenant-bloc-de-texte.chaises-des-generations {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  flex-flow: column;
  width: 1138px;
  max-width: 100%;
  margin-top: 0;
  margin-bottom: 40px;
}

.contenant-bloc-de-texte.porte-voix {
  width: 1138px;
  max-width: 95vw;
}

.carte-porte-voix {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  z-index: 2;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 450px;
  max-width: 95vw;
  height: 450px;
  padding: 32px;
  font-size: 18px;
  line-height: 21.6px;
  display: flex;
  position: relative;
}

.contenant-images-scientifiques {
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  width: 30%;
  height: 100%;
  padding-bottom: 40px;
  display: flex;
}

.icone-environnementale {
  border-radius: 5px;
  width: 160px;
  height: 160px;
}

.contenant-icones-environnementale {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.accordeon-portrait-scientifique {
  border: 1px solid var(--vert-principale);
  border-radius: 5px;
  width: 100%;
}

.titre-accordeon {
  color: var(--vert-principale);
  margin-top: 0;
  margin-bottom: 0;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
}

.en-tete-accordeon {
  opacity: .8;
  cursor: pointer;
  justify-content: flex-start;
  align-items: center;
  transition: opacity .3s ease-in-out;
  display: flex;
}

.en-tete-accordeon:hover {
  opacity: 1;
}

.contenu-accordeon {
  padding-left: 8px;
  padding-right: 8px;
}

.texte-presentation-scientifiques {
  width: 100%;
}

.contenant-accordeons {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  display: flex;
  overflow: auto;
}

.contenant-logo-cdg {
  background-color: var(--noir);
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 360px;
  max-width: 95vw;
  padding: 20px;
  display: flex;
}

.en-tete-cdg {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  width: 60vw;
  margin-top: 40px;
  display: flex;
}

.video {
  border-radius: 5px;
  width: 100%;
}

.contenant-cartes-moyennes-cdg {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: center;
  align-items: center;
  margin-top: 60px;
  margin-bottom: 60px;
  display: flex;
}

.grande-carte-photo {
  color: var(--blanc);
  z-index: 2;
  border-radius: 5px;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 1137px;
  max-width: 95vw;
  height: 600px;
  padding: 40px;
  display: flex;
  position: relative;
}

.carte-de-presentation {
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 545px;
  max-width: 95vw;
  height: 640px;
  padding: 40px;
  display: flex;
  position: relative;
}

.carte-de-presentation.page-acceuil {
  cursor: pointer;
  transition: box-shadow .3s ease-in-out, transform .3s ease-in-out;
}

.carte-de-presentation.page-acceuil:hover {
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.image-carte-chiffre {
  max-width: 100px;
}

.contenant-video {
  width: 1210px;
  max-width: 95vw;
  max-height: 700px;
  margin-top: 40px;
}

.groupe-bouton-rejoindre {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.animation-accueil-curseur {
  z-index: 11;
  width: 25px;
  height: 25px;
  display: none;
  position: absolute;
  top: 50%;
}

.contenant-projets {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: wrap;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.contenant-carte-projet {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.texte-carte-projet {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  display: flex;
}

.contenant-vid-o {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 1138px;
  max-width: 100%;
  display: flex;
}

.contenant-liste-articles {
  width: 940px;
  max-width: 100%;
}

.liste-articles {
  color: var(--blanc);
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.4;
}

.bouton-animation-accueil {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  background-color: var(--vert-principale);
  opacity: 1;
  color: var(--blanc);
  text-align: center;
  letter-spacing: -.15px;
  cursor: pointer;
  z-index: 20;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  height: 48px;
  padding: 1rem 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 21.6px;
  transition-property: box-shadow, transform, border-color, color, background-color;
  transition-duration: .3s, .3s, .2s, .2s, .2s;
  transition-timing-function: ease, ease, ease, ease, ease;
  display: none;
}

.bouton-animation-accueil:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 2px 5px 10px 4px #0003;
}

.bouton-animation-accueil:active {
  border: 1px solid var(--vert-principale);
  background-color: var(--blanc);
  opacity: 1;
  color: var(--vert-principale);
}

.carte-de-presentation-copy {
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 545px;
  max-width: 95vw;
  height: 640px;
  padding: 40px;
  display: flex;
  position: relative;
}

.contenant-boutons {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  display: flex;
}

.texte-grande-carte {
  margin-bottom: 0;
}

.en-tete-principale {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 1138px;
  max-width: 95vw;
  margin-bottom: 60px;
  display: flex;
}

.contenant-informations {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 1138px;
  max-width: 95vw;
  display: flex;
}

.contenant-carte-emploi {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  flex-flow: row;
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  display: flex;
}

.heading-18 {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 50px;
  font-weight: 700;
  line-height: 1;
}

.link-2 {
  color: var(--vert-principale);
  text-decoration: underline;
  display: inline;
}

.image-4 {
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 100%;
}

.div-block-75 {
  width: 60%;
  height: 200px;
}

.div-block-76 {
  width: 40%;
}

.description-detaillee {
  width: 100%;
}

.contenant-tape {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contenant-carrousel {
  width: 1146px;
  max-width: 95vw;
}

.div-block-77 {
  width: 500px;
  height: 15px;
}

.text-block-2 {
  justify-content: center;
  align-items: center;
  width: 250px;
  display: flex;
}

.contenant-logo {
  width: 40%;
  max-width: 95vw;
}

.en-tete-titre-vert {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 1138px;
  max-width: 90vw;
  margin-top: 60px;
  margin-bottom: 60px;
  display: flex;
}

.en-tete-titre-vert.nos-groupes {
  justify-content: space-between;
  align-items: center;
  height: 80vh;
}

.mosaique-6-images {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  place-items: start;
  width: 1200px;
  max-width: 95vw;
  margin-top: 60px;
  margin-bottom: 60px;
  display: flex;
}

.mosaique-6-images.test {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  display: flex;
}

.mosaique-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.contenant-mos-img-1 {
  width: 40%;
  height: 320px;
}

.contenant-mos-img-2 {
  width: 25%;
  height: 320px;
  margin-top: -1.5rem;
}

.contenant-mos-img-3 {
  width: 30%;
  height: 320px;
}

.contenant-mos-img-4 {
  width: 35%;
  height: 440px;
  margin-left: auto;
}

.contenant-mos-img-5 {
  width: 25%;
  height: 480px;
  margin-top: -.5rem;
}

.contenant-mos-img-6 {
  width: 40%;
  height: 375px;
}

.mosaique-ligne {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: center;
  align-items: flex-start;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.deuxieme-ligne {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.logo-porte-voix {
  width: 50%;
}

.contenant-carrousel-1-image {
  width: 1138px;
  max-width: 95vw;
  overflow: hidden;
}

.image-carrousel-1-image {
  object-fit: contain;
  max-width: 100%;
  max-height: 100%;
}

.contenant-temoignage {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.splide-left-arrow-image {
  transition: transform .3s ease-in-out;
}

.splide-left-arrow-image:hover {
  transform: translate(-10px);
}

.splide-right-arrow-image {
  transition: transform .3s ease-in-out;
}

.splide-right-arrow-image:hover {
  transform: translate(10px);
}

.image-faire-un-don {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
}

.small-text {
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}

.small-text.footer {
  max-width: 450px;
}

.bold-text {
  font-size: 80px;
}

.texte-blogue {
  text-align: justify;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 20px;
  font-weight: 400;
  line-height: 1.4;
}

.citation-blogue {
  color: var(--vert-principale);
  border-left-color: #2cb34d;
  font-family: "PP Neue Montreal 500", sans-serif;
}

.image-blogue {
  object-fit: cover;
  width: 60%;
  height: 250px;
  margin-bottom: 20px;
}

.date-blogue {
  color: var(--vert-principale);
  margin-bottom: 0;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
}

.contenant-titre-blogue {
  grid-column-gap: 0rem;
  grid-row-gap: 0rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  max-width: 100%;
  display: flex;
}

.auteure-blogue {
  text-align: left;
  margin-bottom: 10px;
  font-family: "PP Neue Montreal 300-400", sans-serif;
  font-size: 32px;
  font-weight: 400;
  line-height: 1.2;
}

.auteure-blogue.centre {
  text-align: center;
  width: 60%;
  line-height: 38.4px;
}

.auteure-blogue.sous-titre-nos-actions {
  text-align: left;
}

.auteure-blogue.cdg {
  width: auto;
}

.auteure-blogue.court {
  text-align: center;
  width: 100%;
}

.auteure-blogue.court.portevoix {
  text-align: center;
  padding-left: 0;
  padding-right: 0;
}

.auteure-blogue.section-grand-titre {
  width: 100%;
}

.auteure-blogue.blogue.date-blogue {
  color: var(--vert-principale);
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 15px;
}

.contenant-1138px {
  width: 1138px;
  max-width: 100%;
}

.pagination-liste-ville-cdg {
  margin-bottom: 1rem;
}

.contenant-livres {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: wrap;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 2rem;
  display: flex;
}

.carte-livre {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  color: var(--blanc);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 250px;
  height: 450px;
  padding-bottom: 2rem;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.2;
  transition: color .3s ease-in-out, transform .3s ease-in-out;
  display: flex;
}

.carte-livre:hover {
  color: var(--vert-principale);
  transform: translate(0, -4px);
}

.image-livre {
  object-fit: cover;
  width: 100%;
  height: 80%;
}

.titre-livre {
  text-align: center;
}

.nos-livres {
  background-color: var(--anthracite);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 1300px;
  max-width: 95vw;
  margin-top: 40px;
  margin-bottom: 40px;
  display: flex;
  position: relative;
}

.contenant-collections-villes {
  max-height: 70vh;
  overflow: auto;
}

.logo-youtube {
  width: 28px;
}

.hero-campagne {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  max-width: 95vw;
  margin: 60px auto;
  display: flex;
  position: relative;
}

.hero-campagne.sombre {
  background-color: var(--anthracite);
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.hero-campagne.sombre.p-100 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.hero-campagne.sombre.pt-50 {
  padding-top: 50px;
}

.hero-campagne.sombre.lien-nous-connaitre {
  width: 100vw;
  max-width: none;
  padding-top: 70px;
  padding-bottom: 70px;
}

.hero-campagne.sombre.notre-histoire {
  width: 100%;
  padding-top: 40px;
  padding-bottom: 40px;
}

.hero-campagne.sombre.ressources-externes {
  width: 100vw;
  max-width: none;
  margin-top: 40px;
  margin-bottom: 40px;
}

.hero-campagne.sombre.invisible {
  display: none;
}

.hero-campagne.sombre.avec-margin {
  margin-top: 40px;
  margin-bottom: 40px;
}

.hero-campagne.portrait {
  margin-top: 40px;
}

.hero-campagne.page-groupe {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  margin-top: 100px;
}

.hero-campagne.carte {
  width: 100%;
}

.hero-campagne.texte-equite {
  margin-top: 40px;
  margin-bottom: 100px;
}

.hero-campagne.page-action {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  margin-top: 20px;
  margin-bottom: 20px;
}

.hero-campagne.page-action.comment-participer {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  padding-bottom: 20px;
}

.hero-campagne.actions-en-cours {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

.hero-campagne.retour-sur-le-passe {
  margin-top: 20px;
  margin-bottom: 20px;
}

.hero-campagne.section-polygones-acceuil {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  margin-top: 110vh;
  padding-top: 60px;
}

.hero-campagne.inondez-vos-elus {
  width: 100vw;
  max-width: none;
  margin-bottom: 0;
  overflow: visible;
}

.hero-campagne.commentaires {
  width: 40%;
}

.hero-campagne.hidden {
  display: none;
}

.hero-campagne.blogue {
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  margin-top: 0;
  margin-bottom: 60px;
}

.hero-campagne.blogue.avant-footer {
  margin-bottom: 60px;
}

.contenant-video-arriere-plan {
  z-index: -1;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.contenant-video-arriere-plan.notre-histoire {
  z-index: 1;
}

.contenant-video-arriere-plan.index-positif {
  z-index: 0;
}

.contenant-hero-cdg-jappuie {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  justify-content: space-between;
  align-items: flex-start;
  width: 1300px;
  max-width: 95vw;
}

.campagne-cdg-hero-titre {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 60%;
  display: flex;
}

.campagne-cdg-hero-visuel {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.campagne-cdg-hero-visuel.mobile {
  display: none;
}

.image-hero-campagne-cdg {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.contenant-image-hero-campagne-cdg {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  height: 475px;
  display: flex;
}

.credit-image-campagne-cdg {
  color: var(--blanc);
  text-shadow: 0 1px 2px var(--anthracite);
  line-height: 1.3;
}

.contenant-cta-mobile {
  display: none;
}

.contenant-polygones-vert {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  margin-top: 3rem;
  margin-bottom: 3rem;
  display: flex;
}

.contenu-campagne-cdg {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 1138px;
  max-width: 95vw;
  display: flex;
}

.texte-campagne-cdg {
  font-size: 22px;
  line-height: 1.2;
}

.wrapper-principal {
  position: relative;
}

.test-contenant-sticky {
  background-color: var(--maf-pink);
  height: 200vh;
  position: relative;
}

.test-sticky-bar {
  background-color: var(--vert-principale);
  position: sticky;
  top: 0;
}

.body {
  overflow: visible;
}

.contenant-polygone-reseaux-sociaux {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.section-pleine-largeur {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 60px auto;
  padding: 2rem;
  display: flex;
  position: relative;
}

.section-pleine-largeur.sombre {
  background-color: var(--anthracite);
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.section-pleine-largeur.sombre.p-100 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.section-pleine-largeur.sombre.pt-50 {
  padding-top: 50px;
}

.section-pleine-largeur.sombre.lien-nous-connaitre {
  width: 100vw;
  max-width: none;
  padding-top: 70px;
  padding-bottom: 70px;
}

.section-pleine-largeur.sombre.notre-histoire {
  width: 100%;
  padding-top: 40px;
  padding-bottom: 40px;
}

.section-pleine-largeur.sombre.ressources-externes {
  width: 100vw;
  max-width: none;
  margin-top: 40px;
  margin-bottom: 40px;
}

.section-pleine-largeur.sombre.invisible {
  display: none;
}

.section-pleine-largeur.sombre.avec-margin {
  margin-top: 40px;
  margin-bottom: 40px;
}

.section-pleine-largeur.portrait {
  margin-top: 40px;
}

.section-pleine-largeur.page-groupe {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  margin-top: 100px;
}

.section-pleine-largeur.carte {
  width: 100%;
}

.section-pleine-largeur.texte-equite {
  margin-top: 40px;
  margin-bottom: 100px;
}

.section-pleine-largeur.page-action {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  margin-top: 20px;
  margin-bottom: 20px;
}

.section-pleine-largeur.page-action.comment-participer {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  padding-bottom: 20px;
}

.section-pleine-largeur.actions-en-cours {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
}

.section-pleine-largeur.retour-sur-le-passe {
  margin-top: 20px;
  margin-bottom: 20px;
}

.section-pleine-largeur.section-polygones-acceuil {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  margin-top: 110vh;
  padding-top: 60px;
}

.section-pleine-largeur.inondez-vos-elus {
  width: 100vw;
  max-width: none;
  margin-bottom: 0;
  overflow: visible;
}

.section-pleine-largeur.commentaires {
  width: 40%;
}

.section-pleine-largeur.hidden {
  display: none;
}

.section-pleine-largeur.blogue {
  justify-content: center;
  align-items: flex-start;
  width: 1138px;
  margin-top: 0;
  margin-bottom: 60px;
}

.section-pleine-largeur.blogue.avant-footer {
  margin-bottom: 60px;
}

.section-pleine-largeur.gauche {
  justify-content: flex-start;
  align-items: center;
}

.section-pleine-largeur.font-vert-fonce {
  color: var(--blanc);
  background-color: #135935;
}

.section-pleine-largeur.font-vert-fonce.remerciements-bdf {
  margin: 0;
  padding-bottom: 4rem;
}

.contenant-principale {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 1138px;
  max-width: 95vw;
  display: flex;
}

.contenant-principale.gauche {
  justify-content: flex-start;
  align-items: flex-start;
}

.contenant-principale.gauche.stretch {
  align-items: stretch;
}

.contenant-principale.gauche.stretch.gap-1 {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
}

.contenant-principale.shorts {
  justify-content: flex-start;
  align-items: flex-start;
}

.carte-blogue {
  background-color: var(--blanc);
  border-radius: 5px;
  flex-flow: column;
  width: 420px;
  max-width: 90vw;
  transition: box-shadow .3s ease-in-out, transform .3s ease-in-out;
  display: flex;
  box-shadow: 0 2px 5px #0003;
}

.carte-blogue:hover {
  transform: translate(0, -2px);
  box-shadow: 0 2px 10px 1px #0003;
}

.carte-blogue-image {
  object-fit: cover;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  width: 100%;
  height: 150px;
}

.carte-blogue-contenu {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  height: 60%;
  margin-bottom: 2rem;
  padding: .5rem 1rem 1rem;
  display: flex;
}

.carte-blog-texte._500 {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
}

.carte-blogue-titre {
  color: var(--vert-principale);
  margin-top: 0;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
  line-height: 1.1;
}

.carte-blog-date {
  margin-bottom: 1rem;
}

.carte-blog-date.date {
  font-family: "PP Neue Montreal 500", sans-serif;
  font-weight: 500;
}

.collection-carte-blogue {
  flex-flow: column;
  width: 1150px;
  max-width: 100%;
}

.contenant-auteur-e {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  display: flex;
}

.liste-carte-blogue {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: wrap;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.contenant-texte-blogue {
  width: 1138px;
  max-width: 100%;
}

.contenant-page {
  width: 100vw;
  overflow: hidden;
}

.contenant-page.cdg {
  max-width: 100vw;
}

.coeur-remerciements-bdf {
  opacity: .5;
  width: 150px;
  position: absolute;
  inset: auto 15% 0% auto;
}

.image-titre-cdg-j-appuie {
  width: 500px;
}

.contenant-sous-date {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  display: flex;
}

.contenant-date {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  display: flex;
}

.contenant-formulaire {
  width: 1138px;
  max-width: 95vw;
  min-height: 400px;
}

.img-remerciement-bdf {
  z-index: 10;
  max-width: 400px;
}

.youtube {
  height: 100%;
}

.carte-video-video {
  width: 100%;
  height: 100%;
}

.contenant-capsules-video {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: wrap;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  align-items: center;
  width: 1138px;
  max-width: 95vw;
  margin-top: 2rem;
  display: flex;
}

.contenant-capsules-video.gauche {
  justify-content: flex-start;
  align-items: flex-start;
}

.groupe-action-en-cours {
  margin-bottom: 10px;
}

.logo-en-tete-projet-mobile {
  color: var(--blanc);
  border-radius: 10px;
  width: 100%;
  display: none;
}

.contenant-youtube-short {
  border-radius: 8px;
  width: 290px;
  height: 430px;
  overflow: hidden;
  box-shadow: 0 2px 15px 2px #0000004d;
}

.youtube-short {
  border-radius: 8px;
  height: 100%;
}

.section-cpv {
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  max-width: 90vw;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.contenant-liste-short {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  justify-content: flex-start;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.h2-cpv {
  color: var(--blanc);
  font-family: "PP Neue Montreal 500", sans-serif;
}

.h2-cpv.vert {
  color: var(--vert-principale);
}

.en-tete-cpv {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.en-tete-img-cpv {
  object-fit: contain;
  width: 50px;
  height: 50px;
}

.contenant-filtres-cpv {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  justify-content: flex-start;
  align-items: center;
  max-width: 100%;
  display: flex;
  overflow: auto;
}

.contenant-filtres-cpv.capsule {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  overflow: hidden;
}

.filtre-cpv {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  border: 1px solid var(--vert-principale);
  color: var(--vert-principale);
  cursor: pointer;
  border-radius: 50px;
  align-items: center;
  transition: transform .2s ease-in-out, opacity .2s ease-in-out, color .3s ease-in-out, background-color .3s ease-in-out;
  display: flex;
}

.filtre-cpv:hover {
  background-color: var(--vert-principale);
  color: var(--blanc);
}

.filtre-cpv:active {
  opacity: .7;
  transform: scale(.95);
}

.texte-filtre-cpv {
  padding: 10px 20px;
  font-size: 18px;
  line-height: 21.6px;
}

.texte-filtre-cpv.role {
  border-color: var(--vert-principale);
  color: var(--vert-principale);
}

.texte-filtre-cpv.etiquette-groupe {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  border: 0 #000;
  justify-content: center;
  align-items: center;
  transition: transform .3s ease-in-out, box-shadow .3s ease-in-out;
  display: flex;
}

.texte-filtre-cpv.etiquette-groupe:hover {
  color: var(--blanc);
  transform: translate(0, -2px);
  box-shadow: 5px 5px 10px 5px #0003;
}

.texte-filtre-cpv.capsule {
  padding: 4px 12px;
}

.capsule-video-porte-voix {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  z-index: 5;
  border-radius: 8px;
  flex-flow: column;
  width: 500px;
  max-width: 90vw;
  transition-property: box-shadow, transform;
  transition-duration: .3s, .3s;
  transition-timing-function: ease-in-out, ease-in-out;
  display: flex;
  position: relative;
  box-shadow: 0 2px 15px 5px #0003;
}

.capsule-video-porte-voix:hover {
  transform: translate(0, -2px);
  box-shadow: 0 2px 15px 8px #0000004d;
}

.video-vignette-cpv {
  border-radius: 8px 8px 0 0;
  width: 100%;
  height: 285px;
  overflow: hidden;
}

.contenant-details-cpv {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.contenant-details-cpv.page-cpv, .contenant-details-cpv.up {
  justify-content: flex-start;
  align-items: flex-start;
}

.collection-capsules-video {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 95vw;
  display: flex;
}

.collection-capsules-video.action-en-cours-et-a-venir {
  grid-row-gap: 0px;
}

.collection-capsules-video.action-en-cours-et-a-venir.page-groupe {
  grid-row-gap: 30px;
}

.collection-capsules-video.ressources {
  margin-bottom: 40px;
}

.collection-capsules-video.on-parle-de-nous {
  margin-bottom: 60px;
}

.collection-capsules-video.articles-accueil {
  grid-column-gap: 30px;
  grid-row-gap: 0px;
  margin-bottom: 1rem;
}

.collection-capsules-video.liste-rapports {
  margin-bottom: 1.5rem;
}

.contenu-cpv {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  flex-flow: column;
  padding: .5rem .75rem 1.5rem;
  display: flex;
}

.details-cpv {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.lien-video {
  background-color: var(--vert-principale);
  border-radius: 50%;
  padding: .6rem;
}

.lien-video.absolute {
  padding: 1rem;
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
}

.vignette-cpv {
  object-fit: cover;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  width: 100%;
  height: 285px;
  overflow: hidden;
}

.contenant-vignette-cpv {
  width: 100%;
  height: 285px;
  position: relative;
}

.contenant-video-cpv {
  border-radius: 8px;
  width: 100%;
  overflow: hidden;
}

.video-2 {
  width: 100%;
}

.video-cpv {
  border-radius: 8px;
  width: 100%;
  overflow: hidden;
}

.contenant-details-page-cpv {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: row;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.h1-page-cpv {
  font-family: "PP Neue Montreal 700", sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1;
}

.text-block-3 {
  font-size: 1.2rem;
  line-height: 1.4;
}

.icone-partage {
  width: 50px;
}

.tag-cpv {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  border: 1px solid var(--vert-principale);
  color: var(--vert-principale);
  cursor: pointer;
  border-radius: 50px;
  align-items: center;
  display: flex;
}

.tag-cpv.sans-curseur {
  cursor: default;
}

.tag-et-partage-cpv {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.contenant-details-cpv-page {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: row;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contenant-details-cpv-page.up {
  justify-content: flex-start;
  align-items: flex-start;
}

.contenant-boutons-cpv {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.fleche-droite-blanche {
  transform-style: preserve-3d;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.share-toast {
  border-top-style: solid;
  border-top-width: 1px;
  border-top-color: var(--blanc);
  border-right-style: solid;
  border-right-width: 1px;
  border-right-color: var(--blanc);
  border-bottom-style: solid;
  border-bottom-width: 1px;
  border-bottom-color: var(--blanc);
  border-left-style: solid;
  border-left-width: 1px;
  border-left-color: var(--blanc);
  background-color: var(--vert-principale);
  opacity: 0;
  pointer-events: none;
  color: var(--blanc);
  z-index: 9999;
  border-radius: 10px;
  padding: 10px 16px;
  font-family: "PP Neue Montreal 500", sans-serif;
  font-size: 14px;
  font-weight: 500;
  transition-property: opacity;
  transition-duration: .3s;
  transition-timing-function: ease;
  position: fixed;
  bottom: 20px;
  right: 20px;
}

.contenant-icone-partage {
  cursor: pointer;
}

.description-cpv {
  font-size: 1.2rem;
  line-height: 1.4;
}

.contenant-a-propos-cpv {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.image-fond-cpv {
  z-index: -1;
  opacity: .3;
  width: 400px;
  position: absolute;
  inset: auto 0% -200px auto;
}

@media screen and (max-width: 991px) {
  .styleguide-block {
    text-align: center;
  }

  .bouton {
    justify-content: center;
  }

  .bouton.bouton---vert.bouton-passer-a-l-action {
    display: block;
  }

  .bouton.bouton---vert.bouton-passer-a-l-action.blanc {
    background-color: var(--blanc);
    color: var(--vert-principale);
  }

  .heading-jumbo {
    font-size: 56px;
    line-height: 70px;
  }

  .logo-link {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }

  .logo-link.w--current {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    color: var(--noir);
    flex: none;
    justify-content: flex-start;
    align-items: center;
    width: 25%;
    font-family: "PP Neue Montreal 500", sans-serif;
    font-size: 20px;
    transition-property: none;
    display: flex;
  }

  .menu-icon {
    cursor: pointer;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
    height: 14px;
    display: flex;
  }

  .navigation-wrap {
    flex: 1;
  }

  .navigation-item {
    text-align: right;
    padding: 15px 30px;
    transition: background-color .4s, opacity .4s, color .4s;
  }

  .navigation-item:active {
    background-color: #eef0f3;
  }

  .menu-button {
    margin-left: 20px;
    padding: 0;
  }

  .menu-button.w--open {
    background-color: #0000;
  }

  .titre-principal {
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 40px;
  }

  .titre-principal.titre-notre-symbole {
    font-size: 50px;
  }

  .titre-principal.variante {
    max-width: 80%;
  }

  .navigation---menu-fond-blanc {
    z-index: 500;
    background-color: #0000;
    flex-direction: row-reverse;
    display: none;
  }

  .carte-action-en-cours {
    width: 334px;
    height: 350px;
  }

  .carte-d-action---block-informations-en-bas {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .paragraphe {
    width: auto;
    font-size: 28px;
    line-height: 35px;
  }

  .paragraphe.cdg {
    text-align: center;
  }

  .paragraphe.campagne-cdg-hero {
    font-size: 18px;
    line-height: 1.3;
  }

  .paragraphe.campagne-cdg {
    font-size: 24px;
    line-height: 1.3;
  }

  .paragraphe.remerciements-bdf {
    line-height: 1.3;
  }

  .inscription-newsletter {
    display: none;
  }

  .section-titre-vert {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .contenant-bandeau-de-liens {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    margin-top: 60px;
  }

  .lien-blanc {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 16px;
    line-height: 20px;
  }

  .section-principale {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .section-principale.sombre.ressources-externes {
    padding-top: 30px;
  }

  .section-principale.section-polygones-acceuil {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    width: 100%;
  }

  .section-principale.commentaires {
    width: 75%;
  }

  .section-principale.special-shorts {
    -webkit-clip-path: polygon(0 5%, 66% 0, 100% 8%, 100% 95%, 25% 100%, 0 95%);
    clip-path: polygon(0 5%, 66% 0, 100% 8%, 100% 95%, 25% 100%, 0 95%);
  }

  .section-agir-physiquement {
    flex-flow: column;
    margin-top: 60px;
    margin-bottom: 60px;
  }

  .section-devenir-membre {
    flex-flow: column;
  }

  .contenant-bloc-texte-avec-bouton {
    width: 80%;
  }

  .btn.bouton-vert._500 {
    margin-top: 20px;
    margin-left: auto;
    margin-right: auto;
  }

  .gros-bouton.bouton-vert._700 {
    margin-bottom: 40px;
    margin-left: auto;
    margin-right: auto;
  }

  .gros-bouton.bouton-vert._700.contenant-bloc {
    margin-left: 0;
    margin-right: 0;
  }

  .tres-grand-titre {
    text-align: center;
    margin-top: 60px;
    margin-bottom: 60px;
    font-size: 140px;
    line-height: 140px;
  }

  .flex-c.gap40.margin-negatif {
    margin-top: 0;
  }

  .flex-c.gap20 {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .flex-c.gap20.contenu-faire-un-don {
    width: 100%;
  }

  .grande-carte-sans-badge {
    min-height: 400px;
    padding: 30px;
  }

  .flex.center.gap40.margin-negatif {
    flex-flow: column;
    margin-top: 0;
  }

  .flex.texte-faq, .flex.texte-informations-pratiques {
    font-size: 16px;
  }

  .inondez-vos-lus {
    width: 90vw;
  }

  .texte-mosaic {
    font-size: 24px;
  }

  .mosaic-bloc-vert {
    margin-top: 20px;
    padding: 10px;
  }

  .coeur-mosaic {
    width: 4rem;
    height: 4rem;
  }

  .grand-polygone-vert {
    margin-top: 0;
  }

  .contenant-polygone-vert {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    background-attachment: scroll;
    width: 90%;
    height: 150px;
  }

  .contenant-polygone-vert.participer {
    background-size: contain;
    padding-left: 100px;
    padding-right: 100px;
  }

  .contenant-polygone-vert.impaire {
    background-size: contain;
    width: 90%;
  }

  .contenant-polygone-vert.page-devenir-membre {
    max-width: 80vw;
  }

  .coeur-dans-polygone.page-devenir-membre {
    width: 85px;
    height: 75px;
  }

  .contenu-polygone-vert {
    padding-left: 40px;
    padding-right: 10px;
  }

  .contenu-polygone-vert.participer {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    font-size: 50px;
  }

  .notre-mission.flex-c.center {
    background-position: 50%;
    width: 100%;
    height: 400px;
  }

  .coeur-notre-mission {
    display: none;
  }

  .sous-titre-section-sombre {
    font-size: 24px;
  }

  ._700._50px.titre-comment-devenir-membre {
    margin-bottom: 40px;
  }

  ._700._24px._44lh {
    line-height: 30px;
  }

  .element-principe-fondateur {
    flex-flow: column;
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    height: auto;
    min-height: 500px;
  }

  .texte-principe-fondateur {
    padding-top: 10px;
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 28px;
  }

  .nos-valeurs {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    background-attachment: scroll;
    width: 100%;
    height: 500px;
    padding: 20px;
  }

  .texte-nos-valeurs {
    font-size: 25px;
    line-height: 30px;
  }

  .valeur {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    width: 180px;
  }

  .titre-valeur {
    font-size: 20px;
    line-height: 25px;
  }

  .respect {
    left: 5%;
  }

  .solidarit {
    right: 5%;
  }

  .comment-devenir-membre {
    grid-column-gap: 35px;
    grid-row-gap: 35px;
    flex-flow: column;
    max-width: 90vw;
    display: flex;
  }

  .section-faq {
    width: 100%;
    max-width: 100vw;
  }

  .titre-faq {
    font-size: 35px;
  }

  .lien-courriel {
    padding-left: 6px;
  }

  .question {
    width: 80%;
  }

  .titre-vert {
    line-height: 1;
  }

  .titre-vert.devenir-mere-au-front {
    width: 100%;
    font-size: 80px;
    line-height: 80px;
  }

  .titre-vert.nos-actions {
    font-size: 100px;
  }

  .titre-vert.titre-nos-groupes {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 100px;
  }

  .titre-vert.nous-contacter {
    font-size: 130px;
    line-height: 120px;
  }

  .titre-vert.inondez-vos-elus {
    font-size: 80px;
    line-height: 90px;
  }

  .titre-vert.blogue {
    font-size: 65px;
  }

  .titre-vert.campagne-cdg {
    font-size: 50px;
  }

  .arri-re-plan-principe-fondateur {
    width: 100%;
    height: 130px;
  }

  .contenant-texte-principe-fondateur {
    width: 100%;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .images-devenir-membre {
    justify-content: space-around;
  }

  .contenant-swiper {
    flex-flow: row;
    width: 80vw;
    max-width: 95vw;
  }

  .swiper-wrapper.carrousel-actions {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .swiper-slide.principes-fondateurs {
    width: 500px;
  }

  .swiper-slide.agir-en-1-clic, .swiper-slide.carrousel-de-cartes {
    width: 50%;
  }

  .swiper-slide.actions-porte-voix {
    justify-content: center;
    align-items: flex-start;
    width: 50%;
    display: flex;
  }

  .swiper-slide.shorts {
    width: 50%;
  }

  .grand-coeur-blanc {
    display: none;
  }

  .carte-rejoingnez-un-groupe {
    margin-bottom: 0;
  }

  .collection-on-a-besoin-de-vous {
    flex-flow: column;
  }

  .contenant-faire-un-don {
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
  }

  .formulaire-faire-un-don {
    width: 100%;
  }

  .contenant-groupe-portrait {
    flex-flow: column;
  }

  .carte-mini-portrait.variante {
    width: auto;
    padding: 20px;
  }

  .pdp-colonne-gauche, .pdp-colonne-droite {
    width: 50%;
  }

  .formulaire-infolettre {
    width: 400px;
  }

  .contenant-groupe-liens-pdp {
    margin-top: 5px;
    margin-bottom: 5px;
  }

  .contenant-swiper-button {
    display: none;
  }

  .barre-menu-burger-sup {
    background-color: var(--vert-principale);
    border-radius: 2px;
    width: 30px;
    height: 2px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .barre-menu-burger-sup.blanc {
    background-color: var(--blanc);
  }

  .barre-menu-burger {
    background-color: var(--vert-principale);
    border-radius: 2px;
    width: 23px;
    height: 2px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .barre-menu-burger.blanc {
    background-color: var(--blanc);
  }

  .titre-navigation {
    color: var(--noir);
    margin-left: 20px;
    line-height: 21px;
    display: block;
  }

  .titre-navigation.blanc {
    color: var(--blanc);
  }

  .list {
    background-color: var(--blanc);
    border-radius: 5px;
    flex-flow: wrap;
  }

  .list-item.bouton-passer-a-l-action {
    display: none;
  }

  .navbar-logo-left-container {
    padding-left: 35px;
    padding-right: 35px;
  }

  .contenant-principe-fondateur {
    width: 500px;
    height: auto;
  }

  .bouton-vert.pos-relative, .bouton-blanc {
    padding-top: 9px;
    padding-bottom: 9px;
  }

  .carte-video {
    margin-top: 40px;
  }

  .carte-video.video-integree {
    height: 500px;
  }

  .contenant-image {
    -webkit-text-fill-color: inherit;
    background-clip: border-box;
  }

  .contenant-image.notre-histoire {
    padding-left: 0;
    padding-right: 0;
  }

  .contenant-decouvrez-nos-actions {
    flex-flow: column;
  }

  .image-arriere-plan.album-photo-actions-passees {
    margin-left: 20px;
    margin-right: 20px;
  }

  .contenant-texte-carte-action {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .carte-moyenne-badge-et-bouton {
    width: 334px;
    height: auto;
    min-height: 350px;
  }

  .contenant-carte-moyenne {
    height: auto;
    padding: 20px;
  }

  .texte-carte-moyenne {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .carte-moyenne-texte-superieur {
    font-size: 21px;
    line-height: 24px;
  }

  .rapport-activite {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    flex-flow: column-reverse;
    width: 100%;
    height: auto;
    margin-top: 0;
  }

  .rapport-activite-gauche {
    justify-content: flex-end;
    align-items: center;
    width: 90%;
  }

  .texte-rapport-activite {
    margin-bottom: 40px;
  }

  .carte-rapport-activitees {
    width: 334px;
    height: 350px;
  }

  .carte-moyenne-texte-inferieur {
    font-size: 20px;
    line-height: 25px;
  }

  .coeur-vert {
    width: 30px;
  }

  .texte-etapes {
    font-size: 28px;
    line-height: 40px;
  }

  .texte-grand-polygone-verte.page-devenir-membre {
    font-size: 18px;
    line-height: 21px;
  }

  .sous-titre.inondez-vos-elus {
    width: 80%;
  }

  .sous-titre.campagne-cdg {
    font-size: 28px;
  }

  .demi-contenant.gauche.infolettre {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    font-size: 18px;
    line-height: 21px;
  }

  .texte-nous-connaitre {
    font-size: 80px;
    line-height: 80px;
  }

  .liste-on-a-besoin-de-vous {
    width: 100%;
  }

  .dropdown-nous-connaitre {
    left: -110px;
  }

  .liste-dropdown-nous-connaitre {
    justify-content: center;
    align-items: flex-end;
  }

  .titre-hero {
    font-size: 80px;
  }

  .titre-hero.actions-passees {
    font-size: 75px;
    line-height: 85px;
  }

  .image-flottante {
    width: 250px;
    height: 250px;
  }

  .image-flottante.image-1 {
    top: 5%;
    left: 5%;
  }

  .image-flottante.image-2 {
    top: 5%;
    right: 5%;
  }

  .grande-carte-long-texte {
    height: auto;
    padding-top: 100px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .texte-nos-demandes {
    margin-top: 60px;
    margin-bottom: 60px;
  }

  .contenant-liens-nous-connaitre {
    width: 95vw;
    height: 550px;
  }

  .paragraph-hero {
    width: 50%;
  }

  .mini-carte-portrait {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .notre-fonctionnement {
    max-width: 85vw;
    font-size: 28px;
    line-height: 35px;
  }

  .introduction {
    font-size: 28px;
    line-height: 40px;
  }

  .div-block-24, .div-block-25 {
    height: 550px;
  }

  .heading-2 {
    font-size: 25px;
  }

  .heading-3, .heading-4 {
    font-size: 40px;
  }

  .heading-5, .heading-6 {
    line-height: 50px;
  }

  .heading-7, .heading-8 {
    font-size: 40px;
  }

  .heading-9, .heading-10 {
    line-height: 50px;
  }

  .texte-cri-du-coeur {
    width: 75%;
  }

  .texte-notre-symbole {
    width: 40%;
  }

  .grande-carte-avec-badge-et-bouton {
    height: 500px;
    margin-left: auto;
    margin-right: auto;
    padding: 30px;
  }

  .bas-de-carte {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .contenant-collections-ressources {
    max-width: 100vw;
  }

  .contenant-lien-voir-la-carte {
    right: 5px;
  }

  .contenant-portrait {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    height: 500px;
  }

  .photo-portrait {
    width: 40%;
  }

  .photo-portrait.scientifiques {
    width: 100%;
    min-width: 0;
  }

  .contenu-portrait {
    width: 60%;
  }

  .nom-portrait {
    font-size: 70px;
    line-height: 80px;
  }

  .etiquettes-portrait {
    text-align: center;
  }

  .texte-portrait {
    padding-bottom: 100px;
    font-size: 21px;
    line-height: 28px;
  }

  .contenant-onglet-demande {
    grid-column-gap: 50px;
    grid-row-gap: 50px;
    padding: 30px;
  }

  .image-onglet-demande {
    width: 300px;
  }

  .onglet-demande-droite {
    width: auto;
  }

  .titre-onglet-demande {
    font-size: 25px;
    line-height: 30px;
  }

  .demande {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
  }

  .titre-demande {
    font-size: 40px;
    line-height: 45px;
  }

  .texte-demande {
    font-size: 25px;
    line-height: 35px;
  }

  .splide.splide-inondez, .splide.agir-en-1-clic, .splide.actions-porte-voix {
    width: 100%;
  }

  .splide__slide.gallerie-photos {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .carte-conseil {
    padding-left: 60px;
    padding-right: 60px;
  }

  .groupe-titre {
    font-size: 80px;
    line-height: 90px;
  }

  .groupe-description {
    font-size: 21px;
    line-height: 30px;
  }

  .groupe-info-geo, .groupe-contact {
    font-size: 16px;
    line-height: 21px;
  }

  .collection-portraits-de-groupe {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
  }

  .contenant-liste-villes {
    top: 10px;
    left: 10px;
  }

  .contenant-liste-villes.cdg {
    max-width: 33%;
  }

  .en-tete-liste-villes {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
  }

  .groupe-icone {
    height: 16px;
  }

  .offre-emploi-icone-valise {
    width: 15px;
    height: 15px;
  }

  .offre-emploi-logo-coeur {
    width: 75px;
    height: 75px;
  }

  .tabs-menu {
    display: flex;
  }

  .titre-onglet {
    font-size: 21px;
    line-height: 25px;
  }

  .contenant-balado {
    grid-column-gap: 75px;
    grid-row-gap: 75px;
  }

  .balado-titre {
    font-size: 28px;
    line-height: 35px;
  }

  .balado-description {
    font-size: 16px;
    line-height: 25px;
  }

  .action-en-tete {
    height: 450px;
    min-height: 0;
    padding: 20px;
  }

  .action-description {
    font-size: 21px;
    line-height: 30px;
  }

  .action-titre {
    font-size: 80px;
  }

  .action-info {
    font-size: 16px;
    line-height: 21px;
  }

  .section-informations-pratiques {
    width: 100%;
  }

  .titre-informations-pratiques {
    font-size: 35px;
  }

  .page-inondez-vos-elus {
    margin-left: auto;
    margin-right: auto;
  }

  .contenant-images-animation {
    height: 60vh;
  }

  .image-animation-inondez-vos-elus {
    object-fit: cover;
  }

  .image-animation-inondez-vos-elus.bas, .image-animation-inondez-vos-elus.centre {
    object-fit: cover;
    left: auto;
    right: auto;
  }

  .rester-informe {
    font-size: 35px;
    line-height: 40px;
  }

  .contenant-infos-action-passee {
    flex-flow: column;
    justify-content: space-between;
    align-items: center;
  }

  .action-passe-description, .action-passee-infos-details {
    width: 90%;
  }

  .contenant-chiffres {
    grid-template-columns: 1fr 1fr;
  }

  .bouton-vert-album-photo {
    padding-left: 40px;
    padding-right: 40px;
  }

  .texte-grande-carte-long-texte {
    max-height: 400px;
    line-height: 32px;
  }

  .contenant-retour-en-image {
    max-width: 100%;
  }

  .section-inondez-vos-elus {
    margin-top: 40px;
  }

  .element-inondez-vos-elus {
    max-width: 80vw;
  }

  .derniere-etape-inondez {
    max-width: 90vw;
  }

  .citation-inondez {
    font-size: 28px;
    line-height: 35px;
  }

  .logo-en-tete-projet {
    width: 40vw;
    margin-top: 20px;
  }

  .en-tete-projet {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 90vw;
  }

  .contenant-polygones {
    justify-content: flex-start;
    align-items: center;
  }

  .contenant-bloc-de-texte {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    flex-flow: column-reverse;
  }

  .carte-porte-voix {
    width: 350px;
    height: 350px;
  }

  .contenant-images-scientifiques {
    padding: 10px;
  }

  .texte-presentation-scientifiques {
    font-size: 21px;
    line-height: 28px;
  }

  .en-tete-cdg {
    flex-flow: column;
    width: 90vw;
  }

  .video {
    max-width: 95vw;
  }

  .contenant-cartes-moyennes-cdg {
    flex-flow: column;
  }

  .grande-carte-photo {
    height: 500px;
    margin-left: auto;
    margin-right: auto;
    padding: 30px;
  }

  .contenant-carte-emploi {
    max-width: 95vw;
    overflow: hidden;
  }

  .image-mosaic {
    object-fit: contain;
  }

  .contenant-logo {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
  }

  .en-tete-titre-vert {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .contenant-mos-img-1 {
    width: 35%;
    margin-left: 0%;
  }

  .contenant-mos-img-2 {
    width: 30%;
  }

  .contenant-mos-img-3 {
    width: 35%;
  }

  .contenant-mos-img-4 {
    height: 330px;
  }

  .contenant-mos-img-5 {
    width: 30%;
    height: 360px;
    margin-top: -1.5rem;
  }

  .contenant-mos-img-6 {
    width: 35%;
  }

  .logo-porte-voix {
    width: 60%;
  }

  .small-text.footer {
    max-width: 275px;
  }

  .auteure-blogue {
    width: auto;
    font-size: 28px;
    line-height: 35px;
  }

  .auteure-blogue.cdg {
    text-align: center;
  }

  .contenant-livres {
    width: 90%;
  }

  .nos-livres {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .hero-campagne {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .hero-campagne.sombre.ressources-externes {
    padding-top: 30px;
  }

  .hero-campagne.section-polygones-acceuil {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    width: 100%;
  }

  .hero-campagne.commentaires {
    width: 75%;
  }

  .contenant-video-arriere-plan {
    -webkit-text-fill-color: inherit;
    background-clip: border-box;
  }

  .contenant-video-arriere-plan.notre-histoire {
    padding-left: 0;
    padding-right: 0;
  }

  .contenant-hero-cdg-jappuie {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .campagne-cdg-hero-titre {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    width: 80%;
  }

  .contenant-image-hero-campagne-cdg {
    height: 350px;
  }

  .credit-image-campagne-cdg {
    line-height: 1.3;
  }

  .contenant-polygones-vert {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .section-pleine-largeur {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .section-pleine-largeur.sombre.ressources-externes {
    padding-top: 30px;
  }

  .section-pleine-largeur.section-polygones-acceuil {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    width: 100%;
  }

  .section-pleine-largeur.commentaires {
    width: 75%;
  }

  .section-pleine-largeur.font-vert-fonce.remerciements-bdf {
    padding-bottom: 3rem;
  }

  .image-titre-cdg-j-appuie {
    width: 500px;
  }

  .logo-en-tete-projet-mobile {
    width: 40vw;
    margin-top: 20px;
  }

  .contenant-filtres-cpv {
    grid-column-gap: 1.25rem;
    grid-row-gap: 1.25rem;
  }

  .filtre-cpv {
    text-align: center;
  }

  .collection-capsules-video {
    justify-content: center;
    align-items: flex-start;
  }

  .h1-page-cpv {
    font-size: 2rem;
  }

  .tag-cpv {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .section {
    margin-left: 15px;
    margin-right: 15px;
  }

  .container {
    text-align: center;
  }

  .paragraph-bigger {
    font-size: 16px;
    line-height: 28px;
  }

  .rich-text {
    text-align: left;
    width: 90%;
    max-width: 470px;
  }

  .heading-jumbo {
    font-size: 50px;
    line-height: 64px;
  }

  .heading-jumbo-small {
    font-size: 30px;
    line-height: 52px;
  }

  .logo-link {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    width: 25%;
    padding-left: 0;
    transition-property: none;
  }

  .utility-page-wrap {
    padding: 15px;
  }

  ._404-wrap {
    padding: 30px;
  }

  .titre-principal {
    margin-left: 100px;
    margin-right: 100px;
    line-height: 50px;
  }

  .titre-principal.titre-notre-symbole {
    font-size: 40px;
  }

  .titre-principal.variante {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .titre-principal.rapport-activites {
    display: none;
  }

  .pied-de-page---principale {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    text-align: left;
    flex-flow: column;
    justify-content: space-between;
    align-items: center;
    display: flex;
  }

  .pied-de-page---contenant---logo-titre {
    margin-bottom: 0;
  }

  .pdp---menu-gauche {
    justify-content: center;
    align-items: center;
  }

  .pdp---contenant---contribuer-la-cause, .pdp---contribuer-la-cause---contentant-du-bouton {
    align-items: center;
  }

  .collection-cartes-actions {
    margin-left: 10px;
    margin-right: 10px;
  }

  .carte-action-en-cours {
    width: 360px;
  }

  .paragraphe.campagne-cdg {
    font-size: 18px;
  }

  .paragraphe.remerciements-bdf {
    font-size: 1rem;
  }

  .contenant-bandeau-de-liens {
    z-index: 100;
    flex-flow: wrap;
    position: sticky;
    top: 0;
  }

  .lien-blanc.rapport-activites {
    display: none;
  }

  .section-principale {
    width: 100%;
  }

  .section-principale.sombre.lien-nous-connaitre {
    padding-top: 20px;
  }

  .section-principale.sombre.notre-histoire {
    width: 90vw;
    max-width: 90vw;
  }

  .section-principale.page-groupe {
    margin-top: 60px;
  }

  .section-principale.section-polygones-acceuil {
    margin-bottom: 40px;
  }

  .section-principale.inondez-vos-elus {
    margin-left: 0;
    margin-right: 0;
    display: none;
  }

  .section-principale.commentaires {
    width: 90%;
  }

  .section-principale.en-chiffre {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-principale.section-articles {
    margin-top: 20px;
    margin-bottom: 40px;
  }

  .section-principale.bouton-seul, .section-principale.video {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .blanc._500.texte-faire-un-don {
    font-size: 16px;
    line-height: 22px;
  }

  .vert._700._80px.don {
    font-size: 60px;
    line-height: 90px;
  }

  .vert._700.titre-devenir-membre {
    font-size: 60px;
    line-height: 55px;
  }

  .tres-grand-titre {
    font-size: 100px;
    line-height: 100px;
  }

  .flex-c.gap40.margin-negatif {
    width: 100%;
  }

  .grande-carte-sans-badge {
    width: 100%;
    min-height: 350px;
    padding: 20px;
  }

  .flex.texte-faq, .flex.texte-informations-pratiques {
    flex-flow: column;
    font-size: 16px;
  }

  .inondez-vos-lus {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    height: auto;
  }

  .contenant-fil-d-ariane {
    display: none;
  }

  .texte-mosaic {
    font-size: 16px;
    line-height: 21px;
  }

  .coeur-mosaic {
    width: 3rem;
    height: 3rem;
  }

  .contenant-polygone-vert {
    background-color: var(--vert-principale);
    background-image: none;
    border-radius: 12px;
    justify-content: center;
    align-items: center;
    width: 450px;
    height: auto;
    padding: 20px;
  }

  .contenant-polygone-vert.participer {
    margin-top: 0;
    padding: 80px 60px;
  }

  .contenant-polygone-vert.impaire {
    width: 450px;
  }

  .contenant-polygone-vert.paire {
    height: auto;
  }

  .contenant-polygone-vert.infolettre {
    height: auto;
    margin-top: 60px;
  }

  .contenu-polygone-vert {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    padding-left: 0;
    padding-right: 0;
  }

  .contenu-polygone-vert.infolettre {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    flex-flow: column;
    justify-content: center;
    width: 100%;
    height: auto;
    padding-bottom: 0;
  }

  .contenu-polygone-vert.participer {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    flex-flow: column;
    justify-content: center;
    font-size: 35px;
    line-height: 45px;
  }

  .notre-mission.flex-c.center {
    padding-bottom: 80px;
  }

  ._700._50px.titre-comment-devenir-membre {
    font-size: 35px;
    line-height: 40px;
  }

  .texte-principe-fondateur {
    font-size: 14px;
    line-height: 26px;
  }

  .texte-nos-valeurs {
    font-size: 18px;
    line-height: 25px;
  }

  .comment-devenir-membre {
    width: auto;
  }

  .lien-courriel {
    padding-left: 0;
    text-decoration: underline;
  }

  .titre-vert {
    font-size: 80px;
    line-height: 80px;
  }

  .titre-vert.devenir-mere-au-front {
    font-size: 60px;
    line-height: 60px;
  }

  .titre-vert.nos-actions {
    line-height: 100px;
  }

  .titre-vert.titre-nos-groupes {
    font-size: 80px;
    line-height: 90px;
  }

  .titre-vert.nous-contacter {
    font-size: 120px;
    line-height: 100px;
  }

  .titre-vert.inondez-vos-elus {
    margin-bottom: 40px;
    font-size: 50px;
    line-height: 65px;
  }

  .titre-vert.blogue {
    margin-bottom: 40px;
    font-size: 35px;
    line-height: 1.2;
  }

  .contenant-titre-vert {
    width: 100%;
  }

  .image-devenir-membre {
    justify-content: center;
    align-items: center;
    width: 90vw;
    display: flex;
  }

  .collection-list-dates-importantes {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    grid-template-columns: 1fr;
  }

  .contenant-swiper {
    max-width: 95vw;
  }

  .swiper-slide.agir-en-1-clic {
    width: 90%;
  }

  .swiper-slide.actions-porte-voix {
    justify-content: center;
    align-items: flex-start;
    width: 90%;
    display: flex;
  }

  .swiper-slide.shorts {
    width: 90%;
  }

  .carte-rejoingnez-un-groupe {
    width: 100%;
    height: 400px;
  }

  .faire-un-don {
    width: 100%;
  }

  .carte-s-impliquer {
    align-items: flex-start;
    width: 100%;
    height: 300px;
  }

  .carte-besoin-de-vous {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
    background-color: var(--vert-principale);
    background-image: none;
    border-radius: 5px;
    width: 450px;
    max-width: 95vw;
    min-height: 150px;
    padding: 30px;
  }

  .contenant-image-faire-un-don {
    height: 300px;
  }

  .titre-faire-un-don {
    font-size: 60px;
  }

  .carte-mini-portrait {
    padding-left: 30px;
    padding-right: 30px;
  }

  .formulaire-devenir-membre {
    height: 725px;
  }

  .pdp-colonne-gauche {
    justify-content: space-between;
    align-items: center;
    width: 100%;
  }

  .pdp-colonne-droite {
    align-items: center;
    width: 100%;
  }

  .formulaire-infolettre {
    margin-top: 20px;
    margin-left: 0;
  }

  .contenant-groupe-liens-pdp {
    text-align: center;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .titre-navigation {
    margin-left: 15px;
    margin-right: 10px;
  }

  .navbar-logo-left-container {
    max-width: 100%;
  }

  .contenant-principe-fondateur {
    width: 400px;
  }

  .bouton-vert.pos-relative {
    position: relative;
  }

  .contenant-image.notre-histoire {
    padding-left: 0;
    padding-right: 0;
  }

  .carte-moyenne-texte-superieur {
    font-size: 22px;
  }

  .collection-list-actions-passees {
    grid-column-gap: 20px;
    grid-row-gap: 0px;
    grid-template-rows: auto auto auto auto;
    grid-template-columns: 1fr;
  }

  .texte-rapport-activite {
    font-size: 24px;
    line-height: 32px;
  }

  .carte-rapport-activitees {
    width: 360px;
  }

  .texte-etapes {
    font-size: 22px;
    line-height: 30px;
  }

  .texte-grand-polygone-verte {
    font-size: 16px;
    line-height: 22px;
  }

  .sous-titre.gris-principale {
    font-size: 18px;
    line-height: 1.4;
  }

  .sous-titre.inondez-vos-elus {
    font-size: 18px;
    line-height: 25px;
  }

  .demi-contenant.gauche.infolettre, .demi-contenant.droite {
    width: 100%;
  }

  .contenant-texte.grande-carte {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    font-size: 18px;
    line-height: 21px;
  }

  .contenant-hero.cdg {
    padding-top: 4rem;
  }

  .titre-hero {
    font-size: 50px;
  }

  .titre-hero.actions-passees {
    font-size: 50px;
    line-height: 60px;
  }

  .section-bandeau-de-lien {
    display: none;
  }

  .image-flottante {
    width: 150px;
    height: 150px;
  }

  .grande-carte-long-texte {
    padding: 40px 20px;
  }

  .titre-grande-carte-long-texte {
    font-size: 25px;
    line-height: 32px;
  }

  .texte-nos-demandes {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .contenant-liens-nous-connaitre {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    height: 350px;
  }

  .paragraph-hero {
    font-size: 25px;
  }

  .mini-carte-portrait {
    width: 100px;
    height: 100px;
    padding: 5px;
  }

  .mini-carte-prenom {
    font-size: 12px;
    line-height: 16px;
  }

  .contenant-texte-notre-histoire {
    width: 100%;
  }

  .notre-fonctionnement {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 14px;
    line-height: 24px;
  }

  .introduction {
    font-size: 24px;
    line-height: 28.8px;
  }

  .mini-carte-conseil {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    justify-content: center;
    align-items: flex-start;
    width: 150px;
    height: 150px;
  }

  .texte-mini-carte-conseil {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .nom {
    font-size: 16px;
    line-height: 21px;
  }

  .div-block-26, .div-block-27, .div-block-28 {
    height: 350px;
  }

  .heading-11, .heading-12 {
    font-size: 18px;
  }

  .heading-13, .heading-14 {
    line-height: 21.6px;
  }

  .div-block-31 {
    flex-flow: column-reverse;
  }

  .div-block-32 {
    justify-content: center;
    align-items: center;
  }

  .div-block-33, .div-block-34, .div-block-35 {
    align-items: stretch;
  }

  .div-block-36, .div-block-37 {
    justify-content: flex-start;
  }

  .div-block-38, .div-block-39 {
    justify-content: center;
  }

  .div-block-40, .div-block-41 {
    align-items: stretch;
  }

  .div-block-42, .div-block-43 {
    align-items: center;
  }

  .div-block-44, .div-block-45 {
    justify-content: flex-start;
  }

  .div-block-46 {
    justify-content: center;
  }

  .div-block-47 {
    justify-content: flex-end;
  }

  .div-block-48, .div-block-49 {
    justify-content: space-between;
  }

  .div-block-50, .div-block-51 {
    justify-content: flex-start;
  }

  .div-block-52 {
    justify-content: flex-end;
  }

  .div-block-53 {
    justify-content: space-between;
  }

  .div-block-54, .div-block-55 {
    justify-content: space-around;
  }

  .div-block-56, .div-block-57 {
    height: 350px;
  }

  .heading-15 {
    font-size: 18px;
  }

  .heading-16, .heading-17 {
    line-height: 21.6px;
  }

  .div-block-58 {
    flex-flow: column;
  }

  .div-block-59, .div-block-60 {
    justify-content: flex-start;
  }

  .div-block-61, .div-block-62 {
    justify-content: space-around;
  }

  .div-block-63, .div-block-64 {
    align-items: stretch;
  }

  .div-block-65, .div-block-66 {
    align-items: center;
  }

  .nos-balados {
    height: auto;
  }

  .texte-cri-du-coeur {
    width: 80%;
    font-size: 25px;
    line-height: 35px;
  }

  .texte-notre-symbole {
    width: 60%;
  }

  .collection-carte-avec-badge.liste-rapports {
    display: none;
  }

  .bas-de-carte {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .contenant-textes {
    margin-bottom: 10px;
  }

  .texte-principal {
    font-size: 40px;
    line-height: 40px;
  }

  .grande-carte-titre {
    font-size: 45px;
    line-height: 50px;
  }

  .contenant-bouton {
    margin-left: auto;
    margin-right: auto;
  }

  .sous-titre-nos-groupes {
    font-size: 24px;
    line-height: 30px;
  }

  .contenant-citation {
    width: 100%;
    height: auto;
  }

  .citation {
    font-size: 35px;
    line-height: 45px;
  }

  .citation-auteur {
    font-size: 25px;
    line-height: 30px;
  }

  .image-citation {
    width: 100px;
  }

  .lien-voir-la-carte {
    display: none;
  }

  .contenant-etape {
    width: 350px;
    height: 400px;
  }

  .contenant-etape.carte-de-dessous._20degres.etape-1 {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .titre-etape {
    font-size: 28px;
    line-height: 30px;
  }

  .texte-etape {
    font-size: 18px;
    line-height: 21px;
  }

  .coeur-etape {
    width: 80px;
  }

  .nombre-etape {
    font-size: 40px;
    top: 40%;
  }

  .contenant-portrait {
    flex-flow: column;
    justify-content: flex-start;
    align-items: stretch;
  }

  .contenant-portrait.scientifiques {
    align-items: center;
    width: 100%;
    max-width: none;
    height: auto;
    margin-left: auto;
    margin-right: auto;
  }

  .photo-portrait {
    object-position: 50% 25%;
    width: 100%;
    height: 150px;
  }

  .photo-portrait.scientifiques {
    max-height: 350px;
  }

  .contenu-portrait {
    width: 100%;
    height: 380px;
  }

  .contenu-portrait.scientifiques {
    width: 90vw;
    height: auto;
  }

  .nom-portrait {
    font-size: 32px;
    line-height: 38.4px;
  }

  .etiquette-portrait.role, .etiquette-portrait.etiquette-groupe {
    font-size: 12px;
    line-height: 16px;
  }

  .texte-portrait {
    padding-bottom: 60px;
    font-size: 16px;
    line-height: 21px;
  }

  .onglets-demandes {
    max-height: 100vh;
  }

  .contenant-onglet-demande {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
    flex-flow: column;
    padding: 15px;
  }

  .image-onglet-demande {
    width: 100%;
    max-width: 95vw;
    height: 200px;
  }

  .titre-onglet-demande {
    font-size: 21px;
    line-height: 25px;
  }

  .titre-demande {
    font-size: 24px;
    line-height: 28.8px;
  }

  .texte-demande {
    font-size: 16px;
    line-height: 24px;
  }

  .splide.agir-en-1-clic, .splide.actions-porte-voix {
    padding-left: 0;
    padding-right: 0;
  }

  .splide__slide.mini-portrait {
    width: 100px;
    height: 100px;
  }

  .splide__slide.scientifiques {
    height: auto;
    max-height: 105vh;
    overflow: auto;
  }

  .splide__slide.agir-en-1-clic {
    justify-content: center;
    align-items: flex-start;
    display: flex;
  }

  .pdp-contenant {
    flex-flow: column;
  }

  .carte-conseil {
    padding: 20px;
  }

  .carte-conseil-nom {
    font-size: 35px;
    line-height: 45px;
  }

  .splide-extras {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 10px;
  }

  .groupe-en-tete {
    height: 200px;
  }

  .groupe-titre {
    font-size: 40px;
    line-height: 50px;
  }

  .groupe-description {
    height: auto;
    min-height: 0;
    font-size: 16px;
    line-height: 21px;
  }

  .contenant-page-groupe {
    flex-flow: column;
    margin-bottom: 20px;
    display: flex;
  }

  .groupe-info-geo {
    border-width: 2px;
    min-height: 75px;
    padding: 20px;
  }

  .groupe-contact {
    min-height: 75px;
    padding: 20px;
  }

  .collection-portraits-de-groupe {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
    flex-flow: column;
    grid-template-columns: 1fr;
    justify-content: flex-start;
    align-items: stretch;
    display: flex;
  }

  .collection-petite-carte-portrait {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
  }

  .texte-carte-pied-de-page {
    font-size: 14px;
    line-height: 16.8px;
  }

  .fleche-carte-pied-de-page {
    padding: 5px;
  }

  .fleche-bas {
    height: 10px;
  }

  .contenant-liste-villes.cdg {
    max-width: 40%;
  }

  .titre-liste-villes {
    font-size: 16px;
    line-height: 19.2px;
  }

  .ville {
    font-size: 12px;
    line-height: 14.4px;
  }

  .liste-des-villes.groupes {
    max-height: 25vh;
  }

  .offre-emploi-titre-en-tete {
    font-size: 35px;
    line-height: 40px;
  }

  .offre-emploi-coeur-vert {
    display: none;
  }

  .offre-emploi-icone {
    display: none;
    top: 15px;
  }

  .offre-emploi-texte-equite {
    width: 75%;
  }

  .portrait-icon-lien {
    width: 12px;
  }

  .text-block {
    display: none;
  }

  .titre-onglet {
    font-size: 16px;
    line-height: 21px;
  }

  .mini-carte-conseil-icone-coeur {
    width: 30px;
  }

  .contenant-balado {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
    flex-flow: column;
  }

  .balado-infos {
    width: 100%;
  }

  .balado-titre {
    font-size: 22px;
    line-height: 30px;
  }

  .balado-description {
    font-size: 12px;
    line-height: 19px;
  }

  .vignette-balado {
    width: 200px;
    height: 200px;
  }

  .contenant-lecteur-balado {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .balado-texte-extrait {
    font-size: 12px;
    line-height: 20px;
  }

  .contenant-page-action {
    flex-flow: column;
    align-items: stretch;
    width: 100%;
    max-width: none;
    margin-bottom: 20px;
    display: flex;
  }

  .action-en-tete {
    height: 200px;
    padding: 15px;
  }

  .action-description {
    height: auto;
    min-height: 0;
    font-size: 16px;
    line-height: 21px;
  }

  .action-titre {
    font-size: 40px;
  }

  .action-info {
    padding: 20px;
  }

  .formulaire-label {
    font-size: 1.5rem;
  }

  .formulaire-input, .formulaire-input::placeholder {
    font-size: 1.25rem;
  }

  .page-inondez-vos-elus {
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  .icone-polygone-vert {
    width: 60px;
    height: 60px;
  }

  .textes-polygone-vert, .titre-polygone-vert {
    font-size: 14px;
    line-height: 20px;
  }

  .contenant-images-animation {
    height: 50vh;
  }

  .image-animation-inondez-vos-elus.centre {
    bottom: 5%;
  }

  .action-passe-description {
    font-size: 21px;
    line-height: 30px;
  }

  .contenant-chiffres {
    grid-template-columns: 1fr;
  }

  .carte-chiffre-action-passee {
    overflow: auto;
  }

  .texte-grande-carte-long-texte {
    max-height: 350px;
    font-size: 16px;
    line-height: 21px;
  }

  .section-inondez-vos-elus {
    margin-top: 0;
  }

  .cercle-animation-inondez {
    width: 400px;
    height: 400px;
  }

  .element-inondez-vos-elus {
    font-size: 20px;
    line-height: 25px;
  }

  .numero-etape {
    font-size: 90px;
    line-height: 100px;
  }

  .lien.porte-voix:hover {
    background-color: #2db24a;
  }

  .lien.cdg {
    font-size: 16px;
  }

  .progress-bar-inondez {
    width: 80%;
  }

  .contenant-recherche-villes {
    margin-top: 10px;
  }

  .logo-en-tete-projet {
    width: 60vw;
    margin-top: 40px;
  }

  .contenant-bloc-de-texte {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    width: 90vw;
  }

  .carte-porte-voix {
    padding: 1rem;
  }

  .contenant-images-scientifiques {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    flex-flow: column-reverse;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
    height: auto;
    padding: 20px;
  }

  .texte-presentation-scientifiques {
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 21px;
  }

  .en-tete-cdg {
    flex-flow: column;
  }

  .grande-carte-photo {
    width: 100%;
  }

  .groupe-bouton-rejoindre {
    margin-top: 0;
    margin-bottom: 0;
  }

  .image-mosaic {
    object-fit: cover;
  }

  .contenant-logo {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 80%;
    display: flex;
  }

  .contenant-mos-img-1 {
    height: 250px;
  }

  .contenant-mos-img-2 {
    height: 260px;
  }

  .contenant-mos-img-3 {
    height: 250px;
  }

  .contenant-mos-img-4 {
    height: 230px;
  }

  .contenant-mos-img-5 {
    height: 250px;
  }

  .contenant-mos-img-6 {
    height: 240px;
  }

  .mosaique-ligne, .deuxieme-ligne {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .small-text {
    font-size: 14px;
  }

  .small-text.footer {
    max-width: none;
  }

  .image-blogue {
    width: 100%;
  }

  .carte-livre {
    width: 125px;
    height: 180px;
    padding-bottom: 0;
  }

  .image-livre {
    height: 100%;
  }

  .titre-livre {
    display: none;
  }

  .nos-livres {
    height: auto;
  }

  .contenant-collections-villes {
    max-height: 25vh;
  }

  .hero-campagne {
    width: 100%;
  }

  .hero-campagne.sombre.lien-nous-connaitre {
    padding-top: 20px;
  }

  .hero-campagne.sombre.notre-histoire {
    width: 90vw;
    max-width: 90vw;
  }

  .hero-campagne.page-groupe {
    margin-top: 60px;
  }

  .hero-campagne.section-polygones-acceuil {
    margin-bottom: 40px;
  }

  .hero-campagne.inondez-vos-elus {
    margin-left: 0;
    margin-right: 0;
    display: none;
  }

  .hero-campagne.commentaires {
    width: 90%;
  }

  .hero-campagne.en-chiffre {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .hero-campagne.section-articles {
    margin-top: 20px;
    margin-bottom: 40px;
  }

  .hero-campagne.bouton-seul, .hero-campagne.video {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .contenant-video-arriere-plan.notre-histoire {
    padding-left: 0;
    padding-right: 0;
  }

  .section-pleine-largeur {
    width: 100%;
  }

  .section-pleine-largeur.sombre.lien-nous-connaitre {
    padding-top: 20px;
  }

  .section-pleine-largeur.sombre.notre-histoire {
    width: 90vw;
    max-width: 90vw;
  }

  .section-pleine-largeur.page-groupe {
    margin-top: 60px;
  }

  .section-pleine-largeur.section-polygones-acceuil {
    margin-bottom: 40px;
  }

  .section-pleine-largeur.inondez-vos-elus {
    margin-left: 0;
    margin-right: 0;
    display: none;
  }

  .section-pleine-largeur.commentaires {
    width: 90%;
  }

  .section-pleine-largeur.en-chiffre {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-pleine-largeur.section-articles {
    margin-top: 20px;
    margin-bottom: 40px;
  }

  .section-pleine-largeur.bouton-seul, .section-pleine-largeur.video {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .section-pleine-largeur.font-vert-fonce.remerciements-bdf {
    padding-bottom: 2.5rem;
  }

  .contenant-capsules-video {
    flex-flow: wrap;
    display: flex;
  }

  .logo-en-tete-projet-mobile {
    width: 60vw;
    margin-top: 40px;
  }

  .contenant-filtres-cpv {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .texte-filtre-cpv.role, .texte-filtre-cpv.etiquette-groupe {
    font-size: 12px;
    line-height: 16px;
  }

  .collection-capsules-video.liste-rapports {
    display: none;
  }

  .h1-page-cpv {
    font-size: 1.75rem;
  }

  .icone-partage {
    width: 35px;
  }

  .contenant-icone-partage {
    flex: none;
  }

  .description-cpv {
    font-size: 1.2rem;
  }

  .contenant-a-propos-cpv {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    justify-content: flex-start;
    align-items: center;
  }

  .image-fond-cpv {
    width: 200px;
    right: 20%;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    font-size: 36px;
    line-height: 52px;
  }

  .bouton.bouton---vert {
    padding: 10px 16px;
  }

  .rich-text {
    width: 100%;
    max-width: none;
  }

  .heading-jumbo {
    font-size: 36px;
    line-height: 48px;
  }

  .logo-link {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }

  .logo-link.w--current {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex: none;
    width: 25%;
    display: flex;
  }

  .navigation-wrap {
    background-color: #0000;
  }

  .navigation-item {
    text-align: right;
  }

  .menu-button, .menu-button.w--open {
    flex: none;
  }

  .titre-principal {
    margin-left: 40px;
    margin-right: 40px;
    padding-top: 5px;
    padding-bottom: 5px;
    font-size: 26px;
    line-height: 31.2px;
  }

  .titre-principal.sombre {
    max-width: 80vw;
  }

  .titre-principal.titre-notre-symbole {
    font-size: 26px;
  }

  .titre-principal.variante {
    max-width: 90%;
    margin: 0;
    padding: 20px;
  }

  .navigation---logo---image {
    flex: none;
    width: 33px;
  }

  .navigation---menu-fond-blanc {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    z-index: 5000;
    background-color: #0000;
    flex-direction: row-reverse;
    padding: 0;
  }

  .pied-de-page---principale {
    grid-row-gap: 40px;
    flex-direction: column;
  }

  .pdp---logo-blanc {
    width: 42px;
    height: 39.5px;
  }

  .pdp---titre {
    font-family: "PP Neue Montreal 700", sans-serif;
    font-size: 24px;
  }

  .pdp---menu-gauche {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    text-align: center;
    display: flex;
  }

  .pdp---lien {
    font-size: 16px;
    line-height: 19.2px;
  }

  .pdp---contenant---contribuer-la-cause {
    text-align: center;
    padding-top: 10px;
  }

  .pdp---lien-blanc.pdp---contribuer-la-cause---lien.w--current {
    display: none;
  }

  .pied-de-page---formulaire {
    flex-direction: column;
  }

  .collection-cartes-actions {
    grid-template-columns: 1fr;
    margin-left: 10px;
    margin-right: 10px;
  }

  .carte-action-en-cours {
    margin-top: 30px;
  }

  .carte-action---image {
    box-shadow: 0 2px 5px #0003;
  }

  .paragraphe {
    max-width: 90vw;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.4;
  }

  .paragraphe.centre {
    line-height: 20px;
  }

  .paragraphe.campagne-cdg-hero {
    font-size: 17px;
  }

  .paragraphe.campagne-cdg-hero.mobile {
    color: var(--noir);
    text-shadow: none;
  }

  .section-titre-vert {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .section-titre-vert.nos-groupes {
    justify-content: space-between;
    margin-top: 0;
  }

  .contenant-bandeau-de-liens {
    height: auto;
    min-height: 90px;
    padding-top: .75rem;
    padding-bottom: .75rem;
  }

  .contenant-bandeau-de-liens.campagne-cdg, .contenant-bandeau-de-liens.avec-margin {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .section-principale {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-principale.sombre.notre-histoire {
    width: 100vw;
    max-width: none;
    padding-left: 20px;
    padding-right: 20px;
  }

  .section-principale.sombre.avec-margin {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-principale.portrait, .section-principale.page-groupe, .section-principale.page-action {
    margin-top: 20px;
  }

  .section-principale.section-polygones-acceuil {
    margin-bottom: 20px;
    padding-top: 0;
  }

  .section-principale.inondez-vos-elus {
    margin-top: 60px;
  }

  .section-principale.commentaires {
    width: 90vw;
  }

  .section-principale.margin-top {
    margin-top: 40px;
  }

  .section-principale.margin-top-60 {
    margin-top: 60px;
  }

  .section-principale.video-campagne-cdg {
    margin-bottom: 40px;
  }

  .section-principale.special-shorts {
    -webkit-clip-path: polygon(0 3%, 66% 0, 100% 4%, 100% 96%, 25% 100%, 0 97%);
    clip-path: polygon(0 3%, 66% 0, 100% 4%, 100% 96%, 25% 100%, 0 97%);
  }

  .carte-avec-badge-et-bouton {
    -webkit-text-fill-color: inherit;
    background-clip: border-box;
    height: auto;
    min-height: 350px;
    padding: 20px 25px;
  }

  .badge-vert {
    height: 35px;
    padding: 20px 25px;
  }

  .badge-texte, .badge-texte.article {
    font-size: 14px;
  }

  .section-agir-physiquement {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .contenant-bloc-texte-avec-bouton {
    width: 90vw;
  }

  .titre-gris-principale {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    font-size: 26px;
    line-height: 31.2px;
  }

  .paragraphe-gris-principale {
    font-size: 14px;
    line-height: 21.35px;
  }

  .btn.bouton-vert._500 {
    margin-top: 20px;
  }

  .btn.bouton-blanc._500.largeur-auto {
    display: none;
  }

  .btn.bouton-blanc._500.largeur-auto._24px.plus {
    font-size: 16px;
    line-height: 21px;
    display: flex;
  }

  .btn.bouton-blanc._500.largeur-auto._24px.moins {
    font-size: 16px;
    line-height: 21px;
  }

  .gros-bouton.bouton-vert._700.contenant-bloc {
    margin-left: auto;
    margin-right: auto;
  }

  .blanc._700._40px {
    text-align: center;
    font-size: 20px;
    line-height: 24px;
  }

  .blanc._700._32px {
    font-size: 18px;
    line-height: 21.6px;
  }

  .blanc._500._24px {
    margin-top: 20px;
    font-size: 14px;
    line-height: 17px;
  }

  .blanc._500._24px.lh34px {
    line-height: 25px;
  }

  .blanc._500.texte-faire-un-don {
    margin-bottom: 0;
    font-size: 14px;
    line-height: 21px;
  }

  .blanc.action-passee {
    font-size: 14px;
    line-height: 1.4;
  }

  .vert._700._80px {
    font-size: 40px;
    line-height: 18px;
  }

  .vert._700._80px.don {
    font-size: 40px;
    line-height: 40px;
  }

  .vert._700.titre-devenir-membre {
    text-align: center;
    font-size: 60px;
    line-height: 51.6px;
  }

  .tres-grand-titre {
    text-align: center;
    max-width: 90vw;
    margin: 40px auto;
    font-size: 66px;
    line-height: 56.76px;
  }

  .grande-carte-sans-badge {
    min-height: auto;
  }

  .carte-apercu-emploi {
    height: auto;
  }

  .flex.space-between {
    justify-content: space-between;
    align-items: center;
    width: 100%;
  }

  .flex.texte-faq {
    font-size: 14px;
    line-height: 19px;
  }

  .flex.gap20 {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .flex.texte-informations-pratiques {
    font-size: 14px;
    line-height: 21px;
  }

  .contenant-inondez-vos-lus {
    height: auto;
  }

  .inondez-vos-lus {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }

  .logo-emploi {
    width: 29px;
    height: 30px;
    top: 22%;
  }

  .logo-coeur-rose {
    left: 35%;
  }

  .coeur-blanc-emploi {
    width: 70px;
    height: 62px;
  }

  .texte-mosaic {
    margin-bottom: 20px;
  }

  .mosaic-bloc-vert {
    width: 100%;
    height: 100%;
    margin-top: 0;
    margin-bottom: 0;
    display: flex;
  }

  .coeur-mosaic {
    width: 1rem;
    height: 1rem;
    font-size: 10px;
  }

  .grand-polygone-vert {
    margin-bottom: 40px;
  }

  .contenant-polygone-vert {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    background-image: none;
    justify-content: flex-start;
    align-items: center;
    max-width: 90vw;
    height: auto;
    padding: 0;
  }

  .contenant-polygone-vert.participer {
    padding: 0 20px;
  }

  .contenant-polygone-vert.paire {
    height: auto;
  }

  .contenant-polygone-vert.infolettre {
    padding: 20px;
  }

  .contenant-polygone-vert.page-cdg {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .coeur-dans-polygone {
    width: 50px;
    height: 50px;
  }

  .coeur-dans-polygone.page-devenir-membre {
    width: auto;
    height: 50px;
  }

  .contenu-polygone-vert {
    justify-content: flex-start;
    align-items: center;
    width: auto;
    margin-left: 0;
    margin-right: 0;
    padding: 20px;
  }

  .contenu-polygone-vert.infolettre {
    justify-content: center;
    align-items: center;
  }

  .contenu-polygone-vert.participer {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
  }

  .contenu-polygone-vert.page-cdg {
    flex-flow: column;
  }

  .notre-mission.flex-c.center {
    height: 300px;
    padding-bottom: 40px;
  }

  .sous-titre-section-sombre {
    width: 80%;
    font-size: 18px;
  }

  ._700.titre-notre-mission {
    font-size: 25px;
    line-height: 20px;
  }

  ._700._50px.titre-comment-devenir-membre {
    margin-top: 0;
    margin-bottom: 0;
    font-size: 25px;
    line-height: 33px;
  }

  ._700._24px._44lh {
    font-size: 20px;
    line-height: 24px;
  }

  ._700.center {
    text-align: center;
  }

  .texte-principe-fondateur {
    width: 100%;
    overflow: auto;
  }

  .nos-valeurs.nos-raisons {
    margin-top: 60px;
    margin-bottom: 60px;
  }

  .texte-nos-valeurs {
    font-size: 14px;
    line-height: 21px;
  }

  .valeur {
    width: 160px;
    padding: 15px;
  }

  .titre-valeur {
    font-size: 16px;
  }

  .respect {
    top: 8%;
    left: 10px;
  }

  .solidarit {
    top: 15%;
    right: 10px;
  }

  .bienveillance {
    bottom: 15%;
  }

  .comment-devenir-membre {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .sous-titre-dates-importantes {
    width: 75%;
    margin-top: 20px;
    margin-bottom: 0;
    font-size: 18px;
    line-height: 22px;
  }

  .badge-rose {
    background-repeat: no-repeat;
    background-size: contain;
    width: auto;
    padding: 20px 25px;
  }

  .affichage-dates-importantes {
    margin-top: 20px;
  }

  .section-faq {
    margin-bottom: 60px;
  }

  .titre-faq {
    font-size: 28px;
    line-height: 30px;
  }

  .contenant-fleche-faq {
    flex: none;
    width: 35px;
    height: 35px;
  }

  .question-faq {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .question {
    font-size: 16px;
  }

  .reponse {
    font-size: 14px;
    line-height: 17px;
  }

  .titre-vert {
    text-align: left;
    margin-bottom: 32px;
    font-size: 60px;
    line-height: 60px;
  }

  .titre-vert.devenir-mere-au-front {
    line-height: 55px;
  }

  .titre-vert.nos-actions {
    margin-bottom: 20px;
    font-size: 60px;
    line-height: 51.6px;
  }

  .titre-vert.titre-nos-groupes {
    font-size: 60px;
    line-height: 60px;
  }

  .titre-vert.nous-contacter {
    text-align: center;
    margin-bottom: 0;
    font-size: 50px;
    line-height: 50px;
  }

  .titre-vert.inondez-vos-elus {
    margin-bottom: 20px;
    font-size: 35px;
    line-height: 42px;
  }

  .titre-vert.travailler-avec-nous {
    text-align: center;
  }

  .titre-vert.blogue {
    margin-bottom: 20px;
    font-size: 35px;
    line-height: 1.1;
  }

  .titre-vert.campagne-cdg {
    font-size: 40px;
  }

  .titre-vert.projet {
    text-align: center;
  }

  .arri-re-plan-principe-fondateur {
    height: 90px;
  }

  .collection-list-dates-importantes {
    width: 300px;
    max-width: 95vw;
  }

  .tapes {
    width: 100%;
  }

  .contenant-comment-devenir-membre {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
    margin-bottom: 40px;
  }

  .images-devenir-membre {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    justify-content: space-around;
    align-items: center;
    margin-top: -60px;
  }

  .contenant-swiper {
    width: auto;
    max-width: 95vw;
  }

  .contenant-swiper.s-informer {
    margin-bottom: 2rem;
  }

  .swiper.agir-en-1-clic {
    align-items: center;
  }

  .swiper.action-rouyn {
    flex-flow: row;
    align-items: center;
    display: flex;
  }

  .swiper.carrousel-de-cartes {
    align-items: center;
    display: flex;
  }

  .swiper.actions-porte-voix, .swiper.shorts {
    align-items: center;
  }

  .swiper-wrapper.agir-en-1-clic {
    padding-left: 0;
    padding-right: 0;
  }

  .swiper-slide.carrousel-actions {
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    display: flex;
  }

  .swiper-slide.principes-fondateurs {
    width: 375px;
  }

  .swiper-slide.agir-en-1-clic {
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    display: flex;
  }

  .swiper-slide.action-rouyn {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .swiper-slide.carrousel-de-cartes, .swiper-slide.actions-porte-voix, .swiper-slide.shorts {
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    display: flex;
  }

  .principes-fondateurs.margin-bottom {
    margin-bottom: 1.5rem;
  }

  .contenant-impliquez-vous {
    margin-top: 0;
  }

  .carte-rejoingnez-un-groupe {
    height: 300px;
    padding: 20px;
  }

  .faire-un-don {
    height: auto;
  }

  .carte-s-impliquer {
    height: 205px;
    padding: 20px;
  }

  .nous-connaitre {
    height: 173.26px;
    margin-top: 10px;
    padding: 20px;
  }

  .carte-besoin-de-vous {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    background-image: none;
    border-radius: 5px;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    height: auto;
    padding: 20px 25px;
  }

  .badge-blanc {
    background-position: 50%;
    background-size: 100% 80%;
    justify-content: center;
    align-items: center;
    height: auto;
    padding: 15px 20px;
  }

  .icon-on-a-besoin-de-vous {
    width: 35px;
    height: 35px;
    margin-left: 10px;
    margin-right: 10px;
  }

  .contenant-image-faire-un-don {
    height: 200px;
  }

  .titre-faire-un-don {
    font-size: 35px;
  }

  .formulaire-faire-un-don {
    padding: 0;
  }

  .en-tete-formulaire-adhesion {
    max-width: 90vw;
  }

  .noir._500 {
    font-size: 18px;
    line-height: 25px;
  }

  .texte-formulaire-adh-sion {
    font-size: 16px;
    line-height: 21px;
  }

  .contenant-groupe-portrait {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-bottom: 20px;
  }

  .carte-rejoindre-un-groupe {
    width: 100%;
    height: 355px;
    padding: 20px;
  }

  .portraits {
    margin-bottom: -50px;
  }

  .carte-mini-portrait {
    grid-column-gap: 7px;
    grid-row-gap: 7px;
    align-items: stretch;
    width: 100%;
    height: 210px;
    padding: 20px 25px;
    position: relative;
  }

  .partie-gauche {
    width: 80%;
  }

  .partie-droite {
    width: 30%;
    position: absolute;
    inset: 25px 25px auto auto;
  }

  .contenant-formulaire-devenir-membre {
    max-width: 90vw;
    padding: 0;
  }

  .formulaire-devenir-membre {
    height: 800px;
  }

  .pied-de-page {
    padding: 20px;
  }

  .pdp-colonne-gauche {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .pdp-colonne-droite {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .formulaire-infolettre {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 320px;
    min-width: 95vw;
    display: flex;
  }

  .groupe-liens-pdp.campagne-cdg {
    grid-column-gap: .75rem;
    grid-row-gap: .75rem;
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
  }

  .contenant-groupe-liens-pdp {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .titre-navigation {
    margin-left: 15px;
    margin-right: 0;
    font-size: 12px;
    line-height: 10.44px;
  }

  .texte-bouton-navigation {
    font-size: 10px;
  }

  .list {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    z-index: 5000;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-end;
    width: 60%;
    margin-left: auto;
    margin-right: 15px;
  }

  .list-item {
    z-index: 500;
  }

  .navbar-logo-left-container {
    padding-left: 15px;
    padding-right: 15px;
  }

  .swiper-pagination.agir-en-1-clic {
    max-width: 95vw;
    margin-left: auto;
    margin-right: auto;
  }

  .swiper-pagination.agir-au-quotidien {
    max-width: 95vw;
  }

  .swiper-pagination.principes-fondateurs {
    margin-bottom: 20px;
    margin-right: 0;
  }

  .swiper-pagination.carrousel-de-cartes, .swiper-pagination.actions-porte-voix, .swiper-pagination.shorts {
    max-width: 95vw;
    margin-left: auto;
    margin-right: auto;
  }

  .titre-principe-fondateur {
    margin-bottom: 20px;
    margin-left: 20px;
    font-size: 24px;
    line-height: 28.8px;
  }

  .contenant-principe-fondateur {
    width: 375px;
    margin-left: auto;
    margin-right: auto;
  }

  .bouton-vert {
    z-index: 10;
    max-width: 90vw;
    font-size: 16px;
    line-height: 20px;
    overflow: hidden;
  }

  .bouton-vert.grand._500 {
    z-index: 4;
    height: 40px;
    padding: 15px 40px;
  }

  .bouton-vert.pos-relative.centre {
    margin-left: auto;
    margin-right: auto;
  }

  .carte-video {
    height: 350px;
    margin-top: 20px;
  }

  .carte-video.page-acceuil {
    max-width: 100%;
    margin-top: 0;
  }

  .contenant-carte-video {
    padding: 20px;
  }

  .titre-carte-video {
    font-size: 20px;
    line-height: 24px;
  }

  .bouton-lecture {
    width: 112px;
    height: 112px;
  }

  .contenant-image.notre-histoire {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
  }

  .contenant-decouvrez-nos-actions {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    width: 100%;
    margin-bottom: 20px;
  }

  .carte-avec-nombre {
    height: 350px;
    padding: 20px;
  }

  .carte-avec-nombre.page-acceuil {
    max-width: 100%;
  }

  .grand-nombre {
    font-size: 100px;
    line-height: 120px;
  }

  .titre-carte-nombre {
    font-size: 20px;
    line-height: 24px;
  }

  .sous-titre-carte-nombre {
    font-family: "PP Neue Montreal 500", sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 12px;
  }

  .texte-carte-nombre {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .icone-lecture {
    padding-top: 6px;
    padding-left: 5px;
  }

  .carte-moyenne-badge-et-bouton {
    width: 100%;
  }

  .carte-moyenne-texte-superieur {
    text-shadow: 0 1px 3px var(--noir);
    font-size: 22px;
    line-height: 1.3;
  }

  .collection-list-actions-passees {
    margin-bottom: 0;
  }

  .rapport-activite {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .texte-rapport-activite {
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 21.35px;
  }

  .carte-moyenne-texte-inferieur {
    text-shadow: 0 1px 3px var(--noir);
    font-family: "PP Neue Montreal 500", sans-serif;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.2;
  }

  .coeur-vert {
    width: 20px;
  }

  .texte-etapes {
    font-size: 16px;
    line-height: 21px;
  }

  .texte-grand-polygone-verte {
    font-size: 14px;
  }

  .texte-grand-polygone-verte.page-devenir-membre {
    font-size: 14px;
    line-height: 18px;
  }

  .sous-titre {
    width: 80%;
    font-size: 21px;
    line-height: 25px;
  }

  .sous-titre.gris-principale {
    margin-bottom: 20px;
    font-size: 16px;
  }

  .sous-titre.inondez-vos-elus {
    width: 90%;
    font-size: 14px;
    line-height: 19px;
  }

  .carte-emploi {
    max-width: 90vw;
    height: auto;
    min-height: 300px;
  }

  .demi-contenant.gauche.infolettre {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    font-size: 16px;
  }

  .contenant-texte.grande-carte {
    width: 100%;
    font-size: 14px;
    line-height: 16.8px;
  }

  .en-tete-carte {
    max-height: 180px;
    overflow: auto;
  }

  .carte-apercu-benevolat {
    height: auto;
  }

  .texte-nous-connaitre {
    font-size: 20px;
    line-height: 20.5px;
  }

  .liste-on-a-besoin-de-vous {
    padding-left: 0;
    padding-right: 0;
  }

  .titre-carte-besoin-de-vous {
    font-size: 16px;
    line-height: 20px;
  }

  .dropdown-nous-connaitre {
    z-index: 500;
    width: 230px;
    left: auto;
    right: 0%;
  }

  .liste-dropdown-nous-connaitre {
    z-index: 500;
  }

  .contenant-hero.cdg {
    padding-top: 2rem;
  }

  .titre-hero {
    font-size: 28px;
  }

  .titre-hero.actions-passees {
    font-size: 30px;
    line-height: 40px;
  }

  .coeur-echo {
    max-width: 80vw;
  }

  .elements-du-bas {
    font-size: 18px;
    line-height: 21px;
  }

  .image-flottante.image-2 {
    top: 40%;
  }

  .image-flottante.image-3 {
    left: 5%;
  }

  .grande-carte-long-texte {
    padding: 20px;
  }

  .titre-grande-carte-long-texte {
    font-size: 16px;
    line-height: 21px;
  }

  .texte-nos-demandes {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .contenant-liens-nous-connaitre {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    justify-content: center;
    align-items: stretch;
    height: 250px;
  }

  .paragraph-hero {
    width: 90%;
    font-size: 21px;
  }

  .contenant-texte-notre-histoire {
    padding-bottom: 100px;
  }

  .overlay-linear.blanc {
    background-image: linear-gradient(180deg, #0000 70%, var(--blanc) 85%);
  }

  .nom {
    font-family: "PP Neue Montreal 500", sans-serif;
  }

  .div-block-67, .div-block-68 {
    width: 163px;
  }

  .div-block-69, .div-block-70 {
    height: 250px;
  }

  .div-block-71, .div-block-72 {
    width: 163px;
  }

  .div-block-73, .div-block-74 {
    height: 250px;
  }

  .code-embed-3, .code-embed-4 {
    padding: 20px;
  }

  .notre-symbole {
    height: 500px;
  }

  .texte-cri-du-coeur {
    width: 95%;
    max-width: 85vw;
    padding-bottom: 140px;
    font-size: 22px;
    line-height: 30px;
  }

  .texte-notre-symbole {
    font-size: 18px;
    line-height: 20px;
  }

  .collection-carte-avec-badge.ressources, .collection-carte-avec-badge.on-parle-de-nous {
    margin-bottom: 0;
  }

  .collection-carte-avec-badge.articles-accueil {
    margin-bottom: 0;
  }

  .grande-carte-avec-badge-et-bouton {
    width: 360px;
    height: 350px;
    margin-left: 0;
    margin-right: 0;
    padding: 20px 25px;
    overflow: hidden;
  }

  .bas-de-carte {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .contenant-textes {
    width: 100%;
  }

  .texte-principal {
    font-size: 30px;
    line-height: 35px;
  }

  .grande-carte-titre {
    font-size: 18px;
    line-height: 21.6px;
  }

  .contenant-bouton {
    margin-left: 0;
    margin-right: 0;
  }

  .sous-titre-nos-groupes {
    font-size: 18px;
    line-height: 21px;
  }

  .citation {
    font-size: 18px;
    line-height: 21.6px;
  }

  .citation-auteur {
    font-size: 16px;
    line-height: 19px;
  }

  .image-citation {
    width: 75px;
  }

  .lien-voir-la-carte {
    display: none;
  }

  .etapes-rejoindre-un-groupe {
    grid-column-gap: 50px;
    grid-row-gap: 50px;
    padding-top: 40px;
  }

  .contenant-etape {
    width: 350px;
    height: 275px;
  }

  .contenant-etape.intro-etapes {
    transform: none;
  }

  .contenant-etape.intro-etapes.temporaire {
    display: none;
  }

  .contenant-etape.carte-de-dessous {
    height: auto;
  }

  .contenant-etape.carte-de-dessous._20degres {
    transform: none;
  }

  .contenant-etape.carte-de-dessous._20degres.etape-1 {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    transform: none;
  }

  .contenant-etape.carte-de-dessous._20degres.etape-1.temporaire {
    display: none;
  }

  .contenant-etape.carte-de-dessous._20degres.etape2 {
    transform: none;
  }

  .contenant-etape.carte-de-dessous._20degres.etape2.temporaire, .contenant-etape.carte-de-dessous._20degres.etape-0 {
    display: none;
  }

  .contenant-etape.carte-de-dessous._25degres {
    display: none;
    transform: none;
  }

  .contenant-etape.carte-de-dessous._25degres.etape1, .contenant-etape.carte-de-dessous._25degres.etape2 {
    display: none;
  }

  .contenant-etape.carte-de-dessous._30degres {
    display: none;
    transform: none;
  }

  .contenant-etape.carte-de-dessous._30degres.etape1 {
    display: none;
  }

  .titre-etape {
    margin-top: 0;
    margin-bottom: 0;
    font-size: 18px;
    line-height: 21px;
  }

  .texte-etape {
    font-size: 16px;
    line-height: 19px;
  }

  .coeur-etape {
    width: 50px;
    position: relative;
  }

  .nombre-etape {
    font-size: 21px;
    top: 15%;
  }

  .bas-carte-avec-badge-et-bouton {
    justify-content: flex-end;
    align-items: flex-start;
    max-height: 80%;
  }

  .contenant-portrait {
    justify-content: flex-start;
    align-items: stretch;
  }

  .contenant-portrait.scientifiques {
    max-width: 100%;
    max-height: 150vh;
  }

  .photo-portrait.scientifiques {
    max-height: 300px;
  }

  .contenu-portrait.scientifiques {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    overflow: hidden;
  }

  .texte-portrait {
    margin-bottom: 40px;
    padding-bottom: 40px;
  }

  .texte-portrait.scientifiques {
    font-size: 1rem;
  }

  .contenant-onglet-demande {
    padding-top: 0;
  }

  .image-onglet-demande {
    width: 100vw;
    max-width: none;
    height: 125px;
  }

  .titre-onglet-demande {
    margin-top: 0;
  }

  .splide.splide-porte-voix {
    padding-left: 0;
    padding-right: 0;
  }

  .splide__slide.commentaire {
    height: auto;
  }

  .splide__slide.gallerie-photos {
    padding: 0 0 1.5rem;
  }

  .carte-conseil-nom {
    font-size: 25px;
    line-height: 30px;
  }

  .carte-conseil-texte {
    font-size: 16px;
    line-height: 21.6px;
  }

  .splide-extras {
    padding-left: 20px;
    padding-right: 20px;
  }

  .groupe-en-tete {
    padding: 15px;
  }

  .groupe-titre {
    font-size: 25px;
    line-height: 35px;
  }

  .groupe-description, .groupe-info-geo, .groupe-contact {
    padding: 15px;
  }

  .collection-portraits-de-groupe {
    width: 100%;
  }

  .collection-petite-carte-portrait {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .contenant-liste-villes {
    width: 100%;
    max-width: 100vw;
    inset: auto 0% 50px;
  }

  .contenant-liste-villes.cdg {
    max-width: none;
    bottom: 0;
  }

  .en-tete-liste-villes {
    padding: 10px;
  }

  .en-tete {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-flow: column;
    margin-top: 40px;
    margin-bottom: 20px;
  }

  .offre-emploi-titre-en-tete {
    text-align: center;
    font-size: 28px;
    line-height: 30px;
  }

  .offre-emploi-contenant-presentation {
    padding: 10px;
  }

  .offre-emploi-presentation-texte {
    font-size: 16px;
    line-height: 21px;
  }

  .offre-emploi-infos {
    width: 100%;
  }

  .offre-emploi-titre-emploi {
    font-size: 28px;
    line-height: 30px;
  }

  .offre-emploi-liste-infos {
    width: 100%;
    padding-left: 0;
  }

  .ce-que-nous-offrons-titre {
    font-size: 25px;
    line-height: 30px;
  }

  .signe-plus-ou-moins {
    font-size: 50px;
  }

  .offre-emploi-textes-riches {
    line-height: 25px;
  }

  .tabs-menu {
    flex-flow: column;
  }

  .contenant-balado {
    width: 100%;
    max-width: 85vw;
  }

  .icone-lecture {
    padding: 15px;
  }

  .contenant-page-action {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
  }

  .action-en-tete, .action-description {
    padding: 15px;
  }

  .action-titre {
    font-size: 25px;
  }

  .action-info {
    justify-content: flex-start;
    align-items: center;
    margin-top: .5rem;
    margin-bottom: .5rem;
    padding: 10px 30px;
  }

  .section-informations-pratiques {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .titre-informations-pratiques {
    font-size: 28px;
    line-height: 30px;
  }

  .formulaire-label {
    text-align: center;
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .formulaire-input, .formulaire-input::placeholder {
    font-size: 1rem;
  }

  .bouton-de-soumission {
    width: 150px;
    padding-left: 40px;
    padding-right: 40px;
    line-height: 30px;
  }

  .contenant-success-message {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
  }

  .lien-nous-contacter {
    font-size: 1.5rem;
  }

  .page-inondez-vos-elus {
    margin-left: auto;
    margin-right: auto;
    padding-left: 0;
    padding-right: 0;
  }

  .cercle-animation-accueil {
    width: 475px;
    height: 475px;
    top: 45%;
  }

  .cercle-animation-accueil:hover {
    width: 500px;
    height: 500px;
  }

  .section-animation {
    overflow: hidden;
  }

  .texte-animation-accueil {
    max-width: 90vw;
    font-size: 35px;
    line-height: 45px;
    top: 45%;
  }

  .coeurs-animation-accueil {
    max-width: 80vw;
    top: 0%;
  }

  .textes-polygone-vert {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    font-size: 10px;
    line-height: 14px;
  }

  .titre-polygone-vert {
    font-size: 12px;
    line-height: 14px;
  }

  .textes-carte-rejoindre-un-groupe {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .collection-list-wrapper-2, .collection-list-on-a-besoin-de-vous {
    width: 100%;
  }

  .collection-item-portraits {
    padding-left: 0;
    padding-right: 0;
  }

  .coeur-notre-symbole {
    max-width: 80vw;
  }

  .contenant-images-animation {
    height: 50vh;
  }

  .collection-grande-carte-avec-badge {
    border-radius: 5px;
  }

  .rester-informe {
    font-size: 22px;
    line-height: 30px;
  }

  .contenant-commentaire {
    background-color: var(--vert-principale);
    background-image: none;
    border-radius: 5px;
    width: 90vw;
    min-width: 0;
    max-width: 90vw;
    min-height: 0;
    margin-left: 10px;
    margin-right: 10px;
    padding-top: 30px;
    padding-bottom: 40px;
  }

  .coeur-commentaire {
    bottom: -25%;
  }

  .action-passe-description {
    font-size: 16px;
    line-height: 21px;
  }

  .action-passee-infos-details {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .action-passee-detail {
    font-size: 14px;
  }

  .carte-chiffre-action-passee {
    height: auto;
    min-height: 350px;
    overflow: auto;
  }

  .chiffre {
    line-height: 1;
  }

  .carte-chiffre-texte {
    font-size: 18px;
    line-height: 21px;
  }

  .bouton-vert-album-photo {
    z-index: 10;
    max-width: 90vw;
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 16px;
    font-size: 16px;
    line-height: 20px;
    overflow: hidden;
  }

  .texte-grande-carte-long-texte {
    font-size: 14px;
    line-height: 19px;
  }

  .contenant-retour-en-image {
    height: 350px;
  }

  .etes-vous-pret {
    font-size: 18px;
  }

  .section-inondez-vos-elus {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    justify-content: center;
    align-items: center;
    margin-top: 20px;
  }

  .cercle-animation-inondez {
    width: 500px;
    height: 500px;
    top: 0%;
  }

  .cercle-animation-inondez:hover {
    width: 500px;
    height: 500px;
  }

  .element-inondez-vos-elus {
    font-size: 16px;
    line-height: 21px;
  }

  .numero-etape {
    font-size: 50px;
    line-height: 60px;
  }

  .lien.cdg.long {
    font-size: 14px;
  }

  .derniere-etape-inondez {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    justify-content: center;
    align-items: center;
    max-height: 350px;
    margin-top: 100px;
  }

  .citation-inondez {
    font-size: 18px;
    line-height: 22px;
  }

  .auteur-citation-inondez {
    font-size: 16px;
  }

  .photo-margaret-mead {
    width: 60px;
    height: 60px;
  }

  .progress-bar-inondez {
    width: 80%;
    margin-top: 0;
  }

  .polygone-vert-texte {
    margin-bottom: 0;
    font-family: "PP Neue Montreal 300-400", sans-serif;
    line-height: 19px;
  }

  .icone-effacer {
    width: 18px;
    height: 18px;
  }

  .logo-en-tete-projet {
    width: 100px;
    margin-top: 20px;
    display: none;
  }

  .en-tete-projet {
    flex-flow: column-reverse;
  }

  .contenant-polygones {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .contenant-bloc-de-texte.chaises-des-generations {
    margin-bottom: 0;
  }

  .texte-presentation-scientifiques {
    margin-bottom: 0;
    padding-bottom: 0;
  }

  .contenant-logo-cdg {
    max-width: 95vw;
    margin-top: 60px;
  }

  .en-tete-cdg {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-top: 0;
    margin-bottom: 0;
  }

  .contenant-cartes-moyennes-cdg {
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .grande-carte-photo {
    width: 360px;
    height: 350px;
    margin-left: 0;
    margin-right: 0;
    padding: 20px 25px;
    overflow: hidden;
  }

  .carte-de-presentation {
    height: 350px;
    padding: 20px;
  }

  .carte-de-presentation.page-acceuil {
    max-width: 100%;
  }

  .texte-carte-projet {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .bouton-animation-accueil {
    z-index: 4;
    max-width: 90vw;
    font-size: 16px;
    line-height: 20px;
    overflow: hidden;
  }

  .carte-de-presentation-copy {
    height: 350px;
    padding: 20px;
  }

  .en-tete-principale {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .description-detaillee {
    width: 100%;
  }

  .image-mosaic {
    object-fit: cover;
  }

  .image-mosaic.margin-left {
    margin-left: 50%;
  }

  .image-mosaic.margin-right {
    margin-left: -50%;
  }

  .en-tete-titre-vert {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .en-tete-titre-vert.nos-groupes {
    justify-content: space-between;
    margin-top: 0;
  }

  .contenant-mos-img-1 {
    height: 150px;
  }

  .contenant-mos-img-2 {
    height: 160px;
  }

  .contenant-mos-img-3 {
    height: 155px;
  }

  .contenant-mos-img-4 {
    height: 140px;
  }

  .contenant-mos-img-5 {
    height: 150px;
  }

  .contenant-mos-img-6 {
    height: 145px;
  }

  .logo-porte-voix {
    width: 75%;
  }

  .texte-blogue {
    font-size: 16px;
    line-height: 1.4;
  }

  .image-blogue {
    width: 100%;
    height: 200px;
    margin-bottom: 10px;
  }

  .auteure-blogue {
    max-width: 90vw;
    font-size: 14px;
    line-height: 21.35px;
  }

  .auteure-blogue.centre {
    line-height: 20px;
  }

  .contenant-livres {
    grid-column-gap: 1rem;
    grid-row-gap: 2rem;
    flex-flow: wrap;
  }

  .titre-livre {
    text-align: center;
    display: none;
  }

  .hero-campagne {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .hero-campagne.sombre.notre-histoire {
    width: 100vw;
    max-width: none;
    padding-left: 20px;
    padding-right: 20px;
  }

  .hero-campagne.sombre.avec-margin {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .hero-campagne.portrait, .hero-campagne.page-groupe, .hero-campagne.page-action {
    margin-top: 20px;
  }

  .hero-campagne.section-polygones-acceuil {
    margin-bottom: 20px;
    padding-top: 0;
  }

  .hero-campagne.inondez-vos-elus {
    margin-top: 60px;
  }

  .hero-campagne.commentaires {
    width: 90vw;
  }

  .hero-campagne.margin-top {
    margin-top: 40px;
  }

  .hero-campagne.margin-top-60 {
    margin-top: 60px;
  }

  .contenant-video-arriere-plan.notre-histoire {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
  }

  .contenant-hero-cdg-jappuie {
    flex-flow: column;
  }

  .campagne-cdg-hero-titre {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    width: 100%;
  }

  .campagne-cdg-hero-visuel {
    width: 100%;
    display: block;
  }

  .campagne-cdg-hero-visuel.mobile {
    max-width: 95vw;
    padding-top: 2rem;
    padding-bottom: 2rem;
    display: flex;
  }

  .contenant-image-hero-campagne-cdg.sombre {
    background-color: var(--noir);
    color: var(--blanc);
    padding: 1rem;
  }

  .credit-image-campagne-cdg.mobile {
    color: var(--blanc);
    text-shadow: none;
  }

  .contenant-cta-mobile {
    display: block;
  }

  .section-pleine-largeur {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-pleine-largeur.sombre.notre-histoire {
    width: 100vw;
    max-width: none;
    padding-left: 20px;
    padding-right: 20px;
  }

  .section-pleine-largeur.sombre.avec-margin {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .section-pleine-largeur.portrait, .section-pleine-largeur.page-groupe, .section-pleine-largeur.page-action {
    margin-top: 20px;
  }

  .section-pleine-largeur.section-polygones-acceuil {
    margin-bottom: 20px;
    padding-top: 0;
  }

  .section-pleine-largeur.inondez-vos-elus {
    margin-top: 60px;
  }

  .section-pleine-largeur.commentaires {
    width: 90vw;
  }

  .section-pleine-largeur.margin-top {
    margin-top: 40px;
  }

  .section-pleine-largeur.margin-top-60 {
    margin-top: 60px;
  }

  .section-pleine-largeur.video-campagne-cdg {
    margin-bottom: 40px;
  }

  .contenant-principale.gauche.stretch.gap-1 {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .carte-blogue-image {
    height: 120px;
  }

  .carte-blogue-contenu {
    margin-bottom: 0;
  }

  .carte-blogue-titre {
    font-size: 1.5rem;
  }

  .coeur-remerciements-bdf {
    opacity: .3;
  }

  .img-remerciement-bdf {
    max-width: 90vw;
  }

  .contenant-description-et-logo {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    justify-content: flex-start;
    align-items: center;
    display: flex;
  }

  .logo-en-tete-projet-mobile {
    width: 100px;
    height: auto;
    margin-top: 0;
    display: block;
  }

  .contenant-filtres-cpv {
    grid-column-gap: .75rem;
    grid-row-gap: .75rem;
  }

  .contenant-filtres-cpv.capsule {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .collection-capsules-video {
    justify-content: center;
    align-items: flex-start;
  }

  .collection-capsules-video.ressources, .collection-capsules-video.on-parle-de-nous {
    margin-bottom: 0;
  }

  .collection-capsules-video.articles-accueil {
    margin-bottom: 0;
  }

  .details-cpv {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .h1-page-cpv {
    font-size: 1.55rem;
  }

  .icone-partage {
    width: 30px;
  }

  .description-cpv {
    font-size: 1rem;
  }

  .collection-list-wrapper-capsules {
    margin-left: auto;
    margin-right: auto;
  }

  .image-fond-cpv {
    right: 10px;
  }
}

#w-node-_139fbf47-7465-9634-6af5-40aaf61d33c6-5f55804c {
  grid-area: 1 / 1 / 3 / 2;
}

#w-node-_3c533d6c-48b4-d34d-6ade-3fdf00e4d0e0-5f55804c {
  grid-area: 1 / 2 / 2 / 5;
}

#w-node-fcbb1de5-d6a8-f831-def2-d664326d7ed6-5f55804c {
  grid-area: 1 / 5 / 3 / 6;
}

#w-node-_274f77e2-fa6e-6a87-43fc-d3e999970af9-5f55804c {
  grid-area: 2 / 2 / 3 / 3;
}

#w-node-_3d3f6f62-6872-3c7c-d297-632eedab9a44-5f55804c {
  grid-area: span 2 / span 1 / span 2 / span 1;
}

#w-node-_3aa090fd-f6e5-04af-08c7-90f251b7d3e3-5f55804c {
  grid-area: 3 / 1 / 4 / 2;
}

#w-node-be351207-c07f-67f4-dbdc-3affe155ac70-5f55804c {
  grid-area: 2 / 4 / 3 / 5;
}

#w-node-beea726c-25ff-ad84-b2d0-305954c82ff2-5f55804c {
  grid-area: 3 / 2 / 5 / 3;
}

#w-node-_0d306944-5d5d-2fc8-ecb8-315933a3fb37-5f55804c {
  grid-area: 3 / 4 / 5 / 5;
}

#w-node-_0ebc621f-284d-c5ca-cf4f-43639d92effc-5f55804c {
  grid-area: 3 / 5 / 4 / 6;
}

#w-node-cd08831a-9dfa-6847-3425-79fbc09a774e-8eaa9cb3 {
  grid-area: 1 / 1 / 2 / 3;
}

#w-node-_0f9ba429-466b-7486-68ef-6fd5c737fb41-8eaa9cb3 {
  grid-area: 2 / 1 / 3 / 3;
}

#w-node-_8c00e5b8-d817-f52c-2365-7abd94a72ff3-8eaa9cb3 {
  grid-area: 3 / 1 / 7 / 2;
}

#w-node-_941f3c2f-0896-6034-7109-a8f16c9d2409-8eaa9cb3 {
  grid-area: 3 / 2 / 4 / 3;
}

#w-node-_3a2e7093-4026-b128-07ec-c619a9d9146f-8eaa9cb3 {
  grid-area: 4 / 2 / 5 / 3;
}

#w-node-_10d9d8d0-2c41-8ffd-3312-9a26965730f2-8eaa9cb3 {
  grid-area: 5 / 2 / 6 / 3;
}

#w-node-d7b2e0db-8b62-aeca-52fd-646243481915-8eaa9cb3 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_5449d48d-2777-6507-b368-7d9ae4a48c1f-106ca6c5 {
  grid-area: 1 / 1 / 2 / 3;
}

#w-node-d2ab3cc3-fe8a-73ae-1fa8-448a62668862-106ca6c5 {
  grid-area: 2 / 1 / 5 / 2;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b95b-9d54b958 {
  grid-area: 1 / 1 / 2 / 2;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b95d-9d54b958 {
  grid-area: 1 / 2 / 2 / 3;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b95f-9d54b958 {
  grid-area: 1 / 3 / 2 / 4;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b962-9d54b958 {
  grid-area: 2 / 1 / 3 / 2;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b964-9d54b958 {
  grid-area: 2 / 2 / 3 / 3;
}

#w-node-_0b3ed226-b884-5e15-e578-40c49d54b966-9d54b958 {
  grid-area: 2 / 3 / 3 / 4;
}

@media screen and (max-width: 991px) {
  #w-node-_139fbf47-7465-9634-6af5-40aaf61d33c6-5f55804c {
    grid-area: 1 / 1 / 2 / 2;
  }

  #w-node-_3c533d6c-48b4-d34d-6ade-3fdf00e4d0e0-5f55804c {
    grid-area: 1 / 2 / 2 / 5;
  }

  #w-node-fcbb1de5-d6a8-f831-def2-d664326d7ed6-5f55804c {
    grid-area: 1 / 5 / 2 / 6;
  }

  #w-node-_274f77e2-fa6e-6a87-43fc-d3e999970af9-5f55804c {
    grid-area: 2 / 2 / 3 / 3;
  }

  #w-node-_3d3f6f62-6872-3c7c-d297-632eedab9a44-5f55804c {
    grid-area: 2 / 3 / 4 / 4;
  }

  #w-node-_3aa090fd-f6e5-04af-08c7-90f251b7d3e3-5f55804c {
    grid-area: 2 / 1 / 4 / 2;
  }

  #w-node-be351207-c07f-67f4-dbdc-3affe155ac70-5f55804c {
    grid-area: 2 / 4 / 3 / 5;
  }

  #w-node-beea726c-25ff-ad84-b2d0-305954c82ff2-5f55804c {
    grid-area: 3 / 2 / 4 / 3;
  }

  #w-node-_0d306944-5d5d-2fc8-ecb8-315933a3fb37-5f55804c {
    grid-area: 3 / 4 / 4 / 5;
  }

  #w-node-_0ebc621f-284d-c5ca-cf4f-43639d92effc-5f55804c {
    grid-area: 2 / 5 / 4 / 6;
  }
}

@media screen and (max-width: 767px) {
  #w-node-_3d3f6f62-6872-3c7c-d297-632eedab9a44-5f55804c {
    grid-row-end: 5;
  }
}

@media screen and (max-width: 479px) {
  #w-node-_139fbf47-7465-9634-6af5-40aaf61d33c6-5f55804c {
    grid-row: 3 / 5;
  }

  #w-node-_3c533d6c-48b4-d34d-6ade-3fdf00e4d0e0-5f55804c {
    grid-column: 1 / 6;
    grid-row-end: 3;
  }

  #w-node-fcbb1de5-d6a8-f831-def2-d664326d7ed6-5f55804c {
    grid-row: 3 / 5;
  }

  #w-node-_274f77e2-fa6e-6a87-43fc-d3e999970af9-5f55804c {
    grid-area: 3 / 3 / 4 / 4;
  }

  #w-node-_3d3f6f62-6872-3c7c-d297-632eedab9a44-5f55804c {
    grid-row: 4 / 5;
  }

  #w-node-_3aa090fd-f6e5-04af-08c7-90f251b7d3e3-5f55804c {
    grid-area: 5 / 1 / 6 / 2;
  }

  #w-node-be351207-c07f-67f4-dbdc-3affe155ac70-5f55804c {
    grid-area: 5 / 3 / 6 / 4;
  }

  #w-node-beea726c-25ff-ad84-b2d0-305954c82ff2-5f55804c {
    grid-row: 3 / 5;
  }

  #w-node-_0d306944-5d5d-2fc8-ecb8-315933a3fb37-5f55804c {
    grid-row-end: 5;
  }

  #w-node-_0ebc621f-284d-c5ca-cf4f-43639d92effc-5f55804c {
    grid-area: 5 / 5 / 6 / 6;
  }
}
