@charset "UTF-8";
/* --------------------------------------------------------------  
/* # Base
/* -------------------------------------------------------------- */
form > div,
form > p,
form > section {
  margin-bottom: 1em;
}
form label {
  display: block;
}

input[type=text],
input[type=url],
input[type=tel],
input[type=number],
input[type=password],
input[type=color],
input[type=search],
input[type=email],
textarea {
  display: block;
  padding: 0.5em;
}

/* Links */
p a,
li a,
caption a,
cite a,
dt a {
  color: #de4e1e;
}
p a:hover, p a:focus, p a:active,
li a:hover,
li a:focus,
li a:active,
caption a:hover,
caption a:focus,
caption a:active,
cite a:hover,
cite a:focus,
cite a:active,
dt a:hover,
dt a:focus,
dt a:active {
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  color: #e9825f;
}
p a:focus,
li a:focus,
caption a:focus,
cite a:focus,
dt a:focus {
  outline: thin dotted;
}
p a:hover, p a:active,
li a:hover,
li a:active,
caption a:hover,
caption a:active,
cite a:hover,
cite a:active,
dt a:hover,
dt a:active {
  outline: 0;
}

/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
/* Document
   ========================================================================== */
html {
  font-family: sans-serif; /* 1 */
  line-height: 1.15; /* 2 */
  -ms-text-size-adjust: 100%; /* 3 */
  -webkit-text-size-adjust: 100%; /* 3 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0;
}

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */
template {
  display: none;
}

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}

/*
!Reset
 Built from rocssti | https://rocssti.net
=================== */
html {
  box-sizing: border-box;
}

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

html, body,
blockquote, ul,
ol, form, button {
  margin: 0;
  padding: 0;
}

ul, ol {
  padding-left: 2em;
}

img,
iframe {
  vertical-align: middle;
}

img,
table,
td,
blockquote,
code,
pre,
textarea,
input,
svg {
  height: auto;
  max-width: 100%;
}

@viewport {
  width: device-width;
}
/* !Table */
table {
  border-collapse: collapse;
  width: 100%;
}
table caption {
  font-size: em(24);
  padding: 0.3333333333rem 0 0.3333333333rem 0.6666666667rem;
  text-align: left;
}
table tr:hover {
  background: #f4f4f4;
}
table th {
  font-weight: bold;
}
table th,
table td {
  padding: 0.5em 1em;
  text-align: left;
}

tbody tr:not(:first-child) {
  border-top: 1px solid #e1e1e1;
}

h1, h2, h3, h4, h5, h6,
p, li, q, dl, blockquote {
  hyphens: none;
  word-break: normal;
}

/* Inline tags */
abbr[title] {
  border-bottom: dotted 1px;
  text-decoration: none;
  cursor: help;
}

q {
  quotes: "“" "”" "‘" "‘";
}

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

sup, .sup {
  top: -0.5em;
}

sub, .sub {
  bottom: -0.25em;
}

p {
  margin: 0;
}

p + p {
  margin-top: 1em;
}

strong {
  font-weight: 600;
}

/*
* repris de http://tinytypo.tetue.net/ de @tetue
* tuné avec l’aide de http://www.nicolas-hoffmann.net/utilitaires/codes-hexas-ascii-unicode-utf8-caracteres-usuels.php
*
* voir https://en.wikipedia.org/wiki/Quotation_mark#Summary_table pour les références
*/
q {
  quotes: "“" "”" "‘" "’";
}

:lang(fr) > q {
  quotes: "« " " »" "“" "”" "‘" "’";
}

:lang(en) > q {
  quotes: "“" "”" "‘" "’";
}

:lang(es) > q {
  quotes: "«" "»" "“" "”";
}

:lang(it) > q {
  quotes: "« " " »" "“" "”";
}

:lang(de) > q {
  quotes: "„" "“" "‚" "‘";
}

q:before {
  content: open-quote;
}

q:after {
  content: close-quote;
}

/* => Title */
h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4,
h5, .h6 {
  color: #000;
  font-family: "Oswald", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  font-weight: 600;
  line-height: 1.2;
}
h1 strong, .h1 strong,
h2 strong, .h2 strong,
h3 strong, .h3 strong,
h4 strong, .h4 strong,
h5 strong, .h6 strong {
  color: #000;
}

h1, .h1 {
  font-size: 38px;
  font-size: 2.375rem;
}

h2, .h2 {
  font-size: 32px;
  font-size: 2rem;
}

h3, .h3 {
  font-size: 28px;
  font-size: 1.75rem;
}

h4, .h4 {
  font-size: 22px;
  font-size: 1.375rem;
}

h5, .h5 {
  font-size: 20px;
  font-size: 1.25rem;
}

h6, .h6 {
  font-size: 16px;
  font-size: 1rem;
}

.twentytwenty-horizontal .twentytwenty-handle:before, .twentytwenty-horizontal .twentytwenty-handle:after, .twentytwenty-vertical .twentytwenty-handle:before, .twentytwenty-vertical .twentytwenty-handle:after {
  content: " ";
  display: block;
  background: white;
  position: absolute;
  z-index: 30;
  box-shadow: 0px 0px 12px rgba(51, 51, 51, 0.5);
}

.twentytwenty-horizontal .twentytwenty-handle:before, .twentytwenty-horizontal .twentytwenty-handle:after {
  width: 3px;
  height: 9999px;
  left: 50%;
  margin-left: -1.5px;
}

.twentytwenty-vertical .twentytwenty-handle:before, .twentytwenty-vertical .twentytwenty-handle:after {
  width: 9999px;
  height: 3px;
  top: 50%;
  margin-top: -1.5px;
}

.twentytwenty-before-label, .twentytwenty-after-label, .twentytwenty-overlay {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}

.twentytwenty-before-label, .twentytwenty-after-label, .twentytwenty-overlay {
  transition-duration: 0.5s;
}

.twentytwenty-before-label, .twentytwenty-after-label {
  transition-property: opacity;
}

.twentytwenty-before-label:before, .twentytwenty-after-label:before {
  color: white;
  font-size: 13px;
  letter-spacing: 0.1em;
}

.twentytwenty-before-label:before, .twentytwenty-after-label:before {
  position: absolute;
  background: rgba(255, 255, 255, 0.2);
  line-height: 38px;
  padding: 0 20px;
  border-radius: 2px;
}

.twentytwenty-horizontal .twentytwenty-before-label:before, .twentytwenty-horizontal .twentytwenty-after-label:before {
  top: 50%;
  margin-top: -19px;
}

.twentytwenty-vertical .twentytwenty-before-label:before, .twentytwenty-vertical .twentytwenty-after-label:before {
  left: 50%;
  margin-left: -45px;
  text-align: center;
  width: 90px;
}

.twentytwenty-left-arrow, .twentytwenty-right-arrow, .twentytwenty-up-arrow, .twentytwenty-down-arrow {
  width: 0;
  height: 0;
  border: 6px inset transparent;
  position: absolute;
}

.twentytwenty-left-arrow, .twentytwenty-right-arrow {
  top: 50%;
  margin-top: -6px;
}

.twentytwenty-up-arrow, .twentytwenty-down-arrow {
  left: 50%;
  margin-left: -6px;
}

.twentytwenty-container {
  box-sizing: content-box;
  z-index: 0;
  overflow: hidden;
  position: relative;
  -webkit-user-select: none;
  -moz-user-select: none;
}

.twentytwenty-container img {
  max-width: 100%;
  position: absolute;
  top: 0;
  display: block;
}

.twentytwenty-container.active .twentytwenty-overlay, .twentytwenty-container.active :hover.twentytwenty-overlay {
  background: rgba(0, 0, 0, 0);
}

.twentytwenty-container.active .twentytwenty-overlay .twentytwenty-before-label,
.twentytwenty-container.active .twentytwenty-overlay .twentytwenty-after-label, .twentytwenty-container.active :hover.twentytwenty-overlay .twentytwenty-before-label,
.twentytwenty-container.active :hover.twentytwenty-overlay .twentytwenty-after-label {
  opacity: 0;
}

.twentytwenty-container * {
  box-sizing: content-box;
}

.twentytwenty-before-label {
  opacity: 0;
}

.twentytwenty-before-label:before {
  content: attr(data-content);
}

.twentytwenty-after-label {
  opacity: 0;
}

.twentytwenty-after-label:before {
  content: attr(data-content);
}

.twentytwenty-horizontal .twentytwenty-before-label:before {
  left: 10px;
}

.twentytwenty-horizontal .twentytwenty-after-label:before {
  right: 10px;
}

.twentytwenty-vertical .twentytwenty-before-label:before {
  top: 10px;
}

.twentytwenty-vertical .twentytwenty-after-label:before {
  bottom: 10px;
}

.twentytwenty-overlay {
  transition-property: background;
  background: rgba(0, 0, 0, 0);
  z-index: 25;
}

.twentytwenty-overlay:hover {
  background: rgba(0, 0, 0, 0.5);
}

.twentytwenty-overlay:hover .twentytwenty-after-label {
  opacity: 1;
}

.twentytwenty-overlay:hover .twentytwenty-before-label {
  opacity: 1;
}

.twentytwenty-before {
  z-index: 20;
}

.twentytwenty-after {
  z-index: 10;
}

