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

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

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

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

/**
 * Make all elements from the DOM inherit from the parent box-sizing
 * Since `*` has a specificity of 0, it does not override the `html` value
 * making all elements inheriting from the root box-sizing value
 * See: https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/
 */
*,
*::before,
*::after {
  box-sizing: inherit; }

@font-face {
  font-family: 'Larish Alte';
  src: url("../fonts/larishalte-semibold-webfont.woff2") format("woff2"), url("../fonts/larishalte-semibold-webfont.woff") format("woff");
  font-weight: 600;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-bold-webfont.woff2") format("woff2"), url("../fonts/volte-bold-webfont.woff") format("woff");
  font-weight: 700;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-bolditalic-webfont.woff2") format("woff2"), url("../fonts/volte-bolditalic-webfont.woff") format("woff");
  font-weight: 700;
  font-style: italic; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-light-webfont.woff2") format("woff2"), url("../fonts/volte-light-webfont.woff") format("woff");
  font-weight: 300;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-lightitalic-webfont.woff2") format("woff2"), url("../fonts/volte-lightitalic-webfont.woff") format("woff");
  font-weight: 300;
  font-style: italic; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-medium-webfont.woff2") format("woff2"), url("../fonts/volte-medium-webfont.woff") format("woff");
  font-weight: 500;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-mediumitalic-webfont.woff2") format("woff2"), url("../fonts/volte-mediumitalic-webfont.woff") format("woff");
  font-weight: 500;
  font-style: italic; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-regular-webfont.woff2") format("woff2"), url("../fonts/volte-regular-webfont.woff") format("woff");
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-regularitalic-webfont.woff2") format("woff2"), url("../fonts/volte-regularitalic-webfont.woff") format("woff");
  font-weight: 400;
  font-style: italic; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-semibold-webfont.woff2") format("woff2"), url("../fonts/volte-semibold-webfont.woff") format("woff");
  font-weight: 600;
  font-style: normal; }

@font-face {
  font-family: 'Volte';
  src: url("../fonts/volte-semibolditalic-webfont.woff2") format("woff2"), url("../fonts/volte-semibolditalic-webfont.woff") format("woff");
  font-weight: 600;
  font-style: italic; }

body.i18n-fr .i18n .fr {
  opacity: 1; }

body.i18n-fr .i18n .en {
  opacity: 0;
  display: none !important; }

body.i18n-en .i18n .fr {
  opacity: 0;
  display: none !important; }

body.i18n-en .i18n .en {
  opacity: 1; }

.flipping-i18n {
  -webkit-transition: transform ease-in-out 0.25s, opacity 0.25s ease-in-out;
  -moz-transition: transform ease-in-out 0.25s, opacity 0.25s ease-in-out;
  -ms-transition: transform ease-in-out 0.25s, opacity 0.25s ease-in-out;
  -o-transition: transform ease-in-out 0.25s, opacity 0.25s ease-in-out;
  transition: transform ease-in-out 0.25s, opacity 0.25s ease-in-out;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  outline: 0; }
  .flipping-i18n.flip-out {
    backface-visibility: hidden;
    z-index: 2;
    /* for firefox 31 */
    transform: rotateX(90deg); }

.fading-i18n {
  -webkit-transition: opacity 0.25s ease-in-out;
  -moz-transition: opacity 0.25s ease-in-out;
  -ms-transition: opacity 0.25s ease-in-out;
  -o-transition: opacity 0.25s ease-in-out;
  transition: opacity 0.25s ease-in-out;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  outline: 0;
  opacity: 1; }
  .fading-i18n.fade-out {
    opacity: 0 !important; }

* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  font-feature-settings: "tnum"; }

html {
  box-sizing: border-box; }

html, body {
  background-color: #272625;
  width: 1920px;
  height: 1080px;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
  -webkit-text-size-adjust: none;
  -webkit-overflow-scrolling: touch;
  color: #fefefe;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  outline: 0; }

a {
  color: #fefefe;
  text-decoration: none; }
  a:hover, a:active, a:focus {
    color: #fefefe;
    text-decoration: none; }

strong {
  font-weight: bold; }

#main {
  position: fixed;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 1920px;
  height: 1080px; }

.screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 1080px;
  opacity: 0;
  overflow: hidden;
  z-index: 3; }
  .screen h2 {
    font-size: 60px;
    font-family: "Univers", sans-serif; }
  .screen.hidden {
    visibility: hidden;
    pointer-events: none; }
  .screen:not(.current) {
    pointer-events: none !important; }
    .screen:not(.current) * {
      pointer-events: none !important; }

#disable-click {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 1080px;
  opacity: 0.5;
  pointer-events: all;
  z-index: 999;
  display: none; }

#triggers {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: row;
  flex-wrap: wrap;
  width: calc(100% - 100px);
  height: calc(100% - 100px);
  margin: 50px; }
  #triggers .trigger {
    display: inline-block;
    margin: 20px;
    width: 200px;
    height: 200px;
    line-height: 200px;
    padding: 0px 25px;
    box-sizing: border-box;
    font-family: "Univers", sans-serif;
    font-size: 16px;
    cursor: pointer;
    text-align: center;
    letter-spacing: 1px;
    color: #888;
    border: solid #888 1px;
    text-decoration: none;
    -webkit-transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #triggers .trigger .text {
      -webkit-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -webkit-transform: translate3d(0, 0, 0);
      -moz-transform: translate3d(0, 0, 0);
      -ms-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
      backface-visibility: hidden; }
      #triggers .trigger .text span {
        display: inline-block;
        vertical-align: middle;
        line-height: normal;
        width: 100%;
        word-wrap: break-word; }
    #triggers .trigger:hover {
      background-color: #41403e; }
    #triggers .trigger:active {
      background-color: #41403e;
      color: solid #888 1px; }
      #triggers .trigger:active .text {
        -webkit-transform: scale(0.9);
        -ms-transform: scale(0.9);
        transform: scale(0.9); }

#main {
  background-color: #272625;
  color: white;
  font-family: 'Volte';
  font-weight: normal;
  font-style: normal; }
  #main.ready #game-title {
    visibility: visible; }

#game-title {
  position: absolute;
  z-index: 10;
  color: #fefefe;
  left: 65px;
  top: 155px;
  width: 1000px;
  pointer-events: none;
  visibility: hidden;
  backface-visibility: visible; }
  #game-title .title .main-title {
    font-size: 100px;
    line-height: 1.15em;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    pointer-events: none; }
  #game-title .title .subtitle {
    position: absolute;
    top: 280px;
    font-size: 36px;
    line-height: 1.15em;
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal;
    pointer-events: none; }
  #game-title .description {
    margin-top: 100px;
    font-size: 44px;
    line-height: 52px;
    opacity: 0;
    pointer-events: none;
    font-weight: 500;
    overflow: hidden; }

#language-switcher {
  position: absolute;
  left: 1811px;
  top: 973px;
  z-index: 10;
  -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  font-family: 'Volte';
  font-weight: 600;
  font-style: normal; }
  #language-switcher a {
    background: #000;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border: 1px solid #fefefe;
    border-radius: 10px;
    -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  #language-switcher:active a,
  #language-switcher:focus a {
    background: #352e25; }

