/*
Theme Name: Eric Huguenin WP theme starter
Author: Eric Huguenin
Author URI: https://eric-huguenin.com/
Description: This is a starter theme
Version: 2.0
*/

/* import des polices en local (opti) */
@font-face {
    font-family: 'niveau-grotesk-bold';
    src: url('./fonts/AktivGrotesk-Bold.woff2') format('woff2'),
         url('./fonts/AktivGrotesk-Bold.woff') format('woff');
    font-weight: normal;
    font-style: normal;
	font-display: swap;
}
@font-face {
    font-family: 'niveau-grotesk';
    src: url('./fonts/NiveauGroteskLight.woff2') format('woff2'),
         url('./fonts/NiveauGroteskLight.woff') format('woff');
    font-weight: normal;
    font-style: normal;
	font-display: swap;
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    vertical-align: baseline;
    font-style: inherit;
}
ol,
ul {
    list-style: none;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400;
    font-size: inherit;
}
html {
    -webkit-font-smoothing: antialiased !important;
    font-size: 100%;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	overflow-y: scroll;
}
body {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.5;
}
a {
    -webkit-font-smoothing: antialiased !important;
    color: inherit;
}
button {
    border: none;
    cursor: pointer;
    font-size: inherit;
}
button,
input {
    border-radius: 0;
    font-family: inherit;
    color: inherit;
}
.clearfix {
    display: block;
}
.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
}
html[xmlns] .clearfix {
    display: block;
}
* html .clearfix {
    height: 1%;
}
.b,
.bold,
b {
    font-weight: 700;
}
.i,
.italic {
    font-style: italic;
}
.txt_center {
    text-align: center;
}
.txt_right {
    text-align: right;
}
.txt_left {
    text-align: left;
}
.uppercase {
    text-transform: uppercase;
}
.smallcaps {
    font-variant: small-caps;
}
.opa0 {
    opacity: 0;
}
.opa1 {
    opacity: 1;
}
.unselect {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
html {
    box-sizing: border-box;
}
*,
:after,
:before {
    box-sizing: inherit;
}
.extralight {
    font-weight: 100;
}
.thin {
    font-weight: 200;
}
.light {
    font-weight: 300;
}
.normal {
    font-weight: 400;
}
.medium {
    font-weight: 500;
}
.semibold {
    font-weight: 600;
}
.bold {
    font-weight: 700;
}
.extrabold {
    font-weight: 800;
}
.black {
    font-weight: 900;
}
.grid {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 40px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .grid {
        padding: 0 30px;
    }
}
@media (max-width: 1100px) {
    .grid {
        padding: 0 40px;
    }
}
@media (max-width: 660px) {
    .grid {
        padding: 0 20px;
    }
}
.row {
    display: -webkit-box;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    flex-flow: row wrap;
    -webkit-box-align: start;
    align-items: flex-start;
    -webkit-box-pack: start;
    justify-content: flex-start;
    flex-shrink: 0;
    -webkit-box-flex: 1;
    flex-grow: 1;
    margin-left: -20px;
    margin-right: -20px;
}
.row--full-h {
    -webkit-box-align: stretch;
    align-items: stretch;
}
.row--align-end {
    -webkit-box-align: end;
    align-items: flex-end;
}
@media (max-width: 1100px) {
    .row--h-break-tablet {
        -webkit-box-align: start;
        align-items: flex-start;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .row {
        margin-left: -20px;
        margin-right: -20px;
    }
}
@media (max-width: 1100px) {
    .row {
        margin-left: -20px;
        margin-right: -20px;
    }
}
@media (max-width: 660px) {
    .row {
        margin-left: -10px;
        margin-right: -10px;
    }
}
[class*="cell-"] {
    padding-left: 20px;
    padding-right: 20px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    [class*="cell-"] {
        padding-left: 20px;
        padding-right: 20px;
    }
}
@media (max-width: 1100px) {
    [class*="cell-"] {
        padding-left: 20px;
        padding-right: 20px;
    }
}
@media (max-width: 660px) {
    [class*="cell-"] {
        padding-left: 10px;
        padding-right: 10px;
    }
}
.cell-1 {
    width: 8.3333333333%;
}
.prepend-1 {
    margin-left: 8.3333333333%;
}
.append-1 {
    margin-right: 8.3333333333%;
}
.pull-1 {
    position: relative;
    left: -8.3333333333%;
}
.push-1 {
    position: relative;
    right: -8.3333333333%;
}
.cell-2 {
    width: 16.6666666667%;
}
.prepend-2 {
    margin-left: 16.6666666667%;
}
.append-2 {
    margin-right: 16.6666666667%;
}
.pull-2 {
    position: relative;
    left: -16.6666666667%;
}
.push-2 {
    position: relative;
    right: -16.6666666667%;
}
.cell-3 {
    width: 25%;
}
.prepend-3 {
    margin-left: 25%;
}
.append-3 {
    margin-right: 25%;
}
.pull-3 {
    position: relative;
    left: -25%;
}
.push-3 {
    position: relative;
    right: -25%;
}
.cell-4 {
    width: 33.3333333333%;
}
.prepend-4 {
    margin-left: 33.3333333333%;
}
.append-4 {
    margin-right: 33.3333333333%;
}
.pull-4 {
    position: relative;
    left: -33.3333333333%;
}
.push-4 {
    position: relative;
    right: -33.3333333333%;
}
.cell-5 {
    width: 41.6666666667%;
}
.prepend-5 {
    margin-left: 41.6666666667%;
}
.append-5 {
    margin-right: 41.6666666667%;
}
.pull-5 {
    position: relative;
    left: -41.6666666667%;
}
.push-5 {
    position: relative;
    right: -41.6666666667%;
}
.cell-6 {
    width: 50%;
}
.prepend-6 {
    margin-left: 50%;
}
.append-6 {
    margin-right: 50%;
}
.pull-6 {
    position: relative;
    left: -50%;
}
.push-6 {
    position: relative;
    right: -50%;
}
.cell-7 {
    width: 58.3333333333%;
}
.prepend-7 {
    margin-left: 58.3333333333%;
}
.append-7 {
    margin-right: 58.3333333333%;
}
.pull-7 {
    position: relative;
    left: -58.3333333333%;
}
.push-7 {
    position: relative;
    right: -58.3333333333%;
}
.cell-8 {
    width: 66.6666666667%;
}
.prepend-8 {
    margin-left: 66.6666666667%;
}
.append-8 {
    margin-right: 66.6666666667%;
}
.pull-8 {
    position: relative;
    left: -66.6666666667%;
}
.push-8 {
    position: relative;
    right: -66.6666666667%;
}
.cell-9 {
    width: 75%;
}
.prepend-9 {
    margin-left: 75%;
}
.append-9 {
    margin-right: 75%;
}
.pull-9 {
    position: relative;
    left: -75%;
}
.push-9 {
    position: relative;
    right: -75%;
}
.cell-10 {
    width: 83.3333333333%;
}
.prepend-10 {
    margin-left: 83.3333333333%;
}
.append-10 {
    margin-right: 83.3333333333%;
}
.pull-10 {
    position: relative;
    left: -83.3333333333%;
}
.push-10 {
    position: relative;
    right: -83.3333333333%;
}
.cell-11 {
    width: 91.6666666667%;
}
.prepend-11 {
    margin-left: 91.6666666667%;
}
.append-11 {
    margin-right: 91.6666666667%;
}
.pull-11 {
    position: relative;
    left: -91.6666666667%;
}
.push-11 {
    position: relative;
    right: -91.6666666667%;
}
.cell-12 {
    width: 100%;
}
.prepend-12 {
    margin-left: 100%;
}
.append-12 {
    margin-right: 100%;
}
.pull-12 {
    position: relative;
    left: -100%;
}
.push-12 {
    position: relative;
    right: -100%;
}
@media (max-width: 1100px) {
    [class*="cell-"] {
        width: 100%;
    }
    [class*="prepend-"] {
        margin-left: 0;
    }
    [class*="append-"] {
        margin-right: 0;
    }
    [class*="pull-"] {
        left: inherit;
        position: inherit;
    }
    [class*="push-"] {
        right: inherit;
        position: inherit;
    }
    .cell-t-1 {
        width: 8.3333333333%;
    }
    .prepend-t-1 {
        margin-left: 8.3333333333%;
    }
    .append-t-1 {
        margin-right: 8.3333333333%;
    }
    .pull-t-1 {
        position: relative;
        left: -8.3333333333%;
    }
    .push-t-1 {
        position: relative;
        right: -8.3333333333%;
    }
    .cell-t-2 {
        width: 16.6666666667%;
    }
    .prepend-t-2 {
        margin-left: 16.6666666667%;
    }
    .append-t-2 {
        margin-right: 16.6666666667%;
    }
    .pull-t-2 {
        position: relative;
        left: -16.6666666667%;
    }
    .push-t-2 {
        position: relative;
        right: -16.6666666667%;
    }
    .cell-t-3 {
        width: 25%;
    }
    .prepend-t-3 {
        margin-left: 25%;
    }
    .append-t-3 {
        margin-right: 25%;
    }
    .pull-t-3 {
        position: relative;
        left: -25%;
    }
    .push-t-3 {
        position: relative;
        right: -25%;
    }
    .cell-t-4 {
        width: 33.3333333333%;
    }
    .prepend-t-4 {
        margin-left: 33.3333333333%;
    }
    .append-t-4 {
        margin-right: 33.3333333333%;
    }
    .pull-t-4 {
        position: relative;
        left: -33.3333333333%;
    }
    .push-t-4 {
        position: relative;
        right: -33.3333333333%;
    }
    .cell-t-5 {
        width: 41.6666666667%;
    }
    .prepend-t-5 {
        margin-left: 41.6666666667%;
    }
    .append-t-5 {
        margin-right: 41.6666666667%;
    }
    .pull-t-5 {
        position: relative;
        left: -41.6666666667%;
    }
    .push-t-5 {
        position: relative;
        right: -41.6666666667%;
    }
    .cell-t-6 {
        width: 50%;
    }
    .prepend-t-6 {
        margin-left: 50%;
    }
    .append-t-6 {
        margin-right: 50%;
    }
    .pull-t-6 {
        position: relative;
        left: -50%;
    }
    .push-t-6 {
        position: relative;
        right: -50%;
    }
    .cell-t-7 {
        width: 58.3333333333%;
    }
    .prepend-t-7 {
        margin-left: 58.3333333333%;
    }
    .append-t-7 {
        margin-right: 58.3333333333%;
    }
    .pull-t-7 {
        position: relative;
        left: -58.3333333333%;
    }
    .push-t-7 {
        position: relative;
        right: -58.3333333333%;
    }
    .cell-t-8 {
        width: 66.6666666667%;
    }
    .prepend-t-8 {
        margin-left: 66.6666666667%;
    }
    .append-t-8 {
        margin-right: 66.6666666667%;
    }
    .pull-t-8 {
        position: relative;
        left: -66.6666666667%;
    }
    .push-t-8 {
        position: relative;
        right: -66.6666666667%;
    }
    .cell-t-9 {
        width: 75%;
    }
    .prepend-t-9 {
        margin-left: 75%;
    }
    .append-t-9 {
        margin-right: 75%;
    }
    .pull-t-9 {
        position: relative;
        left: -75%;
    }
    .push-t-9 {
        position: relative;
        right: -75%;
    }
    .cell-t-10 {
        width: 83.3333333333%;
    }
    .prepend-t-10 {
        margin-left: 83.3333333333%;
    }
    .append-t-10 {
        margin-right: 83.3333333333%;
    }
    .pull-t-10 {
        position: relative;
        left: -83.3333333333%;
    }
    .push-t-10 {
        position: relative;
        right: -83.3333333333%;
    }
    .cell-t-11 {
        width: 91.6666666667%;
    }
    .prepend-t-11 {
        margin-left: 91.6666666667%;
    }
    .append-t-11 {
        margin-right: 91.6666666667%;
    }
    .pull-t-11 {
        position: relative;
        left: -91.6666666667%;
    }
    .push-t-11 {
        position: relative;
        right: -91.6666666667%;
    }
    .cell-t-12 {
        width: 100%;
    }
    .prepend-t-12 {
        margin-left: 100%;
    }
    .append-t-12 {
        margin-right: 100%;
    }
    .pull-t-12 {
        position: relative;
        left: -100%;
    }
    .push-t-12 {
        position: relative;
        right: -100%;
    }
}
@media (max-width: 660px) {
    [class*="cell-t-"] {
        width: 100%;
    }
    [class*="prepend-t-"] {
        margin-left: 0;
    }
    [class*="append-t-"] {
        margin-right: 0;
    }
    [class*="pull-t-"] {
        left: inherit;
        position: inherit;
    }
    [class*="push-t-"] {
        right: inherit;
        position: inherit;
    }
    .cell-m-1 {
        width: 8.3333333333%;
    }
    .prepend-m-1 {
        margin-left: 8.3333333333%;
    }
    .append-m-1 {
        margin-right: 8.3333333333%;
    }
    .pull-m-1 {
        position: relative;
        left: -8.3333333333%;
    }
    .push-m-1 {
        position: relative;
        right: -8.3333333333%;
    }
    .cell-m-2 {
        width: 16.6666666667%;
    }
    .prepend-m-2 {
        margin-left: 16.6666666667%;
    }
    .append-m-2 {
        margin-right: 16.6666666667%;
    }
    .pull-m-2 {
        position: relative;
        left: -16.6666666667%;
    }
    .push-m-2 {
        position: relative;
        right: -16.6666666667%;
    }
    .cell-m-3 {
        width: 25%;
    }
    .prepend-m-3 {
        margin-left: 25%;
    }
    .append-m-3 {
        margin-right: 25%;
    }
    .pull-m-3 {
        position: relative;
        left: -25%;
    }
    .push-m-3 {
        position: relative;
        right: -25%;
    }
    .cell-m-4 {
        width: 33.3333333333%;
    }
    .prepend-m-4 {
        margin-left: 33.3333333333%;
    }
    .append-m-4 {
        margin-right: 33.3333333333%;
    }
    .pull-m-4 {
        position: relative;
        left: -33.3333333333%;
    }
    .push-m-4 {
        position: relative;
        right: -33.3333333333%;
    }
    .cell-m-5 {
        width: 41.6666666667%;
    }
    .prepend-m-5 {
        margin-left: 41.6666666667%;
    }
    .append-m-5 {
        margin-right: 41.6666666667%;
    }
    .pull-m-5 {
        position: relative;
        left: -41.6666666667%;
    }
    .push-m-5 {
        position: relative;
        right: -41.6666666667%;
    }
    .cell-m-6 {
        width: 50%;
    }
    .prepend-m-6 {
        margin-left: 50%;
    }
    .append-m-6 {
        margin-right: 50%;
    }
    .pull-m-6 {
        position: relative;
        left: -50%;
    }
    .push-m-6 {
        position: relative;
        right: -50%;
    }
    .cell-m-7 {
        width: 58.3333333333%;
    }
    .prepend-m-7 {
        margin-left: 58.3333333333%;
    }
    .append-m-7 {
        margin-right: 58.3333333333%;
    }
    .pull-m-7 {
        position: relative;
        left: -58.3333333333%;
    }
    .push-m-7 {
        position: relative;
        right: -58.3333333333%;
    }
    .cell-m-8 {
        width: 66.6666666667%;
    }
    .prepend-m-8 {
        margin-left: 66.6666666667%;
    }
    .append-m-8 {
        margin-right: 66.6666666667%;
    }
    .pull-m-8 {
        position: relative;
        left: -66.6666666667%;
    }
    .push-m-8 {
        position: relative;
        right: -66.6666666667%;
    }
    .cell-m-9 {
        width: 75%;
    }
    .prepend-m-9 {
        margin-left: 75%;
    }
    .append-m-9 {
        margin-right: 75%;
    }
    .pull-m-9 {
        position: relative;
        left: -75%;
    }
    .push-m-9 {
        position: relative;
        right: -75%;
    }
    .cell-m-10 {
        width: 83.3333333333%;
    }
    .prepend-m-10 {
        margin-left: 83.3333333333%;
    }
    .append-m-10 {
        margin-right: 83.3333333333%;
    }
    .pull-m-10 {
        position: relative;
        left: -83.3333333333%;
    }
    .push-m-10 {
        position: relative;
        right: -83.3333333333%;
    }
    .cell-m-11 {
        width: 91.6666666667%;
    }
    .prepend-m-11 {
        margin-left: 91.6666666667%;
    }
    .append-m-11 {
        margin-right: 91.6666666667%;
    }
    .pull-m-11 {
        position: relative;
        left: -91.6666666667%;
    }
    .push-m-11 {
        position: relative;
        right: -91.6666666667%;
    }
    .cell-m-12 {
        width: 100%;
    }
    .prepend-m-12 {
        margin-left: 100%;
    }
    .append-m-12 {
        margin-right: 100%;
    }
    .pull-m-12 {
        position: relative;
        left: -100%;
    }
    .push-m-12 {
        position: relative;
        right: -100%;
    }
}
.dev-grid {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    max-width: 100%;
    height: 100%;
    z-index: 100;
    pointer-events: none;
}
.dev-grid .grid {
    height: 100%;
}
.dev-grid .row {
    height: 100%;
}
.dev-grid [class*="cell-"] {
    position: relative;
    height: 100%;
}
.dev-grid [class*="cell-"]:before {
    content: "";
    width: 100%;
    height: 100vh;
    display: block;
    background-color: rgba(255, 0, 0, 0.2);
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .dev-grid [class*="cell-"]:before {
        background-color: rgba(255, 165, 0, 0.2);
    }
}
@media (max-width: 1100px) {
    .dev-grid [class*="cell-"]:before {
        background-color: rgba(0, 128, 0, 0.2);
    }
}
@media (max-width: 660px) {
    .dev-grid [class*="cell-"]:before {
        background-color: rgba(0, 0, 255, 0.2);
    }
}
.dev-grid__btn {
    position: fixed;
    z-index: 100;
    bottom: 25px;
    left: 25px;
    width: 30px;
    height: 30px;
    border-radius: 30px;
    color: #fff;
    text-transform: uppercase;
    background-color: #000;
    border: none;
    outline: 0;
    cursor: pointer;
}
.dev-grid__btn span {
    width: 2px;
    height: 10px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background: #fff;
}
.dev-grid__btn span:nth-child(1) {
    -webkit-transform: translateX(-4px);
    transform: translateX(-4px);
}
.dev-grid__btn span:nth-child(3) {
    -webkit-transform: translateX(4px);
    transform: translateX(4px);
}
.dev-grid.is-hidden {
    display: none;
}
@media (max-width: 1100px) {
    .dev-grid__button {
        display: none;
    }
}
.contain {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    -o-object-fit: contain;
    object-fit: contain;
    font-family: "object-fit: contain;";
}
.contain[contain-position="top"] {
    -o-object-position: top;
    object-position: top;
    font-family: "object-fit: contain; object-position: top;";
}
.contain[contain-position="right"] {
    -o-object-position: right;
    object-position: right;
    font-family: "object-fit: contain; object-position: right;";
}
.contain[contain-position="bottom"] {
    -o-object-position: bottom;
    object-position: bottom;
    font-family: "object-fit: contain; object-position: bottom;";
}
.contain[contain-position="left"] {
    -o-object-position: left;
    object-position: left;
    font-family: "object-fit: contain; object-position: left;";
}
.cover,
.videocover {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    z-index: -1;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
}
.cover[cover-position="top"],
.videocover[cover-position="top"] {
    -o-object-position: top;
    object-position: top;
    font-family: "object-fit: cover; object-position: top;";
}
.cover[cover-position="right"],
.videocover[cover-position="right"] {
    -o-object-position: right;
    object-position: right;
    font-family: "object-fit: cover; object-position: right;";
}
.cover[cover-position="bottom"],
.videocover[cover-position="bottom"] {
    -o-object-position: bottom;
    object-position: bottom;
    font-family: "object-fit: cover; object-position: bottom;";
}
.cover[cover-position="left"],
.videocover[cover-position="left"] {
    -o-object-position: left;
    object-position: left;
    font-family: "object-fit: cover; object-position: left;";
}
::-moz-selection {
    background: #000;
    color: #fff;
}
::selection {
    background: #000;
    color: #fff;
}
::-moz-selection {
    background: #000;
    color: #fff;
}
[reveal-hidden-lazy],
[reveal-hidden] {
    opacity: 0;
    will-change: opacity, transform;
}
html.has-scroll-smooth {
    overflow: hidden;
}
html.has-scroll-smooth body {
    overflow: hidden;
}
html.has-scroll-dragging {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.c-scrollbar {
    position: absolute;
    right: 0;
    top: 0;
    width: 10px;
    height: 100vh;
    z-index: 99999999;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
    opacity: 0;
}
.c-scrollbar:hover,
.has-scroll-dragging .c-scrollbar,
.has-scroll-scrolling .c-scrollbar {
    opacity: 1;
}
.c-scrollbar_thumb {
    position: absolute;
    top: 0;
    right: 0;
    background-color: #000;
    opacity: 1;
    width: 7px;
    cursor: -webkit-grab;
    cursor: grab;
}
.c-scrollbar_thumb .has-scroll-dragging {
    cursor: -webkit-grabbing;
    cursor: grabbing;
}
html {
    font-family: niveau-grotesk, Helvetica, Arial, sans-serif;
    /*overflow-x: hidden;*/
}
html:not(.has-scroll-init) {
    /*overflow: hidden;*/
}
.appcont {
    overflow: hidden;
}
.pagecont {
    /*opacity: 0;*/
}
.foot {
    opacity: 0;
}
.jolynavbar--logo {
    position: fixed;
    top: 30px;
    left: 0;
    right: 0;
    width: 240px;
    z-index: 99999;
    margin: auto;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
}
@media (max-width: 1100px) {
    .jolynavbar--logo {
        top: 26px;
    }
}
@media (max-width: 660px) {
    .jolynavbar--logo {
        top: 20px;
    }
}
@media (max-width: 1100px) {
    .jolynavbar--logo {
        width: 204px;
    }
}
@media (max-width: 660px) {
    .jolynavbar--logo {
        width: 156px;
    }
}
.jolynavbar--logo a {
    display: block;
}
.jolynavbar--logo a svg {
    display: block;
    width: 240px;
    height: 24px;
}
@media (max-width: 1100px) {
    .jolynavbar--logo a svg {
        width: 204px;
        height: 20.4px;
    }
}
@media (max-width: 660px) {
    .jolynavbar--logo a svg {
        width: 156px;
        height: 15.6px;
    }
}
@media (min-width: 1101px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--logo {
        -webkit-transform: translateY(-16px) scale(0.8);
        transform: translateY(-16px) scale(0.8);
    }
}
@media (max-width: 1100px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--logo {
        -webkit-transform: translateY(-14px) scale(0.86);
        transform: translateY(-14px) scale(0.86);
    }
}
@media (max-width: 660px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--logo {
        -webkit-transform: translateY(-14px) scale(0.85);
        transform: translateY(-14px) scale(0.85);
    }
}
.jolynavbar--bg {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 96px;
    z-index: 99997;
    background: #fff;
    pointer-events: none;
}
@media (max-width: 1100px) {
    .jolynavbar--bg {
        height: 90px;
    }
}
@media (max-width: 660px) {
    .jolynavbar--bg {
        height: 70px;
    }
}
@media (min-width: 1101px) {
    .jolynavbar--bg {
        -webkit-transform: scaleY(1.9);
        transform: scaleY(1.9);
    }
}
@media (max-width: 1100px) {
    .jolynavbar--bg {
        -webkit-transform: scaleY(1.65);
        transform: scaleY(1.65);
    }
}
@media (max-width: 660px) {
    .jolynavbar--bg {
        -webkit-transform: scaleY(1.55);
        transform: scaleY(1.55);
    }
}
@media (min-width: 1101px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--bg {
        -webkit-transform: translateY(-44px) scaleY(1.9);
        transform: translateY(-44px) scaleY(1.9);
    }
}
@media (max-width: 1100px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--bg {
        -webkit-transform: translateY(-30px) scaleY(1.65);
        transform: translateY(-30px) scaleY(1.65);
    }
}
@media (max-width: 660px) {
    #jolynav.can-reduct.js-scrolled .jolynavbar--bg {
        -webkit-transform: translateY(-20px) scaleY(1.55);
        transform: translateY(-20px) scaleY(1.55);
    }
}
.burger {
    cursor: pointer;
    z-index: 99999;
    position: fixed;
    top: 70px;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    right: 0;
    left: 0;
    margin: auto;
    width: 50px;
    height: 50px;
}
@media (max-width: 1100px) {
    .burger {
        top: 60px;
    }
}
@media (max-width: 660px) {
    .burger {
        top: 40px;
    }
}
@media (min-width: 1101px) {
    #jolynav.can-reduct.js-scrolled .burger {
        -webkit-transform: translateY(-30px);
        transform: translateY(-30px);
    }
}
@media (max-width: 1100px) {
    #jolynav.can-reduct.js-scrolled .burger {
        -webkit-transform: translateY(-26px);
        transform: translateY(-26px);
    }
}
@media (max-width: 660px) {
    #jolynav.can-reduct.js-scrolled .burger {
        -webkit-transform: translateY(-20px);
        transform: translateY(-20px);
    }
}
.burger div {
    width: 24px;
    height: 2px;
    background: #000;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    margin: auto;
    will-change: transform;
    -webkit-transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
}
.burger div:nth-child(1) {
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
}
.burger div:nth-child(2) {
    -webkit-transition-delay: 150ms;
    transition-delay: 150ms;
}
.burger div:nth-child(3) {
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
}
.burger div:nth-child(4) {
    -webkit-transition-delay: 50ms;
    transition-delay: 50ms;
}
.burger div:nth-child(5) {
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
}
.burger div:nth-child(1) {
    -webkit-transform: translateY(-7px) scaleX(1);
    transform: translateY(-7px) scaleX(1);
}
.burger div:nth-child(2) {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
}
.burger div:nth-child(3) {
    -webkit-transform: translateY(7px) scaleX(1);
    transform: translateY(7px) scaleX(1);
}
.burger div:nth-child(4) {
    -webkit-transform: rotate(45deg) scaleX(0);
    transform: rotate(45deg) scaleX(0);
}
.burger div:nth-child(5) {
    -webkit-transform: rotate(-45deg) scaleX(0);
    transform: rotate(-45deg) scaleX(0);
}
.nav-deployed .burger div:nth-child(3) {
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
}
.nav-deployed .burger div:nth-child(2) {
    -webkit-transition-delay: 50ms;
    transition-delay: 50ms;
}
.nav-deployed .burger div:nth-child(1) {
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
}
.nav-deployed .burger div:nth-child(4) {
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
}
.nav-deployed .burger div:nth-child(5) {
    -webkit-transition-delay: 150ms;
    transition-delay: 150ms;
}
.nav-deployed .burger div:nth-child(1) {
    -webkit-transform: translateY(-7px) scaleX(0);
    transform: translateY(-7px) scaleX(0);
}
.nav-deployed .burger div:nth-child(2) {
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
}
.nav-deployed .burger div:nth-child(3) {
    -webkit-transform: translateY(7px) scaleX(0);
    transform: translateY(7px) scaleX(0);
}
.nav-deployed .burger div:nth-child(4) {
    -webkit-transform: rotate(45deg) scaleX(1);
    transform: rotate(45deg) scaleX(1);
}
.nav-deployed .burger div:nth-child(5) {
    -webkit-transform: rotate(-45deg) scaleX(1);
    transform: rotate(-45deg) scaleX(1);
}
.burger:hover div {
    background: #999;
}
html:not(.nav-deployed) .navlay {
    pointer-events: none;
}
.navlay {
    position: relative;
    z-index: 99998;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
	opacity: 0;
    pointer-events: none;
}
html.nav-deployed .navlay {
    opacity: 1;
    pointer-events: auto;
}
.navlay--bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: #fff;
    opacity: 0;
}
.navlay--container {
    position: relative;
    z-index: 9910;
    color: #000;
    min-height: 100%;
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
}
@media (max-width: 660px) {
    .navlay--container {
        padding-top: 40px;
    }
}
.navlay--nav {
    font-size: 24px;
    font-size: 1.5rem;
    font-weight: 300;
    text-align: center;
    letter-spacing: 0.04em;
}
@media (max-width: 1100px) {
    .navlay--nav {
        font-size: 22px;
        font-size: 1.375rem;
    }
}
@media (max-width: 660px) {
    .navlay--nav {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
.navlay--nav li {
    margin: 1em 0;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .navlay--nav li {
        margin: 0.75em 0;
    }
}
@media (max-width: 660px) {
    .navlay--nav li {
        margin: 0.5em 0;
    }
}
.navlay--nav li a {
    -webkit-transform: translateY(110%);
    transform: translateY(110%);
}
.navlay--nav .link-current-page {
    color: #cdcdcd;
}
.navresp--lang {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    opacity: 0;
    -webkit-transform: translateY(10px);
    transform: translateY(10px);
    font-size: 20px;
    font-size: 1.25rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-align: center;
}
@media (max-width: 1100px) {
    .navresp--lang {
        bottom: 16px;
    }
}
@media (max-width: 660px) {
    .navresp--lang {
        bottom: 10px;
    }
}
@media (max-width: 1100px) {
    .navresp--lang {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
@media (max-width: 660px) {
    .navresp--lang {
        font-size: 16px;
        font-size: 1rem;
    }
}
.navresp--lang li {
    display: inline-block;
}
.navresp--lang li:not(:first-child)::before {
    content: "/";
    padding-right: 0.25em;
    padding-left: 0.25em;
    display: inline-block;
    vertical-align: middle;
}
.navresp--lang li a {
    letter-spacing: 0.04em;
}
.blink {
    text-decoration: none;
    position: relative;
    overflow: hidden;
    display: inline-block;
    vertical-align: middle;
}
.blink .blink--padder {
    overflow: hidden;
    position: relative;
}
.blink .blink--normal {
    -webkit-transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
}
.blink .blink--hover {
    -webkit-transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.75s cubic-bezier(0.19, 1, 0.22, 1);
    color: currentcolor;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transform: translateY(110%);
    transform: translateY(110%);
}
.blink:hover .blink--normal {
    -webkit-transform: translateY(-110%);
    transform: translateY(-110%);
}
.blink:hover .blink--hover {
    -webkit-transform: translateY(0);
    transform: translateY(0);
}
.bmarkup {
    margin: auto;
    max-width: 600px;
}
.bmarkup h1,
.bmarkup h2,
.bmarkup h3,
.bmarkup h4,
.bmarkup h5,
.bmarkup h6 {
    font-weight: 500;
    margin-bottom: 1em;
}
.bmarkup h1:not(first-child),
.bmarkup h2:not(first-child),
.bmarkup h3:not(first-child),
.bmarkup h4:not(first-child),
.bmarkup h5:not(first-child),
.bmarkup h6:not(first-child) {
    margin-top: 2em;
}
.bmarkup p {
    margin-bottom: 1em;
}
.bmarkup dl,
.bmarkup ol,
.bmarkup ul {
    margin-bottom: 1em;
}
.bmarkup h1 {
    font-size: 160%;
}
.bmarkup h2 {
    font-size: 150%;
}
.bmarkup h3 {
    font-size: 140%;
}
.bmarkup h4 {
    font-size: 130%;
}
.bmarkup h5 {
    font-size: 120%;
}
.bmarkup h6 {
    font-size: 110%;
}
.markup h1,
.markup h2,
.markup h3,
.markup h4,
.markup h5,
.markup h6 {
    font-weight: 500;
    margin-bottom: 1em;
}
.markup h1:not(first-child),
.markup h2:not(first-child),
.markup h3:not(first-child),
.markup h4:not(first-child),
.markup h5:not(first-child),
.markup h6:not(first-child) {
    margin-top: 2em;
}
.markup p {
    margin-bottom: 1em;
}
.markup dl,
.markup ol,
.markup ul {
    margin-bottom: 1em;
}
.markup h1 {
    font-size: 160%;
}
.markup h2 {
    font-size: 150%;
}
.markup h3 {
    font-size: 140%;
}
.markup h4 {
    font-size: 130%;
}
.markup h5 {
    font-size: 120%;
}
.markup h6 {
    font-size: 110%;
}
.bcenter {
    margin: 0 60px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .bcenter {
        margin: 0 40px;
    }
}
@media (max-width: 1100px) {
    .bcenter {
        margin: 0 40px;
    }
}
@media (max-width: 660px) {
    .bcenter {
        margin: 0 20px;
    }
}
.btitle {
    position: relative;
    padding-bottom: 1em;
    font-size: 22px;
    font-size: 1.375rem;
    line-height: 1.1176470588;
}
@media (max-width: 1100px) {
    .btitle {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .btitle {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.btitle.btitle__single {
    line-height: 1.2;
    font-size: 24px;
    font-size: 1.5rem;
    font-weight: 300;
    letter-spacing: 0.04em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .btitle.btitle__single {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .btitle.btitle__single {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1;
    }
}
@media (max-width: 660px) {
    .btitle.btitle__single {
        font-size: 18px;
        font-size: 1.125rem;
        line-height: 1;
    }
}
.btitle.-small {
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 1.1176470588;
}
@media (max-width: 1100px) {
    .btitle.-small {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .btitle.-small {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
.btitle--text {
    letter-spacing: 0.12em;
    font-weight: inherit;
    text-transform: uppercase;
    overflow: hidden;
}
.btitle__single .btitle--text {
    text-transform: initial;
}
.btitle--stroke {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 2px;
    background: #000;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
}
@media (max-width: 1100px) {
    .btitle--stroke {
        width: 40px;
    }
}
@media (max-width: 660px) {
    .btitle--stroke {
        width: 30px;
    }
}
.homess {
    margin-bottom: 40px;
    position: relative;
}
.homess .btnbrd {
    z-index: 20000;
    position: absolute;
    margin: auto;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    bottom: 10%;
    display: none;
}
@media (max-width: 1100px) {
    .homess .btnbrd {
        bottom: 8%;
    }
}
@media (max-width: 660px) {
    .homess .btnbrd {
        bottom: 8%;
    }
}
.homess.-moving {
    cursor: pointer;
}
.homess--sscont {
    padding: 0 150px;
    position: relative;
}
@media (max-width: 1100px) {
    .homess--sscont {
        padding: 0 40px;
    }
}
@media (max-width: 660px) {
    .homess--sscont {
        padding: 0 20px;
    }
}
.homess--next,
.homess--prev {
    z-index: 100;
    cursor: pointer;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    padding: 30px;
}
.homess--next.homess--prev,
.homess--prev.homess--prev {
    left: 16px;
}
.homess--next.homess--next,
.homess--prev.homess--next {
    right: 16px;
}
@media (max-width: 1100px) {
    .homess--next.homess--prev,
    .homess--prev.homess--prev {
        left: 32px;
    }
    .homess--next.homess--next,
    .homess--prev.homess--next {
        right: 32px;
    }
}
@media (max-width: 660px) {
    .homess--next.homess--prev,
    .homess--prev.homess--prev {
        left: 16px;
    }
    .homess--next.homess--next,
    .homess--prev.homess--next {
        right: 16px;
    }
}
@media (max-width: 1100px) {
    .homess--next,
    .homess--prev {
        background: #fff;
    }
}
@media (max-width: 660px) {
    .homess--next,
    .homess--prev {
        background: #fff;
    }
}
@media (max-width: 1100px) {
    .homess--next,
    .homess--prev {
        padding: 20px;
    }
}
@media (max-width: 660px) {
    .homess--next,
    .homess--prev {
        padding: 10px;
    }
}
.homess--next svg,
.homess--prev svg {
    width: 32px;
    height: 32px;
    display: block;
}
@media (max-width: 1100px) {
    .homess--next svg,
    .homess--prev svg {
        width: 28px;
        height: 28px;
    }
}
@media (max-width: 660px) {
    .homess--next svg,
    .homess--prev svg {
        width: 24px;
        height: 24px;
    }
}
.homess--next svg path,
.homess--prev svg path {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    stroke-dasharray: 33.16338348388672px;
    stroke-dashoffset: 0;
}
.js-complexified .homess--next.homess--prev:hover svg path:nth-child(2),
.js-complexified .homess--prev.homess--prev:hover svg path:nth-child(2) {
    stroke-dashoffset: -10px;
}
.js-complexified .homess--next.homess--next:hover svg path:nth-child(1),
.js-complexified .homess--prev.homess--next:hover svg path:nth-child(1) {
    stroke-dashoffset: -10px;
}
.js-complexified.js-safari .homess--next.homess--prev:hover svg path:nth-child(2),
.js-complexified.js-safari .homess--prev.homess--prev:hover svg path:nth-child(2) {
    stroke-dashoffset: 10px;
}
.js-complexified.js-safari .homess--next.homess--next:hover svg path:nth-child(1),
.js-complexified.js-safari .homess--prev.homess--next:hover svg path:nth-child(1) {
    stroke-dashoffset: 10px;
}
.homess--ss {
    position: relative;
    width: 100%;
    height: calc(100vh - 140px - 140px);
    overflow: hidden;
    cursor: pointer;
}
@media (max-width: 1100px) {
    .homess--ss {
        height: calc(100vh - 120px - 100px);
    }
}
@media (max-width: 660px) {
    .homess--ss {
        height: 90vw !important;
    }
}
.js-simplified .homess--ss {
    height: auto;
    min-height: 200px;
}
.homess--item {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    display: -webkit-box;
    display: flex;
    -webkit-transition: 1s opacity cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s opacity cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
    pointer-events: none;
}
.homess--item.js-active {
    opacity: 1;
    pointer-events: auto;
}
.homess--item-arc,
.homess--item-round {
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 280px;
    height: 280px;
    border-radius: 50%;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .homess--item-arc,
    .homess--item-round {
        width: 250px;
        height: 250px;
    }
}
@media (max-width: 1100px) {
    .homess--item-arc,
    .homess--item-round {
        width: 230px;
        height: 230px;
    }
}
@media (max-width: 660px) {
    .homess--item-arc,
    .homess--item-round {
        width: 200px;
        height: 200px;
    }
}
.homess--item-arc::before {
    content: "";
    position: absolute;
    top: 22px;
    right: 22px;
    bottom: 22px;
    left: 22px;
    background: #fff;
    z-index: 10;
    border-radius: 50%;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .homess--item-arc::before {
        top: 20px;
        right: 20px;
        bottom: 20px;
        left: 20px;
    }
}
@media (max-width: 1100px) {
    .homess--item-arc::before {
        top: 18px;
        right: 18px;
        bottom: 18px;
        left: 18px;
    }
}
@media (max-width: 660px) {
    .homess--item-arc::before {
        top: 15px;
        right: 15px;
        bottom: 15px;
        left: 15px;
    }
}
.homess--item-arc-half {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    bottom: auto;
    height: 50%;
    width: 100%;
    overflow: hidden;
}
.homess--item-bg {
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: 30;
}
.homess--item-arc {
    z-index: 10;
    background: #fff;
}
.homess--item-round {
    z-index: 20;
}
.homess--item-arc,
.homess--item-bg,
.homess--item-round {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) opacity;
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1) opacity;
}
.homess--item-bg {
    opacity: 1;
}
.js-simplified .homess--item.js-active .homess--item-bg {
    opacity: 1;
}
.js-complexified .homess--item.js-active .homess--item-bg {
    opacity: 1;
}
.js-complexified .homess--sscont:hover .homess--item.js-active .homess--item-bg {
    opacity: 1;
}
.js-complexified .homess--sscont:hover .-moving .homess--item.js-active .homess--item-bg {
    opacity: 1;
}
.homess--item-arc {
    opacity: 1;
}
.js-simplified .homess--item.js-active .homess--item-arc {
    opacity: 0;
}
.homess--item-round {
    opacity: 0;
}
.js-simplified .homess--item.js-active .homess--item-round {
    opacity: 0;
}
.js-complexified .homess--item.js-active .homess--item-round {
    opacity: 0.5;
}
.js-complexified .-moving .homess--item.js-active .homess--item-round {
    opacity: 1;
}
.homess--item-img {
    position: absolute;
}
.homess--item-bg .-bis {
    z-index: 9000;
    display: none;
}
@media (max-width: 660px) {
    .homess--item-bg .-bis {
        display: block;
    }
}
.homess--item-title {
    display: none;
    position: absolute;
    bottom: 32.5%;
    left: 0;
    right: 0;
    z-index: 10;
    overflow: hidden;
    font-size: 50px;
    font-size: 3.125rem;
    line-height: 1;
    font-weight: 300;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    text-align: center;
}
@media (max-width: 1100px) {
    .homess--item-title {
        bottom: calc(50% - 120px);
    }
}
@media (max-width: 660px) {
    .homess--item-title {
        bottom: calc(50% - 90px);
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .homess--item-title {
        font-size: 36px;
        font-size: 2.25rem;
    }
}
@media (max-width: 1100px) {
    .homess--item-title {
        font-size: 30px;
        font-size: 1.875rem;
    }
}
@media (max-width: 660px) {
    .homess--item-title {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
.homess--item-title div {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1) -webkit-transform;
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1) -webkit-transform;
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1) transform;
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1) transform, 1s cubic-bezier(0.19, 1, 0.22, 1) -webkit-transform;
    -webkit-transform: translateY(106%);
    transform: translateY(106%);
}
.homess--item.js-active .homess--item-title div {
    -webkit-transform: translateY(0);
    transform: translateY(0);
}
.homess.-moving .homess--item.js-active .homess--item-title div {
    -webkit-transform: translateY(106%);
    transform: translateY(106%);
}
.homess--dots {
    display: -webkit-box;
    display: flex;
    padding: 40px 60px 80px;
    text-align: center;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
    position: relative;
}
@media (max-width: 1100px) {
    .homess--dots {
        padding: 30px 40px 50px;
    }
}
@media (max-width: 660px) {
    .homess--dots {
        padding: 10px 20px 30px;
    }
}
.homess--dot {
    padding: 8px;
    display: block;
    cursor: pointer;
}
@media (max-width: 1100px) {
    .homess--dot {
        padding: 12px;
    }
}
@media (max-width: 660px) {
    .homess--dot {
        padding: 12px;
    }
}
.homess--dot div {
    background: #cdcdcd;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
@media (max-width: 1100px) {
    .homess--dot div {
        width: 10px;
        height: 10px;
    }
}
@media (max-width: 660px) {
    .homess--dot div {
        width: 10px;
        height: 10px;
    }
}
.homess--dot:hover div {
    background: #666;
}
.homess--dot.js-active div {
    background: #000;
}
.homess--scroll {
    z-index: 10;
    text-align: center;
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    text-align: center;
}
@media (max-width: 1100px) {
    .homess--scroll {
        display: none;
    }
}
@media (max-width: 660px) {
    .homess--scroll {
        display: none;
    }
}
.homess--scroll .homess--scroll-btn {
    position: relative;
    width: 80px;
    height: 80px;
    display: inline-block;
    cursor: pointer;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .homess--scroll .homess--scroll-btn {
        width: 70px;
        height: 70px;
    }
}
.homess--scroll .homess--scroll-btn svg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    margin: auto;
    width: 32px;
    height: 32px;
    -webkit-transform: rotate(-90deg) translateX(0);
    transform: rotate(-90deg) translateX(0);
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
}
.homess--scroll .homess--scroll-btn svg path {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    stroke-dasharray: 33.16338348388672px;
    stroke-dashoffset: 0;
}
.js-complexified .homess--scroll .homess--scroll-btn:hover svg {
    opacity: 1;
    -webkit-transform: rotate(-90deg) translateX(0);
    transform: rotate(-90deg) translateX(0);
}
.js-complexified .homess--scroll .homess--scroll-btn:hover svg path:nth-child(2) {
    stroke-dashoffset: -10px;
}
.js-complexified.js-safari .homess--scroll .homess--scroll-btn:hover svg path:nth-child(2) {
    stroke-dashoffset: 10px;
}
.supagrid {
    padding: 36px 40px;
}
.supagrid:after,
.supagrid:before {
    content: "";
    display: table;
}
.supagrid:after {
    clear: both;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .supagrid {
        padding: 34px 20px 0;
    }
}
@media (max-width: 1100px) {
    .supagrid {
        padding: 34px 20px 0;
    }
}
@media (max-width: 660px) {
    .supagrid {
        padding: 30px 0;
    }
}
.supaitem {
    float: left;
    position: relative;
    padding: 0 20px;
	display: block;
  cursor: pointer;
}

.supaitem--imgc {
  position: relative;
  z-index: 1;
}

.supaitem--desc {
  position: relative;
  z-index: 2;
  pointer-events: none; /* le texte ne bloque plus le hover global */
}

.supaitem--desc a {
  pointer-events: auto; /* mais les liens internes restent cliquables */
}

@media (min-width: 1101px) {
    .supaitem {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transition-property: opacity;
        transition-property: opacity;
    }
    /*.supagrid.-hovering .supaitem {
        opacity: 0.5;
    }
    .supagrid.-hovering .supaitem.-hovering {
        opacity: 1;
    }*/
}
@media (min-width: 1101px) {
    .supaitem {
        margin-bottom: 120px;
        width: 75%;
        margin-right: 25%;
        float: left;
        display: flex;
        flex-direction: row;
    }

    /* 2e, 4e, 6e, ... à droite */
    .supaitem:nth-child(2n) {
        float: right;
        margin-left: 25%;
        margin-right: auto;
        flex-direction: row-reverse;
    }

}
@media (min-width: 1101px) and (max-width: 1440px) {
    .supaitem {
        margin-bottom: 100px;
    }
}

.supaitem--imgc {
    display: block;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 27vw;
}
@media (max-width: 1100px) {
    .supaitem--imgc {
        height: 32vw;
    }
}
@media (max-width: 660px) {
    .supaitem--imgc {
        height: 50vw;
    }
}
.supaitem--imgc-in {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    -webkit-transition: 3s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 3s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transform: scale(1);
    transform: scale(1);
}
.supaitem.-hovering .supaitem--imgc-in {
    -webkit-transform: scale(1.025);
    transform: scale(1.025);
}
/*
.supaitem--imgc-in img {
    display: none;
}
.supaitem--imgc-in img:not([src]) {
    display: none;
}
.supaitem--imgc-in img.js-active {
    display: block;
}
*/
@media (min-width: 1101px) {
    .supaitem--desc {
        position: absolute;
        bottom: 40px;
        width: 100%;
        pointer-events: none;
    }
    .supaitem.-hovering .supaitem--desc {
        pointer-events: auto;
    }
    .supaitem .supaitem--desc {
        left: 100%;
        padding: 20px;
    }
    .supaitem:nth-child(2n) .supaitem--desc {
        right: 100%;
        padding: 20px;
		text-align: right;
		left: auto;
    }

    
}
.supaitem--title {
    line-height: 1.2;
    font-size: 24px;
    font-size: 1.5rem;
    letter-spacing: 0.04em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .supaitem--title {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .supaitem--title {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1;
    }
}
@media (max-width: 660px) {
    .supaitem--title {
        font-size: 18px;
        font-size: 1.125rem;
        line-height: 1;
    }
}
@media (max-width: 1100px) {
    .supaitem--title {
        margin-top: 30px;
    }
}
@media (max-width: 660px) {
    .supaitem--title {
        margin-top: 20px;
    }
}
@media (min-width: 1101px) {
	/*
    .supaitem--title {
        overflow: hidden;
    }
    .supaitem--title div {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transition-property: -webkit-transform;
        transition-property: -webkit-transform;
        transition-property: transform;
        transition-property: transform, -webkit-transform;
        -webkit-transform: translateY(106%);
        transform: translateY(106%);
    }
    .supaitem.-hovering .supaitem--title div {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
	*/
}
.supaitem--btnc {
    overflow: hidden;
    display: none;
}
.supaitem--stupidstroke {
    display: inline-block;
    margin-top: 40px;
    width: 40px;
    height: 2px;
    background: #000;
}
@media (max-width: 1100px) {
    .supaitem--stupidstroke {
        margin-top: 30px;
    }
}
@media (max-width: 660px) {
    .supaitem--stupidstroke {
        margin-top: 20px;
    }
}
@media (max-width: 1100px) {
    .supaitem--stupidstroke {
        width: 40px;
    }
}
@media (max-width: 660px) {
    .supaitem--stupidstroke {
        width: 30px;
    }
}
/*
@media (min-width: 1101px) {
    .supaitem--stupidstroke {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transition-property: -webkit-transform;
        transition-property: -webkit-transform;
        transition-property: transform;
        transition-property: transform, -webkit-transform;
        -webkit-transform: scaleY(0);
        transform: scaleY(0);
    }
    .supaitem.-hovering .supaitem--stupidstroke {
        -webkit-transform: scaleY(1);
        transform: scaleY(1);
    }
}
.btnbrd {
    white-space: nowrap;
    font-size: 14px;
    font-size: 0.875rem;
    padding: 1.5em 2.5em;
    cursor: pointer;
    text-decoration: none;
    position: relative;
    display: block;
    position: relative;
    display: inline-block;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .btnbrd {
        font-size: 13px;
        font-size: 0.8125rem;
    }
}
@media (max-width: 660px) {
    .btnbrd {
        font-size: 12px;
        font-size: 0.75rem;
    }
}
@media (max-width: 1100px) {
    .btnbrd {
        padding: 1.45em 2.25em;
    }
}
@media (max-width: 660px) {
    .btnbrd {
        padding: 1.35em 2em;
    }
}
.btnbrd--text {
    line-height: 1;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}
.btnbrd--t {
    width: 100%;
    height: 2px;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    bottom: auto;
    background: #000;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transform: translateX(-24px);
    transform: translateX(-24px);
}
.js-complexified .btnbrd:hover .btnbrd--t {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
.btnbrd--b {
    width: 100%;
    height: 2px;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    top: auto;
    background: #000;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transform: translateX(24px);
    transform: translateX(24px);
}
.js-complexified .btnbrd:hover .btnbrd--b {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
.btnbrd--r {
    width: 2px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    left: auto;
    background: #000;
}
.btnbrd--l {
    width: 2px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    right: auto;
    background: #000;
}

.btnstr {
    padding: 30px 0;
    text-decoration: none;
    position: relative;
    display: inline-block;
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1;
    letter-spacing: 0.04em;
}
@media (max-width: 1100px) {
    .btnstr {
        padding: 16px 0 22px;
    }
}
@media (max-width: 660px) {
    .btnstr {
        padding: 14px 0 14px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .btnstr {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 1100px) {
    .btnstr {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .btnstr {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
.btnstr::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 2px;
    background: #000;
}
@media (max-width: 1100px) {
    .btnstr::after {
        width: 40px;
    }
}
@media (max-width: 660px) {
    .btnstr::after {
        width: 30px;
    }
}
@media (min-width: 1101px) {
    .supaitem .btnstr {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transition-property: -webkit-transform;
        transition-property: -webkit-transform;
        transition-property: transform;
        transition-property: transform, -webkit-transform;
        -webkit-transform: translateY(106%);
        transform: translateY(106%);
    }
    .supaitem.-hovering .btnstr {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}

*/
.sampleParallax {
    overflow: hidden;
    position: relative;
    height: 400px;
}
.grid__item-img {
    display: block;
    height: 500px;
    width: 500px;
    max-width: 100%;
}
.grid__item-img canvas {
    height: 500px;
    width: 500px;
}
.grid__item-img img {
    display: none;
}
#js-scroll {
    min-height: 100vh;
}
.foot {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    padding: 40px 60px;
    font-size: 18px;
    font-size: 1.125rem;
    letter-spacing: 0.02em;
}
@media (max-width: 660px) {
    .foot {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        flex-direction: column;
        -webkit-box-align: center;
        align-items: center;
        -webkit-box-pack: center;
        justify-content: center;
        text-align: center;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .foot {
        padding: 30px 40px;
    }
}
@media (max-width: 1100px) {
    .foot {
        padding: 40px;
    }
}
@media (max-width: 660px) {
    .foot {
        padding: 20px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .foot {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 1100px) {
    .foot {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .foot {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
.pcontact {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    width: 100%;
    height: auto;
    min-height: calc(100vh - 140px - 110px);
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pcontact {
        min-height: calc(100vh - 140px - 90px);
    }
}
@media (max-width: 1100px) {
    .pcontact {
        min-height: calc(100vh - 120px - 106px);
    }
}
@media (max-width: 660px) {
    .pcontact {
        min-height: calc(100vh - 90px - 100px);
    }
}
.pcontact--in {
    display: -webkit-box;
    display: flex;
    height: 100%;
    width: 100%;
    -webkit-box-align: center;
    align-items: center;
}
@media (max-width: 660px) {
    .pcontact--in {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        flex-direction: column-reverse;
    }
}
.pcontact--mapc {
    width: 50%;
}
@media (max-width: 660px) {
    .pcontact--mapc {
        width: 100%;
        margin-bottom: 2em;
    }
}
.pcontact--mapc img {
    display: block;
    width: 100%;
}
.pcontact--cont {
    width: 50%;
    padding-left: 80px;
}
@media (max-width: 660px) {
    .pcontact--cont {
        width: 100%;
    }
}
@media (max-width: 660px) {
    .pcontact--cont {
        padding: 40px 0;
    }
}
#mapid {
    width: 100%;
    height: 100%;
    min-height: 460px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    #mapid {
        min-height: 420px;
    }
}
@media (max-width: 1100px) {
    #mapid {
        min-height: 360px;
    }
}
@media (max-width: 660px) {
    #mapid {
        min-height: 260px;
    }
}
.pcontact--link {
    font-size: 22px;
    font-size: 1.0625rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-bottom: 1.25em;
    margin-top: 2em;
}
@media (max-width: 1100px) {
    .pcontact--link {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .pcontact--link {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.pcontact--text {
    font-size: 17px;
    font-size: 1.0625rem;
    line-height: 1.3;
    font-weight: 300;
    letter-spacing: 0.02em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pcontact--text {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
@media (max-width: 1100px) {
    .pcontact--text {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .pcontact--text {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
.pcontact--text p:not(:last-child) {
    margin-bottom: 1em;
}
.pcontact--social {
    margin-top: 2em;
}
@media (max-width: 1100px) {
    .pcontact--social {
        text-align: left;
        margin-top: 2em;
    }
}
@media (max-width: 660px) {
    .pcontact--social {
        text-align: left;
        margin-top: 4em;
    }
}
.pcontact--social ul {
    margin-top: 1em;
}
.pcontact--social ul li {
    display: inline-block;
    margin: 0.5em;
}
.pcontact--social ul li a {
    display: block;
    fill: #000;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}
.pcontact--social ul li a svg {
    width: 30px;
    height: 30px;
    display: block;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pcontact--social ul li a svg {
        width: 28px;
        height: 28px;
    }
}
@media (max-width: 1100px) {
    .pcontact--social ul li a svg {
        width: 24px;
        height: 24px;
    }
}
@media (max-width: 660px) {
    .pcontact--social ul li a svg {
        width: 22px;
        height: 22px;
    }
}
.pcontact--social ul li a:hover {
    fill: #878787;
}
.pagecont {
    padding-top: 140px;
}
@media (max-width: 1100px) {
    .pagecont {
        padding-top: 120px;
    }
}
@media (max-width: 660px) {
    .pagecont {
        padding-top: 90px;
    }
}
.pphead {
    height: calc(100vh - 140px - 60px);
    font-size: 22px;
    font-size: 1.375rem;
    margin-bottom: 3em;
    position: relative;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pphead {
        height: calc(100vh - 140px - 40px);
    }
}
@media (max-width: 1100px) {
    .pphead {
        height: auto;
    }
}
@media (max-width: 660px) {
    .pphead {
        height: auto;
    }
}
@media (max-width: 1100px) {
    .pphead {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .pphead {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.pphead--imgc {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .pphead--imgc {
        position: relative;
    }
}
@media (max-width: 660px) {
    .pphead--imgc {
        position: relative;
    }
}
.pphead--imgc-size {
    position: relative;
    display: none;
    width: 100%;
    height: auto;
}
@media (max-width: 1100px) {
    .pphead--imgc-size {
        display: block;
    }
}
@media (max-width: 660px) {
    .pphead--imgc-size {
        display: block;
    }
}
@media (max-width: 660px) {
    .pphead--imgc-size.-notmobile {
        display: none;
    }
}
.pphead--imgc-mobile {
    display: none;
    width: 100%;	height : auto;
}
@media (max-width: 660px) {
    .pphead--imgc-mobile {
        display: block;
        z-index: 2;
    }
}
.pphead--pastille {
    width: 168px;
    height: 168px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    -webkit-transform: translateY(50%);
    transform: translateY(50%);
    cursor: pointer;
    z-index: 10;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pphead--pastille {
        width: 140px;
        height: 140px;
    }
}
@media (max-width: 1100px) {
    .pphead--pastille {
        width: 144px;
        height: 144px;
    }
}
@media (max-width: 660px) {
    .pphead--pastille {
        width: 80px;
        height: 80px;
    }
}
.pphead--pastille-bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    margin: auto;
    background: #fff;
    border-radius: 50%;
    z-index: -1;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
}
@media (min-width: 1101px) {
    .pphead--pastille:hover .pphead--pastille-bg {
        -webkit-transform: scale(0.6);
        transform: scale(0.6);
    }
}
.pphead--scroll {
    z-index: 10;
    text-align: center;
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
    text-align: center;
}
.pphead--scroll .pphead--scroll-btn {
    position: relative;
    width: 80px;
    height: 80px;
    display: inline-block;
    cursor: pointer;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pphead--scroll .pphead--scroll-btn {
        width: 70px;
        height: 70px;
    }
}
.pphead--scroll .pphead--scroll-btn svg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    margin: auto;
    width: 32px;
    height: 32px;
    -webkit-transform: rotate(-90deg) translateX(0);
    transform: rotate(-90deg) translateX(0);
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
}
@media (max-width: 1100px) {
    .pphead--scroll .pphead--scroll-btn svg {
        width: 28px;
        height: 28px;
    }
}
@media (max-width: 660px) {
    .pphead--scroll .pphead--scroll-btn svg {
        width: 22px;
        height: 22px;
    }
}
.pphead--scroll .pphead--scroll-btn svg path {
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    stroke-dasharray: 33.16338348388672px;
    stroke-dashoffset: 0;
}
.js-complexified .pphead--scroll .pphead--scroll-btn:hover svg {
    opacity: 1;
    -webkit-transform: rotate(-90deg) translateX(0);
    transform: rotate(-90deg) translateX(0);
}
.js-complexified .pphead--scroll .pphead--scroll-btn:hover svg path:nth-child(2) {
    stroke-dashoffset: -10px;
}
.js-complexified.js-safari .pphead--scroll .pphead--scroll-btn:hover svg path:nth-child(2) {
    stroke-dashoffset: 10px;
}
.ppsubtitle {
    line-height: 1.2;
    font-size: 24px;
    font-size: 1.5rem;
    font-weight: 300;
    letter-spacing: 0.04em;
    margin-bottom: 3em;
    margin-top: 1.4em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .ppsubtitle {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .ppsubtitle {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1;
    }
}
@media (max-width: 660px) {
    .ppsubtitle {
        font-size: 18px;
        font-size: 1.125rem;
        line-height: 1;
    }
}
.pptitle {
    line-height: 1.2;
    font-size: 24px;
    font-size: 1.5rem;
    font-weight: 300;
    letter-spacing: 0.04em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pptitle {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .pptitle {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1;
    }
}
@media (max-width: 660px) {
    .pptitle {
        font-size: 18px;
        font-size: 1.125rem;
        line-height: 1;
    }
}
.pptext {
    font-size: 17px;
    font-size: 1.0625rem;
    line-height: 1.3;
    font-weight: 300;
    letter-spacing: 0.02em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pptext {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
@media (max-width: 1100px) {
    .pptext {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .pptext {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
.pptext p:not(:last-child) {
    margin-bottom: 1em;
}
.ppshare {
    margin-top: 2em;
}
.ppshare a {
    text-decoration: none;
}
.ppdesc {
    width: 770px;
    max-width: 85%;
    margin-bottom: 6em;
}
@media (max-width: 1100px) {
    .ppdesc {
        margin-bottom: 4em;
    }
}
@media (max-width: 660px) {
    .ppdesc {
        margin-bottom: 2em;
    }
}
.projectgrid {
    margin-bottom: 4em;
}
.ppitem {
    position: relative;
    overflow: hidden;
    margin: 90px 0;
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
}
@media (max-width: 1100px) {
    .ppitem {
        margin: 40px 0;
    }
}
.ppitem .fake-img {
    opacity: 0;
    width: 100%;
    height: auto;
}
@media (max-width: 660px) {
    .ppitem {
        height: auto !important;
    }
}
.ppitem--imgnormal {
    max-width: 100%;
}
.projectgrid .row {
    -webkit-box-align: center;
    align-items: center;
}
@media (max-width: 1100px) {
    .projectgrid .cell-1,
    .projectgrid .cell-2,
    .projectgrid .cell-3,
    .projectgrid .cell-4,
    .projectgrid .cell-5,
    .projectgrid .cell-6 {
        width: 50%;
    }
    .projectgrid .cell-10,
    .projectgrid .cell-11,
    .projectgrid .cell-12,
    .projectgrid .cell-7,
    .projectgrid .cell-8,
    .projectgrid .cell-9 {
        width: 100%;
    }
}
@media (max-width: 660px) {
    .projectgrid .cell-1,
    .projectgrid .cell-10,
    .projectgrid .cell-11,
    .projectgrid .cell-12,
    .projectgrid .cell-2,
    .projectgrid .cell-3,
    .projectgrid .cell-4,
    .projectgrid .cell-5,
    .projectgrid .cell-6,
    .projectgrid .cell-7,
    .projectgrid .cell-8,
    .projectgrid .cell-9 {
        width: 100%;
    }
}
.ppfastnav {
    position: fixed;
    bottom: 100px;
    right: 60px;
    display: -webkit-box;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    flex-direction: column;
    -webkit-box-align: end;
    align-items: flex-end;
    z-index: 90000;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .ppfastnav {
        bottom: 80px;
    }
}
@media (max-width: 1100px) {
    .ppfastnav {
        bottom: 80px;
    }
}
@media (max-width: 660px) {
    .ppfastnav {
        bottom: 60px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .ppfastnav {
        right: 40px;
    }
}
@media (max-width: 1100px) {
    .ppfastnav {
        right: 20px;
    }
}
.ppfastnav--btn {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: end;
    justify-content: flex-end;
    cursor: pointer;
    margin-top: 24px;
    fill: #e2e2e1;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    text-decoration: none;
}
.ppfastnav--btn:hover {
    fill: #000;
}
.js-backtotop {
    opacity: 0;
    pointer-events: none;
}
.js-scrolled .js-backtotop {
    opacity: 1;
    pointer-events: auto;
}
@media (max-width: 660px) {
    .js-backtotop {
        display: none;
    }
}
.ppfastnav--btn-label {
    pointer-events: none;
    text-align: right;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.1875;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    position: absolute;
    opacity: 1;
    white-space: nowrap;
    right: 66px;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
    -webkit-transform: translateX(-6px);
    transform: translateX(-6px);
}
@media (max-width: 1100px) {
    .ppfastnav--btn-label {
        display: none;
    }
}
@media (max-width: 660px) {
    .ppfastnav--btn-label {
        display: none;
    }
}
.ppfastnav--btn:hover .ppfastnav--btn-label {
    opacity: 1;
    -webkit-transform: translateX(0);
    transform: translateX(0);
}
.ppfastnav--btn-icon {
    width: 48px;
    height: 48px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.15);
    background: #fff;
    border-radius: 50%;
    display: -webkit-box;
    display: flex;
}
.ppfastnav--btn-icon svg {
    width: 26px;
    height: 26px;
    margin: auto;
}
.ppnav {
    display: -webkit-box;
    display: flex;
}
@media (max-width: 660px) {
    .ppnav {
        display: block;
    }
}
.ppnav--item {
    display: block;
    text-decoration: none;
    width: 50%;
}
@media (max-width: 660px) {
    .ppnav--item {
        width: 100%;
    }
}
@media (max-width: 660px) {
    .ppnav--item:not(:last-child) {
        margin-bottom: 2em;
    }
}
.ppnav--item-headline {
    margin-left: calc(100% / 6);
}
@media (max-width: 1100px) {
    .ppnav--item-headline {
        margin-left: 0;
    }
}
@media (max-width: 660px) {
    .ppnav--item-headline {
        margin-left: 0;
    }
}
.ppnav--item:last-child .ppnav--item-headline {
    margin-left: 0;
    text-align: right;
    margin-right: calc(100% / 6);
}
@media (max-width: 1100px) {
    .ppnav--item:last-child .ppnav--item-headline {
        margin-right: 0;
    }
}
@media (max-width: 660px) {
    .ppnav--item:last-child .ppnav--item-headline {
        margin-right: 0;
    }
}
.ppnav--item-headline {
    position: relative;
    margin-bottom: 3em;
    padding-bottom: 1em;
}
@media (max-width: 1100px) {
    .ppnav--item-headline {
        margin-bottom: 2em;
    }
}
@media (max-width: 660px) {
    .ppnav--item-headline {
        margin-bottom: 1em;
    }
}
.ppnav--item-kicker {
    font-size: 19px;
    font-size: 1.1875rem;
    line-height: 1.3;
    font-weight: 300;
    letter-spacing: 0.03em;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .ppnav--item-kicker {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
@media (max-width: 660px) {
    .ppnav--item-kicker {
        font-size: 16px;
        font-size: 1rem;
    }
}
@media (min-width: 1101px) {
    .ppnav--item-kicker div {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transform: translateY(110%);
        transform: translateY(110%);
    }
    .ppnav--item:hover .ppnav--item-kicker div {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}
.ppnav--item-title {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: 1.3;
    font-weight: 500;
    letter-spacing: 0.07em;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .ppnav--item-title {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
@media (max-width: 660px) {
    .ppnav--item-title {
        font-size: 16px;
        font-size: 1rem;
    }
}
@media (min-width: 1101px) {
    .ppnav--item-title div {
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transform: translateY(110%);
        transform: translateY(110%);
    }
    .ppnav--item:hover .ppnav--item-title div {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}
.ppnav--item-stroke {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 50px;
    height: 2px;
    background: #000;
}
@media (max-width: 1100px) {
    .ppnav--item-stroke {
        width: 40px;
    }
}
@media (max-width: 660px) {
    .ppnav--item-stroke {
        width: 30px;
    }
}
.ppnav--item:last-child .ppnav--item-stroke {
    left: auto;
    right: 0;
}
@media (min-width: 1101px) {
    .ppnav--item-stroke {
        -webkit-transform-origin: 0 0;
        transform-origin: 0 0;
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
    }
    .ppnav--item:hover .ppnav--item-stroke {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }
}
.ppnav--item-visu {
    width: 100%;
    height: 12vw;
    position: relative;
    overflow: hidden;
}
@media (max-width: 1100px) {
    .ppnav--item-visu {
        height: 16vw;
    }
}
.ppnav--item-visu-in {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    overflow: hidden;
}
@media (min-width: 1101px) {
    .ppnav--item-visu-in {
        -webkit-transform: translateY(25%);
        transform: translateY(25%);
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        opacity: 0.3;
    }
    .ppnav--item:hover .ppnav--item-visu-in {
        -webkit-transform: translateY(0);
        transform: translateY(0);
        opacity: 1;
    }
}
.ppnav--item-visu-inin {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}
@media (min-width: 1101px) {
    .ppnav--item-visu-inin {
        -webkit-transform: translateY(-12.5%);
        transform: translateY(-12.5%);
        -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    }
    .ppnav--item:hover .ppnav--item-visu-inin {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
}
.team {
    position: relative;
    margin-bottom: 40px;
}
.team img,
.team svg {
    display: block;
    width: 100%;
    height: auto;
}
.team img:not(:first-child),
.team svg:not(:first-child) {
    position: absolute;
    top: 0;
    left: 0;
}
.team svg {
    opacity: 0;
}
.team svg path {
    cursor: pointer;
}
@media (min-width: 1101px) {
    .team {
        padding: 0 60px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .team {
        padding: 0 40px;
    }
}
.team--in {
    padding: 0 8.3333333333%;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .team--in {
        padding: 0;
    }
}
@media (max-width: 1100px) {
    .team--in {
        padding: 0;
    }
}
@media (max-width: 660px) {
    .team--in {
        padding: 0;
    }
}
.team--imgc {
    position: relative;
}
.team--item {
    -webkit-transition: 0.2s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.2s cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
}
.team--item[team-id="0"] {
    opacity: 1;
}
.team--item.js-active {
    opacity: 1;
}
.team--txtcont {
    position: relative;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1) height;
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1) height;
    width: 100%;
    max-width: 600px;
}
.team--txtbg {
    position: absolute;
    top: -1px;
    left: 0;
    right: 0;
    z-index: -1;
    background: #fff;
    height: 1px;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
}
@media (max-width: 1100px) {
    .team--txtbg {
        display: none;
    }
}
.team--txt-item {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transform: translateY(10px);
    transform: translateY(10px);
    top: 0;
    left: 0;
    padding: 50px 0;
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.2;
    font-weight: 300;
}
.team--txt-item.js-active {
    opacity: 1;
    pointer-events: auto;
    -webkit-transition: 0.6s 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 0.6s 0.3s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transform: translateY(0);
    transform: translateY(0);
}
@media (max-width: 1100px) {
    .team--txt-item.js-active {
        -webkit-transition: 0.6s 0.6s cubic-bezier(0.19, 1, 0.22, 1);
        transition: 0.6s 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    }
}
@media (max-width: 1100px) {
    .team--txt-item {
        bottom: auto;
        top: 0;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .team--txt-item {
        padding: 50px 0;
    }
}
@media (max-width: 1100px) {
    .team--txt-item {
        padding: 50px 40px;
    }
}
@media (max-width: 660px) {
    .team--txt-item {
        padding: 20px 0;
    }
}
@media (max-width: 1100px) {
    .team--txt-item {
        font-size: 17px;
        font-size: 1.0625rem;
    }
}
@media (max-width: 660px) {
    .team--txt-item {
        font-size: 16px;
        font-size: 1rem;
    }
}
.team--name {
    font-size: 22px;
    font-size: 1.375rem;
    line-height: 1.3;
    letter-spacing: 0.13em;
    white-space: nowrap;
}
@media (max-width: 1100px) {
    .team--name {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .team--name {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.team--job {
    letter-spacing: 0.05em;
    margin-bottom: 1em;
    font-size: 16px;
    font-size: 1rem;
}
@media (max-width: 1100px) {
    .team--job {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .team--job {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
.team--desc {
    letter-spacing: 0.02em;
    font-size: 14px;
    font-size: 0.875rem;
}
@media (max-width: 1100px) {
    .team--desc {
        font-size: 13px;
        font-size: 0.8125rem;
    }
}
@media (max-width: 660px) {
    .team--desc {
        font-size: 12px;
        font-size: 0.75rem;
    }
}
.agencemouse {
    position: fixed;
    top: 20px;
    left: 20px;
    z-index: 90000000;
}
.agencemouse--item {
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
}
.agencemouse--item.js-active {
    opacity: 1;
}
.agencemouse--name {
    font-size: 22px;
    font-size: 1.375rem;
    line-height: 1.3;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}
@media (max-width: 1100px) {
    .agencemouse--name {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .agencemouse--name {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.agencemouse--job {
    letter-spacing: 0.05em;
    font-size: 16px;
    font-size: 1rem;
}
@media (max-width: 1100px) {
    .agencemouse--job {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .agencemouse--job {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
.teamppl--item {
    position: absolute;
    top: 0;
    pointer-events: none;
    z-index: 1;
    padding: 8px 16px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .teamppl--item {
        padding: 6px 12px;
    }
}
@media (max-width: 1100px) {
    .teamppl--item {
        padding: 5px 10px;
    }
}
@media (max-width: 660px) {
    .teamppl--item {
        padding: 4px 8px;
    }
}
.teamppl--item[team-id="1"] {
    top: 30%;
    left: 15%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.teamppl--item[team-id="2"] {
    top: 60%;
    left: 30%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.teamppl--item[team-id="3"] {
    top: 24%;
    left: 52%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.teamppl--item[team-id="4"] {
    top: 55%;
    right: 37%;
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
}
.teamppl--item[team-id="5"] {
    top: 30%;
    right: 20%;
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
}
@media (max-width: 660px) {
    .teamppl--item[team-id="1"],
    .teamppl--item[team-id="2"],
    .teamppl--item[team-id="3"],
    .teamppl--item[team-id="4"],
    .teamppl--item[team-id="5"] {
        top: auto;
        left: 0;
        bottom: 0;
        right: auto;
        -webkit-transform: none;
        transform: none;
    }
}
.teamppl--bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: #fff;
    z-index: -1;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
    opacity: 0;
}
.teamppl--item.js-active .teamppl--bg {
    -webkit-transform: scaleY(1);
    transform: scaleY(1);
    opacity: 1;
}
.teamppl--name {
    font-size: 17px;
    font-size: 1.0625rem;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 0.02em;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .teamppl--name {
        font-size: 16px;
        font-size: 1rem;
    }
}
@media (max-width: 1100px) {
    .teamppl--name {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .teamppl--name {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
.teamppl--item.js-active .teamppl--name {
    opacity: 1;
}
.teamppl--job {
    letter-spacing: 0.05em;
    font-size: 14px;
    font-size: 0.875rem;
    -webkit-transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    transition: 1s cubic-bezier(0.19, 1, 0.22, 1);
    opacity: 0;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .teamppl--job {
        font-size: 13px;
        font-size: 0.8125rem;
    }
}
@media (max-width: 1100px) {
    .teamppl--job {
        font-size: 12px;
        font-size: 0.75rem;
    }
}
@media (max-width: 660px) {
    .teamppl--job {
        font-size: 12px;
        font-size: 0.75rem;
    }
}
.teamppl--item.js-active .teamppl--job {
    opacity: 1;
}
.pagence {
    padding: 0 8.3333333333%;
    margin-top: 80px;
}
@media (max-width: 1100px) {
    .pagence {
        padding: 0 40px;
    }
}
@media (max-width: 660px) {
    .pagence {
        padding: 0;
    }
}
@media (max-width: 1100px) {
    .pagence {
        margin-top: 60px;
    }
}
@media (max-width: 660px) {
    .pagence {
        margin-top: 20px;
    }
}
.pagence--desc {
    padding-top: 40px;
    padding-bottom: 60px;
    position: relative;
}
.pagence--desc-stroke {
    position: absolute;
    top: 40px;
    bottom: 0;
    right: 10px;
    width: 1px;
    background: #000;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
}
.pagence--desc-in {
    width: 60%;
}
@media (max-width: 1100px) {
    .pagence--desc-in {
        width: 80%;
    }
}
@media (max-width: 660px) {
    .pagence--desc-in {
        width: calc(100% - 40px);
    }
}
.pagence--desctxt {
    margin-top: 4em;
    font-size: 17px;
    font-size: 1.0625rem;
    line-height: 1.3;
    font-weight: 300;
    letter-spacing: 0.02em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pagence--desctxt {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
@media (max-width: 1100px) {
    .pagence--desctxt {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 660px) {
    .pagence--desctxt {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
.pagence--desctxt p:not(:last-child) {
    margin-bottom: 1em;
}
.pagence--quote {
    text-align: right;
}
.pagence--quote-in {
    display: inline-block;
    max-width: 600px;
}
.pagence--quote-text {
    overflow: hidden;
    font-size: 21px;
    font-size: 1.3125rem;
    line-height: 1.3846153846;
    letter-spacing: 0.04em;
    margin-bottom: 0.5em;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pagence--quote-text {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .pagence--quote-text {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
@media (max-width: 660px) {
    .pagence--quote-text {
        font-size: 16px;
        font-size: 1rem;
    }
}
.pagence--quote-who {
    overflow: hidden;
    font-size: 15px;
    font-size: 0.9375rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 500;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pagence--quote-who {
        font-size: 15px;
        font-size: 0.9375rem;
    }
}
@media (max-width: 1100px) {
    .pagence--quote-who {
        font-size: 14px;
        font-size: 0.875rem;
    }
}
@media (max-width: 660px) {
    .pagence--quote-who {
        font-size: 13px;
        font-size: 0.8125rem;
    }
}
.pageloader {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    z-index: 9999999;
    pointer-events: none;
}
.pageloader.js-inactive {
    opacity: 0;
}
.pageloader--bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: #fff;
    z-index: -1;
    opacity: 1;
}
.pageloader--in {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 280px;
    height: 140px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    overflow: hidden;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pageloader--in {
        width: 250px;
        height: 125px;
    }
}
@media (max-width: 1100px) {
    .pageloader--in {
        width: 230px;
        height: 115px;
    }
}
@media (max-width: 660px) {
    .pageloader--in {
        width: 200px;
        height: 100px;
    }
}
@media (max-width: 1100px) {
    .pageloader--in {
        -webkit-transform: translateY(-44%);
        transform: translateY(-44%);
    }
}
@media (max-width: 660px) {
    .pageloader--in {
        -webkit-transform: translateY(-36%);
        transform: translateY(-36%);
    }
}
.pageloader--inin {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    bottom: auto;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    border: 12px solid #000;
    border-width: 22px;
    border-top-color: transparent;
    border-right-color: transparent;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pageloader--inin {
        width: 250px;
        height: 250px;
    }
}
@media (max-width: 1100px) {
    .pageloader--inin {
        width: 230px;
        height: 230px;
    }
}
@media (max-width: 660px) {
    .pageloader--inin {
        width: 200px;
        height: 200px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .pageloader--inin {
        border-width: 20px;
    }
}
@media (max-width: 1100px) {
    .pageloader--inin {
        border-width: 18px;
    }
}
@media (max-width: 660px) {
    .pageloader--inin {
        border-width: 15px;
    }
}
.p404 {
    min-height: calc(100vh - 140px - 140px);
    display: -webkit-box;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    flex-direction: column;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
}
@media (max-width: 1100px) {
    .p404 {
        min-height: calc(100vh - 120px - 100px);
    }
}
@media (max-width: 660px) {
    .p404 {
        min-height: calc(100vh - 90px - 60px);
    }
}
.p404 h1 {
    font-size: 6vw;
    font-weight: 700;
}
.nb {
    padding: 0 8.3333333333%;
    margin-top: 80px;
    --decal: 55px;
}
@media (max-width: 1100px) {
    .nb {
        padding: 0 40px;
    }
}
@media (max-width: 660px) {
    .nb {
        padding: 0;
    }
}
@media (max-width: 1100px) {
    .nb {
        margin-top: 60px;
    }
}
@media (max-width: 660px) {
    .nb {
        margin-top: 20px;
    }
}
@media (max-width: 1100px) {
    .nb {
        --decal: 32px;
    }
}
.nb--in {
    position: relative;
}
.nbparent:first-child .nb--in::before {
    top: -800px;
}
.nb--title {
    position: relative;
    padding-bottom: 2.5em;
    font-size: 22px;
    font-size: 1.375rem;
    line-height: 1.1176470588;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-left: calc(var(--decal) * -1);
}
@media (max-width: 1100px) {
    .nb--title {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 660px) {
    .nb--title {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
@media (max-width: 660px) {
    .nb--title {
        margin-left: 0;
    }
}
.nb--stroke {
    position: absolute;
    top: 0;
    right: -1px;
    bottom: 0;
    width: 1px;
    z-index: -1;
    background: currentColor;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
}
@media (max-width: 660px) {
    .nb--stroke {
        content: none;
    }
}
.nb--title .nb--stroke {
    top: -80px;
}
.nb--cont {
    position: relative;
}
.nb--cont.-visual {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
}
.nb--cont.-visual .nb--item-title {
    width: 100%;
    -webkit-box-ordinal-group: 2;
    order: 1;
}
.nb--cont.-visual .nb--item-image {
    width: 100%;
    -webkit-box-ordinal-group: 3;
    order: 2;
}
.nb--cont.-visual .nb--item-subtitle {
    width: 100%;
    -webkit-box-ordinal-group: 4;
    order: 3;
}
.nb--cont.-visual .nb--item-subtitle .nb--item-subtitlein {
    margin-left: var(--decal);
    font-size: 11px;
    font-size: 0.6875rem;
    line-height: 1.1818181818;
    padding-top: 20px;
    padding-left: 16px;
    padding-bottom: 5px;
    position: relative;
    background: #fff;
    margin-right: -1px;
}
.nb--cont.-visual .nb--item-subtitle .nb--item-subtitlein::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 1px;
    height: 100%;
    background: currentColor;
}
.nb--cont.-default {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
}
.nb--cont.-default .nb--item-title {
    width: 50%;
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-title {
        width: 100%;
    }
}
.nb--cont.-default .nb--item-subtitle {
    width: 50%;
    text-align: right;
    font-size: 21px;
    font-size: 1.3125rem;
    line-height: 1.3846153846;
    letter-spacing: 0.04em;
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-subtitle {
        width: 100%;
        text-align: left;
    }
}
.nb--cont.-default .nb--item-subtitle .nb--item-subtitlein {
    margin-right: calc(var(--decal) * -1);
    overflow: hidden;
    max-width: 420px;
    margin-left: auto;
    background: #fff;
    padding-bottom: 1.575em;
    margin-top: -1.575em;
    padding-top: 1.575em;
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-subtitle .nb--item-subtitlein {
        margin-right: 0;
        max-width: 100%;
        padding-bottom: 24px;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .nb--cont.-default .nb--item-subtitle {
        font-size: 20px;
        font-size: 1.25rem;
    }
}
@media (max-width: 1100px) {
    .nb--cont.-default .nb--item-subtitle {
        font-size: 19px;
        font-size: 1.1875rem;
    }
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-subtitle {
        font-size: 18px;
        font-size: 1.125rem;
    }
}
.nb--cont.-default .nb--item-image {
    width: 50%;
    padding-left: 120px;
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-image {
        width: 100%;
        -webkit-box-ordinal-group: 4;
        order: 3;
    }
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .nb--cont.-default .nb--item-image {
        padding-left: 80px;
    }
}
@media (max-width: 1100px) {
    .nb--cont.-default .nb--item-image {
        padding-left: 40px;
    }
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-image {
        padding-left: 0;
    }
}
.nb--cont.-default .nb--item-image .nb--item-imagein {
    margin-left: auto;
    margin-right: calc(var(--decal) * -1);
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-image .nb--item-imagein {
        margin-right: 0;
        margin-left: 0;
    }
}
.nb--cont.-default .nb--item-image .nb--item-imagein img {
    margin-left: auto;
}
.nb--cont.-default .nb--item-markup {
    width: 50%;
}
@media (max-width: 660px) {
    .nb--cont.-default .nb--item-markup {
        width: 100%;
        -webkit-box-ordinal-group: 5;
        order: 4;
        margin-top: 24px;
    }
}
.nb--cont:not(:last-child) {
    padding-bottom: 120px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .nb--cont:not(:last-child) {
        padding-bottom: 100px;
    }
}
@media (max-width: 1100px) {
    .nb--cont:not(:last-child) {
        padding-bottom: 80px;
    }
}
@media (max-width: 660px) {
    .nb--cont:not(:last-child) {
        padding-bottom: 40px;
    }
}
.nb--cont:last-child {
    margin-bottom: 120px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .nb--cont:last-child {
        margin-bottom: 100px;
    }
}
@media (max-width: 1100px) {
    .nb--cont:last-child {
        margin-bottom: 80px;
    }
}
@media (max-width: 660px) {
    .nb--cont:last-child {
        margin-bottom: 40px;
    }
}
.nb--item-title {
    margin-bottom: 60px;
}
@media (max-width: 660px) {
    .nb--item-title {
        margin-bottom: 24px;
    }
}
.nb--item-image img {
    display: block;
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
}
.jolytl {
    padding: 0 8.3333333333%;
    margin-top: 80px;
}
@media (max-width: 1100px) {
    .jolytl {
        padding: 0 40px;
    }
}
@media (max-width: 660px) {
    .jolytl {
        padding: 0;
    }
}
@media (max-width: 1100px) {
    .jolytl {
        margin-top: 60px;
    }
}
@media (max-width: 660px) {
    .jolytl {
        margin-top: 20px;
    }
}
.jolytl:not(:last-child) {
    padding-bottom: 120px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .jolytl:not(:last-child) {
        padding-bottom: 100px;
    }
}
@media (max-width: 1100px) {
    .jolytl:not(:last-child) {
        padding-bottom: 80px;
    }
}
@media (max-width: 660px) {
    .jolytl:not(:last-child) {
        padding-bottom: 40px;
    }
}
.jolytl:last-child {
    margin-bottom: 120px;
}
@media (min-width: 1101px) and (max-width: 1440px) {
    .jolytl:last-child {
        margin-bottom: 100px;
    }
}
@media (max-width: 1100px) {
    .jolytl:last-child {
        margin-bottom: 80px;
    }
}
@media (max-width: 660px) {
    .jolytl:last-child {
        margin-bottom: 40px;
    }
}
.jolytl--title {
    margin-bottom: 42px;
}
.jolytl--subtitle {
    font-size: 14px;
    letter-spacing: 0.32px;
    line-height: 1.2142857143;
}
.jolytl--tl {
    margin-top: 40px;
    position: relative;
}
.jolytl--item {
    position: relative;
    --spaceImgBorder: 70px;
    --spaceDotImg: 10px;
    width: 50%;
    margin-top: -100px;
}
@media (max-width: 1100px) {
    .jolytl--item {
        --spaceImgBorder: 40px;
        --spaceDotImg: 10px;
    }
}
@media (max-width: 660px) {
    .jolytl--item {
        --spaceImgBorder: 20px;
        --spaceDotImg: 20px;
    }
}
@media (max-width: 660px) {
    .jolytl--item {
        width: 100%;
    }
}
.jolytl--item:nth-child(odd) {
    padding-right: var(--spaceImgBorder);
    text-align: right;
}
@media (max-width: 660px) {
    .jolytl--item:nth-child(odd) {
        text-align: left;
        padding-right: 0;
        padding-left: var(--spaceImgBorder);
    }
}
.jolytl--item:nth-child(even) {
    margin-left: 50%;
    padding-left: var(--spaceImgBorder);
}
@media (max-width: 660px) {
    .jolytl--item:nth-child(even) {
        margin-left: 0;
    }
}
@media (max-width: 1100px) {
    .jolytl--item {
        margin-top: -50px;
    }
}
.jolytl--item:first-child {
    margin-top: 0;
}
@media (max-width: 660px) {
    .jolytl--item {
        margin-top: 0;
    }
    .jolytl--item:not(:last-child) {
        margin-bottom: 40px;
    }
}
.jolytl--stroke {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    z-index: -1;
    background: currentColor;
    margin: auto;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    -webkit-transform: scaleY(0);
    transform: scaleY(0);
}
@media (max-width: 660px) {
    .jolytl--stroke {
        right: auto;
    }
}
.jolytl--item:nth-child(odd) .jolytl--stroke {
    right: 0;
}
.jolytl--item:nth-child(even) .jolytl--stroke {
    right: 100%;
}
.jolytl--item-image {
    position: relative;
}
.jolytl--item-image::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}
.jolytl--item-image::after {
    content: "";
    width: calc(var(--spaceImgBorder) + var(--spaceDotImg));
    height: 1px;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    background-image: -webkit-gradient(linear, left top, right top, color-stop(33%, #000), color-stop(0, rgba(255, 255, 255, 0)));
    background-image: linear-gradient(to right, #000 33%, rgba(255, 255, 255, 0) 0);
    background-position: bottom;
    background-size: 10px 1px;
    background-repeat: repeat-x;
}
.jolytl--item:nth-child(odd) .jolytl--item-image::before {
    right: var(--spaceDotImg);
}
.jolytl--item:nth-child(odd) .jolytl--item-image::after {
    left: calc(100% - var(--spaceDotImg));
}
@media (max-width: 660px) {
    .jolytl--item:nth-child(odd) .jolytl--item-image::before {
        right: auto;
    }
    .jolytl--item:nth-child(odd) .jolytl--item-image::after {
        left: auto;
    }
    .jolytl--item:nth-child(odd) .jolytl--item-image::before {
        left: var(--spaceDotImg);
    }
    .jolytl--item:nth-child(odd) .jolytl--item-image::after {
        right: calc(100% - var(--spaceDotImg));
    }
}
.jolytl--item:nth-child(even) .jolytl--item-image::before {
    left: var(--spaceDotImg);
}
.jolytl--item:nth-child(even) .jolytl--item-image::after {
    right: calc(100% - var(--spaceDotImg));
}
.jolytl--item-imagein {
    position: relative;
    z-index: -1;
}
.jolytl--item-imagein img {
    display: block;
    width: 100%;
    height: auto;
}
.jolytl--item-text {
    margin-top: 10px;
}
.jolytl--item-year {
    font-weight: 700;
}


/* ajouts Cyril */

.projectgrid img{height : auto;}
.ppitem {height: auto !important;}
body{font-family: 'niveau-grotesk','Helvetica Neue', Arial, sans-serif;}
.ppdesc {
	max-width: 60%;
	margin: 0 auto;
	hyphens: auto;
} 
.ppdesc strong{font-family: 'niveau-grotesk','Helvetica Neue',Arial,sans-serif; font-weight:bold;}
.ppdesc h2 {
	font-size: 25px;
	margin: 40px 0 20px 0;
	text-align: center;
}
.ppdesc img.alignleft{float : left;}
.ppshare {
	text-align: center;
	margin: 2em;
}
.btitle--stroke {
  left: 50%;
  transform: translateX(-50%);
}
.btitle.btitle__single {text-align: center;}
.ppsubtitle {text-align: center;}
.cell-5 {width: 50%;}
.prepend-1 {
	margin-left: auto;
	margin-right: auto;
}
.ppitem {margin: 20px 0;}

.footerfinal{
	text-align : center;
	margin-bottom : 50px;
}
.footerfinal a{
	text-decoration : none;
}
.aligncenter {
	text-align : center;
}

@media screen and (max-width : 700px){
	.ppdesc {
		max-width: 80%;
	} 
}





.ppdesc .alignfull {
    width: 100vw;                   /* pleine largeur de l'écran */
    max-width: 100vw;
    margin-left: calc(-50vw + 50%); /* compense le centrage de .ppdesc */
}

.ppdesc .alignwide {
    width: 90vw;
    max-width: 90vw;
    margin-left: calc(-45vw + 50%);
}


.listing-articles{
	width : 1200px;
	display : flex;
	flex-direction : row;
	flex-wrap : wrap;
	margin : 0 auto;
    align-items: stretch;
}

.listing-articles article{
	width : calc(50% - 80px);
	margin : 40px;
	text-align : center;
}
.listing-articles article.nothing{
	width : 100%;
}
.listing-articles article img{
	width : 100%;
	height : auto;
}
.listing-articles article.card {
    display: flex;
}
.listing-articles article.card .card--cont {
    display: flex;
    flex-direction: column;
    flex: 1;
}
.listing-articles .card--content{
	text-align: center;
}
.listing-articles h2{
	font-size : 30px;
	margin-top: 10px;
}
.listing-articles h2 a{
	text-decoration : none;
}
.category h1{
	text-align: center;
	font-size: 30px;
}
.listing-articles .card--date {
  color: #585858;
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.listing-articles .supaitem--stupidstroke {
  display: block;
  width: 40px;
  height: 1px;
  background: #000;
  text-align: center;
  margin: 10px auto;
}


.single h3{
	font-size: 22px;
	font-weight:900;
}




/* catégorie Presse */

.category-press .listing-articles article,
#presse .listing-articles article {
  width: calc(100% / 3 - 80px);
  margin: 40px;
  text-align: center;
}
.category-press .card .card--thumb,
#presse .card .card--thumb {
	z-index: 5;
	position: relative;
	margin: 0 auto -170px;
	max-width: 220px;
	max-height: 290px;
}
.category-press  .card .card--thumb img,
#presse .card .card--thumb img {
	box-shadow: 0 15px 30px 0 rgba(0,0,0,.15);
	max-width: 100%;
	max-height: 100%;
	height: auto;
	width: auto;
	vertical-align: middle;
}

.category-press  .card .card--content,
#presse .card .card--content {
	background-color: #efefef;
	position: relative;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 220px 50px 40px;
}


/* fin catégorie Presse */




/* contact */

h1.titrecontact {
  text-transform: uppercase;
  font-size: 22px;
  letter-spacing: .12em;
  margin-bottom: 1.25em;
  margin-top: 2em;
}

.mail a{
  font-size: 1.375rem;
  font-weight: 500;
  letter-spacing: .02em;
  margin-bottom: 1.25em;
  margin-top: 2em;
  text-decoration: none;
  display: block;
}
.telcontact{
	margin-bottom: 1em;
}

.social-icons{
	margin-top: 1em;
}
.social-icons li {
  display: inline-block;
  margin-right: 1em;
}
.social-icons li a {
  display: block;
  fill: #000;
  -webkit-transition: .6s cubic-bezier(.19,1,.22,1);
  transition: .6s cubic-bezier(.19,1,.22,1);
}
.social-icons li a svg {
  width: 30px;
  height: 30px;
  display: block;
}




/* Responsive */
@media screen and (max-width : 1100px){
	.supaitem {
		width : 100%;
	}
	.supaitem .supaitem--imgc-in,
	.supaitem .cover{
		position : relative;
	}
	.supaitem .supaitem--imgc {
		height: auto;
	}
	.supaitem .supaitem--desc {
	  margin-bottom: 50px;
	}
	.pcontact--social{
		margin-top: 0;
		text-align: center;
	}
	.listing-articles article,
	.listing-articles {
		width: 100%;
	}
	.category-press .listing-articles article,
	#presse .listing-articles article {
		width: 100%;
	}
	.wp-block-media-text__content{
		text-align: center;
	}
	.wp-block-media-text.is-stacked-on-mobile{
		display: flex;
		flex-direction: column-reverse;
	}
	

}





body:not(.home) .pageloader {
  display: none !important;
}


.post-type-projets .block-editor-writing-flow{
	display : none;
}