.twentytwenty-handle {
  height: 38px;
  width: 38px;
  background: #de4e1e;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -22px;
  margin-top: -22px;
  border: 3px solid white;
  border-radius: 1000px;
  box-shadow: 0px 0px 12px rgba(51, 51, 51, 0.5);
  z-index: 40;
  cursor: pointer;
}

.twentytwenty-horizontal .twentytwenty-handle:before {
  bottom: 50%;
  margin-bottom: 22px;
  box-shadow: 0 3px 0 white, 0px 0px 12px rgba(51, 51, 51, 0.5);
}

.twentytwenty-horizontal .twentytwenty-handle:after {
  top: 50%;
  margin-top: 22px;
  box-shadow: 0 -3px 0 white, 0px 0px 12px rgba(51, 51, 51, 0.5);
}

.twentytwenty-vertical .twentytwenty-handle:before {
  left: 50%;
  margin-left: 22px;
  box-shadow: 3px 0 0 white, 0px 0px 12px rgba(51, 51, 51, 0.5);
}

.twentytwenty-vertical .twentytwenty-handle:after {
  right: 50%;
  margin-right: 22px;
  box-shadow: -3px 0 0 white, 0px 0px 12px rgba(51, 51, 51, 0.5);
}

.twentytwenty-left-arrow {
  border-right: 6px solid white;
  left: 50%;
  margin-left: -17px;
}

.twentytwenty-right-arrow {
  border-left: 6px solid white;
  right: 50%;
  margin-right: -17px;
}

.twentytwenty-up-arrow {
  border-bottom: 6px solid white;
  top: 50%;
  margin-top: -17px;
}

.twentytwenty-down-arrow {
  border-top: 6px solid white;
  bottom: 50%;
  margin-bottom: -17px;
}

/*!
 * baguetteBox.js
 * @author  feimosi
 * @version 1.9.1
 * @url https://github.com/feimosi/baguetteBox.js
 */
#baguetteBox-overlay {
  display: none;
  opacity: 0;
  position: fixed;
  overflow: hidden;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000000;
  background-color: #222;
  background-color: rgba(0, 0, 0, 0.8);
  transition: opacity 0.5s ease;
}

#baguetteBox-overlay.visible {
  opacity: 1;
}

#baguetteBox-overlay .full-image {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 100%;
  text-align: center;
}

#baguetteBox-overlay .full-image figure {
  display: inline;
  margin: 0;
  height: 100%;
}

#baguetteBox-overlay .full-image img {
  display: inline-block;
  width: auto;
  height: auto;
  max-height: 100%;
  max-width: 100%;
  vertical-align: middle;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

#baguetteBox-overlay .full-image figcaption {
  display: block;
  position: absolute;
  bottom: 0;
  width: 100%;
  text-align: center;
  line-height: 1.8;
  white-space: normal;
  color: #ccc;
  background-color: #000;
  background-color: rgba(0, 0, 0, 0.6);
  font-family: sans-serif;
}

#baguetteBox-overlay .full-image:before {
  content: "";
  display: inline-block;
  height: 50%;
  width: 1px;
  margin-right: -1px;
}

#baguetteBox-slider {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  white-space: nowrap;
  transition: left 0.4s ease, transform 0.4s ease;
}

#baguetteBox-slider.bounce-from-right {
  animation: bounceFromRight 0.4s ease-out;
}

#baguetteBox-slider.bounce-from-left {
  animation: bounceFromLeft 0.4s ease-out;
}
@keyframes bounceFromRight {
  0% {
    margin-left: 0;
  }
  50% {
    margin-left: -30px;
  }
  100% {
    margin-left: 0;
  }
}
@keyframes bounceFromLeft {
  0% {
    margin-left: 0;
  }
  50% {
    margin-left: 30px;
  }
  100% {
    margin-left: 0;
  }
}
.baguetteBox-button#next-button, .baguetteBox-button#previous-button {
  top: 50%;
  top: calc(50% - 30px);
  width: 44px;
  height: 60px;
}

.baguetteBox-button {
  position: absolute !important;
  cursor: pointer;
  outline: none;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 15%;
  background-color: #323232;
  background-color: rgba(50, 50, 50, 0.5);
  color: #ddd;
  font: 1.6em sans-serif;
  transition: background-color 0.4s ease;
}

.baguetteBox-button:focus, .baguetteBox-button:hover {
  background-color: rgba(50, 50, 50, 0.9);
}

.baguetteBox-button#next-button {
  right: 2%;
}

.baguetteBox-button#previous-button {
  left: 2%;
}

.baguetteBox-button#close-button {
  top: 20px;
  right: 2%;
  right: calc(2% + 6px);
  width: 30px;
  height: 30px;
}

.baguetteBox-button svg {
  position: absolute;
  left: 0;
  top: 0;
}

/*
    Preloader
    Borrowed from http://tobiasahlin.com/spinkit/
*/
.baguetteBox-spinner {
  width: 40px;
  height: 40px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -20px;
  margin-left: -20px;
}

.baguetteBox-double-bounce1,
.baguetteBox-double-bounce2 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #fff;
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;
  animation: bounce 2s infinite ease-in-out;
}

.baguetteBox-double-bounce2 {
  animation-delay: -1s;
}
@keyframes bounce {
  0%, 100% {
    transform: scale(0);
  }
  50% {
    transform: scale(1);
  }
}
/* --------------------------------------------------------------  
/* # Components
/* -------------------------------------------------------------- */
.alert-box {
  padding: 0.5em 1em;
  margin-top: 1em;
  margin-bottom: 1em;
}

.alert-warning {
  background: #f9edbe;
  color: #1c1703;
}

.alert-success {
  background: #259f6c;
  color: #fff;
}

.alert-error {
  background: #ff3232;
  color: #fff;
}

/*
 * Boutons
*/
/* Style de base */
button,
.button,
[class*=button] {
  background: transparent;
  border: 1px solid transparent;
  display: inline-block;
  line-height: 1.5;
  padding: 0.4375rem 1.875rem;
  position: relative;
  text-decoration: none;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}
button:hover, button:focus,
.button:hover,
.button:focus,
[class*=button]:hover,
[class*=button]:focus {
  cursor: pointer;
}

.cta {
  background: #de4e1e;
  color: #fff;
  box-shadow: inset 0 0 0 0 white, 0 0 0 4px #fff, 0 0 0 5px #de4e1e, 0 0 10px 5px rgba(0, 0, 0, 0);
}
.cta:hover, .cta:focus {
  color: #de4e1e;
  box-shadow: inset 0 0 0 40px white, 0 0 0 0 rgba(255, 255, 255, 0), 0 0 0 1px #de4e1e, 0 0 10px 2px rgba(0, 0, 0, 0.2);
}

/* Bouton avec un arrière plan de couleur */
.button-solid,
.button.button-solid.main-color {
  background: #de4e1e;
  color: white;
  box-shadow: 0 2px 10px 3px rgba(222, 78, 30, 0.5);
  border-radius: 0.25rem;
}
.button-solid:hover, .button-solid:focus,
.button.button-solid.main-color:hover,
.button.button-solid.main-color:focus {
  background: #e67049;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(222, 78, 30, 0.5);
}
.films-discretions .button-solid,
.films-discretions .button.button-solid.main-color {
  background: #899710;
  box-shadow: 0 2px 10px 3px rgba(137, 151, 16, 0.5);
}
.films-discretions .button-solid:hover, .films-discretions .button-solid:focus,
.films-discretions .button.button-solid.main-color:hover,
.films-discretions .button.button-solid.main-color:focus {
  background: #a2b313;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(137, 151, 16, 0.5);
}
.films-securitaires .button-solid,
.films-securitaires .button.button-solid.main-color {
  background: #265ba8;
  box-shadow: 0 2px 10px 3px rgba(38, 91, 168, 0.5);
}
.films-securitaires .button-solid:hover, .films-securitaires .button-solid:focus,
.films-securitaires .button.button-solid.main-color:hover,
.films-securitaires .button.button-solid.main-color:focus {
  background: #4a83d6;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(38, 91, 168, 0.5);
}
.films-decoratifs .button-solid,
.films-decoratifs .button.button-solid.main-color {
  background: #3f2041;
  box-shadow: 0 2px 10px 3px rgba(63, 32, 65, 0.5);
}
.films-decoratifs .button-solid:hover, .films-decoratifs .button-solid:focus,
.films-decoratifs .button.button-solid.main-color:hover,
.films-decoratifs .button.button-solid.main-color:focus {
  background: #67346a;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(63, 32, 65, 0.5);
}
.button-solid.main-color,
.button.button-solid.main-color.main-color {
  background: #de4e1e;
  color: white;
  box-shadow: 0 2px 10px 3px rgba(222, 78, 30, 0.5);
  border-radius: 0.25rem;
}
.button-solid.main-color:hover, .button-solid.main-color:focus,
.button.button-solid.main-color.main-color:hover,
.button.button-solid.main-color.main-color:focus {
  background: #e67049;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(222, 78, 30, 0.5);
}