#intro-language-selectors {
  position: absolute;
  left: 700px;
  top: 834px;
  width: 502px; }
  #intro-language-selectors .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    font-weight: 600;
    background: #171410;
    width: 211px;
    height: 66px;
    border: 1px solid #FFF;
    border-radius: 10px;
    -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #intro-language-selectors .button:last-child {
      margin-left: 75px; }
    #intro-language-selectors .button:active, #intro-language-selectors .button:focus {
      background: #352e25; }

#burning-protect {
  position: fixed;
  left: 0;
  top: -100px;
  width: 100vw;
  height: 10px;
  opacity: 1;
  z-index: 10000;
  pointer-events: none;
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, white 10%, white 90%, rgba(255, 255, 255, 0) 100%); }

#still-there {
  visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 1080px;
  z-index: 100; }
  #still-there .overlay {
    width: 100%;
    height: 100%; }
  #still-there .modal {
    display: flex;
    position: absolute;
    justify-content: center;
    align-items: center;
    flex-flow: row;
    flex-wrap: wrap;
    left: calc(50% - (545px / 2));
    bottom: 0;
    width: 545px;
    height: 180px;
    background-color: #005FC5;
    border: none;
    border-radius: 10px 10px 0 0;
    box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.2); }
    #still-there .modal .content {
      display: flex;
      align-items: center;
      flex-flow: column; }
      #still-there .modal .content .description {
        position: absolute;
        left: 0px;
        top: 50px;
        width: 310px;
        display: inline-block;
        text-align: center;
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal;
        color: #fefefe;
        font-size: 26px; }
      #still-there .modal .content .still-there-counter {
        position: absolute;
        left: 0px;
        top: 88px;
        width: 310px;
        position: absolute;
        text-align: center;
        font-family: 'Volte';
        font-weight: 500;
        font-style: normal;
        color: #fefefe;
        font-size: 45px; }
      #still-there .modal .content .cta {
        position: absolute;
        left: 350px;
        top: 70px;
        display: inline-block;
        text-align: center;
        font-size: 32px;
        color: #fefefe;
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal;
        border: 1px solid #fefefe;
        border-radius: 10px;
        background-color: #0A51B7;
        font-size: 18px;
        padding: 12px 25px;
        width: 150px; }

#main.grande-paix #game-title {
  width: 1160px; }
  #main.grande-paix #game-title .subtitle {
    color: #AB749F; }
  #main.grande-paix #game-title .description {
    width: 992px;
    line-height: 55px; }

#main.grande-paix #screen-1 #intro-background {
  position: absolute;
  top: 0;
  left: 0; }

#main.grande-paix #screen-1 #screensaver-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
  height: 1080px; }

#main.grande-paix #screen-1 #intro-language-selectors {
  position: absolute;
  left: 700px;
  top: 834px;
  width: 502px; }
  #main.grande-paix #screen-1 #intro-language-selectors .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    font-weight: 600;
    background: #171410;
    width: 211px;
    height: 66px;
    border: 1px solid #FFF;
    border-radius: 10px;
    -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #main.grande-paix #screen-1 #intro-language-selectors .button:last-child {
      margin-left: 75px; }
    #main.grande-paix #screen-1 #intro-language-selectors .button:active, #main.grande-paix #screen-1 #intro-language-selectors .button:focus {
      background: #352e25; }

#main.grande-paix #screen-2 .page-grid {
  display: inline-block;
  position: absolute;
  width: 276px; }
  #main.grande-paix #screen-2 .page-grid .image-wrapper {
    width: 276px;
    height: 375px;
    overflow: hidden;
    border-radius: 10px; }
    #main.grande-paix #screen-2 .page-grid .image-wrapper .main-image {
      -webkit-transform: scale(0.455);
      -ms-transform: scale(0.455);
      transform: scale(0.455);
      -webkit-transform-origin: top left;
      -moz-transform-origin: top left;
      -ms-transform-origin: top left;
      transform-origin: top left; }
  #main.grande-paix #screen-2 .page-grid .page-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 390px;
    left: 100px;
    background: #4E4E4E;
    width: 70px;
    height: 22px;
    border-radius: 17px;
    font-size: 12px;
    font-weight: 500; }

#main.grande-paix #page-clone {
  backface-visibility: hidden;
  will-change: transform, opacity; }
  #main.grande-paix #page-clone.position-left .image-wrapper {
    overflow: hidden;
    border-radius: 14px 0 0 14px; }
  #main.grande-paix #page-clone.position-right .image-wrapper {
    overflow: hidden;
    border-radius: 0 14px 14px 0; }

#main.grande-paix #screen-3 #pages-groups .page-group {
  pointer-events: none; }
  #main.grande-paix #screen-3 #pages-groups .page-group.active {
    pointer-events: auto; }
  #main.grande-paix #screen-3 #pages-groups .page-group .page {
    position: absolute;
    width: 608px;
    height: 925px;
    backface-visibility: hidden;
    will-change: transform, opacity; }
    #main.grande-paix #screen-3 #pages-groups .page-group .page .page-image-wrapper {
      overflow: hidden;
      border-radius: 15px; }
    #main.grande-paix #screen-3 #pages-groups .page-group .page.position-left .page-image-wrapper {
      border-radius: 15px 0 0 15px; }
    #main.grande-paix #screen-3 #pages-groups .page-group .page.position-right .page-image-wrapper {
      border-radius: 0 15px 15px 0; }
  #main.grande-paix #screen-3 #pages-groups .page-group .hotspots-overlay {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(39, 38, 37, 0.9);
    pointer-events: none;
    opacity: 0; }
  #main.grande-paix #screen-3 #pages-groups .page-group .hotspots {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%; }
    #main.grande-paix #screen-3 #pages-groups .page-group .hotspots.disabled {
      pointer-events: none; }
    #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot {
      position: absolute;
      overflow: visible; }
      #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word .inner {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
        box-shadow: 0px 4px 9px -1px rgba(0, 0, 0, 0.65);
        border-radius: 6px; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word .inner .page-image {
          position: absolute;
          width: 100%;
          height: 100%; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word .inner .hotspot-overlay {
          position: absolute;
          width: 100%;
          height: 100%;
          background: #D8A400;
          mix-blend-mode: multiply; }
      #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word:before {
        position: absolute;
        background: transparent;
        content: '';
        width: 130%;
        height: 250%;
        left: -15%;
        top: -75%;
        -webkit-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -moz-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -ms-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -o-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
      #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word:after {
        position: absolute;
        content: url("../images/grande_paix/close-2.svg");
        width: 22px;
        height: 22px;
        top: -11px;
        right: -11px;
        opacity: 0;
        -webkit-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -moz-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -ms-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -o-transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        transition: opacity 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
      #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word.active {
        pointer-events: none; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-word.active:after {
          opacity: 1; }
      #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-illustration {
        width: 20px;
        height: 20px; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-illustration .dot {
          position: absolute;
          left: 0;
          top: 0;
          width: 20px;
          height: 20px;
          overflow: hidden;
          box-shadow: 0px 4px 9px -1px rgba(0, 0, 0, 0.65);
          border-radius: 50%;
          border: 1px solid #fefefe; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-illustration.alliance-angleterre .dot {
          background-color: #E0261E; }
        #main.grande-paix #screen-3 #pages-groups .page-group .hotspots .hotspot.mode-illustration.alliance-france .dot {
          background-color: #005FC5; }
  #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader {
    position: absolute;
    z-index: 1; }
    #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page {
      position: absolute;
      background-color: white;
      border-radius: 30px; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text, #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text p,
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .hotspot.mode-word .inner,
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .hotspot.mode-word .inner p {
        font-size: 17px;
        line-height: 21px;
        font-weight: 500; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text {
        color: #000;
        margin: 30px 30px;
        position: relative; }
        #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text p {
          margin-bottom: 10px; }
        #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text strong {
          font-weight: 600; }
        #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text .en, #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-text .fr {
          position: absolute;
          top: 0;
          left: 0; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .hotspot.mode-word .inner {
        display: inline-block;
        background-color: #D8A400;
        color: #000;
        line-height: 30px;
        padding: 0px 2px; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page .reader-page-image {
        position: absolute; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page[data-page-position='left'] {
        border-radius: 30px 0 0 30px; }
      #main.grande-paix #screen-3 #pages-groups .page-group .mode-reader .page[data-page-position='right'] {
        border-radius: 0 30px 30px 0; }

#main.grande-paix #screen-3 #pages-legend {
  display: inline-block;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 650px;
  top: 973px;
  width: 280px;
  font-size: 15px;
  font-style: italic; }
  #main.grande-paix #screen-3 #pages-legend .alliance {
    position: relative;
    padding: 4px 32px 10px; }
  #main.grande-paix #screen-3 #pages-legend .alliance:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    display: inline-block;
    width: 20px;
    height: 20px;
    overflow: hidden;
    box-shadow: 0px 4px 9px -1px rgba(0, 0, 0, 0.65);
    border-radius: 50%;
    border: 1px solid #fefefe; }
  #main.grande-paix #screen-3 #pages-legend .alliance-angleterre.alliance:before {
    background-color: #E0261E; }
  #main.grande-paix #screen-3 #pages-legend .alliance-france.alliance:before {
    background-color: #005FC5; }