/* Bouton avec juste une bordure de couleur */
.button-ghost,
.js-expandmore-button {
  border: 2px solid #de4e1e;
  color: #de4e1e;
  border-radius: 3px;
}
.button-ghost .icon,
.js-expandmore-button .icon {
  border-radius: 50%;
  box-shadow: inset 0 0 0 rgba(255, 255, 255, 0);
}
.button-ghost:hover, .button-ghost:focus,
.js-expandmore-button:hover,
.js-expandmore-button:focus {
  box-shadow: inset 0 0 0 5em #de4e1e;
  color: #fff;
}
.button-ghost:hover.is-opened .icon-add, .button-ghost:focus.is-opened .icon-add,
.js-expandmore-button:hover.is-opened .icon-add,
.js-expandmore-button:focus.is-opened .icon-add {
  transform: rotate(45deg);
}
.button-ghost:hover .icon, .button-ghost:focus .icon,
.js-expandmore-button:hover .icon,
.js-expandmore-button:focus .icon {
  transform: translateX(0.5em);
  color: #de4e1e;
  box-shadow: inset 0 0 0 2em white;
}
.button-ghost.is-opened .icon-add,
.js-expandmore-button.is-opened .icon-add {
  transform: rotate(45deg);
}
.button-ghost.is-opened .icon-add:hover, .button-ghost.is-opened .icon-add:focus,
.js-expandmore-button.is-opened .icon-add:hover,
.js-expandmore-button.is-opened .icon-add:focus {
  transform: rotate(45deg);
}
.films-discretions .button-ghost,
.films-discretions .js-expandmore-button {
  border: 2px solid #899710;
  color: #899710;
}
.films-discretions .button-ghost:hover, .films-discretions .button-ghost:focus,
.films-discretions .js-expandmore-button:hover,
.films-discretions .js-expandmore-button:focus {
  box-shadow: inset 0 0 0 5em #899710;
  color: #fff;
}
.films-discretions .button-ghost:hover .icon, .films-discretions .button-ghost:focus .icon,
.films-discretions .js-expandmore-button:hover .icon,
.films-discretions .js-expandmore-button:focus .icon {
  color: #899710;
}
.films-securitaires .button-ghost,
.films-securitaires .js-expandmore-button {
  border: 2px solid #265ba8;
  color: #265ba8;
}
.films-securitaires .button-ghost:hover, .films-securitaires .button-ghost:focus,
.films-securitaires .js-expandmore-button:hover,
.films-securitaires .js-expandmore-button:focus {
  box-shadow: inset 0 0 0 5em #265ba8;
  color: #fff;
}
.films-securitaires .button-ghost:hover .icon, .films-securitaires .button-ghost:focus .icon,
.films-securitaires .js-expandmore-button:hover .icon,
.films-securitaires .js-expandmore-button:focus .icon {
  color: #265ba8;
}
.films-decoratifs .button-ghost,
.films-decoratifs .js-expandmore-button {
  border: 2px solid #3f2041;
  color: #3f2041;
}
.films-decoratifs .button-ghost:hover, .films-decoratifs .button-ghost:focus,
.films-decoratifs .js-expandmore-button:hover,
.films-decoratifs .js-expandmore-button:focus {
  box-shadow: inset 0 0 0 5em #3f2041;
  color: #fff;
}
.films-decoratifs .button-ghost:hover .icon, .films-decoratifs .button-ghost:focus .icon,
.films-decoratifs .js-expandmore-button:hover .icon,
.films-decoratifs .js-expandmore-button:focus .icon {
  color: #3f2041;
}

/* Bouton sans bordure ni arrière-plan */
.button-text-only {
  color: #565656;
  padding-left: 0;
}
.button-text-only:hover, .button-text-only:focus {
  color: #de4e1e;
}

/* Forme des boutons */
.radius-tiny {
  border-radius: em(3);
}

.radius-big {
  border-radius: em(9);
}

.pills {
  border-radius: 5em;
}

/* Bouton avec Icône */
/* Bouton avec une icône à droite
 * En position absolute pour éviter que le boutton se redimentionne
 * quand l'icône bouge sur la droite au hover/focus
 */
.icon-on-right {
  padding-right: 2em;
}
.icon-on-right:hover .icon, .icon-on-right:focus .icon {
  transform: translateY(-50%) translateX(0.25em);
}
.icon-on-right .icon {
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}

/* Bouton avec icône à gauche
 * Réduction du padding pour rapprocher l'icône du bord
 */
.icon-on-left {
  padding: 0.5em 1em 0.5em 0.75em;
}
.icon-on-left .icon {
  display: inline-block;
  margin-right: 0.25em;
}

dt {
  color: #de4e1e;
}

dd {
  margin-left: 0;
  position: relative;
}
dd:before {
  content: "";
  position: absolute;
  left: -3rem;
  width: 32px;
  height: 32px;
  background: url(/img/chevron-right-white.svg) center no-repeat #f6f6f6;
  text-align: center;
  line-height: 2;
  top: 0;
  color: #fff;
  border-radius: 50%;
}

input[type=text],
input[type=url],
input[type=tel],
input[type=number],
input[type=password],
input[type=color],
input[type=search],
input[type=email],
textarea {
  border: 0;
  background: #eee;
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
  padding: 0.5em 1em;
  line-height: 1.5;
  display: block;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  width: 100%;
}
input[type=text]:hover, input[type=text]:focus,
input[type=url]:hover,
input[type=url]:focus,
input[type=tel]:hover,
input[type=tel]:focus,
input[type=number]:hover,
input[type=number]:focus,
input[type=password]:hover,
input[type=password]:focus,
input[type=color]:hover,
input[type=color]:focus,
input[type=search]:hover,
input[type=search]:focus,
input[type=email]:hover,
input[type=email]:focus,
textarea:hover,
textarea:focus {
  background: #fff;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  outline-color: #ccc;
}

form label {
  display: block;
  margin-bottom: 0.25em;
}

.check label {
  display: inline-block;
}
.check .js-expandmore,
.check .js-expandmore-button {
  border: 0;
  margin-top: 0.5rem;
}
.check .js-to_expand {
  font-size: 0.875em;
}
.check .js-expandmore-button {
  font-size: 80%;
  padding: 0.25em 0.5em 0.25em 0;
}
.check .js-expandmore-button:hover, .check .js-expandmore-button:focus {
  padding-left: 0.5em;
}

.control-group {
  margin-bottom: 0.5em;
}

.indispensable {
  color: #000;
  font-weight: bold;
}

/*!
 * Validetta (http://lab.hasanaydogdu.com/validetta/)
 * Version 1.0.1 ( 16-08-2015 )
 * Licensed under MIT (https://github.com/hsnayd/validetta/blob/master/LICENCE)
 * Copyright 2013-2015 Hasan Aydoğdu - http://www.hasanaydogdu.com 
 */
.validetta-inline {
  background-color: #ff3232;
  display: inline-block;
  margin: 0.5em 0;
  font-size: 0.875rem;
  color: #fff;
  padding: 0.25em;
  position: relative;
}
.validetta-inline:before {
  content: "";
  border-bottom: 0.5em solid #ff3232;
  border-left: 0.4em solid transparent;
  border-right: 0.4em solid transparent;
  content: "";
  display: block;
  height: 0;
  width: 0;
  position: absolute;
  bottom: 100%;
  left: 0.5em;
}

.validetta-error input[type=text],
.validetta-error input[type=url],
.validetta-error input[type=tel],
.validetta-error input[type=number],
.validetta-error input[type=password],
.validetta-error input[type=color],
.validetta-error input[type=search],
.validetta-error input[type=email],
.validetta-error textarea {
  border: 1px solid #ff3232;
  color: #ff3232;
}
.validetta-error label {
  color: #ff3232;
}
.validetta-error label:before {
  content: "!";
  background-color: #ff3232;
  color: #fff;
  width: 1.5rem;
  display: inline-block;
  text-align: center;
  margin-right: 0.5em;
  line-height: 2;
  font-weight: bold;
  border-radius: 50%;
  font-size: 0.75rem;
}

.validetta-valid input[type=text],
.validetta-valid input[type=url],
.validetta-valid input[type=tel],
.validetta-valid input[type=number],
.validetta-valid input[type=password],
.validetta-valid input[type=color],
.validetta-valid input[type=search],
.validetta-valid input[type=email],
.validetta-valid textarea {
  border: 1px solid #259f6c;
  color: #259f6c;
}
.validetta-valid label {
  color: #259f6c;
}
.validetta-valid label:before {
  content: "✔";
  color: #259f6c;
}

.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  stroke-width: 0;
  stroke: currentColor;
  fill: currentColor;
  position: relative;
  top: 0.125em;
  transition-timing-function: cubic-bezier(0.77, 0, 0.175, 1);
  transition-duration: 300ms;
  transition-property: transform, fill, color, box-shadow;
}
.icon > * {
  fill: currentColor;
}

.animated-expandmore__to_expand {
  display: block;
  overflow: hidden;
  transition: visibility 0s ease, max-height 300ms ease, opacity 300ms ease;
  /* magic number for max-height = enough height */
  visibility: visible;
  transition-delay: 0s;
}

/* This is the hidden state */
[data-hidden=true].animated-expandmore__to_expand {
  display: block;
  max-height: 0;
  visibility: hidden;
  transition-delay: 300ms, 0s, 0s;
}

/**
 * Grid
 * 1. Initialize
 * 2. Repeat item width
 * */
/* 
1. !Initialize
(a) Negative margin for facilitate the gutters management */
.repeat-grid-container {
  display: flex;
  flex-wrap: wrap;
  margin-left: -1%;
  margin-left: calc(-1rem * 1);
  letter-spacing: -0.33em;
}

.grid-items-center {
  justify-content: center;
}