#main.grande-paix #screen-3 #pages-toolbar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 970px;
  top: 973px;
  width: 550px; }
  #main.grande-paix #screen-3 #pages-toolbar.disabled {
    pointer-events: none; }
  #main.grande-paix #screen-3 #pages-toolbar #button-selected-marker {
    position: absolute;
    display: inline-block;
    height: 50px;
    width: 50px;
    left: 0;
    top: 0; }
    #main.grande-paix #screen-3 #pages-toolbar #button-selected-marker:after, #main.grande-paix #screen-3 #pages-toolbar #button-selected-marker:before {
      content: "";
      display: inline-block;
      position: absolute;
      left: 0;
      height: 1px;
      width: 100%;
      background: #D8A400; }
    #main.grande-paix #screen-3 #pages-toolbar #button-selected-marker:after {
      top: 0; }
    #main.grande-paix #screen-3 #pages-toolbar #button-selected-marker:before {
      bottom: 0; }
  #main.grande-paix #screen-3 #pages-toolbar .button-prev,
  #main.grande-paix #screen-3 #pages-toolbar .button-next {
    margin: 0 40px; }
    #main.grande-paix #screen-3 #pages-toolbar .button-prev .inner,
    #main.grande-paix #screen-3 #pages-toolbar .button-next .inner {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      border: 1px solid #899789;
      width: 50px;
      height: 50px;
      -webkit-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.grande-paix #screen-3 #pages-toolbar .button-prev.disabled,
    #main.grande-paix #screen-3 #pages-toolbar .button-next.disabled {
      opacity: 0.4; }
    #main.grande-paix #screen-3 #pages-toolbar .button-prev:active .inner,
    #main.grande-paix #screen-3 #pages-toolbar .button-next:active .inner {
      -webkit-transform: scale(0.85);
      -ms-transform: scale(0.85);
      transform: scale(0.85); }
  #main.grande-paix #screen-3 #pages-toolbar .button-one-page,
  #main.grande-paix #screen-3 #pages-toolbar .button-two-pages,
  #main.grande-paix #screen-3 #pages-toolbar .button-grid {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    height: 50px; }
    #main.grande-paix #screen-3 #pages-toolbar .button-one-page, #main.grande-paix #screen-3 #pages-toolbar .button-one-page path, #main.grande-paix #screen-3 #pages-toolbar .button-one-page g,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages path,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages g,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid path,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid g {
      -webkit-transition: stroke 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: stroke 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: stroke 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: stroke 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: stroke 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.grande-paix #screen-3 #pages-toolbar .button-one-page.active, #main.grande-paix #screen-3 #pages-toolbar .button-one-page.active path, #main.grande-paix #screen-3 #pages-toolbar .button-one-page.active g,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages.active,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages.active path,
    #main.grande-paix #screen-3 #pages-toolbar .button-two-pages.active g,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid.active,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid.active path,
    #main.grande-paix #screen-3 #pages-toolbar .button-grid.active g {
      stroke: #D8A400; }

#main.grande-paix #screen-3 #toggle-reader {
  display: inline-block;
  position: absolute;
  left: 1775px;
  top: 864px;
  background-color: #fefefe;
  padding: 15px 12px;
  border-radius: 10px;
  box-shadow: 0px 4px 9px -1px rgba(0, 0, 0, 0.65);
  -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  #main.grande-paix #screen-3 #toggle-reader svg path {
    -webkit-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  #main.grande-paix #screen-3 #toggle-reader.active {
    background-color: #D8A400; }
    #main.grande-paix #screen-3 #toggle-reader.active svg path {
      fill: #fefefe; }

#main.grande-paix #screen-4 {
  --swiper-navigation-color: #000;
  --swiper-navigation-size: 60px; }
  #main.grande-paix #screen-4 #illustration-slider,
  #main.grande-paix #screen-4 .close-slider-topbar {
    position: absolute;
    left: 631px;
    top: 38px;
    width: 1225px; }
  #main.grande-paix #screen-4 #illustration-slider {
    height: 922px;
    background-color: #E7E2DF;
    border-radius: 30px; }
    #main.grande-paix #screen-4 #illustration-slider .swiper-slide > .inner {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      height: 100%; }
      #main.grande-paix #screen-4 #illustration-slider .swiper-slide > .inner img {
        max-height: 70%;
        max-width: 70%; }
    #main.grande-paix #screen-4 #illustration-slider .swiper-button-prev {
      left: 50px; }
    #main.grande-paix #screen-4 #illustration-slider .swiper-button-next {
      right: 50px; }
    #main.grande-paix #screen-4 #illustration-slider .swiper-button-disabled {
      opacity: 0.05; }
  #main.grande-paix #screen-4 .close-slider-topbar {
    height: 100px;
    z-index: 11; }
  #main.grande-paix #screen-4 .close-slider {
    position: absolute;
    right: 38px;
    top: 38px;
    z-index: 11; }
    #main.grande-paix #screen-4 .close-slider .inner {
      padding: 10px;
      line-height: 0; }
    #main.grande-paix #screen-4 .close-slider:active .inner {
      -webkit-transform: scale(0.9);
      -ms-transform: scale(0.9);
      transform: scale(0.9); }