.repeat-grid-container > * {
  vertical-align: top;
  margin-bottom: 1rem;
  margin-left: 1%;
  margin-left: calc(1rem * 1);
  display: inline-block; /* Flexbox fallback */
  letter-spacing: normal;
}

/* 
2. !Repeat item width */
.two-items-per-row-from-start > * {
  width: 49%;
  width: calc((100% / 2) - 1rem);
}

@media (min-width: 37.5em) {
  .two-items-per-row-from-600px > * {
    width: 49%;
    width: calc((100% / 2) - 1rem);
  }
  .three-items-per-row-from-600px > * {
    width: 32.3333333333%;
    width: calc((100% / 3) - 1rem);
  }
}
@media (min-width: 48em) {
  .two-items-per-row-from-768px > * {
    width: 49%;
    width: calc((100% / 2) - 1rem);
  }
  .three-items-per-row-from-768px > * {
    width: 32.3333333333%;
    width: calc((100% / 3) - 1rem);
  }
  .four-items-per-row-from-768px > * {
    width: 24%;
    width: calc((100% / 4) - 1rem);
  }
}
@media (min-width: 64em) {
  .two-items-per-row-from-1024px > * {
    width: 49%;
    width: calc((100% / 2) - 1rem);
  }
  .three-items-per-row-from-1024px > * {
    width: 32.3333333333%;
    width: calc((100% / 3) - 1rem);
  }
  .four-items-per-row-from-1024px > * {
    width: 24%;
    width: calc((100% / 4) - 1rem);
  }
}
@media (min-width: 75em) {
  .two-items-per-row-from-1200px > * {
    width: 49%;
    width: calc((100% / 2) - 1rem);
  }
  .three-items-per-row-from-1200px > * {
    width: 32.3333333333%;
    width: calc((100% / 3) - 1rem);
  }
  .four-items-per-row-from-1200px > * {
    width: 24%;
    width: calc((100% / 4) - 1rem);
  }
  .five-items-per-row-from-1200px > * {
    width: 19%;
    width: calc((100% / 5) - 1rem);
  }
}
@media (min-width: 85.375em) {
  .two-items-per-row-from-1366px > * {
    width: 49%;
    width: calc((100% / 2) - 1rem);
  }
  .three-items-per-row-from-1366px > * {
    width: 32.3333333333%;
    width: calc((100% / 3) - 1rem);
  }
  .four-items-per-row-from-1366px > * {
    width: 24%;
    width: calc((100% / 4) - 1rem);
  }
  .five-items-per-row-from-1366px > * {
    width: 19%;
    width: calc((100% / 5) - 1rem);
  }
  .six-items-per-row-from-1366px > * {
    width: 15.6666666667%;
    width: calc((100% / 6) - 1rem);
  }
}
.skip-link {
  background: #fefefe;
  padding: 0.5em 1em;
  position: absolute;
  top: -5em;
}
.skip-link:focus {
  top: 0;
}

/*
 * TAG : petite étiquette de couleur 
*/
.tag {
  display: inline-block;
  padding-left: 0.5em;
  padding-right: 0.5em;
}

.product-cta {
  position: fixed;
  display: flex;
  opacity: 0;
  background: #fff;
  align-items: center;
  justify-content: center;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0.5em 1em;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  z-index: 20;
  max-width: 1024px;
  margin: 0 auto 1em auto;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}
.product-cta > * {
  margin: 0 1em;
}
.product-cta.show {
  transform: translateY(0%);
  opacity: 1;
}
.product-cta.hide {
  transform: translateY(100%);
}
.product-cta.hey {
  background: orange;
}

@media (max-width: 37.5em) {
  .product-cta {
    flex-direction: column;
    padding-top: 1rem;
  }
  .product-cta .product-section-title {
    font-size: 1.375rem;
    margin-bottom: 1rem;
  }
}
.product-hero {
  position: relative;
  overflow: hidden;
}
.product-hero:before {
  content: "";
  position: absolute;
  top: -1em;
  left: -1em;
  right: -1em;
  bottom: 44%;
  z-index: -1;
}
@supports (filter: blur(10px)) {
  .product-hero:before {
    filter: blur(20px);
  }
}

.product-image-container {
  margin: 0;
  padding-top: 3em;
}
.product-image-container > * {
  position: relative;
  padding-top: 56.25%;
  display: block;
  overflow: hidden;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.15);
  width: 100%;
}
.product-image-container > * > * {
  bottom: 0;
  left: 50%;
  max-width: none;
  min-height: 100%;
  min-width: 100%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: auto;
}
@supports (object-fit: cover) {
  .product-image-container > * > * {
    left: 0;
    right: 0;
    object-fit: cover;
    transform: translateX(0);
    transform-origin: center;
    width: 100%;
  }
}

.product-hero-content {
  position: relative;
  margin: -2em 2em 0 2em;
  z-index: 5;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  padding: 2em;
}

.product-category {
  background: #de4e1e;
  font-family: "Oswald", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  font-weight: 300;
  display: inline-block;
  position: absolute;
  top: -1em;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.25em 0.5em;
  color: #fff;
  white-space: nowrap;
}
.films-discretions .product-category {
  background: #899710;
}
.films-securitaires .product-category {
  background: #265ba8;
}
.films-decoratifs .product-category {
  background: #3f2041;
}

.product-title {
  color: #fff;
  margin: 0;
  text-transform: uppercase;
  font-size: 1.375rem;
  text-align: left;
}

@media (max-width: 75em) {
  .product-image-container {
    margin: 0 1em;
  }
}
@media (min-width: 37.5em) {
  .product-title {
    font-size: 1.75rem;
  }
}
@media (min-width: 48em) {
  .product-hero-content {
    margin: -4em auto 0 auto;
    max-width: 50rem;
  }
  .product-title {
    font-size: 1.75rem;
    text-align: center;
  }
}
@media (min-width: 61.25em) {
  .product-category {
    font-size: 1.125rem;
  }
  .product-title {
    font-size: 2rem;
  }
}
@media (min-width: 75em) {
  .product-title {
    font-size: 3rem;
  }
}
.products-gallery-container .product-gallery {
  margin-bottom: 1em;
  position: relative;
}
.products-gallery-container .product-gallery img {
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  height: 100%;
  object-fit: cover;
}
.products-gallery-container .product-gallery a {
  position: relative;
  overflow: hidden;
  display: block;
  height: 100%;
}
.products-gallery-container .product-gallery a:hover button, .products-gallery-container .product-gallery a:focus button {
  background: #fff;
  color: #de4e1e;
  transform: translateX(-50%) scale(1.05);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}
.films-discretions .products-gallery-container .product-gallery a:hover button, .films-discretions .products-gallery-container .product-gallery a:focus button {
  color: #899710;
}
.films-securitaires .products-gallery-container .product-gallery a:hover button, .films-securitaires .products-gallery-container .product-gallery a:focus button {
  color: #265ba8;
}
.films-decoratifs .products-gallery-container .product-gallery a:hover button, .films-decoratifs .products-gallery-container .product-gallery a:focus button {
  color: #3f2041;
}
.products-gallery-container .product-gallery a:hover img, .products-gallery-container .product-gallery a:focus img {
  transform: scale(1.05);
  filter: brightness(1.1);
}
.products-gallery-container .product-gallery button {
  position: absolute;
  bottom: 0.5em;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  padding: 0.5em 1em;
  z-index: 2;
}
.products-gallery-container .product-gallery button .icon {
  margin-left: 0.5em;
  font-size: 0.75rem;
}

.product-section {
  background: #fff;
  padding: 1em;
  margin-top: 3em;
}

.product-section-resume {
  font-size: 1.125rem;
  margin: 1em auto;
  max-width: 50rem;
}

.product-section-features {
  text-align: center;
  transform: translateX(-1em);
}

.product-section-feature {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  margin-left: 1em;
  font-size: 1.125rem;
}
.product-section-feature:not(:last-child) {
  margin-bottom: 0.5em;
}
.product-section-feature .icon {
  color: #de4e1e;
  top: 0;
  font-size: 0.75rem;
  margin-right: 0.5em;
}
.films-discretions .product-section-feature .icon {
  color: #899710;
}
.films-securitaires .product-section-feature .icon {
  color: #265ba8;
}
.films-decoratifs .product-section-feature .icon {
  color: #3f2041;
}

.product-section .product-section-title {
  text-transform: uppercase;
  margin-bottom: 0;
  max-width: 50rem;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 75em) {
  .product-section .product-section-title {
    font-size: 3rem;
    margin-top: 0;
  }
}
@media (max-width: 75em) {
  .product-section {
    margin-left: 1em !important;
    margin-right: 1em !important;
  }
}
@media (min-width: 48em) {
  .product-section .product-section-resume {
    text-align: center;
    margin-top: 2rem;
    margin-bottom: 2rem;
  }
}
.products-list-item {
  border-top: 1px solid #dedede;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0);
  margin: 0 -1em;
  padding: 1.5em 1em;
  position: relative;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}
.products-list-item:hover {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}
.products-list-item:hover .product-name {
  color: #de4e1e;
}
.films-discretions .products-list-item:hover .product-name {
  color: #899710;
}
.films-securitaires .products-list-item:hover .product-name {
  color: #265ba8;
}
.films-decoratifs .products-list-item:hover .product-name {
  color: #3f2041;
}
.products-list-item:hover .product-thumb img {
  transform: scale(1.2);
  filter: brightness(1.3);
}

.product-thumb {
  text-align: center;
  overflow: hidden;
}
.product-thumb img {
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}

.product-name-container {
  text-align: center;
  margin-top: -1rem;
  margin-bottom: 0;
}

.product-name {
  display: block;
  font-size: 2rem;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  transform-origin: left bottom;
}

.product-logo {
  display: inline-block;
  text-align: center;
  background: #fff;
  padding: 0.25em 0.5em;
  position: relative;
  z-index: 2;
}

.product-features {
  text-align: center;
}
.product-features li {
  color: #de4e1e;
  padding: 0.5em;
  display: inline-block;
}
.films-discretions .product-features li {
  color: #899710;
}
.films-securitaires .product-features li {
  color: #265ba8;
}
.films-decoratifs .product-features li {
  color: #3f2041;
}

.product-content {
  text-align: center;
}
.product-content p {
  margin: 0.5em 1em 2em 1em;
  text-align: left;
  max-width: 50rem;
}
.product-content .label {
  font-size: 0.75rem;
  text-transform: uppercase;
  display: inline-block;
  padding: 0 0.5em;
  color: #fff;
  position: relative;
  bottom: 2rem;
}
.product-content .label.featured {
  background-color: #75A306;
}

.product-informations {
  text-align: center;
}
.product-informations .button-solid {
  position: static;
}
.product-informations .button-solid:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.product-informations .price {
  display: block;
  margin-top: 0.5em;
}

@media (min-width: 48em) {
  .products-list-item {
    display: flex;
  }
  .product-thumb {
    min-width: 236px;
  }
  .product-content {
    text-align: left;
  }
  .product-content .label {
    bottom: 0;
    margin-left: 1rem;
  }
  .product-name-container {
    position: relative;
    text-align: left;
    margin-top: 0;
    padding: 0 1em 0 1rem;
  }
  .product-logo {
    float: right;
  }
  .product-features {
    text-align: left;
    margin-top: 0.5em;
  }
  .product-features .icon {
    font-size: 0.75rem;
  }
  .product-informations {
    display: flex;
    padding: 0 1em;
  }
  .product-informations .price {
    padding: 0 1em;
  }
}
/* --------------------------------------------------------------  
/* # page
/* -------------------------------------------------------------- */
#message-info + .alert-box {
  display: none;
}

.check {
  background: #f9edbe;
  color: #342a05;
  padding: 0.5em;
  margin-bottom: 2em;
}
.check label {
  display: inline-block;
}
.check input {
  display: inline-block;
  margin-right: 0.5em;
}

/*
===== MAIN
*/
body {
  background: #f1f1f1;
  color: #565656;
  font-family: "Open Sans", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  line-height: 1.5;
  overflow-x: hidden;
  font-weight: 400;
  color: #565656;
}

.main-section {
  padding: 0 1em;
}
@media (min-width: 37.5em) {
  .main-section {
    padding: 0 2em;
  }
}
@media (min-width: 48em) {
  .main-section {
    padding: 0 3em;
  }
}

div:target {
  background: #fff;
}

/*
===== Title
*/
@media (min-width: 75em) {
  .section-title {
    font-size: 2.5rem;
  }
}

/*
===== Financement
*/
.section-features {
  background: #ebe939;
  text-align: left;
  box-shadow: inset 0 -4px 8px rgba(0, 0, 0, 0.2);
  padding: 0.5em;
  box-shadow: inset 0 -8px 8px rgba(0, 0, 0, 0.2);
  margin-left: -0.75em;
  margin-right: -0.75em;
}

.features-list {
  margin-bottom: 0;
  list-style: none;
  padding: 0;
}

@media screen and (min-width: 48em) {
  .features-list {
    display: flex;
    justify-content: center;
  }
}
.feature-item {
  color: #464507;
  margin: 0;
  padding: 0.25em 0.5em;
  text-transform: uppercase;
  font-feature-settings: "lnum";
}

.feature-item:last-child {
  margin: 0;
  padding-left: 0.5em;
  color: #2f2e04;
}

@media screen and (max-width: 47.9375em) {
  .feature-item + .feature-item {
    border-top: 1px solid #d2d015;
  }
}
@media screen and (min-width: 48em) {
  .feature-item {
    margin-left: 1em;
  }
  .feature-item:last-child {
    border-left: 1px solid #95940f;
  }
}
.feature-item .feature {
  color: #2f2e04;
}

.feature-item .icon {
  color: #6b6a0a;
  margin-right: 0.5em;
}

.feature-item .way {
  font-size: 0.875em;
}

/*
===== TOPBAR
*/
.stick-head {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  z-index: 20;
}
.stick-head.show {
  transform: translateY(0%);
}
.stick-head.hide {
  transform: translateY(-100%);
}
.contact .stick-head {
  position: absolute;
}
.stick-head.headroom--not-top #financement-topbar {
  display: none;
}

.topbar {
  background: #fff;
  text-align: center;
  margin-bottom: 0;
}
.topbar .site-logo {
  padding-left: 0;
  display: inline-block;
}
.topbar .site-title {
  margin: 0;
}

.topbar .contacts-info {
  background: #eee;
  margin-top: 0;
  letter-spacing: -0.31em;
  padding: 0.33em 0;
  white-space: nowrap;
  overflow-x: auto;
}
.topbar .contacts-info > li {
  display: inline-block;
  letter-spacing: normal;
  white-space: nowrap;
  vertical-align: middle;
}
.topbar .contacts-info > li.acces-pro {
  margin-left: 0.5em;
  border-left: 1px solid rgba(0, 0, 0, 0.25);
  padding-left: 0.5em;
}
.topbar .contacts-info a {
  display: block;
  box-shadow: inset 0 0 0 -1px #de4e1e, 0 2px 3px rgba(0, 0, 0, 0.2);
  background: #fff;
  color: #de4e1e;
  border-radius: 3px;
}
.topbar .contacts-info a .icon {
  font-size: 1.5em;
}
.topbar .contacts-info a:hover, .topbar .contacts-info a:focus {
  box-shadow: inset 0 0 256px 0 #de4e1e, 0 2px 3px rgba(0, 0, 0, 0.2);
  color: #fff;
}

.topbar a {
  display: block;
  padding: 0.5em;
  text-decoration: none;
  color: #000;
  background: #fff;
}