#main.grande-paix #sidebar {
  position: absolute;
  left: 66px;
  top: 250px;
  width: 432px;
  display: inline-block;
  opacity: 0;
  height: 715px;
  overflow: hidden;
  z-index: 5; }
  #main.grande-paix #sidebar:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0px;
    height: 20px;
    width: 100%;
    background: linear-gradient(rgba(39, 38, 37, 0), #272625); }
  #main.grande-paix #sidebar .inner {
    position: relative; }
  #main.grande-paix #sidebar:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 100%;
    background-color: #4E4E4E;
    z-index: 2; }
  #main.grande-paix #sidebar #sidebar-fixed-header {
    background: #272625;
    position: relative;
    padding-top: 30px;
    padding-bottom: 20px;
    z-index: 1; }
    #main.grande-paix #sidebar #sidebar-fixed-header #sidebar-title {
      font-weight: 600;
      font-size: 35px;
      line-height: 35px;
      margin-right: 60px; }
    #main.grande-paix #sidebar #sidebar-fixed-header:after {
      content: "";
      position: absolute;
      left: 0;
      bottom: -20px;
      height: 20px;
      width: 100%;
      background: linear-gradient(#272625, rgba(39, 38, 37, 0)); }
  #main.grande-paix #sidebar #sidebar-content {
    padding-top: 20px;
    padding-bottom: 20px; }
    #main.grande-paix #sidebar #sidebar-content, #main.grande-paix #sidebar #sidebar-content p, #main.grande-paix #sidebar #sidebar-content div {
      font-size: 17px;
      font-weight: 500;
      line-height: 22px; }
    #main.grande-paix #sidebar #sidebar-content p {
      margin-bottom: 20px; }
    #main.grande-paix #sidebar #sidebar-content #alliance-content {
      margin-top: 40px; }
      #main.grande-paix #sidebar #sidebar-content #alliance-content, #main.grande-paix #sidebar #sidebar-content #alliance-content p, #main.grande-paix #sidebar #sidebar-content #alliance-content div {
        font-size: 17px;
        font-weight: 500;
        text-transform: uppercase; }
      #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-france, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-angleterre {
        margin-top: 5px; }
        #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-france, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-france p, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-france div, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-angleterre, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-angleterre p, #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-angleterre div {
          text-transform: none;
          font-size: 28px;
          font-weight: 600; }
      #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-france {
        color: #005FC5; }
      #main.grande-paix #sidebar #sidebar-content #alliance-content .alliance-angleterre {
        color: #E0261E; }
  #main.grande-paix #sidebar .inner.no-title #sidebar-fixed-header {
    padding-bottom: 0px; }
  #main.grande-paix #sidebar #sidebar-images {
    margin-top: 40px; }
    #main.grande-paix #sidebar #sidebar-images .sidebar-image-legend .fr,
    #main.grande-paix #sidebar #sidebar-images .sidebar-image-legend .en {
      font-size: 15px;
      margin-bottom: 7px; }
    #main.grande-paix #sidebar #sidebar-images img {
      width: 100%;
      height: auto; }

#main.grande-paix #sidebar-close {
  position: absolute;
  top: 15px;
  right: -18px;
  padding: 20px; }

#main.lexique #screen-2 #grid,
#main.lexique #screen-2 #grid-sticky-category {
  position: fixed;
  left: 360px;
  top: 0;
  width: 860px; }

#main.lexique #screen-2 #grid {
  display: inline-block;
  position: absolute;
  left: 360px;
  top: 35px;
  width: 860px;
  height: 733px;
  overflow: hidden; }
  #main.lexique #screen-2 #grid .inner {
    will-change: transform;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    overflow: hidden;
    justify-content: flex-start;
    padding-bottom: 100px; }

#main.lexique #screen-2 .grid-category {
  width: 100%; }
  #main.lexique #screen-2 .grid-category .title {
    padding: 35px 0 70px 0;
    text-align: center;
    background: #272625;
    background: linear-gradient(180deg, #272625 75%, rgba(39, 38, 37, 0) 100%);
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    color: #3D8B51;
    font-size: 30px; }

#main.lexique #screen-2 #grid-sticky-category {
  position: fixed;
  z-index: 100; }

#main.lexique #screen-2 #sidebar {
  position: absolute;
  left: 58px;
  top: 195px;
  width: 224px; }
  #main.lexique #screen-2 #sidebar .dot {
    position: absolute;
    left: -18px;
    top: 19px;
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 4px;
    background-color: #3D8B51;
    -webkit-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
  #main.lexique #screen-2 #sidebar .category {
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    padding: 14px 0px;
    letter-spacing: 0.5px;
    font-size: 18px; }
    #main.lexique #screen-2 #sidebar .category .title {
      -webkit-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.lexique #screen-2 #sidebar .category.active .title {
      color: #3D8B51; }

#main.lexique #screen-2 .grid-item {
  display: inline-flex;
  width: 215px;
  height: 260px;
  flex-direction: column;
  align-items: center;
  padding: 0px 20px;
  box-sizing: border-box; }
  #main.lexique #screen-2 .grid-item .main-image {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 180px; }
  #main.lexique #screen-2 .grid-item .title {
    text-align: center;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 22px; }

#main.lexique {
  width: 1366px;
  height: 768px; }
  #main.lexique .screen {
    width: 1366px;
    height: 768px; }
  #main.lexique #still-there {
    width: 1366px;
    height: 768px; }
  #main.lexique #language-switcher {
    position: absolute;
    left: 1262px;
    top: 684px; }

#main.lexique #game-title {
  left: 90px;
  top: 95px; }
  #main.lexique #game-title .main-title {
    font-size: 70px;
    line-height: 1.15em;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    pointer-events: none; }
  #main.lexique #game-title .subtitle {
    font-size: 25px;
    line-height: 36px;
    color: #3D8B51;
    top: 200px; }

#main.lexique #category-clone {
  position: absolute;
  padding: 35px 0 70px 0;
  text-align: center;
  background: #272625;
  background: linear-gradient(180deg, #272625 75%, rgba(39, 38, 37, 0) 100%);
  font-family: 'Volte';
  font-weight: 600;
  font-style: normal;
  color: #3D8B51;
  font-size: 30px;
  top: 35px;
  left: 360px;
  width: 860px;
  visibility: hidden;
  pointer-events: none;
  opacity: 0; }

#main.lexique #screen-1 #intro-background {
  position: absolute;
  top: 0;
  left: 0; }