@media (max-width: 37.4375em) {
  .topbar .wrapper {
    text-align: left;
    display: flex;
  }
  .topbar .wrapper .brand {
    flex-grow: 1;
  }
  .topbar .wrapper .contacts-info {
    padding: 0.5em;
    display: flex;
    align-items: center;
  }
  .topbar .wrapper .contacts-info > * {
    flex-grow: 1;
  }
  .topbar .wrapper .contacts-info > * + * {
    margin-left: 0.25em;
  }
  .topbar .wrapper .contacts-info .label {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
}
@media (min-width: 37.5em) {
  .topbar .wrapper {
    padding: 0 0.5em;
    display: flex;
  }
  .topbar .wrapper .brand {
    flex: 1;
    text-align: left;
  }
  .topbar .wrapper .contacts-info {
    background: #fff;
    position: relative;
    display: flex;
    align-items: center;
  }
  .topbar .wrapper .contacts-info > * + * {
    margin-left: 0.25em;
  }
  .topbar .wrapper .contacts-info .label {
    margin-left: 0.25em;
  }
  .topbar .wrapper .contacts-info a {
    display: flex;
    align-items: center;
  }
  .topbar .wrapper .contacts-info a .icon {
    top: 0;
  }
  .topbar .wrapper .contacts-info .contact-phone a {
    pointer-events: none;
    box-shadow: none;
  }
  .topbar .wrapper .contacts-info .contact-phone a .label {
    color: #565656;
  }
  .topbar .wrapper .contacts-info .item {
    letter-spacing: normal;
  }
}
@media (min-width: 52.5em) {
  .topbar .contacts-info .item {
    font-size: 16px;
    font-size: 1rem;
  }
  .topbar .contact-mail a {
    border-radius: 3px;
  }
  .topbar .contact-mail a:hover {
    border-color: rgba(255, 255, 255, 0.0001);
  }
}
/*
===== NAV PRIMARY
*/
.nav-primary {
  background: #de4e1e;
  border: 0;
  position: relative;
  z-index: 55;
  font-size: 0.875rem;
}
.nav-primary .wrapper {
  overflow-x: auto;
}

.nav-container.lv1 {
  letter-spacing: -0.31em;
  white-space: nowrap;
  vertical-align: top;
}
.nav-container.lv1 > li {
  display: inline-block;
  letter-spacing: normal;
  white-space: nowrap;
  vertical-align: top;
}

.nav-item.lv1 {
  display: block;
  padding: 0.5rem;
  color: #fff;
  text-decoration: none;
  position: relative;
}
.nav-item.lv1:hover, .nav-item.lv1:focus {
  background: rgba(255, 255, 255, 0.25);
}
.nav-item.lv1.current-page {
  font-weight: bold;
}
.nav-item.lv1.current-page:before {
  border-top: 0.5em solid #fff;
  border-left: 0.4em solid transparent;
  border-right: 0.4em solid transparent;
  content: "";
  display: block;
  height: 0;
  width: 0;
  position: absolute;
  top: -0.125em;
  left: 50%;
  transform: translateX(-50%);
}
.nav-item.lv1.nav-home {
  padding-bottom: 0;
}
.nav-item.lv1.nav-home .icon {
  font-size: 1.5rem;
  top: 0;
  line-height: 0;
}
.nav-item.lv1 button {
  padding: 0;
  color: inherit;
}
.nav-item.lv1 button .icon {
  top: 0.125em;
}
.nav-item.lv1 .tag {
  padding: 0;
  font-size: 0.75rem;
}
.nav-item.lv1 .icon-angle-down {
  margin-left: 0.125em;
}

.has-subnav .sub-nav {
  position: absolute;
  margin-top: 0;
  top: 100%;
  top: calc(100% - 0.25em);
}
.has-subnav .sub-nav li {
  font-size: 0.875rem;
  display: block;
}
.has-subnav .sub-nav li + li a {
  border-top: 1px solid #ccc;
}

.nav-item.lv2 {
  display: block;
  background: #fff;
  padding: 0.5em 3em 0.5em 1em;
  margin-top: 0;
  text-decoration: none;
  color: #565656;
  position: relative;
}
.nav-item.lv2:hover, .nav-item.lv2:focus {
  color: #de4e1e;
  border-color: #de4e1e;
}
.nav-item.lv2:hover .icon, .nav-item.lv2:focus .icon {
  background-color: #de4e1e;
}
.nav-item.lv2 .icon {
  position: absolute;
  box-sizing: content-box;
  border-radius: 50%;
  background: #999;
  color: #fff;
  font-size: 0.75rem;
  padding: 0.5em;
  top: 50%;
  transform: translateY(-50%);
  right: 1em;
}

@media (max-width: 37.5em) {
  .nav-primary:after {
    background: linear-gradient(to left, #de4e1e 0, #de4e1e 24px, rgba(0, 0, 0, 0.5) 24px, transparent);
    content: "";
    text-align: right;
    position: absolute;
    right: 0;
    width: 48px;
    overflow-y: hidden;
    top: 0;
    bottom: 0;
  }
  body.films-discretions .nav-primary:after {
    background: linear-gradient(to left, #899710 0, #899710 24px, rgba(0, 0, 0, 0.5) 24px, transparent);
  }
  body.films-securitaires .nav-primary:after {
    background: linear-gradient(to left, #265ba8 0, #265ba8 24px, rgba(0, 0, 0, 0.5) 24px, transparent);
  }
  body.films-decoratifs .nav-primary:after {
    background: linear-gradient(to left, #3f2041 0, #3f2041 24px, rgba(0, 0, 0, 0.5) 24px, transparent);
  }
  .nav-container.lv1 > li:last-child {
    margin-right: 48px;
  }
}
@media (max-width: 61.25em) {
  .nav-item.lv1 .tag {
    display: block;
  }
}
@media (min-width: 61.25em) {
  .nav-item.lv1 {
    padding: 0.5em 1em;
    font-size: 1rem;
  }
  .nav-item.lv1 .tag {
    font-size: 1rem;
  }
}
@media (min-width: 37.5em) and (max-width: 61.25em) {
  .nav-item.lv1 {
    padding: 1em 1em 0.5em 1em;
  }
}
/*
 ===== FOOTER
*/
.site-footer {
  background: url(../img/maison-gauche.jpg) no-repeat bottom left, url(../img/maison-droite.jpg) no-repeat bottom right;
  padding: 1em;
}
body[class*=films-] .site-footer {
  padding-bottom: 7em;
}
.site-footer .artecfilm-univers li:not(:last-child) {
  margin-bottom: 1em;
}
.site-footer .artecfilm-univers a {
  background: #eee;
  box-shadow: inset 0 0 0 -1px white, 0 2px 5px rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  text-decoration: none;
  padding: 0.5em;
  color: #565656;
  position: relative;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
  border: 1px solid #fff;
  overflow-x: auto;
}
.site-footer .artecfilm-univers a:hover, .site-footer .artecfilm-univers a:focus {
  box-shadow: inset 0 0 0 4em white, 0 2px 5px rgba(0, 0, 0, 0.2);
  transform: translateY(-0.5em);
}
.site-footer .artecfilm-univers img {
  width: 64px;
  margin-right: 0.5em;
}
.site-footer .artecfilm-univers strong {
  flex-grow: 1;
  font-weight: normal;
}
.site-footer .artecfilm-univers .label-new {
  position: absolute;
  top: 0;
  background: #ff0;
  color: #000;
  padding: 0.125em 0.25em;
  line-height: 1;
  font-size: 0.75rem;
  left: 80px;
}

.footer-aside {
  max-width: 61.25rem;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 37.5em) and (max-width: 52.5em) {
  .footer-aside .artecfilm-univers ul {
    display: flex;
    flex-wrap: wrap;
    margin-left: -1em;
  }
  .footer-aside .artecfilm-univers li {
    width: calc(50% - 1em);
    margin-left: 1em;
  }
}
@media (min-width: 52.5em) {
  .footer-aside {
    display: flex;
  }
  .footer-aside .artecfilm-univers {
    margin-left: 2em;
    width: 50%;
  }
}
@media (min-width: 61.25em) {
  .footer-aside .artecfilm-univers {
    width: 40%;
  }
}
/* Colors */
body.films-discretions .nav-primary {
  background: #899710;
}
body.films-discretions .color-secondary {
  color: #899710;
}
body.films-discretions .topbar .contacts-info a {
  color: #899710;
  box-shadow: inset 0 0 0 -1px #899710, 0 2px 3px rgba(0, 0, 0, 0.2);
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}
body.films-discretions .topbar .contacts-info a .icon {
  color: inherit;
}
body.films-discretions .topbar .contacts-info a:hover, body.films-discretions .topbar .contacts-info a:focus {
  box-shadow: inset 0 0 256px 0 #899710, 0 2px 3px rgba(0, 0, 0, 0.2);
  color: #fff;
}

body.films-securitaires .nav-primary {
  background: #265ba8;
}
body.films-securitaires .color-secondary {
  color: #265ba8;
}
body.films-securitaires .topbar .contacts-info a {
  color: #265ba8;
  box-shadow: inset 0 0 0 -1px #5289d8, 0 2px 3px rgba(0, 0, 0, 0.2);
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}
body.films-securitaires .topbar .contacts-info a .icon {
  color: inherit;
}
body.films-securitaires .topbar .contacts-info a:hover, body.films-securitaires .topbar .contacts-info a:focus {
  box-shadow: inset 0 0 256px 0 #5289d8, 0 2px 3px rgba(0, 0, 0, 0.2);
  color: #fff;
}

body.films-decoratifs .nav-primary {
  background: #3f2041;
}
body.films-decoratifs .color-secondary {
  color: #3f2041;
}
body.films-decoratifs .topbar .contacts-info a {
  color: #3f2041;
  transition: 300ms all cubic-bezier(0.77, 0, 0.175, 1);
}
body.films-decoratifs .topbar .contacts-info a .icon {
  color: inherit;
}
body.films-decoratifs .topbar .contacts-info a:hover, body.films-decoratifs .topbar .contacts-info a:focus {
  box-shadow: inset 0 0 256px 0 #7b3e7f, 0 2px 3px rgba(0, 0, 0, 0.2);
  color: #fff;
}

[id=banner] {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.4)), url(../img/bg-banner-home.jpg) no-repeat center;
  background-size: cover;
  color: #fff;
}
[id=banner] .wrapper {
  width: 100%;
}
[id=banner] .hgroup {
  vertical-align: middle;
  padding: 4em 2em;
}
[id=banner] .banner-title {
  font-weight: 700;
  color: #fff;
  font-family: "Oswald", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  display: block;
}
[id=banner] .banner-baseline {
  font-weight: 300;
  color: #de4e1e;
  display: block;
  font-size: 1.5rem;
}
[id=banner] .banner-description {
  font-size: 1rem;
  margin-top: 1em;
  opacity: 0;
  line-height: 1.3;
  max-width: 35.5555555556rem;
}
[id=banner] .banner-description.play {
  animation: fade 2s ease-out 3s alternate 1 forwards;
}

@keyframes fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeScale {
  from {
    opacity: 0;
    transform: scale(0) translateY(-0.5em);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}
.anime-fade .word {
  opacity: 0;
  display: block;
  line-height: 1.2;
  font-size: 8.889vw;
  font-weight: 300;
}

.anime-fade.play .word {
  opacity: 0;
  animation: fadeScale 300ms ease-out 0s alternate 1 forwards;
}
.anime-fade.play .word.two {
  animation-delay: 1s;
}
.anime-fade.play .word.three {
  animation-delay: 2s;
}

@media (min-width: 48em) {
  .anime-fade .word {
    opacity: 0;
    display: block;
    font-size: 68px;
  }
}
@media (min-width: 75em) {
  [id=banner] {
    padding: 0 2em;
  }
  [id=banner] .hgroup {
    padding: 8em 0;
  }
  [id=banner] .banner-description {
    font-size: 1.375rem;
    margin-top: 1em;
    max-width: 31.8181818182rem;
  }
}
.section-catalog {
  position: relative;
  transition: 300ms ease all;
  --bg-hover: #fff;
}
@media screen and (max-width: 599px) {
  .section-catalog.product-section {
    border: 0;
    padding: 0;
    margin-left: 0 !important;
    margin-right: 0 !important;
    font-size: 14px;
    margin-bottom: 0;
  }
  .section-catalog.product-section a {
    padding-top: 1em;
    padding-bottom: 1em;
  }
  .section-catalog.product-section + * {
    margin-top: 0;
  }
}
.section-catalog.product-section + * {
  margin-top: 0;
}
.section-catalog a {
  display: flex;
  border-bottom: 0;
  position: relative;
  align-items: center;
  text-decoration: none;
  transition: 300ms ease all;
  background: linear-gradient(to top, rgba(17, 33, 49, 0.3), rgba(17, 18, 49, 0.3)) center bottom/100% 0 no-repeat, linear-gradient(to top, rgba(17, 33, 49, 0.8), rgba(17, 33, 49, 0.8)) center center/100% 100% no-repeat, url(http://artecfilm.fr/pdf/catalogue-2021-thumb.jpg) center center/100% auto no-repeat;
}
.section-catalog a:hover, .section-catalog a:focus {
  background-size: 100% 100%, 100% 100%, 100% auto;
}
.section-catalog a:hover .button, .section-catalog a:focus .button {
  background: #e67049;
  color: #fff;
  box-shadow: 0 2px 15px 6px rgba(222, 78, 30, 0.5);
}
.section-catalog a:hover img, .section-catalog a:focus img {
  transform: translateY(-8px) rotate(-2deg);
}
.section-catalog a .section-main {
  padding: 0.5em;
  flex-grow: 1;
  text-align: center;
}
.section-catalog a .section-title {
  color: #fff;
  font-size: 1.25em;
}
.section-catalog a .button {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  margin-top: 0.25em;
  margin-left: 0.25em;
  background: #de4e1e;
}
.section-catalog a .button .icon {
  margin-left: 0.25rem;
  font-size: 1.5em;
}
.section-catalog a img {
  width: 128px;
  transition: 300ms ease transform;
}

@media screen and (min-width: 600px) {
  .section-catalog a img {
    width: 164px;
  }
}
@media screen and (min-width: 768px) {
  .section-catalog a .section-main {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .section-catalog a .section-title {
    font-size: 1.75rem;
  }
  .section-catalog a .button {
    margin-top: 0;
    margin-left: 0.5em;
  }
  .section-catalog a img {
    width: 196px;
  }
}
@media screen and (min-width: 1280px) {
  .section-catalog a {
    justify-content: flex-start;
    padding-top: 1em;
  }
  .section-catalog a .section-main {
    flex-direction: column;
    flex-grow: 0;
    padding: 0 2em;
    margin-left: auto;
  }
  .section-catalog a .section-title {
    font-size: 2rem;
    text-shadow: 0 1px 2px #000;
    text-transform: uppercase;
  }
  .section-catalog a .button {
    margin-top: 1rem;
    margin-left: 0;
    font-size: 1.3125rem;
  }
  .section-catalog a img {
    width: 312px;
    margin-right: auto;
  }
}
/*
  Gamme films
*/
.gamme-films-container .section-title {
  text-transform: uppercase;
  color: #de4e1e;
  margin-bottom: 2em;
  margin-top: 1em;
}
.gamme-films-container .section-title strong {
  display: block;
  font-weight: 300;
  color: #000;
  font-size: em(20px, 28px);
}
.gamme-films-container .product-container {
  background: #fff;
  margin: 2em 0;
  border-top: 3px solid #de4e1e;
  position: relative;
}
.gamme-films-container .product-container.discretions {
  border-top-color: #899710;
}
.gamme-films-container .product-container.discretions .product-category {
  background: #899710;
}
.gamme-films-container .product-container.discretions .keyword {
  color: #899710;
}
.gamme-films-container .product-container.discretions .button {
  background-color: #899710;
  box-shadow: inset 0 0 0 -1px #fff;
}
.gamme-films-container .product-container.discretions .button:hover, .gamme-films-container .product-container.discretions .button:focus {
  box-shadow: inset 0 0 2px 10em #fff;
  color: #899710;
}
.gamme-films-container .product-container.decoratifs {
  border-top-color: #3f2041;
}
.gamme-films-container .product-container.decoratifs .product-category {
  background: #3f2041;
}
.gamme-films-container .product-container.decoratifs .keyword {
  color: #3f2041;
}
.gamme-films-container .product-container.decoratifs .button {
  background-color: #3f2041;
  box-shadow: inset 0 0 0 -1px #fff;
}
.gamme-films-container .product-container.decoratifs .button:hover, .gamme-films-container .product-container.decoratifs .button:focus {
  box-shadow: inset 0 0 2px 10em #fff;
  color: #3f2041;
}
.gamme-films-container .product-container.securitaires {
  border-top-color: #265ba8;
}
.gamme-films-container .product-container.securitaires .product-category {
  background: #265ba8;
}
.gamme-films-container .product-container.securitaires .keyword {
  color: #265ba8;
}
.gamme-films-container .product-container.securitaires .button {
  background-color: #265ba8;
  box-shadow: inset 0 0 0 -1px #fff;
}
.gamme-films-container .product-container.securitaires .button:hover, .gamme-films-container .product-container.securitaires .button:focus {
  box-shadow: inset 0 0 2px 10em #fff;
  color: #265ba8;
}
.gamme-films-container .product-category {
  font-family: "Oswald", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  font-weight: 300;
  font-size: 1.25rem;
  text-transform: uppercase;
  display: inline-block;
  background: #de4e1e;
  padding: 0.25em 0.5em;
  position: absolute;
  top: -1em;
  color: #fff;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.gamme-films-container .product-header {
  background-position: center;
  background-size: cover;
  font-family: "Oswald", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", "sans-serif";
  font-weight: 600;
  letter-spacing: 0.03em;
  margin: 0;
  padding: 4em 1em 1em;
  position: relative;
  text-transform: uppercase;
  color: #fff;
  font-size: 1.375rem;
}
.gamme-films-container .product-header:before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.65) 40%, transparent);
  z-index: 1;
}
.gamme-films-container .product-header > * {
  position: relative;
  z-index: 3;
}
.gamme-films-container .product-content {
  padding: 1em 2em 2em;
}
.gamme-films-container .keywords-title {
  font-weight: bold;
  margin-top: 0;
  color: #000;
  margin-bottom: 0.5em;
}
.gamme-films-container .keywords-list {
  margin-top: 0;
  overflow: auto;
  text-align: left;
}
.gamme-films-container .keyword {
  color: #de4e1e;
  display: inline-block;
}
.gamme-films-container .keyword:before {
  content: "✓ ";
}
.gamme-films-container .keyword:not(:last-child) {
  margin-right: 1em;
}
.gamme-films-container .product-description {
  margin: 1em 0;
  font-size: 1.1428571429rem;
}
.gamme-films-container .button {
  margin-top: 1em;
  border: 0px solid #de4e1e;
  border-radius: 2px;
  display: inline-block;
  background-color: #de4e1e;
  color: #fff;
  padding: 0.5em 1em;
  text-decoration: none;
  transition: 300ms ease-in-out all;
  box-shadow: inset 0 0 0 -1px #fff;
}
.gamme-films-container .button .icon {
  bottom: 0;
  top: 0;
  transform: translateY(0.125em);
}
.gamme-films-container .button:hover, .gamme-films-container .button:focus {
  box-shadow: inset 0 0 2px 10em #fff;
  color: #de4e1e;
}
.gamme-films-container .button:hover .icon, .gamme-films-container .button:focus .icon {
  transform: translateY(0.125em) translateX(0.25em);
}

@media (min-width: 37.5rem) {
  .gamme-films-container .product-header {
    font-size: em(28px);
  }
  .gamme-films-container .product-header p {
    min-height: 3em;
    line-height: 1.5;
  }
}
@media (min-width: 48rem) and (max-width: 53.75rem) {
  .gamme-films-container .product-container.decoratifs .product-header p {
    min-height: 4.5em;
  }
}
@media (min-width: 48rem) {
  .gamme-films-container .section-title {
    text-align: center;
  }
  .gamme-films-container .products-container {
    display: flex;
    flex-wrap: wrap;
    letter-spacing: -0.31em;
    justify-content: space-between;
  }
  .gamme-films-container .product-header {
    font-size: 2rem;
  }
  .gamme-films-container .product-container {
    display: inline-block;
    vertical-align: top;
    letter-spacing: normal;
    width: 50%;
    width: calc(50% - 1em);
  }
}
@media (max-width: 75rem) {
  .gamme-films-container .wrapper {
    padding: 0 2em;
  }
}
@media (min-width: 75rem) {
  .gamme-films-container .section-title {
    font-size: 2.5rem;
  }
}
/*
 === A PROPOS
*/
#apropos {
  padding: 0 1em;
}
#apropos .small-wrap p {
  font-size: 1.125rem;
}
#apropos img {
  mix-blend-mode: darken;
}
#apropos #bouton-facebook {
  margin-top: 1em;
}
#apropos #bouton-facebook a {
  background: #3b5998;
  display: inline-block;
  padding: 1em 2em;
  box-shadow: 0px 2px 20px 0 rgba(0, 0, 0, 0.35);
}
#apropos #bouton-facebook a .icon {
  background: #3b5998;
  position: relative;
  transform: translateY(-3rem);
  margin-bottom: -3rem;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);
  font-size: 4rem;
  border: 2px solid #fff;
  padding: 1rem;
  border-radius: 0.125rem;
  color: #fff;
}
#apropos #bouton-facebook a:hover, #apropos #bouton-facebook a:focus {
  background: #fff;
  color: #3b5998;
  box-shadow: 0px 2px 30px 5px 0 rgba(0, 0, 0, 0.35);
}
#apropos #bouton-facebook a:hover .icon, #apropos #bouton-facebook a:focus .icon {
  fill: #fff;
  color: #fff;
  transform: scale(1.1) translateY(-3rem);
}