#main.lexique #screen-1 #intro-language-selectors {
  position: absolute;
  left: 450px;
  top: 590px;
  width: 502px; }
  #main.lexique #screen-1 #intro-language-selectors .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    font-weight: 600;
    background: #171410;
    width: 211px;
    height: 66px;
    border: 1px solid #FFF;
    border-radius: 10px;
    -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #main.lexique #screen-1 #intro-language-selectors .button:last-child {
      margin-left: 75px; }
    #main.lexique #screen-1 #intro-language-selectors .button:active, #main.lexique #screen-1 #intro-language-selectors .button:focus {
      background: #352e25; }

#main.lexique #screen-2 #grid,
#main.lexique #screen-2 #grid-sticky-category {
  position: fixed;
  left: 360px;
  top: 0;
  width: 860px; }

#main.lexique #screen-2 #grid {
  display: inline-block;
  position: absolute;
  left: 360px;
  top: 35px;
  width: 860px;
  height: 733px;
  overflow: hidden; }
  #main.lexique #screen-2 #grid .inner {
    will-change: transform;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    overflow: hidden;
    justify-content: flex-start;
    padding-bottom: 100px; }

#main.lexique #screen-2 .grid-category {
  width: 100%; }
  #main.lexique #screen-2 .grid-category .title {
    padding: 35px 0 70px 0;
    text-align: center;
    background: #272625;
    background: linear-gradient(180deg, #272625 75%, rgba(39, 38, 37, 0) 100%);
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    color: #3D8B51;
    font-size: 30px; }

#main.lexique #screen-2 #grid-sticky-category {
  position: fixed;
  z-index: 100; }

#main.lexique #screen-2 #sidebar {
  position: absolute;
  left: 58px;
  top: 195px;
  width: 224px; }
  #main.lexique #screen-2 #sidebar .dot {
    position: absolute;
    left: -18px;
    top: 19px;
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 4px;
    background-color: #3D8B51;
    -webkit-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: transform 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
  #main.lexique #screen-2 #sidebar .category {
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    padding: 14px 0px;
    letter-spacing: 0.5px;
    font-size: 18px; }
    #main.lexique #screen-2 #sidebar .category .title {
      -webkit-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.lexique #screen-2 #sidebar .category.active .title {
      color: #3D8B51; }

#main.lexique #screen-2 .grid-item {
  display: inline-flex;
  width: 215px;
  height: 260px;
  flex-direction: column;
  align-items: center;
  padding: 0px 20px;
  box-sizing: border-box; }
  #main.lexique #screen-2 .grid-item .main-image {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 180px; }
  #main.lexique #screen-2 .grid-item .title {
    text-align: center;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 22px; }

#main.lexique #screen-3 {
  --swiper-navigation-color: #fefefe;
  --swiper-navigation-size: 60px; }
  #main.lexique #screen-3 #main-slider {
    position: absolute;
    left: 148px;
    top: 104px;
    width: 1221px;
    height: 593px; }
    #main.lexique #screen-3 #main-slider .right-fade,
    #main.lexique #screen-3 #main-slider .left-fade {
      position: absolute;
      top: 4px;
      width: 185px;
      height: 100%;
      background: #272625;
      z-index: 2; }
    #main.lexique #screen-3 #main-slider .left-fade {
      left: -2px;
      background: linear-gradient(90deg, #272625 15%, rgba(39, 38, 37, 0) 100%); }
    #main.lexique #screen-3 #main-slider .right-fade {
      right: -2px;
      background: linear-gradient(-90deg, #272625 15%, rgba(39, 38, 37, 0) 100%); }
    #main.lexique #screen-3 #main-slider .swiper-button-next,
    #main.lexique #screen-3 #main-slider .swiper-button-prev {
      top: 36.5%;
      z-index: 3; }
    #main.lexique #screen-3 #main-slider .swiper-button-prev {
      left: 140px; }
    #main.lexique #screen-3 #main-slider .swiper-button-next {
      right: 70px; }
    #main.lexique #screen-3 #main-slider .swiper-button-disabled {
      opacity: 0.05; }
    #main.lexique #screen-3 #main-slider .swiper-slide {
      opacity: 0;
      will-change: transform;
      -webkit-transition: opacity 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -moz-transition: opacity 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -ms-transition: opacity 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -o-transition: opacity 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      transition: opacity 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
      #main.lexique #screen-3 #main-slider .swiper-slide.swiper-slide-active {
        opacity: 1; }
    #main.lexique #screen-3 #main-slider .swiper-slide > .inner {
      position: relative;
      margin: 0 100px; }
      #main.lexique #screen-3 #main-slider .swiper-slide > .inner .image-wrapper {
        position: absolute;
        top: 170px;
        left: 220px;
        -webkit-transform: scale(2.3);
        -ms-transform: scale(2.3);
        transform: scale(2.3); }
      #main.lexique #screen-3 #main-slider .swiper-slide > .inner .content-wrapper {
        position: absolute;
        left: 540px;
        top: 100px;
        width: 310px;
        height: 300px; }
      #main.lexique #screen-3 #main-slider .swiper-slide > .inner .title {
        position: relative;
        display: block;
        font-family: 'Larish Alte';
        font-weight: 600;
        font-style: normal;
        font-size: 60px;
        width: 100%;
        margin-bottom: 50px; }
        #main.lexique #screen-3 #main-slider .swiper-slide > .inner .title .small {
          font-size: 50px; }
        #main.lexique #screen-3 #main-slider .swiper-slide > .inner .title .smaller {
          font-size: 30px; }
        #main.lexique #screen-3 #main-slider .swiper-slide > .inner .title .subtitle {
          font-family: 'Volte';
          font-weight: normal;
          font-style: normal;
          font-size: 30px;
          margin-top: 10px; }
      #main.lexique #screen-3 #main-slider .swiper-slide > .inner .translations-items {
        position: absolute;
        left: 0px;
        top: 120px;
        width: 100%; }
      #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous {
        display: inline-block;
        position: absolute;
        display: block;
        width: 100%;
        visibility: hidden;
        left: 0px;
        top: 0px;
        pointer-events: none; }
        #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item {
          display: inline-block;
          position: relative;
          margin-bottom: 20px;
          pointer-events: none; }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .translation-item-title {
            font-size: 18px;
            font-weight: 500;
            margin-bottom: 0px; }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .language-word {
            font-family: 'Larish Alte';
            font-weight: 600;
            font-style: normal;
            font-size: 40px; }
            #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .language-word.small {
              font-size: 30px; }
            #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .language-word.smaller {
              font-size: 22px; }
            #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .language-word .part {
              position: relative;
              display: inline-block;
              white-space: nowrap;
              color: #3D8B51;
              line-height: 1.35em; }
              #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .language-word .part .progress {
                position: absolute;
                overflow: hidden;
                left: 0px;
                top: 0px;
                opacity: 1;
                border-bottom: 2px solid #3D8B51; }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .play-button {
            position: absolute;
            top: 50%;
            left: -60px;
            width: 37px;
            height: 37px;
            margin-top: -18.5px;
            -webkit-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
            -moz-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
            -ms-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
            -o-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
            transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
            #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .play-button .inner {
              display: flex;
              justify-content: center;
              align-items: center;
              background: #3D8B51;
              width: 100%;
              height: 100%;
              border-radius: 20px; }
            #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item .play-button:active .inner {
              -webkit-transform: scale(0.85);
              -ms-transform: scale(0.85);
              transform: scale(0.85); }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item.non-existent .language-word {
            font-size: 24px; }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous .translation-item.non-existent .play-button {
            display: none; }
        #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous.current {
          visibility: visible;
          pointer-events: auto; }
          #main.lexique #screen-3 #main-slider .swiper-slide > .inner .indigenous.current .translation-item {
            pointer-events: auto; }
  #main.lexique #screen-3 #language-bar {
    display: flex;
    position: absolute;
    top: 572px;
    left: 392px;
    z-index: 3; }
    #main.lexique #screen-3 #language-bar .language-item {
      display: inline-flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      width: 260px;
      height: 572px;
      width: 259px;
      height: 112px;
      background-color: #A89D9B;
      margin: 1px;
      -webkit-transition: background-color 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -moz-transition: background-color 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -ms-transition: background-color 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -o-transition: background-color 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      transition: background-color 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
      #main.lexique #screen-3 #language-bar .language-item .nation-name {
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal;
        font-size: 26px;
        margin-bottom: 7px;
        text-align: center;
        padding: 0 15px; }
      #main.lexique #screen-3 #language-bar .language-item .language-name {
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal;
        font-size: 14px; }
      #main.lexique #screen-3 #language-bar .language-item.active {
        background-color: #24844B; }
      #main.lexique #screen-3 #language-bar .language-item:first-child {
        border-radius: 20px 0 0 20px; }
      #main.lexique #screen-3 #language-bar .language-item:last-child {
        border-radius: 0 20px 20px 0; }
  #main.lexique #screen-3 .close-slider {
    position: absolute;
    right: 115px;
    top: 10px;
    z-index: 11; }
    #main.lexique #screen-3 .close-slider .inner {
      padding: 10px;
      line-height: 0; }
      #main.lexique #screen-3 .close-slider .inner svg {
        width: 46px;
        height: 46px; }
    #main.lexique #screen-3 .close-slider:active .inner {
      -webkit-transform: scale(0.9);
      -ms-transform: scale(0.9);
      transform: scale(0.9); }

#main.carte-montreal {
  background-color: #333130; }
  #main.carte-montreal #language-switcher {
    left: 1804px;
    top: 979px; }

#main.carte-montreal #game-title {
  width: 1200px; }
  #main.carte-montreal #game-title .subtitle {
    color: #D8A400; }

#main.carte-montreal #screen-2 #sidebar {
  position: absolute;
  display: inline-block;
  width: 470px;
  height: 941px;
  left: 21px;
  top: 139px;
  will-change: opacity;
  -webkit-transition: opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -moz-transition: opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -ms-transition: opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -o-transition: opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  border-radius: 10px;
  overflow: hidden; }
  #main.carte-montreal #screen-2 #sidebar.disabled {
    opacity: 0.5;
    pointer-events: none; }
  #main.carte-montreal #screen-2 #sidebar .sidebar-tab-content {
    position: absolute;
    width: 470px;
    height: 864px;
    top: 0;
    left: 0;
    padding: 0;
    visibility: hidden; }
    #main.carte-montreal #screen-2 #sidebar .sidebar-tab-content .default-content {
      position: absolute;
      width: 470px;
      height: 864px;
      -webkit-transition: background 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: background 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: background 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: background 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: background 0.25s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      border-radius: 10px 10px 0 0;
      background: #242221; }
    #main.carte-montreal #screen-2 #sidebar .sidebar-tab-content.card-opened .default-content {
      pointer-events: none;
      background: #202932; }
    #main.carte-montreal #screen-2 #sidebar .sidebar-tab-content#sidebar-explore.card-opened .list:before, #main.carte-montreal #screen-2 #sidebar .sidebar-tab-content#sidebar-explore.card-opened .list:after {
      background: #202932; }
  #main.carte-montreal #screen-2 #sidebar .details-card {
    position: absolute;
    width: 470px;
    height: 864px;
    top: 0;
    left: 0;
    padding: 0;
    border-radius: 10px 10px 0 0;
    visibility: hidden; }
    #main.carte-montreal #screen-2 #sidebar .details-card > .reveal-wrapper {
      position: absolute;
      overflow: hidden;
      width: 470px;
      height: 864px;
      border-radius: 12px; }
      #main.carte-montreal #screen-2 #sidebar .details-card > .reveal-wrapper > .inner {
        position: relative; }
    #main.carte-montreal #screen-2 #sidebar .details-card.active {
      visibility: visible; }
    #main.carte-montreal #screen-2 #sidebar .details-card .details-close {
      position: absolute;
      top: 810px;
      left: 218px; }
      #main.carte-montreal #screen-2 #sidebar .details-card .details-close .inner {
        background: url("../images/carte_montreal/close-1.svg") no-repeat center center;
        background-size: contain;
        width: 34px;
        height: 34px;
        -webkit-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
        -moz-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
        -ms-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
        -o-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
        transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
      #main.carte-montreal #screen-2 #sidebar .details-card .details-close:active .inner {
        -webkit-transform: scale(0.9);
        -ms-transform: scale(0.9);
        transform: scale(0.9); }
  #main.carte-montreal #screen-2 #sidebar #sidebar-tabs {
    display: inline-block;
    position: absolute;
    bottom: 0px;
    background: #D8A400;
    border-radius: 10px 10px 0 0;
    width: 100%;
    height: 77px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab {
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      position: absolute;
      top: 10px;
      width: 98px;
      height: 63px;
      border-radius: 10px;
      background: #D8A400;
      -webkit-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      padding-bottom: 6px;
      box-sizing: border-box;
      z-index: 10;
      font-family: 'Volte';
      font-weight: 500;
      font-style: normal;
      font-size: 15px; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab.active {
        background: #79621C; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab:nth-child(1) {
        left: 40px; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab:nth-child(2) {
        left: 185px; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab:nth-child(3) {
        left: 335px; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-tabs .sidebar-tab .icon {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 32px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-infos {
  background: #333130; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-infos .top-info {
    padding: 20px;
    font-size: 20px;
    margin: 30px 35px 30px 0;
    line-height: 1.35em;
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-infos .top-info strong {
      font-family: 'Volte';
      font-weight: 600;
      font-style: normal; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-infos .top-info p {
      margin-bottom: 30px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info {
    width: 100%;
    padding: 20px 20px 100px 20px;
    position: absolute;
    top: 515px;
    background-color: #79621c;
    border-radius: 8px 8px 0 0; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-title {
      display: block;
      color: #D8A400;
      font-family: 'Volte';
      font-weight: 600;
      font-style: normal;
      font-size: 25px;
      margin: 20px 0; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-explore,
    #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-routes {
      margin: 10px 0;
      display: flex;
      flex-direction: row;
      font-size: 18px;
      font-family: 'Volte';
      font-weight: 500;
      font-style: normal;
      font-size: 18px;
      line-height: 1.2em; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-explore p,
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-routes p {
        margin: 10px 0; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-explore strong,
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-routes strong {
        font-size: 20px;
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-explore .icon,
      #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-routes .icon {
        margin-left: 7px;
        margin-right: 20px; }
        #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-explore .icon img,
        #main.carte-montreal #screen-2 #sidebar #sidebar-infos .bottom-info .bottom-info-routes .icon img {
          width: 42px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-explore .top-info {
  padding: 30px 55px 40px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .top-info .line-1 {
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    font-size: 20px;
    margin-bottom: 20px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .top-info .line-2 {
    position: relative;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 25px;
    margin-bottom: 16px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .top-info .line-2 .pin-icon {
      position: absolute;
      top: -15px;
      left: -52px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .top-info .line-3 {
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal;
    font-size: 16px;
    line-height: 22px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-explore .list-title {
  position: absolute;
  top: 250px;
  width: 100%;
  border-top: 1px #888 solid;
  padding: 25px 15px;
  font-family: 'Larish Alte';
  font-weight: 600;
  font-style: normal;
  font-size: 27px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-explore .list {
  position: absolute;
  top: 330px;
  width: 100%;
  height: 515px;
  overflow: hidden; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list:after, #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list:before {
    content: "";
    position: absolute;
    height: 20px;
    width: 100%;
    z-index: 10;
    left: 0;
    background: #242221;
    -webkit-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: background 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list:before {
    top: 0;
    mask-image: linear-gradient(white, transparent);
    -webkit-mask-image: linear-gradient(white, transparent); }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list:after {
    bottom: 0;
    mask-image: linear-gradient(transparent, white);
    -webkit-mask-image: linear-gradient(transparent, white); }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list .content {
    padding: 20px 0; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list .item {
    display: flex;
    align-items: flex-start;
    border-top: 1px #888 solid;
    margin: 0 20px 0 60px;
    height: 70px;
    padding-top: 10px;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 19px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .list .item:before {
      display: inline-block;
      content: url("../images/carte_montreal/pin-B.svg");
      height: 23px;
      margin-right: 5px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card {
  padding: 50px 0 0 0;
  color: #E7E2DF; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .reveal-wrapper {
    top: 105px;
    height: 759px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .vertical-line {
    position: absolute;
    left: 30px;
    top: 0px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats {
    display: flex;
    margin: 0px 0 30px 50px;
    padding-right: 15px;
    padding-top: 10px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-distance,
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-duration {
      width: 50%; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-distance .stat-value,
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-duration .stat-value {
        font-family: 'Larish Alte';
        font-weight: 600;
        font-style: normal;
        font-size: 40px;
        border-left: 2px solid #4E4E4E;
        padding: 0 0 14px 10px;
        margin-bottom: 7px;
        height: 50px; }
        #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-distance .stat-value .mode,
        #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-duration .stat-value .mode {
          visibility: hidden;
          position: absolute; }
          #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-distance .stat-value .mode.active,
          #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .stats-duration .stat-value .mode.active {
            visibility: unset; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .distance-mode,
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .duration-mode {
      display: inline-flex;
      justify-content: center;
      align-items: center;
      padding: 0px 14px;
      border-radius: 10px;
      font-size: 15px;
      height: 40px;
      min-width: 65px;
      background-color: transparent;
      margin-top: 10px;
      font-family: 'Volte';
      font-weight: 500;
      font-style: normal;
      line-height: 10px;
      -webkit-transition: background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .distance-mode img,
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .duration-mode img {
        max-height: 27px;
        width: auto; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .distance-mode:last-child,
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .duration-mode:last-child {
        margin-left: 3px; }
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .distance-mode.active,
      #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .duration-mode.active {
        background-color: #194773; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .stats .distance-legend {
      font-style: italic;
      margin-top: 25px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-image {
    margin: 0 0 13px 50px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-image img {
      width: 100%;
      max-width: 100%;
      height: auto; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-image .details-image-legend {
      padding-bottom: 10px;
      font-size: 13px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-title {
    position: relative;
    display: flex;
    align-items: center;
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 33px;
    margin: 0 45px 2px 0; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-title .pin-icon {
      position: relative;
      z-index: 1;
      margin-right: 3px;
      margin-left: 3px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-title:after {
      content: "";
      position: absolute;
      top: 15px;
      left: 0;
      width: 50px;
      height: 700px;
      background-color: #202932; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-person {
    margin: 0 45px 0 61px;
    font-size: 23px;
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-explore .details-card .details-text {
    font-size: 16px;
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal;
    margin: 20px 70px 0 61px;
    line-height: 1.4;
    overflow: hidden; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes {
  color: #E7E2DF; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .default-content {
    top: 100px;
    height: 764px;
    padding: 50px 26px 0 26px;
    -webkit-transition: background 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes .default-content .wrapper {
      position: relative;
      top: 0;
      -webkit-transition: top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -moz-transition: top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -ms-transition: top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -o-transition: top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      transition: top 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes.card-opened .default-content {
    top: 0;
    height: 864px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes.card-opened .default-content .wrapper {
      top: 100px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .top-info {
    font-family: 'Larish Alte';
    font-weight: 600;
    font-style: normal;
    font-size: 42px;
    margin-bottom: 75px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .list .item {
    display: flex;
    align-items: flex-start;
    border-top: 2px solid #4E4E4E;
    padding: 9px 0; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes .list .item .group-right {
      flex-grow: 1;
      margin-left: 18px;
      line-height: 1.2; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes .list .item .route-title {
      font-family: 'Larish Alte';
      font-weight: 600;
      font-style: normal;
      font-size: 22px; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes .list .item .route-subtitle {
      font-size: 16px;
      margin-top: 10px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .wrapper {
  padding: 0 20px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .round-button .inner {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid #fefefe;
  border-radius: 50%;
  background-color: #2E2F30;
  -webkit-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -moz-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -ms-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  -o-transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: opacity 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955); }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .round-button:active .inner {
  -webkit-transform: scale(0.9);
  -ms-transform: scale(0.9);
  transform: scale(0.9); }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .round-button.active .inner {
  background-color: #005FC5; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-image {
  position: relative;
  height: 185px;
  width: 470px;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  border-radius: 10px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .route-image-legend {
  font-size: 13px;
  padding: 10px 20px 0 20px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-title {
  display: flex;
  align-items: center;
  position: relative;
  min-height: 130px;
  font-family: 'Larish Alte';
  font-weight: 600;
  font-style: normal;
  font-size: 30px;
  padding: 0 80px 0 20px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-title .details-perso-button {
    position: absolute;
    right: 20px;
    top: 50%;
    margin-top: -22px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-slider .character-slide .character-description {
  font-family: 'Volte';
  font-weight: 500;
  font-style: normal;
  font-size: 20px;
  line-height: 25px; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-slider .swiper-slide .wrapper {
  display: flex;
  flex-direction: row; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-slider .swiper-slide .wrapper .group-left {
    width: 98px;
    margin-right: 20px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-slider .swiper-slide .wrapper .poi-title {
    font-family: 'Volte';
    font-weight: 600;
    font-style: normal;
    font-size: 22px;
    margin-bottom: 15px;
    line-height: normal; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-slider .swiper-slide .wrapper .poi-description {
    font-family: 'Volte';
    font-weight: 500;
    font-style: normal;
    font-size: 16px;
    line-height: 1.40em; }

#main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-submenu {
  position: absolute;
  top: 600px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: calc(100% - 40px);
  margin-top: 40px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-submenu .details-route-button {
    position: relative; }
    #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-submenu .details-route-button .inner span {
      font-family: 'Larish Alte';
      font-weight: 600;
      font-style: normal;
      font-size: 23px;
      line-height: 18px; }
  #main.carte-montreal #screen-2 #sidebar #sidebar-routes .details-card .details-submenu:before {
    content: "••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••••";
    position: absolute;
    left: 21px;
    top: 17px;
    font-size: 10px;
    letter-spacing: 1px;
    transform-origin: 0% 50%; }

#main.carte-montreal #screen-2 .route-image {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  width: 98px;
  height: 98px;
  overflow: hidden;
  border-radius: 10px; }
  #main.carte-montreal #screen-2 .route-image img {
    position: absolute; }

#main.carte-montreal #screen-2 #map {
  position: absolute;
  left: 518px;
  top: 59px;
  width: 1356px;
  height: 901px; }
  #main.carte-montreal #screen-2 #map .map-overlay {
    position: absolute;
    left: 0;
    top: 0;
    width: 1356px;
    height: 901px;
    -webkit-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.carte-montreal #screen-2 #map .map-overlay:not(.active) {
      opacity: 0;
      pointer-events: none; }
  #main.carte-montreal #screen-2 #map .map-initial-poi-pin,
  #main.carte-montreal #screen-2 #map .map-poi-path,
  #main.carte-montreal #screen-2 #map .map-route {
    filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.4)); }
  #main.carte-montreal #screen-2 #map .map-poi-path {
    position: absolute;
    display: inline-block;
    top: 0;
    left: 0;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), visibility 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), visibility 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), visibility 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), visibility 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), visibility 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
    #main.carte-montreal #screen-2 #map .map-poi-path.active {
      visibility: visible;
      opacity: 1; }
    #main.carte-montreal #screen-2 #map .map-poi-path .path mask path {
      will-change: stroke-dashoffset; }
  #main.carte-montreal #screen-2 #map #map-explore-overlay.poi-opened .map-poi-pin {
    pointer-events: none; }
    #main.carte-montreal #screen-2 #map #map-explore-overlay.poi-opened .map-poi-pin:not(.active):not(.selected) {
      opacity: 0.5; }
  #main.carte-montreal #screen-2 #map #map-explore-overlay .map-initial-poi-pin {
    position: absolute;
    display: inline-block;
    z-index: 1; }
  #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin {
    display: inline-block;
    position: absolute;
    -webkit-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -moz-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -ms-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transform-origin: center bottom;
    width: 40px;
    height: 50px;
    margin-left: -22.5px;
    margin-top: -40px; }
    #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin.active {
      z-index: 100; }
    #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip {
      position: absolute;
      left: 15px;
      top: 5px;
      background: #fefefe;
      color: #000;
      width: 190px;
      padding: 5px 20px 5px 30px;
      border-radius: 15px;
      -webkit-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: transform 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955); }
      #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip .title {
        font-family: 'Volte';
        font-weight: 600;
        font-style: normal;
        font-size: 14px; }
      #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip .person {
        font-family: 'Volte';
        font-weight: 500;
        font-style: normal;
        font-size: 12px; }
      #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip .close {
        position: absolute;
        display: inline-block;
        right: -12px;
        top: -10px;
        width: 22px;
        height: 22px;
        -webkit-transition: transform 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -moz-transition: transform 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -ms-transition: transform 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        -o-transition: transform 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        transition: transform 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
        #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip .close .inner {
          pointer-events: none;
          display: inline-flex;
          justify-content: center;
          align-items: center;
          width: 22px;
          height: 22px;
          border-radius: 50%;
          position: absolute;
          background: #333130; }
        #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin .tooltip .close:active .inner {
          -webkit-transform: scale(0.8);
          -ms-transform: scale(0.8);
          transform: scale(0.8); }
    #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin.tooltip-on-left .tooltip {
      left: -170px; }
      #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin.tooltip-on-left .tooltip .close {
        left: -10px; }
    #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin:after {
      position: absolute;
      display: inline-block;
      content: url("../images/carte_montreal/pin-B.svg");
      -webkit-transform: scale(2.4);
      -ms-transform: scale(2.4);
      transform: scale(2.4);
      margin-top: 20px;
      transform-origin: left center;
      filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.75)); }
    #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin:not(.active) {
      -webkit-transform: scale(0.6);
      -ms-transform: scale(0.6);
      transform: scale(0.6); }
      #main.carte-montreal #screen-2 #map #map-explore-overlay .map-poi-pin:not(.active) .tooltip {
        pointer-events: none;
        opacity: 0; }
  #main.carte-montreal #screen-2 #map #map-routes-overlay .map-poi-pin {
    width: 4px;
    height: 4px;
    position: absolute;
    margin-left: -2px;
    margin-top: -2px; }
    #main.carte-montreal #screen-2 #map #map-routes-overlay .map-poi-pin .inner {
      display: flex;
      justify-content: center;
      align-items: center;
      width: 44px;
      height: 44px;
      border: 1px solid #fefefe;
      border-radius: 50%;
      background-color: #2E2F30;
      font-family: 'Larish Alte';
      font-weight: 600;
      font-style: normal;
      font-size: 23px;
      line-height: 18px;
      -webkit-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -moz-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -ms-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      -o-transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transition: transform 0.1s cubic-bezier(0.455, 0.03, 0.515, 0.955), opacity 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955), background-color 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
      transform: translate(-50%, -50%) scale(1); }
    #main.carte-montreal #screen-2 #map #map-routes-overlay .map-poi-pin.active .inner {
      background-color: #005FC5; }
    #main.carte-montreal #screen-2 #map #map-routes-overlay .map-poi-pin:active .inner {
      transform: translate(-50%, -50%) scale(0.9); }
  #main.carte-montreal #screen-2 #map #toggle-layers {
    display: inline-block;
    position: absolute;
    bottom: 15px;
    right: 70px;
    background-color: #fefefe;
    padding: 10px 8px;
    border-radius: 10px;
    box-shadow: 0px 4px 9px -1px rgba(0, 0, 0, 0.65);
    -webkit-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -moz-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -ms-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    -o-transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transition: background-color 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #main.carte-montreal #screen-2 #map #toggle-layers svg path {
      -webkit-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -moz-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -ms-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      -o-transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
      transition: fill 0.1s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
    #main.carte-montreal #screen-2 #map #toggle-layers.active {
      background-color: #D8A400; }
      #main.carte-montreal #screen-2 #map #toggle-layers.active svg path {
        fill: #fefefe; }
  #main.carte-montreal #screen-2 #map #layers {
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    z-index: 101; }

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