@media (min-width: 37.5em) {
  #apropos {
    padding: 0 2em;
  }
}
@media (min-width: 75em) {
  #apropos {
    background: url(../img/bg-services-2.jpg) no-repeat top right, url(../img/bg-services.jpg) no-repeat top left;
    position: relative;
  }
  #apropos:after {
    content: "";
    display: block;
    background: linear-gradient(to top, #f1f1f1, rgba(241, 241, 241, 0));
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    height: 150px;
    z-index: 1;
  }
  #apropos .wrapper {
    position: relative;
    z-index: 2;
  }
}
/*
 === FAQ
*/
#faq img {
  mix-blend-mode: darken;
}
#faq dd:before {
  content: none;
}
@media (min-width: 61.25em) {
  #faq > div {
    display: table;
    width: 100%;
    table-layout: fixed;
  }
  #faq > div > * {
    display: table-cell;
    vertical-align: top;
  }
  #faq > div figure {
    width: 40%;
  }
}

/* --------------------------------------------------------------  
/* # Helpers
/* -------------------------------------------------------------- */
/*
!Helpers
=================== */
/* ==> !Alignement */
.txt-left {
  text-align: left;
}

.txt-center {
  text-align: center;
}

.txt-right {
  text-align: right;
}

.box-center {
  margin-left: auto;
  margin-right: auto;
}

/* ==> !Margin */
.margin-0 {
  margin: 0;
}

.mt-0 {
  margin-top: 0;
}

.mb-0 {
  margin-bottom: 0;
}

.ml-0 {
  margin-left: 0;
}

.mr-0 {
  margin-right: 0;
}

.m-half-em {
  margin: 0.5em;
}

.mt-half-em {
  margin-top: 0.5em;
}

.mb-half-em {
  margin-bottom: 0.5em;
}

.mr-half-em {
  margin-right: 0.5em;
}

.ml-half-em {
  margin-left: 0.5em;
}

.m-1em {
  margin: 1em;
}

.mt-1em {
  margin-top: 1em;
}

.mb-1em {
  margin-bottom: 1em;
}

.mr-1em {
  margin-right: 1em;
}

.ml-1em {
  margin-left: 1em;
}

.m-2em {
  margin: 2em;
}

.mt-2em {
  margin-top: 2em;
}

.mb-2em {
  margin-bottom: 2em;
}

.mr-2em {
  margin-right: 2em;
}

.ml-2em {
  margin-left: 2em;
}

.m-3em {
  margin: 3em;
}

.mt-3em {
  margin-top: 3em;
}

.mb-3em {
  margin-bottom: 3em;
}

.mr-3em {
  margin-right: 3em;
}

.ml-3em {
  margin-left: 3em;
}

/* ==> !Padding */
.padding-0 {
  padding: 0;
}

.pt-0 {
  padding-top: 0;
}

.pb-0 {
  padding-bottom: 0;
}

.pl-0 {
  padding-left: 0;
}

.pr-0 {
  padding-right: 0;
}

.p-half-em {
  padding: 0.5em;
}

.pt-half-em {
  padding-top: 0.5em;
}

.pb-half-em {
  padding-bottom: 0.5em;
}

.pr-half-em {
  padding-right: 0.5em;
}

.pl-half-em {
  padding-left: 0.5em;
}

.p-1em {
  padding: 1em;
}

.pt-1em {
  padding-top: 1em;
}

.pb-1em {
  padding-bottom: 1em;
}

.pr-1em {
  padding-right: 1em;
}

.pl-1em {
  padding-left: 1em;
}

.p-2em {
  padding: 2em;
}

.pt-2em {
  padding-top: 2em;
}

.pb-2em {
  padding-bottom: 2em;
}

.pr-2em {
  padding-right: 2em;
}

.pl-2em {
  padding-left: 2em;
}

.p-3em {
  padding: 3em;
}

.pt-3em {
  padding-top: 3em;
}

.pb-3em {
  padding-bottom: 3em;
}

.pr-3em {
  padding-right: 3em;
}

.pl-3em {
  padding-left: 3em;
}

.padding-side-2em {
  padding-left: 2em;
  padding-right: 2em;
}

/* ==> !Layout */
.row,
.wrapper {
  margin-left: auto;
  margin-right: auto;
  max-width: 80rem;
}

.small-wrap {
  max-width: 50rem;
}

.wrapper-medium {
  max-width: 64rem;
}

.break-row {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}

.fake-break-row {
  position: relative;
}
.fake-break-row > * {
  position: relative;
  z-index: 2;
}
.fake-break-row:before {
  background: inherit;
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  right: -100%;
  bottom: 0;
  z-index: 1;
}

.float-left {
  float: left;
}

.hidden,
.display-none {
  display: none;
}

.relative {
  position: relative;
}

.display-block {
  display: block;
}

.invisible {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  white-space: nowrap;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

/*
 UI
*/
[class*=divider-] {
  margin-top: 0;
  margin-bottom: 0;
}
[class*=divider-]:before, [class*=divider-]:after {
  background: #de4e1e;
  height: 2px;
  display: block;
  margin: 1rem auto;
  width: 2rem;
}
.films-discretions [class*=divider-]:after, .films-discretions [class*=divider-]:before {
  background: #899710;
}
.films-securitaires [class*=divider-]:after, .films-securitaires [class*=divider-]:before {
  background: #265ba8;
}
.films-decoratifs [class*=divider-]:after, .films-decoratifs [class*=divider-]:before {
  background: #3f2041;
}

.divider-before:before {
  content: "";
}

.divider-after:after {
  content: "";
}

.rounded {
  border-radius: 50%;
}

/*
 Text
*/
.weight-lighter {
  font-weight: 300;
}

.txt-smaller {
  font-size: 0.5em;
}

.txt-small {
  font-size: 0.75em;
}

.txt-medium {
  font-size: 1em;
}

.txt-big {
  font-size: 1.25em;
}

.txt-bigger {
  font-size: 1.5em;
}

.txt-biggest {
  font-size: 2em;
}

.bold {
  font-weight: bold;
}

.italic {
  font-style: italic;
}

.uppercase {
  text-transform: uppercase;
}

.color-white {
  color: #fff;
}

.color-black {
  color: #000;
}

.font-quote {
  font-family: "georgia", "Times", "Times New Roman", serif;
}

/*
 Background
*/
.bg-grey {
  background-color: #f1f1f1;
}

.bg-white {
  background-color: #fff;
}

.color-secondary {
  color: #de4e1e;
}

/*
 Reset
*/
.reset-list {
  list-style: none;
  padding-left: 0;
}

/*
Preserve ratio
*/
.preserve-ratio > * {
  position: relative;
  padding-top: 56.25%;
  display: block;
  overflow: hidden;
  width: 100%;
}
.preserve-ratio > * > * {
  bottom: 0;
  left: 50%;
  max-width: none;
  min-height: 100%;
  min-width: 100%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: auto;
}
@supports (object-fit: cover) {
  .preserve-ratio > * > * {
    left: 0;
    right: 0;
    object-fit: cover;
    transform: translateX(0);
    transform-origin: center;
    width: 100%;
  }
}

.ratio-1-1 > * {
  padding-top: 100% !important;
}

.ratio-3-2 > * {
  padding-top: 66.66% !important;
}

.ratio-4-3 > * {
  padding-top: 75% !important;
}

.ratio-16-9 > * {
  padding-top: 56.25% !important;
}

.ratio-16-10 > * {
  padding-top: 62.5% !important;
}

.ratio-3-2-portrait > * {
  padding-top: 150% !important;
}

.ratio-4-3-portrait > * {
  padding-top: 133.33% !important;
}

.ratio-16-9-portrait > * {
  padding-top: 177.77% !important;
}

.ratio-16-10-portrait > * {
  padding-top: 166% !important;
}

/* --------------------------------------------------------------  
/* # Print
/* -------------------------------------------------------------- */
/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   http://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */
@media print {
  *,
*:before,
*:after {
    background: transparent !important;
    color: #000 !important; /* Black prints faster:
   http://www.sanbeiji.com/archives/953 */
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a,
a:visited {
    text-decoration: underline;
  }
  a[href]:after {
    content: " (" attr(href) ")";
  }
  abbr[title]:after {
    content: " (" attr(title) ")";
  }
  /*
   * Don't show links that are fragment identifiers,
   * or use the `javascript:` pseudo protocol
   */
  a[href^="#"]:after,
a[href^="javascript:"]:after {
    content: "";
  }
  pre {
    white-space: pre-wrap !important;
  }
  pre,
blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  /*
   * Printing Tables:
   * http://css-discuss.incutio.com/wiki/Printing_Tables
   */
  thead {
    display: table-header-group;
  }
  tr,
img {
    page-break-inside: avoid;
  }
  p,
h2,
h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
h3 {
    page-break-after: avoid;
  }
}