@charset "UTF-8";
@font-face {
  font-family: "kanit--regular";
  font-style: normal;
  font-weight: 400;
  font-display: auto;
  src: url("../../../../../../themes/custom/frontend_tertiary/fonts/kanit--regular.woff2") format("woff2"); }

@font-face {
  font-family: "kanit--semibold";
  font-style: normal;
  font-weight: 500;
  font-display: auto;
  src: url("../../../../../../themes/custom/frontend_tertiary/fonts/kanit--semibold.woff2") format("woff2"); }

/* ==========================================================================
   COLORS
   ========================================================================== */
/* ==========================================================================
   TEXT
   ========================================================================== */
/* ==========================================================================
   FONT
   ========================================================================== */
/* ==========================================================================
   TITLE
   ========================================================================== */
/* ==========================================================================
   GRID
   ========================================================================== */
/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
/* ==========================================================================
   ZINDEX
   ========================================================================== */
/* ==========================================================================
   BTN
   ========================================================================== */
/* ==========================================================================
   INPUT
   ========================================================================== */
/* ==========================================================================
   TAG
   ========================================================================== */
/* ==========================================================================
   TABLE
   ========================================================================== */
/* ==========================================================================
   NOTICE
   ========================================================================== */
/* ==========================================================================
   TABS
   ========================================================================== */
/* ==========================================================================
   SPINNER
   ========================================================================== */
/* ==========================================================================
   CUSTOM
   ========================================================================== */
/* ==========================================================================
   PRINT
   ========================================================================== */
/* ==========================================================================
   MIXINS
   ========================================================================== */
/* ==========================================================================
   TEXT & FONTS
   ========================================================================== */
/* ==========================================================================
   STATES
   ========================================================================== */
/* ==========================================================================
   VISIBILITY
   ========================================================================== */
/*
 * Only display content to screen readers
 */
/*
 * Use in conjunction with .sr-only to only display content when it's focused.
 */
/* ==========================================================================
   COLORS
   ========================================================================== */
/* ==========================================================================
   LAYOUT
   ========================================================================== */
/* ==========================================================================
   ALIGNMENT
   ========================================================================== */
/* ==========================================================================
   OTHER
   ========================================================================== */
/* ==========================================================================
    ROUNDED
   ========================================================================== */
/**
 * $center-v: start/center/end
 * $center-h: start/center/end/around/beween
 */
/*

 */
/**
 * breakpoint : min width breakpoint
 * $columns: int or string = inline list
 * $center-v: start/center/end
 */
/* ==========================================================================
   MAIN
   ========================================================================== */
@-webkit-keyframes mouse-wheel {
  0% {
    top: 1px;
    opacity: 1; }
  50% {
    top: 30%;
    opacity: 0; }
  100% {
    top: 1px;
    opacity: 0; } }
@keyframes mouse-wheel {
  0% {
    top: 1px;
    opacity: 1; }
  50% {
    top: 30%;
    opacity: 0; }
  100% {
    top: 1px;
    opacity: 0; } }

@-webkit-keyframes mouse-scroll {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes mouse-scroll {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

/* ==========================================================================
   MAIN
   ========================================================================== */
html,
body {
  width: 100%; }

@media all and (max-width: 767px) {
  html {
    font-size: 0.938rem; } }

body {
  min-width: 320px;
  overflow-x: hidden;
  overflow-y: auto;
  color: #959595;
  font-weight: normal;
  font-family: "kanit--regular", Arial, sans-serif;
  font-size: 1.063rem;
  line-height: 1.5;
  background-color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

/* ==========================================================================
   INLINE
   ========================================================================== */
a {
  color: #4C1E5C;
  text-decoration: none;
  transition: .2s; }

strong,
b {
  font-weight: normal;
  font-family: Arial, sans-serif; }

abbr {
  border-bottom: 1px dotted #4C1E5C;
  cursor: help; }

/* ==========================================================================
   TEXT
   ========================================================================== */
p,
blockquote,
form,
ul,
ol,
fieldset {
  margin: 0 0 1.6em; }

blockquote {
  position: relative;
  margin: 36px auto; }
  blockquote > *:last-of-type {
    margin-bottom: 0; }

/* ==========================================================================
   LISTING
   ========================================================================== */
li {
  margin: 0; }

ul,
ol {
  padding: 0;
  list-style-position: inside; }

/* ==========================================================================
   MEDIA
   ========================================================================== */
img {
  max-width: 100%;
  height: auto; }

iframe {
  max-width: 100%;
  border: 0; }

figure {
  margin: 0; }

hr {
  height: 1px;
  margin: 36px auto;
  background: #8e929c;
  border: 0; }

fieldset {
  min-width: 0;
  padding: 22px 32px;
  border: 1px solid #8e929c; }

/* ==========================================================================
   Rows
   ========================================================================== */
.row {
  position: relative;
  width: 100%;
  max-width: 908px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box; }

.row--small {
  max-width: 1441px; }

.row--full {
  max-width: 1920px; }

.row--fluid {
  max-width: 1140px; }
  body.l-wide-page .row--fluid {
    max-width: 1920px; }
  body.l-print.l-print--portrait .row--fluid {
    max-width: 210mm; }
  body.l-print.l-print--landscape .row--fluid {
    max-width: 297mm; }

.row--print {
  margin-left: 0; }

/* ==========================================================================
   Layouts
   ========================================================================== */
.l-wrapper {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px; }

.l-half {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
  margin-bottom: 24px;
  padding-left: 12px;
  padding-right: 12px;
  flex: 0 0 auto;
  max-width: 100%; }
  @media all and (min-width: 768px) {
    .l-half {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 auto;
      max-width: 50%; } }

.l-twothird {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
  margin-bottom: 24px;
  padding-left: 12px;
  padding-right: 12px;
  flex: 0 0 auto;
  max-width: 100%; }
  @media all and (min-width: 1280px) {
    .l-twothird {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 66.66667%;
      max-width: 66.66667%; } }

.l-third, .list--primary .l-half {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
  margin-bottom: 24px;
  padding-left: 12px;
  padding-right: 12px;
  flex: 0 0 auto;
  max-width: 100%; }
  @media all and (min-width: 768px) {
    .l-third, .list--primary .l-half {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 auto;
      max-width: 50%; } }
  @media all and (min-width: 1280px) {
    .l-third, .list--primary .l-half {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 33.33333%;
      max-width: 33.33333%; } }

.l-quarter {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
  margin-bottom: 24px;
  padding-left: 12px;
  padding-right: 12px;
  flex: 0 0 auto;
  max-width: 100%; }
  @media all and (min-width: 768px) {
    .l-quarter {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 auto;
      max-width: 50%; } }
  @media all and (min-width: 1280px) {
    .l-quarter {
      margin-bottom: 24px;
      padding-left: 12px;
      padding-right: 12px;
      flex: 0 0 25%;
      max-width: 25%; } }

.l-full {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 1px;
  box-sizing: border-box;
  margin-bottom: 24px;
  padding-left: 12px;
  padding-right: 12px;
  flex: 0 0 auto;
  max-width: 100%; }

/* ==========================================================================
   Page
   ========================================================================== */
.page {
  position: relative;
  margin: 0 auto;
  box-sizing: border-box;
  overflow: hidden; }

/* ==========================================================================
   Header
   ========================================================================== */
.main-header {
  background-color: #fff;
  box-sizing: border-box;
  /* Responsive
  ========================================================================== */ }
  .main-header > .row {
    display: flex;
    align-items: center;
    justify-content: space-between; }
  .main-header .nav--main .level-1 > a,
  .main-header .nav-toggle > a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 86px; }
  @media all and (min-width: 1280px) {
    .main-header .btn--togglemenu {
      display: none; } }
  @media all and (max-width: 1279px) {
    .main-header > .row {
      min-height: 190px; }
    .main-header .nav--main {
      display: none; }
    .main-header .main-header-middle {
      order: -1; }
    .main-header .main-header-top {
      padding: 0 10px;
      margin-right: auto; } }
  @media all and (min-width: 768px) {
    .main-header {
      min-height: 190px; } }
  @media all and (max-width: 767px) {
    .main-header > .row {
      min-height: 70px; } }
  @media all and (max-width: 499px) {
    .main-header > .row {
      padding-left: 10px;
      padding-right: 10px; }
    .main-header .block .nav--dropdown .nav-toggle .icon {
      width: 40px;
      height: 40px;
      line-height: 40px; }
    .main-header .block .nav--dropdown .nav-content {
      position: fixed;
      top: 71px;
      right: 0;
      left: 0;
      width: auto;
      -webkit-transform: none;
              transform: none; } }

@media all and (min-width: 1441px) {
  .main-header-top,
  .main-header-bottom {
    flex: 200px; } }

@media all and (min-width: 1280px) {
  .main-header-middle {
    margin: 0 auto;
    padding: 0 24px; } }

.main-header-bottom {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end; }
  .main-header-bottom .block {
    padding: 0; }
    @media all and (min-width: 768px) {
      .main-header-bottom .block + .block {
        margin-left: 8px; } }

.main-header-navigation {
  background: #fff; }
  .main-header-navigation .row {
    background: rgba(76, 30, 92, 0.1); }

.fixer-header-container.is-fixed .main-header-navigation {
  position: fixed;
  top: 0;
  z-index: 100;
  width: 100%; }

.fixer-header-container.toolbar-horizontal.toolbar-fixed.is-fixed .main-header-navigation {
  top: var(--drupal-displace-offset-top); }

.fixer-header-container.toolbar-horizontal.toolbar-fixed.is-fixed.route--layout-builder-overrides-node-view .main-header-navigation {
  top: calc(var(--drupal-displace-offset-top) + 60px); }

/* ==========================================================================
   Contenu
   ========================================================================== */
.main-content > .row {
  padding: 0; }

.content-before {
  position: relative;
  margin: 36px 0;
  background: #fff;
  transition: padding .2s; }
  .content-before .row {
    display: flex;
    justify-content: space-between;
    align-items: center; }
  @media all and (min-width: 1280px) {
    .l-breadcrumb-fixed .content-before {
      position: fixed;
      z-index: 25;
      left: 0;
      right: 0;
      box-sizing: border-box; }
    .l-breadcrumb-fixed.l-menu-dashboard .content-before {
      padding-left: 72px; }
    .l-breadcrumb-fixed.l-menu-dashboard-open .content-before {
      padding-left: 192px; } }

@media all and (min-width: 1280px) {
  .l-breadcrumb-fixed:not(.is-front) .content {
    padding-top: 70px; } }

.content-header .nav--toolbar {
  margin-bottom: 9px; }

.content-titles .content-title {
  display: flex;
  justify-content: center;
  margin: 0; }

.content-titles .content-subtitle {
  margin: 1em 0 54px; }

.content-details {
  margin-top: 9px; }
  .content-details .item-category {
    color: #4C1E5C; }
    .content-details .item-category + .item-date {
      margin-left: 12px; }
      .content-details .item-category + .item-date span:before {
        content: "/";
        margin-right: 3px; }

.content-subtitle {
  color: #2B2929;
  font-size: 1.25rem;
  line-height: 1.35; }

.content-body {
  margin-bottom: 36px; }

/* Bannière
   ========================================================================== */
.content-banner {
  position: relative;
  margin-bottom: 36px;
  border-radius: 4px;
  overflow: hidden; }
  .content-banner img,
  .content-banner picture {
    display: block; }
  .content-banner:before {
    content: "";
    position: absolute;
    z-index: 5;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.2); }

.content-banner--body {
  position: absolute;
  z-index: 10;
  padding: 9px 48px;
  bottom: 0;
  /* Responsive
     ========================================================================== */ }
  .content-banner--body .content-title {
    color: #fff; }
  @media all and (min-width: 768px) {
    .content-banner--body {
      padding-top: 36px;
      padding-bottom: 36px; } }

/* ==========================================================================
   Content builder
   ========================================================================== */
.builder-row {
  position: relative;
  display: flex;
  margin-top: 18px;
  margin-bottom: 36px;
  margin-left: -24px;
  margin-right: -24px; }
  .builder-row > .builder-item {
    flex: 0 1 100%;
    position: relative;
    margin-left: 24px;
    margin-right: 24px;
    box-sizing: border-box; }
  .builder-row.l-background {
    margin-top: -36px;
    margin-bottom: -36px;
    margin-left: -24px;
    margin-right: -24px; }
    .builder-row.l-background > .builder-item {
      margin: 0; }
    .builder-row.l-background .block--richtext {
      margin: 216px 96px 108px;
      padding: 36px 48px 1px;
      border-top: 4px solid #4C1E5C;
      background: rgba(43, 41, 41, 0.72);
      -webkit-backdrop-filter: blur(5px);
              backdrop-filter: blur(5px);
      color: #fff;
      width: 422px;
      box-sizing: border-box; }
      .builder-row.l-background .block--richtext h2 {
        font-size: 2.813rem;
        margin-bottom: 9px; }
        .builder-row.l-background .block--richtext h2:before {
          content: none; }
      .builder-row.l-background .block--richtext p,
      .builder-row.l-background .block--richtext a,
      .builder-row.l-background .block--richtext h2 {
        color: inherit; }

.builder-row-background {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: no-repeat center #4C1E5C;
  background-size: cover; }

.layout--onecol .dataviz {
  margin: 36px auto; }

.layout--onecol.layout--space {
  margin-top: 0; }

.layout--onecol.theme-bg-tertiary, .layout--onecol.theme-bg-muted {
  margin-top: -18px;
  margin-left: -24px;
  margin-right: -24px;
  padding-left: 12px;
  padding-right: 12px; }

.layout--onecol.theme-bg-muted {
  margin-top: 54px;
  margin-bottom: -36px; }

@media all and (min-width: 1280px) {
  .layout--twocol > .builder-item,
  .layout--threecol > .builder-item {
    flex: 0 1 100%; }
  .layout--twocol.l-33-67 > .layout__region--first {
    flex: 0 1 33%; }
  .layout--twocol.l-33-67 > .layout__region--second {
    flex: 0 1 67%; }
  .layout--twocol.l-67-33 > .layout__region--first {
    flex: 0 1 67%; }
  .layout--twocol.l-67-33 > .layout__region--second {
    flex: 0 1 33%; } }

@media all and (max-width: 767px) {
  .builder-row {
    flex-wrap: wrap;
    margin-top: 0; }
    .builder-row > .builder-item {
      flex: 1 0 100%;
      margin-top: 1.6em;
      margin-left: 0;
      margin-right: 0; } }

/* Builder with sidebar(s)
   ========================================================================== */
.content-builder.l-sidebar {
  display: flex;
  flex-direction: column; }

.content-builder-main {
  flex: 1; }

.content-builder-sidebar {
  width: 100%;
  margin-bottom: 18px;
  padding: 0 24px;
  background: #F6F6F6;
  box-sizing: border-box; }
  .l-breadcrumb-fixed .content-builder-sidebar {
    padding-top: 72px; }
  .content-builder-sidebar .builder-item {
    margin-top: 0; }

.content-builder-sidebar--left {
  order: -1; }

@media all and (min-width: 768px) {
  .content-builder.l-sidebar {
    flex-direction: row; }
  .content-builder-sidebar {
    margin-top: -36px;
    flex-shrink: 0;
    margin-bottom: 0;
    width: 300px; }
    .is-front .content-builder-sidebar {
      padding-top: 18px; }
  .content-builder-sidebar-inner {
    position: fixed;
    height: 66.67%;
    margin-top: 18px;
    padding-right: 12px;
    width: 252px;
    overflow-y: auto;
    overflow-x: hidden; }
    .is-fixed .content-builder-sidebar-inner {
      top: 86px; }
    .toolbar-horizontal.toolbar-fixed.is-fixed .content-builder-sidebar-inner {
      top: calc(86px + 53px); }
    .is-reset.toolbar-horizontal.toolbar-fixed .content-builder-sidebar-inner,
    .is-front:not(.is-reset) .content-builder-sidebar-inner,
    .is-reset .content-builder-sidebar-inner {
      position: relative;
      top: 0; } }

/* ==========================================================================
   Footer
   ========================================================================== */
.main-footer {
  background: #fff; }
  .main-footer .row {
    display: flex;
    align-items: center;
    flex-direction: column; }
    .main-footer .row .nav--footer {
      margin: 0 auto; }
  @media all and (max-width: 1279px) {
    .main-footer .nav--footer {
      display: none; } }

.main-footer-inner {
  padding-top: 18px;
  padding-bottom: 18px;
  background-color: #2B2929; }

/* ==========================================================================
   Page site unpublished.
   ========================================================================== */
.route--datagone-site-unpublished {
  text-align: center; }
  .route--datagone-site-unpublished header {
    margin: 18px 0; }
  .route--datagone-site-unpublished .logo {
    text-align: center; }
    .route--datagone-site-unpublished .logo a {
      display: inline-block; }
  .route--datagone-site-unpublished h1 {
    margin-bottom: 18px; }
  .route--datagone-site-unpublished .form {
    margin-top: 36px;
    padding-top: 36px; }
    .route--datagone-site-unpublished .form:before {
      content: "";
      display: block;
      width: 100px;
      height: 2px;
      background: #4C1E5C;
      -webkit-transform: translate(100px, -36px);
              transform: translate(100px, -36px); }
    .route--datagone-site-unpublished .form label {
      text-align: left; }

/* ==========================================================================
   Views.
   ========================================================================== */
.view-empty {
  margin: 18px 0;
  padding-bottom: 9px;
  text-align: center;
  font-style: italic; }

/* ==========================================================================
   Print preview.
   ========================================================================== */
.entity-type--print {
  background: #F6F6F6; }

.page--print {
  overflow: hidden; }

.print-header {
  position: fixed;
  z-index: 100;
  width: 100%;
  background: #fff; }
  .print-header .row {
    padding-top: 9px;
    padding-bottom: 9px;
    background: rgba(76, 30, 92, 0.1); }
  .print-header .nav li {
    margin-right: 24px; }

.print-content {
  padding-top: 61px;
  margin-top: 36px; }

.print-page {
  position: relative;
  margin-bottom: 36px;
  padding: 10mm;
  background: #fff; }
  .print-page.l-portrait {
    width: 190mm;
    min-height: 276.5mm; }
  .print-page.l-landscape {
    width: 277mm;
    min-height: 189.5mm; }
  .print-page .dataviz .nav--toolbar {
    display: none; }
  .print-page .dataviz-container {
    position: relative; }
  .print-page .node-admin {
    position: absolute;
    z-index: 50;
    left: 100%;
    width: 100%;
    margin-left: 96px; }
    .print-page .node-admin .node--admin-toolbar {
      display: none; }
  .print-page .dataviz-form {
    position: absolute;
    z-index: 50;
    right: -200%;
    margin-right: -78px;
    padding: 10px;
    width: 100%;
    background: rgba(255, 255, 255, 0.75);
    border: 1px dashed #8e929c;
    border-radius: 2px;
    box-sizing: border-box;
    transition: .2s; }
    .print-page .dataviz-form:empty {
      display: none; }
    .print-page .dataviz-form:hover {
      z-index: 200;
      background-color: #fff; }
  .print-page .layout--onecol .dataviz-form {
    right: -50%;
    margin-right: -58px;
    width: 50%; }
  .print-page .nav--children .row {
    padding-left: 0;
    padding-right: 0; }
  .print-page .nav--children .nav-menu {
    grid-template-columns: 1fr 1fr; }
  .print-page .nav--children .item-type--accordion a {
    display: block;
    text-align: left; }
  .print-page .nav--children .item-type--accordion .item-wrapper {
    display: block;
    padding: 24px 72px; }
  .print-page .nav--children .item-type--accordion .item-title {
    margin: 0;
    max-width: none; }
    .print-page .nav--children .item-type--accordion .item-title:after {
      content: none; }
  .print-page .block--video .item-image .icon {
    display: none; }
  .print-page .content-banner--body {
    padding-top: 16px;
    padding-bottom: 16px; }

.print-page-header {
  position: relative; }

.print-toc {
  max-width: 50%; }

/* Print: Quick layout builder actions
   ========================================================================== */
.layout--twocol .layout__region--first .print-quick-layout-actions,
.layout--threecol .layout__region--first .print-quick-layout-actions,
.layout--threecol .layout__region--second .print-quick-layout-actions {
  display: none; }

/* Print: Page Break line
   ========================================================================== */
.print-page-break {
  position: absolute;
  left: 0;
  margin: 0;
  width: 100%;
  background: none; }
  .print-page-break:before {
    content: "Limite de page";
    position: absolute;
    top: -8px;
    left: 30px;
    padding: 0 10px 0 5px;
    color: #fff;
    font-style: italic;
    font-size: 0.938rem;
    background-color: #d9534f; }
  .print-page-break:after {
    content: "";
    display: block;
    border-bottom: 3px dashed #d9534f; }

html[lang="en"] .print-page-break:before {
  content: "Page limit"; }

/* ==========================================================================
   MODULES
   ========================================================================== */
/*
Généré par Gulp

Commande : gulp fonticon
*/
/* ==========================================================================
Font
========================================================================== */
@font-face {
  font-family: "icons-1712325806";
  font-weight: normal;
  font-style: normal;
  src: url("../../../../../../themes/custom/frontend_tertiary/fonts/icons-1712325806.woff2?v=1712325806") format("woff2"), url("../../../../../../themes/custom/frontend_tertiary/fonts/icons-1712325806.woff?v=1712325806") format("woff"); }

/*
.icon--arrow-bottom - \EA01
.icon--arrow-left - \EA02
.icon--arrow-long-left - \EA03
.icon--arrow-long-right - \EA04
.icon--arrow-right - \EA05
.icon--arrow-small-bottom - \EA06
.icon--arrow-top - \EA07
.icon--bell - \EA08
.icon--checkbox - \EA09
.icon--circle - \EA0A
.icon--close - \EA0B
.icon--code - \EA0C
.icon--comments - \EA0D
.icon--contact - \EA0E
.icon--download - \EA0F
.icon--edit - \EA10
.icon--expand - \EA11
.icon--export - \EA12
.icon--facebook - \EA13
.icon--file-add - \EA14
.icon--file-chart - \EA15
.icon--file-download - \EA16
.icon--file-transfer - \EA17
.icon--fullscreen - \EA18
.icon--grid - \EA19
.icon--image - \EA1A
.icon--layout - \EA1B
.icon--linkedin - \EA1C
.icon--list - \EA1D
.icon--location - \EA1E
.icon--minus - \EA1F
.icon--phone - \EA20
.icon--play - \EA21
.icon--plus - \EA22
.icon--print - \EA23
.icon--printer - \EA24
.icon--row-add - \EA25
.icon--row-remove - \EA26
.icon--search - \EA27
.icon--share - \EA28
.icon--skew - \EA29
.icon--thread - \EA2A
.icon--ticket - \EA2B
.icon--todo - \EA2C
.icon--twitter - \EA2D
.icon--user - \EA2E
.icon--view - \EA2F

Markup: <span class="icon $modifierClass"></span>

Styleguide Icons - 1.icon
*/
.icon--arrow-bottom:before, .customform-select-toggle:after {
  content: "\EA01"; }

.icon--arrow-left:before {
  content: "\EA02"; }

.icon--arrow-long-left:before, .btn--nav.prev:before {
  content: "\EA03"; }

.icon--arrow-long-right:before, .btn--nav.next:before {
  content: "\EA04"; }

.icon--arrow-right:before, .nav--main .nav-item.level-2.is-parent > a:after {
  content: "\EA05"; }

.icon--arrow-small-bottom:before, .accordion-item .accordion-trigger:after, .nav--summary .nav-menu-trigger:after, .nav--detail .l-accordion > a:after,
.nav--detail .l-accordion > span:after {
  content: "\EA06"; }

.icon--arrow-top:before, .list--page-selection .item-footer .btn:before, .list--page-selection .item-footer .pager a:before, .pager .list--page-selection .item-footer a:before,
.list--page-selection .item-footer .nav--pager a:before, .nav--pager .list--page-selection .item-footer a:before, .customform--select.is-open .customform-select-toggle:after {
  content: "\EA07"; }

.icon--bell:before {
  content: "\EA08"; }

.icon--checkbox:before {
  content: "\EA09"; }

.icon--circle:before {
  content: "\EA0A"; }

.icon--close:before {
  content: "\EA0B"; }

.icon--code:before {
  content: "\EA0C"; }

.icon--comments:before {
  content: "\EA0D"; }

.icon--contact:before {
  content: "\EA0E"; }

.icon--download:before {
  content: "\EA0F"; }

.icon--edit:before, .tabs--primary-toggle:before, .btn--block-admin:after {
  content: "\EA10"; }

.icon--expand:before {
  content: "\EA11"; }

.icon--export:before {
  content: "\EA12"; }

.icon--facebook:before {
  content: "\EA13"; }

.icon--file-add:before {
  content: "\EA14"; }

.icon--file-chart:before {
  content: "\EA15"; }

.icon--file-download:before {
  content: "\EA16"; }

.icon--file-transfer:before {
  content: "\EA17"; }

.icon--fullscreen:before {
  content: "\EA18"; }

.icon--grid:before {
  content: "\EA19"; }

.icon--image:before, .list--search-result .media-empty:before, .list--page-selection .item-thumbnail .is-empty:before {
  content: "\EA1A"; }

.icon--layout:before {
  content: "\EA1B"; }

.icon--linkedin:before {
  content: "\EA1C"; }

.icon--list:before {
  content: "\EA1D"; }

.icon--location:before {
  content: "\EA1E"; }

.icon--minus:before {
  content: "\EA1F"; }

.icon--phone:before {
  content: "\EA20"; }

.icon--play:before {
  content: "\EA21"; }

.icon--plus:before {
  content: "\EA22"; }

.icon--print:before {
  content: "\EA23"; }

.icon--printer:before {
  content: "\EA24"; }

.icon--row-add:before {
  content: "\EA25"; }

.icon--row-remove:before {
  content: "\EA26"; }

.icon--search:before, .form--search-global .form-item-keywords:before {
  content: "\EA27"; }

.icon--share:before {
  content: "\EA28"; }

.icon--skew:before {
  content: "\EA29"; }

.icon--thread:before {
  content: "\EA2A"; }

.icon--ticket:before {
  content: "\EA2B"; }

.icon--todo:before {
  content: "\EA2C"; }

.icon--twitter:before {
  content: "\EA2D"; }

.icon--user:before {
  content: "\EA2E"; }

.icon--view:before {
  content: "\EA2F"; }

/* ==========================================================================
   Icons
   ========================================================================== */
.icon.icon--datagone:before {
  display: inline-block;
  font-family: "icons-1712325806";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.btn.icon:before, .pager a.icon:before,
.nav--pager a.icon:before,
p.icon:before {
  margin-right: .6em; }

.icon--inline {
  display: flex;
  float: left;
  margin-right: 48px; }

/* ==========================================================================
   Sizes
   ========================================================================== */
.icon-size--small:before {
  font-size: 1.5rem; }

.icon-size--normal:before {
  font-size: 2rem; }

.icon-size--medium:before {
  font-size: 3rem; }

.icon-size--big:before {
  font-size: 4.25rem; }

/* ==========================================================================
   Custom
   ========================================================================== */
.icon.icon--datagone.icon--plus:before {
  content: "\EA22"; }

/*
.title--h1 - H1
.title--h2 - H2
.title--h3 - H3
.title--h4 - H4

Markup: <span class="$modifierClass">Titre</span>

Styleguide Titles - 1.title
*/
h1,
.title--h1,
.content-title,
h2,
.title--h2,
h3,
.title--h3,
h4,
.title--h4 {
  display: inline-flex;
  margin: 0 0 1.6em;
  line-height: 1.2; }
  h1:before,
  .title--h1:before,
  .content-title:before,
  h2:before,
  .title--h2:before,
  h3:before,
  .title--h3:before,
  h4:before,
  .title--h4:before {
    content: "";
    position: relative;
    top: 13px;
    display: inline-block;
    flex-shrink: 0;
    width: 10px;
    height: 24px;
    margin-right: 16px;
    background: #4C1E5C;
    -webkit-transform: skew(-35deg);
            transform: skew(-35deg); }

h1,
.title--h1,
.content-title {
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  color: #2B2929;
  font-size: 2.5rem; }
  @media all and (max-width: 767px) {
    h1,
    .title--h1,
    .content-title {
      font-size: 2rem; } }

h2,
.title--h2 {
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  color: #2B2929;
  font-size: 1.875rem; }
  h2:before,
  .title--h2:before {
    top: 7px; }

h3,
.title--h3 {
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  color: #2B2929;
  font-size: 1.5rem; }
  h3:before,
  .title--h3:before {
    top: 8px; }

h4,
.title--h4 {
  color: #2B2929;
  font-size: 1.125rem; }
  h4:before,
  .title--h4:before {
    top: 8px; }

/* ==========================================================================
   Dataviz
   ========================================================================== */
.title--dataviz {
  margin: 0;
  color: #4C1E5C; }

/* Iframe
   ========================================================================== */
.iframe-container {
  position: relative;
  overflow: hidden; }
  .iframe-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
  .iframe-container.l-responsive {
    height: 0;
    padding-bottom: 56.25%; }

/* ==========================================================================
   Document
   ========================================================================== */
.route--entity-media-canonical .main {
  padding-top: 0; }

.media--document .header-content {
  align-items: center; }

.media--document .item-content p {
  margin-bottom: 9px; }

.logo a,
.logo img {
  display: block; }

.logo img {
  max-width: none; }

.logo--primary {
  margin: 30px 0; }
  .logo--primary img {
    max-height: 44px; }
    .logo--primary img[src*=".svg"] {
      height: 44px;
      max-width: 200px; }
    @media all and (max-width: 767px) {
      .logo--primary img {
        max-height: 34px; }
        .logo--primary img[src*=".svg"] {
          height: 34px;
          max-width: 150px; } }

/*
:hover    - Bouton au survol
:disabled - Bouton désactivé
.btn--primary - Principal

Markup: <button class="btn $modifierClass">Bouton</button>

Styleguide Buttons - 1.btn
 */
.btn, .pager a,
.nav--pager a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  font-weight: normal;
  font-family: "kanit--regular", Arial, sans-serif;
  font-size: 1.125rem;
  line-height: 1.5;
  text-decoration: none;
  border: 1px solid;
  border-radius: 29px;
  cursor: pointer;
  box-sizing: border-box;
  transition: .2s; }
  .btn, .pager a,
  .nav--pager a, .btn:disabled, .pager a:disabled,
  .nav--pager a:disabled, .btn.is-disabled, .pager a.is-disabled,
  .nav--pager a.is-disabled, .btn:disabled:hover, .pager a:disabled:hover,
  .nav--pager a:disabled:hover, .btn.is-disabled:hover, .pager a.is-disabled:hover,
  .nav--pager a.is-disabled:hover, .btn:disabled:focus, .pager a:disabled:focus,
  .nav--pager a:disabled:focus, .pager .pager__item.is-active a:disabled,
  .nav--pager .pager__item.is-active a:disabled, .btn.is-disabled:focus, .pager a.is-disabled:focus,
  .nav--pager a.is-disabled:focus, .pager .pager__item.is-active a.is-disabled,
  .nav--pager .pager__item.is-active a.is-disabled {
    color: #959595;
    border-color: transparent;
    background-color: #F6F6F6; }
  .btn:active, .pager a:active,
  .nav--pager a:active, .btn.is-active, .pager a.is-active,
  .nav--pager a.is-active, .btn:focus, .pager a:focus,
  .nav--pager a:focus, .pager .pager__item.is-active a,
  .nav--pager .pager__item.is-active a, .btn:hover, .pager a:hover,
  .nav--pager a:hover,
  a:focus .btn,
  a:focus .pager a,
  .pager a:focus a,
  a:focus .nav--pager a,
  .nav--pager a:focus a,
  a:hover .btn,
  a:hover .pager a,
  .pager a:hover a,
  a:hover .nav--pager a,
  .nav--pager a:hover a {
    color: #4C1E5C;
    border-color: transparent;
    background-color: rgba(76, 30, 92, 0.2); }
  .btn:focus, .pager a:focus,
  .nav--pager a:focus, .pager .pager__item.is-active a,
  .nav--pager .pager__item.is-active a {
    outline: 0; }
  .btn.is-disabled, .pager a.is-disabled,
  .nav--pager a.is-disabled, .btn:disabled, .pager a:disabled,
  .nav--pager a:disabled {
    opacity: .5;
    cursor: default; }
  .btn .icon, .pager a .icon, .nav--pager a .icon {
    margin-left: 10px;
    line-height: 1; }
    .btn .icon.l-left, .pager a .icon.l-left, .nav--pager a .icon.l-left {
      margin-right: 10px; }
    .btn .icon.icon--datagone.icon--download:before, .pager a .icon.icon--datagone.icon--download:before, .nav--pager a .icon.icon--datagone.icon--download:before {
      font-size: 1rem; }
    .btn .icon.icon--datagone.icon--play:before, .pager a .icon.icon--datagone.icon--play:before, .nav--pager a .icon.icon--datagone.icon--play:before {
      font-size: 1.25rem; }

button {
  cursor: pointer;
  background-color: #F6F6F6;
  border: 0; }
  button:focus {
    outline: 0; }
  button.btn {
    min-height: 57px; }

/*
Btn primary

Markup: url()->find(.btn--primary)

Styleguide Buttons - 10.btn--primary
*/
.btn--primary, .btn--primary:disabled, .btn--primary.is-disabled, .btn--primary:disabled:hover, .btn--primary.is-disabled:hover, .btn--primary:disabled:focus, .btn--primary.is-disabled:focus {
  color: #fff;
  background-color: #4C1E5C;
  border-color: transparent; }

.btn--primary:active, .btn--primary.is-active, .btn--primary:focus, .btn--primary:hover,
a:focus .btn--primary,
a:hover .btn--primary {
  color: #fff;
  border-color: #4C1E5C; }

/*
Bouton secondaire :

Markup: url()->find(.btn--secondary)

Styleguide Buttons - 15.btn--secondary
*/
.btn--secondary, .btn--secondary:disabled, .btn--secondary.is-disabled, .btn--secondary:disabled:hover, .btn--secondary.is-disabled:hover, .btn--secondary:disabled:focus, .btn--secondary.is-disabled:focus {
  color: #2B2929;
  background: none;
  border-color: #4C1E5C; }
  .btn--secondary .icon:before, .btn--secondary:disabled .icon:before, .btn--secondary.is-disabled .icon:before, .btn--secondary:disabled:hover .icon:before, .btn--secondary.is-disabled:hover .icon:before, .btn--secondary:disabled:focus .icon:before, .btn--secondary.is-disabled:focus .icon:before {
    color: #4C1E5C;
    transition: .2s; }

.btn--secondary:active, .btn--secondary.is-active, .btn--secondary:focus, .btn--secondary:hover {
  color: #fff;
  background-color: #4C1E5C;
  border-color: #4C1E5C; }
  .btn--secondary:active .icon:before, .btn--secondary.is-active .icon:before, .btn--secondary:focus .icon:before, .btn--secondary:hover .icon:before {
    color: inherit; }

/*
Bouton lien : arrow

Markup: url()->find(.btn--link)

Styleguide Buttons - 30.btn--link
*/
.btn--link {
  background: none;
  border: 0; }
  .btn--link, .btn--link:disabled, .btn--link.is-disabled, .btn--link:disabled:hover, .btn--link.is-disabled:hover, .btn--link:disabled:focus, .btn--link.is-disabled:focus {
    color: #fff; }

/*
Bouton navigation précedent / suivant

Markup: url()->find(.btn--link)

Styleguide Buttons - 40.btn--link
*/
.btn--nav {
  padding-top: 0;
  padding-bottom: 0;
  min-height: 57px; }
  .btn--nav span {
    line-height: 1.2; }
  .btn--nav:before {
    width: 57px;
    height: 57px;
    font-size: 1rem;
    line-height: 57px;
    text-align: center;
    color: #fff;
    border-radius: 50%;
    background: #4C1E5C;
    box-sizing: border-box;
    position: absolute;
    top: -1px; }
    .btn--nav:before:before {
      vertical-align: top;
      top: 1px; }
  .btn--nav.prev {
    padding-left: 71px;
    text-align: left; }
    .btn--nav.prev:before {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      left: -1px; }
  .btn--nav.next {
    padding-right: 71px;
    text-align: right; }
    .btn--nav.next:before {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      right: -1px; }
  .btn--nav, .btn--nav:disabled, .btn--nav.is-disabled, .btn--nav:disabled:hover, .btn--nav.is-disabled:hover, .btn--nav:disabled:focus, .btn--nav.is-disabled:focus {
    color: #959595;
    background-color: transparent;
    border-color: transparent; }
  .btn--nav:active, .btn--nav.is-active, .btn--nav:focus, .btn--nav:hover,
  a:focus .btn--nav,
  a:hover .btn--nav {
    color: #4C1E5C;
    background-color: rgba(76, 30, 92, 0.15);
    border-color: transparent; }

/*
Bouton toggle menu push

Markup: url()->find(.btn--togglemenu)

Styleguide Boutons - 50.btn--togglemenu
*/
.btn--togglemenu {
  padding: 0;
  width: 50px;
  height: 50px;
  background-color: transparent;
  border-radius: 50%; }
  .btn--togglemenu .part {
    position: absolute;
    top: 50%;
    width: 50%;
    right: 25%;
    height: 2px;
    background-color: #4C1E5C;
    transition: .3s; }
    .btn--togglemenu .part:nth-child(1) {
      margin-top: -10px; }
    .btn--togglemenu .part:nth-child(2) {
      width: 35%; }
    .btn--togglemenu .part:nth-child(3) {
      margin-top: 10px; }
  .btn--togglemenu:hover .part:nth-child(1), .btn--togglemenu:focus .part:nth-child(1),
  .is-togglemenuOpen .btn--togglemenu .part:nth-child(1) {
    right: 20%; }
  .btn--togglemenu:hover .part:nth-child(2), .btn--togglemenu:focus .part:nth-child(2),
  .is-togglemenuOpen .btn--togglemenu .part:nth-child(2) {
    width: 55%; }

/* ==========================================================================
   Icon.
   ========================================================================== */
.btn--icon {
  padding: 0;
  width: 72px;
  height: 72px;
  border-radius: 50%; }
  .btn--icon.btn--small {
    width: 44px;
    height: 44px;
    min-height: 44px; }
  .btn--icon .icon {
    margin: 0; }
  .btn--icon, .btn--icon:disabled, .btn--icon.is-disabled, .btn--icon:disabled:hover, .btn--icon.is-disabled:hover, .btn--icon:disabled:focus, .btn--icon.is-disabled:focus {
    color: #fff;
    background: #4C1E5C;
    border: 1px solid transparent; }
  .btn--icon:active, .btn--icon.is-active, .btn--icon:focus, .btn--icon:hover {
    border-color: #4C1E5C; }

/*
Tag par défaut

Markup: url()->find(.tag)

Styleguide Tags - 1.tag
 */
.tag {
  position: relative;
  display: inline-block;
  padding: 7px 15px;
  color: #4C1E5C;
  font-weight: normal;
  font-family: Arial, sans-serif;
  font-size: 0.688rem;
  line-height: 1.1;
  background: #4C1E5C;
  border-radius: 15px;
  box-sizing: border-box;
  transition: .3s; }

a.tag {
  text-decoration: none; }

/*
Tag principal

Markup: url()->find(.tag--primary)

Styleguide Tags - 10.tag--primary
*/
/* ==========================================================================
   Formulaires
   ========================================================================== */
form {
  position: relative;
  margin-bottom: 36px;
  font-weight: normal;
  font-family: "kanit--regular", Arial, sans-serif; }
  form:focus {
    outline: 0; }

.form-group,
.form-wrapper,
.form-item {
  margin-bottom: 18px; }

/* Fieldset
   ========================================================================== */
fieldset {
  margin: 1rem 0;
  padding: 0;
  min-width: 0;
  background: none;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  color: inherit; }

label,
legend,
.form-group-title {
  display: block;
  margin-bottom: .5rem; }

.fieldset-legend {
  display: contents;
  /* For Firefox. */
  float: left;
  /* iOS Safari, Android Chrome, Edge. */
  width: 100%;
  /* iOS Safari, Android Chrome, Edge. */
  margin-bottom: 1rem;
  color: var(--color-davysgrey);
  font-weight: bold; }

/* Form elements
   ========================================================================== */
form input[disabled], form input[readonly], form input:disabled,
form select[disabled],
form select[readonly],
form select:disabled,
form textarea[disabled],
form textarea[readonly],
form textarea:disabled {
  opacity: .5;
  cursor: default; }

form input:not([readonly]):focus,
form select:not([readonly]):focus,
form textarea:not([readonly]):focus {
  outline: 0;
  border-color: #2B2929;
  box-shadow: inset 0 0 0 1px #2B2929; }

form .description {
  font-weight: normal;
  font-family: "kanit--regular", Arial, sans-serif; }

.form-text,
.form-number,
.form-email,
.form-tel,
.form-select,
.form-search,
.form-textarea {
  display: block;
  width: 100%;
  height: 65px;
  padding: 22px 32px;
  color: #2B2929;
  font-family: inherit;
  font-size: 1.063rem;
  line-height: 1.15;
  background-color: #fff;
  border: 1px solid #4C1E5C;
  border-radius: 10px;
  box-sizing: border-box;
  transition: border-color .3s;
  -webkit-appearance: none;
          appearance: none; }
  .form-text::-webkit-input-placeholder,
  .form-number::-webkit-input-placeholder,
  .form-email::-webkit-input-placeholder,
  .form-tel::-webkit-input-placeholder,
  .form-select::-webkit-input-placeholder,
  .form-search::-webkit-input-placeholder,
  .form-textarea::-webkit-input-placeholder {
    color: #959595;
    opacity: 1; }
  .form-text:-moz-placeholder,
  .form-number:-moz-placeholder,
  .form-email:-moz-placeholder,
  .form-tel:-moz-placeholder,
  .form-select:-moz-placeholder,
  .form-search:-moz-placeholder,
  .form-textarea:-moz-placeholder {
    color: #959595;
    opacity: 1; }
  .form-text::-moz-placeholder,
  .form-number::-moz-placeholder,
  .form-email::-moz-placeholder,
  .form-tel::-moz-placeholder,
  .form-select::-moz-placeholder,
  .form-search::-moz-placeholder,
  .form-textarea::-moz-placeholder {
    color: #959595;
    opacity: 1; }
  .form-text:-ms-input-placeholder,
  .form-number:-ms-input-placeholder,
  .form-email:-ms-input-placeholder,
  .form-tel:-ms-input-placeholder,
  .form-select:-ms-input-placeholder,
  .form-search:-ms-input-placeholder,
  .form-textarea:-ms-input-placeholder {
    color: #959595;
    opacity: 1; }
  .form-text.error,
  .form-number.error,
  .form-email.error,
  .form-tel.error,
  .form-select.error,
  .form-search.error,
  .form-textarea.error {
    border-color: #d9534f; }

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

.form-textarea {
  height: auto;
  resize: vertical; }

.js-form-type-radio,
.js-form-type-checkbox {
  display: flex;
  align-items: flex-start; }
  .form-item .js-form-type-radio, .form-item
  .js-form-type-checkbox {
    margin-bottom: 0; }
  .js-form-type-radio label,
  .js-form-type-checkbox label {
    display: inline-flex;
    flex-direction: column;
    margin-left: .75em;
    vertical-align: middle;
    cursor: pointer; }
    .js-form-type-radio label .item-title,
    .js-form-type-checkbox label .item-title {
      cursor: inherit; }
  .js-form-type-radio .form-radio,
  .js-form-type-radio .form-checkbox,
  .js-form-type-checkbox .form-radio,
  .js-form-type-checkbox .form-checkbox {
    flex-shrink: 0;
    display: inline-block;
    box-sizing: border-box;
    width: 18px;
    height: 18px;
    vertical-align: text-bottom;
    border: 1px solid #8e929c;
    border-radius: 2px;
    background: #fff no-repeat 50% 50%;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='10' viewBox='0 0 12 10' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.18182 6.96572L1.97655 4.64855L1.79545 4.45826L1.61436 4.64855L0.818904 5.48437L0.654878 5.65672L0.818904 5.82907L4.00072 9.17235L4.18182 9.36263L4.36291 9.17235L11.1811 2.00817L11.3451 1.83582L11.1811 1.66347L10.3856 .827651L10.2045 .637365L10.0234 .82765L4.18182 6.96572Z' fill='white' /%3E%3C/svg%3E");
    background-size: 100% 100%;
    box-shadow: 0 0 0 4px transparent;
    -webkit-appearance: none;
            appearance: none;
    cursor: pointer; }
    .js-form-type-radio .form-radio:active, .js-form-type-radio .form-radio:hover,
    .js-form-type-radio .form-checkbox:active,
    .js-form-type-radio .form-checkbox:hover,
    .js-form-type-checkbox .form-radio:active,
    .js-form-type-checkbox .form-radio:hover,
    .js-form-type-checkbox .form-checkbox:active,
    .js-form-type-checkbox .form-checkbox:hover {
      border-color: #222330;
      box-shadow: inset 0 0 0 1px #222330; }
  .js-form-type-radio .form-radio,
  .js-form-type-checkbox .form-radio {
    width: 19px;
    height: 19px;
    border-radius: 19px; }
    .js-form-type-radio .form-radio:checked,
    .js-form-type-checkbox .form-radio:checked {
      border-color: #4C1E5C;
      background-image: url("data:image/svg+xml,%3Csvg width='17' height='17' viewBox='0 0 17 17' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle r='4.5' cx='8.5' cy='8.5' fill='%234C1E5C'/%3E%3C/svg%3E");
      box-shadow: inset 0 0 0 1px #4C1E5C; }
  .js-form-type-radio .form-checkbox:checked,
  .js-form-type-checkbox .form-checkbox:checked {
    border-color: #4C1E5C;
    background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3.7949219,7.095703 6.1816406,9.601563 12.205078,3.2753906 13.689453,4.8359375 6.1816406,12.724609 2.3105469,8.65625 Z' fill='%234C1E5C'/%3E%3C/svg%3E");
    box-shadow: inset 0 0 0 1px #4C1E5C; }

.js input.form-autocomplete {
  background: none; }

/* Captcha
   ========================================================================== */
.captcha {
  margin: 18px 0; }

.g-recaptcha > div {
  margin-left: auto; }

/* Messages
   ========================================================================== */
.form-item--error-message {
  padding-top: 4px;
  color: #d9534f;
  font-style: italic;
  font-size: 0.938rem; }

/* ==========================================================================
   Views Forms exposed
   ========================================================================== */
.views-exposed-form[data-bef-auto-submit-full-form] .form-actions {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  border: 0; }

/* ==========================================================================
   Login
   ========================================================================== */
.form--login {
  /* Responsive
     ========================================================================== */ }
  .form--login .form-actions {
    padding-top: 18px; }
  .form--login .form-item-reset {
    margin-top: 18px; }
    .form--login .form-item-reset a {
      color: #969CA1; }
      .form--login .form-item-reset a:active, .form--login .form-item-reset a.is-active, .form--login .form-item-reset a:focus, .form--login .form-item-reset a:hover {
        color: #959595; }
  @media all and (min-width: 768px) {
    .form--login {
      max-width: 300px;
      margin: 0 auto; } }

/* ==========================================================================
   Register
   ========================================================================== */
.form--register {
  /* Responsive
     ========================================================================== */ }
  .form--register .horizontal-tabs {
    border: 0; }
  .form--register .horizontal-tabs-list {
    display: none; }
  .form--register .field-group-tab {
    padding: 18px 48px 9px;
    background: #F6F6F6;
    border-radius: 10px; }
  @media all and (min-width: 768px) {
    .form--register {
      max-width: 500px; } }

.route--user-register .form--register {
  position: relative;
  /* Responsive
       ========================================================================== */ }
  .route--user-register .form--register .field-group-tabs-wrapper {
    position: relative;
    z-index: 10; }
  .route--user-register .form--register .form-illustration {
    display: none; }
  @media all and (min-width: 768px) {
    .route--user-register .form--register .form-illustration {
      position: absolute;
      top: 0;
      right: -600px;
      z-index: 5;
      display: inline;
      width: 600px; } }

/* ==========================================================================
   Export dataviz
   ========================================================================== */
.form--embed,
.form--export-dataviz {
  margin: 0; }
  .form--embed .form-no-label,
  .form--export-dataviz .form-no-label {
    display: none; }

/* ==========================================================================
   Embed
   ========================================================================== */
.form--embed {
  display: flex;
  align-items: flex-start;
  /* Responsive
     ========================================================================== */ }
  .form--embed .form-content {
    order: -1;
    display: none;
    min-width: 60vw; }
  .form--embed .form-sidebar {
    width: 300px; }
  @media all and (min-width: 768px) {
    .form--embed .form-content {
      display: block;
      padding-right: 48px; } }

/* ==========================================================================
   Recherche globale
   ========================================================================== */
.form--search-global {
  padding: 18px 48px;
  border-bottom: 1px solid #4C1E5C; }
  .form--search-global .form-search-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center; }
  .form--search-global .form-group-title,
  .form--search-global .form-submit {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    -webkit-clip-path: inset(50%);
            clip-path: inset(50%);
    border: 0; }
  .form--search-global .form-item-keywords {
    display: flex;
    align-items: center;
    margin: 0;
    width: 100%; }
    .form--search-global .form-item-keywords:before {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      color: #2B2929;
      font-size: 1.25rem; }
    .form--search-global .form-item-keywords .form-element {
      border: 0; }
      .form--search-global .form-item-keywords .form-element:focus {
        box-shadow: none; }
  .form--search-global .form-search-close {
    height: 42px;
    background: none; }
    .form--search-global .form-search-close.icon {
      display: flex;
      align-items: center; }
      .form--search-global .form-search-close.icon:before {
        color: #969CA1;
        font-size: 1.25rem;
        transition: color .2s; }
      .form--search-global .form-search-close.icon:after {
        background-color: #969CA1;
        transition: background-color .2s; }
      .form--search-global .form-search-close.icon:hover:before, .form--search-global .form-search-close.icon:focus:before {
        color: #959595; }
      .form--search-global .form-search-close.icon:hover:after, .form--search-global .form-search-close.icon:focus:after {
        background-color: #959595; }
  .form--search-global .form-checkboxes {
    display: flex; }
    body:not(.role--authenticated) .form--search-global .form-checkboxes {
      display: none; }
    .form--search-global .form-checkboxes .form-item {
      margin: 0 20px 0 0; }
    .form--search-global .form-checkboxes label {
      font-size: 0.938rem; }

/* ==========================================================================
   Events
   ========================================================================== */
.form--events {
  display: inline-flex;
  align-items: flex-end; }
  .form--events .form-item-category {
    min-width: 200px; }
  .form--events .form-submit {
    display: none; }

/* ==========================================================================
   Comment
   ========================================================================== */
.form--comment .js-filter-wrapper {
  display: none; }

.comment-dataviz-delete-form .form-actions {
  margin-top: 18px; }
  .comment-dataviz-delete-form .form-actions a {
    display: none; }

.comment-dataviz-delete-form .button + button {
  margin-left: 12px; }

/* ==========================================================================
   Glossary.
   ========================================================================== */
.form--glossary .form-item-filter,
.form--glossary .form-actions {
  display: none; }

.form--glossary .form-wrapper[data-drupal-selector="edit-alphabet"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  font-size: 1.563rem; }

.form--glossary .form-item-alphabet .option {
  position: relative;
  margin-left: 0;
  padding: 0 20px;
  transition: .2s; }
  .form--glossary .form-item-alphabet .option:after {
    content: "";
    position: absolute;
    left: 25%;
    bottom: 0;
    width: 50%;
    height: 1px;
    background: #4C1E5C;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
    transition: -webkit-transform .2s ease-out;
    transition: transform .2s ease-out;
    transition: transform .2s ease-out, -webkit-transform .2s ease-out; }

.form--glossary .form-item-alphabet + .form-item-alphabet .option {
  position: relative; }
  .form--glossary .form-item-alphabet + .form-item-alphabet .option:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -1px;
    z-index: 5;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 1px;
    height: 18px;
    background: #8e929c; }

.form--glossary .form-item-alphabet:not(.form-disabled) .is-checked .option,
.form--glossary .form-item-alphabet:not(.form-disabled) .option:hover,
.form--glossary .form-item-alphabet:not(.form-disabled) .option:focus {
  color: #2B2929; }
  .form--glossary .form-item-alphabet:not(.form-disabled) .is-checked .option:after,
  .form--glossary .form-item-alphabet:not(.form-disabled) .option:hover:after,
  .form--glossary .form-item-alphabet:not(.form-disabled) .option:focus:after {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 0 50%;
            transform-origin: 0 50%; }

/* ==========================================================================
   Media library.
   ========================================================================== */
.form--media-library {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  align-items: center;
  margin: 0;
  /* Responsive
     ========================================================================== */ }
  .form--media-library .form-item-sort-by,
  .form--media-library .form-item-sort-order,
  .form--media-library .form-submit {
    display: none; }
  .form--media-library .form-item-thematic {
    width: 386px; }
  .form--media-library .form-item-type {
    width: 386px; }
  .form--media-library .form-item-secondary {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: column;
    margin: 36px 0 0;
    padding: 36px 0;
    background: #F6F6F6; }
    .form--media-library .form-item-secondary:before, .form--media-library .form-item-secondary:after {
      content: "";
      position: absolute;
      top: 0;
      z-index: -1;
      width: 1000px;
      height: 100%;
      background: inherit; }
    .form--media-library .form-item-secondary:before {
      left: -1000px; }
    .form--media-library .form-item-secondary:after {
      right: -1000px; }
    .form--media-library .form-item-secondary .form-item .customform {
      display: flex;
      align-items: center; }
    .form--media-library .form-item-secondary .form-group-title {
      margin: 0 20px 0 0;
      color: #2B2929; }
    .form--media-library .form-item-secondary .customform-select-toggle {
      min-width: 280px;
      line-height: 27px;
      padding-left: 11px;
      padding-right: 33px; }
      .form--media-library .form-item-secondary .customform-select-toggle:after {
        right: 11px; }
    .form--media-library .form-item-secondary .form-item-sorting {
      margin-right: 24px;
      margin-bottom: 0; }
    .form--media-library .form-item-secondary .form-group-items {
      display: flex;
      align-items: center; }
    .form--media-library .form-item-secondary .form-item-display {
      display: none; }
    .form--media-library .form-item-secondary .form-display-layout {
      margin-right: 18px;
      text-decoration: none; }
      .form--media-library .form-item-secondary .form-display-layout .form-group-title {
        margin: 0; }
      .form--media-library .form-item-secondary .form-display-layout .icon {
        color: #2B2929; }
        .form--media-library .form-item-secondary .form-display-layout .icon:before {
          font-size: 1.875rem; }
      .form--media-library .form-item-secondary .form-display-layout.is-disabled {
        opacity: .5; }
  @media all and (min-width: 768px) {
    .form--media-library {
      flex-direction: row;
      justify-content: center; }
      .form--media-library .form-item-thematic {
        margin-bottom: 0;
        margin-left: 10%; }
      .form--media-library .form-item-type {
        margin-bottom: 0;
        margin-left: 24px;
        margin-right: 24px; }
      .form--media-library .form-item-secondary {
        justify-content: flex-end;
        flex-direction: row; }
        .form--media-library .form-item-secondary .form-item-display {
          display: flex;
          align-items: center;
          height: 50%;
          margin: -18px 0 0; } }

.accordion {
  list-style: none; }

.accordion-item {
  margin-bottom: 18px;
  /* States
       ========================================================================== */ }
  .accordion-item .accordion-trigger {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0;
    padding: 8px;
    width: 100%;
    color: #2B2929;
    cursor: pointer;
    transition: .2s;
    text-align: left;
    background: rgba(76, 30, 92, 0.1);
    border-radius: 30px; }
    .accordion-item .accordion-trigger:after {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      display: block;
      width: 42px;
      height: 42px;
      line-height: 42px;
      text-align: center;
      color: #4C1E5C;
      font-size: 0.688rem;
      background: #fff;
      border-radius: 50%;
      transition: .2s; }
  .accordion-item .accordion-title {
    position: relative;
    padding: 0 16px; }
  .accordion-item .item-content {
    padding: 18px 48px;
    overflow: hidden; }
    .accordion-item .item-content table {
      margin: 0; }
    .accordion-item .item-content p,
    .accordion-item .item-content ul,
    .accordion-item .item-content ol {
      margin-bottom: 9px; }
  .accordion-item.is-open .accordion-trigger,
  .accordion-item .accordion-trigger:hover {
    color: #fff;
    background-color: #4C1E5C; }
  .accordion-item.is-open .accordion-trigger:after {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg); }

/*
Message pour les navigateurs non optimisés

Markup: url()->find(.notice--browser)

Styleguide Notices - 10.notice--browser
*/
.notice--browser {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  padding: 350px 15%;
  font-weight: normal;
  font-family: Arial, sans-serif;
  text-align: center;
  background: #fff url("../../config/favicons/android-chrome-512x512.png") no-repeat center 175px;
  background-size: 150px auto; }

.block {
  padding-top: 36px;
  padding-bottom: 36px;
  box-sizing: border-box; }
  .block.l-narrow {
    padding-top: 0;
    padding-bottom: 0; }
  .block .block--view {
    margin-bottom: 0;
    padding: 0; }

.block--view {
  padding: 0; }

.block--embed-legend {
  padding-bottom: 0;
  font-size: 0.938rem; }

.block-empty {
  margin: 10px;
  padding: 30px;
  font-family: monospace;
  font-size: 0.938rem;
  text-align: center;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.75);
  border: 1px dashed #8e929c;
  border-radius: 2px; }
  .block-empty .empty {
    display: block; }
    .block-empty .empty:before {
      content: "<"; }
    .block-empty .empty:after {
      content: "/>"; }
    .block-empty .empty + .empty {
      margin-top: 4.5px; }

/*
Copyright

Markup: url()->find(.block--copyright)

Styleguide Blocks - 10.block--copyright
*/
.block--copyright {
  display: none;
  color: #fff; }
  .block--copyright a {
    color: inherit; }

/*
Notifications

Markup: url()->find(.block--user-notifications)

Styleguide Blocks - 30.block--user-notifications
*/
.block--user-notifications .nav--dropdown .nav-content {
  padding: 0;
  width: 300px; }

.block--user-notifications .nav--dropdown .item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background-color: #fdfdfd;
  border-bottom: 1px solid #F6F6F6; }

.block--user-notifications .nav--dropdown .item-header-title {
  color: #2B2929; }

.block--user-notifications .nav--dropdown .item-header-action {
  color: #4C1E5C;
  font-weight: normal;
  font-family: "kanit--regular", Arial, sans-serif;
  background: none; }
  .block--user-notifications .nav--dropdown .item-header-action:not([disabled]):hover {
    text-decoration: underline; }
  .block--user-notifications .nav--dropdown .item-header-action[disabled] {
    opacity: .5;
    cursor: default; }

.block--user-notifications .nav--dropdown .nav-menu {
  flex-direction: column;
  padding: 15px 16px 6px; }

.block--user-notifications .nav--dropdown .item-unread-count {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 5;
  width: 20px;
  height: 20px;
  line-height: 20px;
  color: #fff;
  font-size: 0.688rem;
  text-align: center;
  background: #d9534f;
  border-radius: 50%; }

.block--user-notifications .nav--dropdown .notification-message {
  font-size: 1.063rem;
  line-height: 1.2;
  margin-bottom: 4px; }
  .block--user-notifications .nav--dropdown .notification-message a {
    display: inline;
    font-size: 1.063rem; }

.block--user-notifications .nav--dropdown .notification-time {
  margin-bottom: 9px;
  color: #969CA1;
  font-size: 0.688rem; }

/*
Saut de page

Markup: url()->find(.block--space)

Styleguide Blocks - 40.block--space
*/
.block--space {
  position: absolute;
  width: 100%;
  /* Layout builder
       ========================================================================== */
  /* Preview
       ========================================================================== */ }
  .block--space:before {
    content: "Saut de page";
    position: absolute;
    top: -10px;
    left: 30px;
    padding: 0 10px 0 5px;
    font-style: italic;
    font-size: 0.938rem;
    background-color: #fff; }
  .block--space:after {
    content: "";
    display: block;
    border-bottom: 1px dashed #8e929c; }
  .block--space a[data-action] {
    position: absolute;
    z-index: 5;
    top: -20px;
    right: -30px;
    padding: 10px; }
    .block--space a[data-action] .icon:before {
      color: #d9534f; }
  .layout-builder .block--space {
    position: relative;
    margin-top: 36px;
    height: 54px; }
  .block--space.l-preview:before {
    color: #d9534f; }
  .block--space.l-preview:after {
    border-color: #d9534f; }

/*
Affichage d'une image

Markup: url()->find(.block--image)

Styleguide Blocks - 45.block--image
*/
.block--image {
  position: relative;
  margin-bottom: 18px;
  overflow: hidden; }
  .block--image:before {
    content: "";
    position: absolute;
    bottom: 0;
    right: -11px;
    z-index: 5;
    width: 70px;
    height: 150px;
    background: #4C1E5C;
    -webkit-transform: skew(-38deg);
            transform: skew(-38deg); }
  .block--image img {
    display: block;
    border-radius: 30px; }

/*
Liste des documents

Markup: url()->find(.block--documents)

Styleguide Blocks - 50.block--documents
*/
.block--documents {
  /* Responsive
       ========================================================================== */ }
  .block--documents .l-wrapper {
    justify-content: center; }
  .block--documents .media {
    padding-left: 12px;
    padding-right: 12px;
    margin-bottom: 18px; }
  @media all and (min-width: 768px) {
    .block--documents .l-wrapper {
      justify-content: flex-start; } }

/*
Recherche globale

Markup: url()->find(.block--search-global)

Styleguide Blocks - 60.block--search-global
*/
.block--search-global .nav--dropdown .nav-content {
  position: fixed;
  z-index: 200;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  max-height: none;
  background: rgba(0, 0, 0, 0.3);
  -webkit-transform: none;
          transform: none;
  transition: background-color .25s ease-out;
  box-shadow: none;
  transition: .6s; }

.block--search-global .nav--dropdown.is-open .search-sidebar {
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%); }

.block--search-global .search-sidebar {
  position: absolute;
  top: 0;
  left: 100%;
  bottom: 0;
  background: #fff;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  min-width: 400px;
  width: 33vw;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s; }
  .toolbar-fixed .block--search-global .search-sidebar {
    padding-top: 39px; }
  .toolbar-fixed.toolbar-horizontal.toolbar-tray-open .block--search-global .search-sidebar {
    padding-top: 78px; }

.block--search-global .search-result {
  overflow: auto;
  height: calc(100% - 160px); }

/*
Vidéo

Markup: url()->find(.block--video)

Styleguide Blocks - 70.block--video
*/
.block--video {
  position: relative; }
  .block--video.is-playing .item-iframe {
    opacity: 1;
    visibility: visible; }
  .block--video .item-iframe {
    position: absolute;
    z-index: 10;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    opacity: 0;
    visibility: hidden;
    transition: .3s; }
    .block--video .item-iframe iframe {
      width: 100%; }
  .block--video .item-image {
    cursor: pointer;
    border-radius: 30px;
    overflow: hidden; }
    .block--video .item-image:hover .icon:before, .block--video .item-image:focus .icon:before {
      -webkit-transform: scale(1.1);
              transform: scale(1.1); }
    .block--video .item-image .icon {
      display: block;
      position: absolute;
      z-index: 5;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
      .block--video .item-image .icon:before {
        line-height: 1;
        color: #fff;
        font-size: 5.625rem;
        transition: -webkit-transform .3s;
        transition: transform .3s;
        transition: transform .3s, -webkit-transform .3s;
        text-shadow: 2px 4px 12px rgba(0, 0, 0, 0.5); }
    .block--video .item-image img {
      display: block;
      width: 100%; }

/*
Last events

Markup: url()->find(.block--last-events)

Styleguide Blocks - 80.block--last-events
*/
.block--last-events .item-footer {
  margin-bottom: 18px;
  text-align: center; }
  .block--last-events .item-footer a {
    min-width: 200px; }

/*
Page summary

Markup: url()->find(.block--nav-summary)

Styleguide Blocks - 90.block--nav-summary
*/
.block--nav-summary {
  display: none;
  /* Responsive
       ========================================================================== */ }
  @media all and (min-width: 1601px) {
    .block--nav-summary {
      display: block;
      position: fixed;
      top: 50vh;
      left: 48px;
      z-index: 20;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
      margin-top: 190px;
      width: 12%;
      max-height: 58vh;
      font-size: 0.938rem;
      overflow-y: auto;
      transition: left .2s; }
      .l-menu-dashboard .block--nav-summary {
        left: 120px; }
      .l-menu-dashboard-open .block--nav-summary {
        left: 216px; }
      .l-wide-page .block--nav-summary {
        display: none; } }

/*
User login

Markup: url()->find(.block--user-login)

Styleguide Blocks - 100.block--user-login
*/
.block--user-login .form {
  padding: 18px 0 36px; }

.block--user-login .form-actions,
.block--user-login .form-secondary-link {
  text-align: center; }

/*
Menu reference

Markup: url()->find(.block--menu-reference)

Styleguide Blocks - 110.block--menu-reference
*/
.block--menu-reference {
  margin-bottom: 18px; }

/* ==========================================================================
   Footer.
   ========================================================================== */
.block--footer {
  display: flex;
  align-items: center;
  margin-bottom: 18px; }
  .block--footer .item-logo {
    margin-right: 80px; }
    .block--footer .item-logo svg {
      display: block; }
  .block--footer .nav-menu {
    display: flex;
    align-items: center;
    margin: 0;
    list-style: none; }
  .block--footer .nav-item + .nav-item {
    margin-left: 24px; }

/* ==========================================================================
   Contact.
   ========================================================================== */
.block--contact a {
  position: relative;
  z-index: 5;
  display: inline-block;
  padding: 0;
  background: #fff;
  border: 1px solid #4C1E5C;
  border-radius: 50%; }
  .block--contact a:hover .icon, .block--contact a:focus .icon {
    color: #fff;
    background-color: #4C1E5C; }

.block--contact .icon {
  display: block;
  width: 42px;
  height: 42px;
  color: #4C1E5C;
  font-size: 1.25rem;
  line-height: 42px;
  text-align: center;
  border-radius: 50%;
  transition: .1s; }

/* ==========================================================================
   Block SlideShow.
   ========================================================================== */
.block--slideshow {
  margin-top: -18px;
  margin-bottom: -18px;
  margin-left: -24px;
  margin-right: -24px;
  padding: 0; }

.route--layout-builder-overrides-node-view .block--slideshow {
  visibility: visible; }

/* ==========================================================================
   Rich text.
   ========================================================================== */
.block--richtext {
  /* Liste.
       ========================================================================== */
  /* Media.
       ========================================================================== */
  /* Texte.
       ========================================================================== */
  /* Table.
       ========================================================================== */
  /* Push.
       ========================================================================== */
  /* Keynumber
       ========================================================================== */ }
  @media all and (min-width: 768px) {
    .block--richtext > div > ul.nav-menu,
    .block--richtext ul:not([class]),
    .block--richtext ol:not([class]) {
      margin-left: 48px; } }
  .block--richtext > div > ul.nav-menu ul,
  .block--richtext > div > ul.nav-menu ol,
  .block--richtext ul:not([class]) ul,
  .block--richtext ul:not([class]) ol,
  .block--richtext ol:not([class]) ul,
  .block--richtext ol:not([class]) ol {
    margin: 0.5em 0 0 48px; }
  .block--richtext > div > ul.nav-menu li,
  .block--richtext ul:not([class]) li,
  .block--richtext ol:not([class]) li {
    position: relative;
    margin-bottom: .5em;
    list-style: none; }
    .block--richtext > div > ul.nav-menu li:before,
    .block--richtext ul:not([class]) li:before,
    .block--richtext ol:not([class]) li:before {
      margin-right: .4em;
      color: #4C1E5C; }
  .block--richtext > div > ul.nav-menu,
  .block--richtext ul:not([class]) {
    list-style: disc inside; }
    .block--richtext > div > ul.nav-menu li:before,
    .block--richtext ul:not([class]) li:before {
      content: "•"; }
  .block--richtext ol:not([class]) {
    list-style: none;
    counter-reset: decimal; }
    .block--richtext ol:not([class]) > li {
      counter-increment: decimal; }
      .block--richtext ol:not([class]) > li:before {
        content: counter(decimal) "."; }
  .block--richtext .item-media {
    position: relative; }
    .block--richtext .item-media a {
      position: relative; }
  .block--richtext h2:not(:first-child),
  .block--richtext h3:not(:first-child),
  .block--richtext h4:not(:first-child) {
    margin-top: .5em; }
  .block--richtext .btn, .block--richtext .pager a, .pager .block--richtext a,
  .block--richtext .nav--pager a, .nav--pager .block--richtext a {
    margin: 0; }
    .block--richtext .btn + .btn, .block--richtext .pager a + .btn, .pager .block--richtext a + .btn, .block--richtext .nav--pager a + .btn, .nav--pager .block--richtext a + .btn, .block--richtext .pager .btn + a, .pager .block--richtext .btn + a, .block--richtext .pager a + a, .pager .block--richtext a + a, .block--richtext .nav--pager .pager a + a, .pager .nav--pager .block--richtext a + a,
    .block--richtext .nav--pager .btn + a, .nav--pager .block--richtext .btn + a,
    .block--richtext .pager .nav--pager a + a, .nav--pager .block--richtext .pager a + a, .pager .block--richtext .nav--pager a + a, .nav--pager .pager .block--richtext a + a,
    .block--richtext .nav--pager a + a, .nav--pager .block--richtext a + a {
      margin-left: 24px; }
  .block--richtext table {
    max-width: 100%;
    margin: 18px auto 36px;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 0.938rem;
    overflow: hidden; }
    .block--richtext table p {
      margin: 0; }
    .block--richtext table caption {
      margin-bottom: 18px;
      font-style: italic; }
    .block--richtext table th,
    .block--richtext table td {
      vertical-align: middle;
      padding: 22px 32px; }
      .block--richtext table th + .block--richtext table th,
      .block--richtext table td + .block--richtext table th, .block--richtext table th +
      .block--richtext table td,
      .block--richtext table td +
      .block--richtext table td {
        border-left: 1px solid #fff; }
    .block--richtext table th {
      color: #fff;
      vertical-align: bottom;
      background: #2B2929; }
    .block--richtext table thead {
      font-weight: normal;
      font-family: "kanit--semibold", Arial, sans-serif;
      color: #fff; }
      .block--richtext table thead,
      .block--richtext table thead a {
        color: #fff; }
    .block--richtext table tbody td {
      background-color: transparent; }
    .block--richtext table tbody tr:nth-of-type(even) td {
      background-color: #F6F6F6; }
  .block--richtext .item-push.push--primary {
    color: #2B2929;
    font-size: 1.5rem;
    max-width: 908px; }
    .block--richtext .item-push.push--primary.text-align-center {
      margin: 0 auto 1.6em; }
  .block--richtext .item-keyfacts {
    padding: 36px 48px; }
    .block--richtext .item-keyfacts strong,
    .block--richtext .item-keyfacts b {
      margin-bottom: 18px;
      font-weight: normal;
      font-family: "kanit--semibold", Arial, sans-serif;
      font-size: 3em;
      line-height: 1.3; }
    .block--richtext .item-keyfacts.keyfacts--primary {
      color: #2B2929; }
    .block--richtext .item-keyfacts.keyfacts--secondary strong,
    .block--richtext .item-keyfacts.keyfacts--secondary b {
      color: #4C1E5C; }

.list {
  margin: 0;
  list-style: none; }

.list-item {
  position: relative; }
  .list-item > a {
    display: block;
    width: 100%;
    height: 100%;
    color: inherit;
    font-family: inherit;
    -webkit-user-select: none;
        -ms-user-select: none;
            user-select: none;
    box-sizing: border-box;
    text-decoration: none; }
    .list-item > a:hover, .list-item > a:focus {
      color: inherit; }
  .list-item .item-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    box-sizing: border-box; }
  .list-item .item-media {
    position: relative;
    margin-bottom: 48px;
    overflow: hidden; }
    .list-item .item-media img {
      display: block;
      margin: 0 auto; }
  .list-item .item-footer,
  .list-item .item-content {
    padding: 0 48px; }
  .list-item .item-content {
    position: relative; }
  .list-item .item-title {
    margin-bottom: 48px;
    color: inherit; }
  .list-item .item-body {
    margin-bottom: 18px;
    font-size: 0.938rem;
    line-height: normal;
    box-sizing: border-box; }
    .list-item .item-body p {
      margin-bottom: 0; }

/*
Liste des résultats de recherche

Markup: url()->find(.list--search-result)

Styleguide Lists - 1.list--search-result
*/
.list--search-result .list-item + .list-item {
  border-top: 1px solid rgba(142, 146, 156, 0.25); }

.list--search-result .list-item a {
  display: flex;
  align-items: center;
  padding: 18px 48px; }
  .list--search-result .list-item a:hover, .list--search-result .list-item a:focus {
    background-color: rgba(76, 30, 92, 0.1); }

.list--search-result .item-media,
.list--search-result .item-title {
  margin-bottom: 0; }

.list--search-result .item-media {
  flex-shrink: 0; }

.list--search-result .media-empty {
  display: block;
  width: 100px;
  height: 60px;
  background: #2B2929; }
  .list--search-result .media-empty:before {
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 5;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    color: rgba(150, 156, 161, 0.5); }

/*
Liste principale

Markup: url()->find(.list--primary)

Styleguide Lists - 10.list--primary
*/
.list--primary {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px; }
  .list--primary .item-wrapper {
    display: flex;
    flex-direction: column; }
  .list--primary .item-media {
    flex-shrink: 0;
    width: 100%;
    margin-bottom: 0; }
  .list--primary .item-content {
    padding: 18px 0 0; }
  .list--primary .content-details {
    margin: 0 0 9px; }
    .list--primary .content-details + .item-title {
      margin-top: 0; }
  .list--primary .item-date {
    position: absolute;
    top: -66px;
    right: 0;
    padding: 22px 32px;
    color: #2B2929;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif;
    font-size: 1.25rem;
    text-align: center;
    line-height: 1.1;
    background: #fff;
    border-top: 4px solid #4C1E5C; }
    .list--primary .item-date span {
      display: block; }
  .list--primary .item-title {
    margin-bottom: 9px;
    color: #2B2929;
    font-size: 1.375rem; }
    .list--primary .item-title:before {
      content: none; }
  .list--primary .item-body {
    color: #969CA1;
    font-size: 1.063rem;
    line-height: 1.4; }
  .list--primary .item-footer {
    padding: 0;
    text-align: left; }

/*
Comments list

Markup: url()->find(.list--comments)

Styleguide Lists - 30.list--comments
*/
.list--comments, .js-comment {
  padding: 18px 48px; }
  .list--comments .list-item, .js-comment .list-item {
    padding: 9px;
    padding-bottom: 0;
    margin-bottom: 9px;
    border-radius: 4px;
    transition: .3s; }
    .list--comments .list-item.is-selected, .js-comment .list-item.is-selected, .list--comments .list-item:hover, .js-comment .list-item:hover, .list--comments .list-item:focus, .js-comment .list-item:focus {
      background: #fff;
      padding-bottom: 22px; }
      .list--comments .list-item.is-selected .links, .js-comment .list-item.is-selected .links, .list--comments .list-item:hover .links, .js-comment .list-item:hover .links, .list--comments .list-item:focus .links, .js-comment .list-item:focus .links {
        opacity: 1; }
  .list--comments .indented, .js-comment .indented {
    margin-left: 24px; }
  .list--comments .item-footer, .js-comment .item-footer,
  .list--comments .item-content,
  .js-comment .item-content {
    padding: 0; }
  
  .list--comments .item-content,
  .js-comment .item-content {
    overflow: visible; }
    .list--comments .item-content p, .js-comment .item-content p {
      margin-bottom: 9px; }
  .list--comments .item-footer, .js-comment .item-footer {
    margin-bottom: 9px;
    font-weight: normal;
    font-family: "kanit--regular", Arial, sans-serif; }
    .list--comments .item-footer p, .js-comment .item-footer p {
      margin: 0; }
  .list--comments .item-author, .js-comment .item-author {
    font-weight: normal;
    font-family: Arial, sans-serif; }
  .list--comments .links, .js-comment .links {
    position: absolute;
    bottom: -26px;
    left: 0;
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    margin: 0;
    list-style: none;
    opacity: 0;
    transition: .3s; }
    .list--comments .links li, .js-comment .links li {
      margin-right: 12px;
      font-size: 0.938rem; }
    .list--comments .links a:not(.btn), .js-comment .links a:not(.btn) {
      font-weight: normal;
      font-family: "kanit--regular", Arial, sans-serif;
      font-size: 0.938rem;
      color: #959595;
      text-decoration: none;
      transition: .2s; }
      .list--comments .links a:not(.btn).is-active, .js-comment .links a:not(.btn).is-active, .list--comments .links a:not(.btn):hover, .js-comment .links a:not(.btn):hover, .list--comments .links a:not(.btn):focus, .js-comment .links a:not(.btn):focus {
        color: #4C1E5C;
        text-decoration: underline; }
  .list--comments .item-form.is-loaded, .js-comment .item-form.is-loaded {
    margin-top: 36px; }
  .list--comments .item-form form, .js-comment .item-form form,
  .list--comments .item-form .form-actions,
  .js-comment .item-form .form-actions {
    margin-bottom: 0; }
  .list--comments .view-empty, .js-comment .view-empty {
    padding-bottom: 0;
    margin-bottom: 0; }

/*
List page selection

Markup: url()->find(.list--page-selection)

Styleguide Lists - 40.list--page-selection
*/
.list--page-selection {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
  /* Layout.
       ========================================================================== */
  /* States
       ========================================================================== */ }
  .list--page-selection .list-item a:not(.btn) {
    text-decoration: none; }
  .list--page-selection .item-wrapper {
    background: #fff;
    border-radius: 30px 30px 30px 0;
    transition: .2s; }
  .list--page-selection .item-header {
    position: absolute;
    bottom: 0;
    z-index: 25;
    padding: 9px 24px;
    color: #fff;
    background: #4C1E5C;
    box-sizing: border-box;
    transition: .2s; }
  .list--page-selection .item-title-icon {
    display: flex;
    align-items: center; }
  .list--page-selection .item-title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif; }
  .list--page-selection .icon {
    margin-right: 12px;
    order: -1;
    color: #fff; }
    .list--page-selection .icon:before {
      font-size: 1.5rem; }
  .list--page-selection .item-content {
    padding: 0; }
  .list--page-selection .item-introduction {
    display: none; }
  .list--page-selection .item-thumbnail {
    position: relative;
    height: 316px;
    background: #2B2929; }
    .list--page-selection .item-thumbnail .is-empty {
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: 5;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
      .list--page-selection .item-thumbnail .is-empty:before {
        display: inline-block;
        font-family: "icons-1712325806";
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        speak: none;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        color: rgba(255, 255, 255, 0.5);
        font-size: 2rem; }
    .list--page-selection .item-thumbnail img {
      height: inherit;
      -o-object-fit: cover;
         object-fit: cover; }
  .list--page-selection .item-footer {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-align: center;
    box-sizing: border-box;
    -webkit-backdrop-filter: blur(8px);
            backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    transition: .3s; }
    .list--page-selection .item-footer:before {
      position: absolute;
      top: 0;
      right: 0;
      z-index: 5;
      content: "";
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 114px 114px 0;
      border-color: transparent #4C1E5C transparent transparent; }
    .list--page-selection .item-footer .btn, .list--page-selection .item-footer .pager a, .pager .list--page-selection .item-footer a,
    .list--page-selection .item-footer .nav--pager a, .nav--pager .list--page-selection .item-footer a {
      position: relative;
      margin: 0 auto;
      background: none;
      border-radius: 0;
      display: inline-flex;
      flex-direction: column;
      justify-content: center;
      font-weight: normal;
      font-family: "kanit--regular", Arial, sans-serif;
      font-size: 1.063rem;
      border: 0; }
      .list--page-selection .item-footer .btn:before, .list--page-selection .item-footer .pager a:before, .pager .list--page-selection .item-footer a:before,
      .list--page-selection .item-footer .nav--pager a:before, .nav--pager .list--page-selection .item-footer a:before {
        display: inline-block;
        font-family: "icons-1712325806";
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        speak: none;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        margin-bottom: 9px;
        width: 68px;
        height: 68px;
        border: 1px solid #4C1E5C;
        text-align: center;
        line-height: 68px;
        border-radius: 50%; }
  @media all and (min-width: 768px) {
    .list--page-selection.l-twolines {
      display: grid;
      grid-template: 1fr 1fr/2fr 1fr;
      gap: 0 0;
      justify-items: stretch;
      align-items: stretch; }
      .list--page-selection.l-twolines .list-item {
        width: 100%;
        max-width: none; }
        .list--page-selection.l-twolines .list-item.l-twothird {
          grid-column: 1/2;
          grid-row: 1/3; }
          .list--page-selection.l-twolines .list-item.l-twothird .item-thumbnail {
            height: 656px; }
        .list--page-selection.l-twolines .list-item.l-third, .list--page-selection.l-twolines .list--primary .list-item.l-half, .list--primary .list--page-selection.l-twolines .list-item.l-half {
          grid-column: 2/3;
          grid-row: 1/2; }
          .list--page-selection.l-twolines .list-item.l-third:last-child, .list--page-selection.l-twolines .list--primary .list-item.l-half:last-child, .list--primary .list--page-selection.l-twolines .list-item.l-half:last-child {
            grid-row: 2/2; } }
  .list--page-selection a:hover .item-wrapper, .list--page-selection a:focus .item-wrapper {
    border-radius: 30px 0 30px 30px; }
  .list--page-selection a:hover .item-header, .list--page-selection a:focus .item-header {
    background: none; }
  .list--page-selection a:hover .item-footer, .list--page-selection a:focus .item-footer {
    visibility: visible;
    opacity: 1; }
    .list--page-selection a:hover .item-footer .btn, .list--page-selection a:hover .item-footer .pager a, .pager .list--page-selection a:hover .item-footer a,
    .list--page-selection a:hover .item-footer .nav--pager a, .nav--pager .list--page-selection a:hover .item-footer a, .list--page-selection a:focus .item-footer .btn, .list--page-selection a:focus .item-footer .pager a, .pager .list--page-selection a:focus .item-footer a,
    .list--page-selection a:focus .item-footer .nav--pager a, .nav--pager .list--page-selection a:focus .item-footer a {
      border: 0; }

/* ==========================================================================
   Glossary.
   ========================================================================== */
.list--glossary {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
  background: #F6F6F6;
  /* Responsive
       ========================================================================== */ }
  .list--glossary .glossary-letter {
    color: #2B2929;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif;
    font-size: 2.125rem; }
  .list--glossary .item-title {
    margin-bottom: 9px;
    color: #4C1E5C;
    font-size: 1.375rem; }
    .list--glossary .item-title:before {
      content: none; }
  .list--glossary .item-content {
    padding: 0;
    line-height: 1.3; }
  @media all and (min-width: 768px) {
    .list--glossary .l-full {
      padding-left: 48px;
      padding-right: 48px; }
    .list--glossary .l-half {
      padding-left: 48px;
      padding-right: 48px; }
      .list--glossary .l-half + .l-half {
        border-left: 1px solid #8e929c; } }

/* ==========================================================================
   Media library.
   ========================================================================== */
.list--media-library {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
  position: relative;
  background: #F6F6F6; }
  .list--media-library:before, .list--media-library:after {
    content: "";
    position: absolute;
    top: 0;
    z-index: -1;
    width: 1000px;
    height: 100%;
    background: inherit; }
  .list--media-library:before {
    left: -1000px; }
  .list--media-library:after {
    right: -1000px; }
  .list--media-library .item-wrapper {
    display: flex;
    align-items: center;
    padding: 15px;
    background: #fff; }
  .list--media-library .item-content {
    padding: 9px 0; }
  .list--media-library .item-thematic {
    display: inline-block;
    margin-bottom: 9px;
    color: #4C1E5C;
    line-height: 1; }
  .list--media-library .item-title {
    margin-bottom: 18px;
    color: #2B2929;
    font-size: 1.375rem; }
    .list--media-library .item-title:before {
      content: none; }
  .list--media-library .item-details .item-date:before {
    content: "-";
    margin-right: 5px; }
  .list--media-library .item-thumbnail {
    margin-right: 48px; }

.nav .nav-menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center; }

.nav p,
.nav ul,
.nav ol {
  margin-bottom: 0; }

.nav li {
  list-style: none; }

.nav a {
  position: relative;
  display: block;
  line-height: 1.2; }

.nav .is-active {
  color: inherit; }

/*
Navigation principale

Markup: url()->find(.nav--main)

Styleguide Navigation - 10.nav--main
*/
.nav--main {
  /* states
       ========================================================================== */ }
  .nav--main,
  .nav--main a {
    color: #2B2929; }
  .nav--main a {
    box-sizing: border-box; }
  .nav--main .nav-menu.level-1 {
    flex-wrap: nowrap; }
  .nav--main .nav-menu.level-2, .nav--main .nav-menu.level-3 {
    position: absolute;
    z-index: -1;
    top: 100%;
    left: 0;
    display: block;
    width: 264px;
    padding: 10px 0;
    background-color: #fff;
    border: 0;
    visibility: hidden;
    opacity: 0;
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    transition: .3s; }
    .nav--main .nav-menu.level-2:before, .nav--main .nav-menu.level-3:before {
      content: "";
      position: absolute;
      z-index: 5;
      top: -12px;
      left: 40px;
      display: block;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 11px 12px 11px;
      border-color: transparent transparent #fff; }
  .nav--main .nav-menu.level-3 {
    top: -10px;
    left: 264px; }
    .nav--main .nav-menu.level-3:before {
      content: none; }
  .nav--main .nav-item.level-1 {
    position: relative;
    margin-left: 1px;
    font-size: 0.938rem; }
    .nav--main .nav-item.level-1 > a {
      width: 100%;
      padding: 10px 15px;
      text-align: center; }
    .nav--main .nav-item.level-1 + .nav-item.level-1:before {
      content: "";
      position: absolute;
      top: 50%;
      left: -1px;
      z-index: 5;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
      display: inline-block;
      width: 1px;
      height: 38px;
      background: rgba(0, 0, 0, 0.12); }
  .nav--main .nav-item:not(.level-1) {
    min-height: 1px;
    box-sizing: border-box;
    font-size: 0.938rem; }
    .nav--main .nav-item:not(.level-1) > a {
      padding: 10px 20px; }
  .nav--main .nav-item.level-2.is-parent {
    position: relative; }
    .nav--main .nav-item.level-2.is-parent > a:after {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      position: absolute;
      top: 50%;
      right: 16px;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%);
      font-size: 0.688rem; }
  .nav--main .nav-item.level-2.is-active .nav-menu {
    z-index: 100;
    visibility: visible;
    opacity: 1; }
  .nav--main .nav-item.level-4 {
    width: 100%; }
    .nav--main .nav-item.level-4 > a:before {
      content: "-";
      margin-right: 12px; }
  .nav--main .nav-item.level-1 > a:active,
  .nav--main .nav-item.level-1 > a:focus,
  .nav--main .nav-item.level-1:hover > a,
  .nav--main .nav-item.level-1.is-active-trail > a {
    color: #fff;
    background: #4C1E5C; }
  .nav--main .nav-item.is-active > .nav-menu {
    z-index: 100;
    visibility: visible;
    opacity: 1; }
  .nav--main .nav-item:not(.level-1) > a {
    color: #2B2929; }
    .nav--main .nav-item:not(.level-1) > a:hover, .nav--main .nav-item:not(.level-1) > a:focus {
      color: #4C1E5C;
      background: rgba(76, 30, 92, 0.1); }

.nav--secondary {
  margin-right: 24px; }
  .nav--secondary .nav-item {
    position: relative;
    color: #2B2929;
    font-size: 0.938rem;
    padding-left: 24px;
    padding-right: 24px;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif; }
    .nav--secondary .nav-item + .nav-item:before {
      content: "";
      position: absolute;
      top: 2px;
      left: 0;
      width: 1px;
      height: 14px;
      background: #4C1E5C; }
    .nav--secondary .nav-item a {
      color: inherit;
      position: relative; }
      .nav--secondary .nav-item a:after {
        content: "";
        position: absolute;
        left: 0;
        bottom: -1px;
        width: 100%;
        height: 1px;
        background: #4C1E5C;
        -webkit-transform: scaleX(0);
                transform: scaleX(0);
        -webkit-transform-origin: 100% 50%;
                transform-origin: 100% 50%;
        transition: -webkit-transform .2s ease-out;
        transition: transform .2s ease-out;
        transition: transform .2s ease-out, -webkit-transform .2s ease-out; }
      .nav--secondary .nav-item a:not(.active):hover:after {
        -webkit-transform: scaleX(1);
                transform: scaleX(1);
        -webkit-transform-origin: 0 50%;
                transform-origin: 0 50%; }

/*
Navigation footer

Markup: url()->find(.nav--footer)

Styleguide Navigation - 20.nav--footer
*/
.nav--footer .nav-item {
  display: inline-flex;
  align-items: center;
  margin: 0 32px;
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  text-transform: uppercase;
  font-size: 0.938rem; }

.nav--footer a {
  color: #fff; }
  .nav--footer a:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 100%;
    height: 1px;
    background: #fff;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
    transition: -webkit-transform .2s ease-out;
    transition: transform .2s ease-out;
    transition: transform .2s ease-out, -webkit-transform .2s ease-out; }
  .nav--footer a:not(.active):hover:after {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 0 50%;
            transform-origin: 0 50%; }

/*
Fil d'ariane

Markup: url()->find(.nav--breadcrumb)

Styleguide Navigation - 30.nav--breadcrumb
*/
.nav--breadcrumb {
  padding: 8px 0 4px;
  font-size: 0.938rem;
  /* Responsive
       ========================================================================== */ }
  .nav--breadcrumb .nav-item {
    margin-bottom: 4px;
    line-height: 1; }
  .nav--breadcrumb a {
    display: inline;
    padding: 5px 0;
    color: inherit; }
    .nav--breadcrumb a:after {
      content: "";
      position: absolute;
      left: 0;
      bottom: 2px;
      width: 20px;
      height: 1px;
      background: #4C1E5C;
      -webkit-transform: scaleX(0);
              transform: scaleX(0);
      -webkit-transform-origin: 100% 50%;
              transform-origin: 100% 50%;
      transition: -webkit-transform .2s ease-out;
      transition: transform .2s ease-out;
      transition: transform .2s ease-out, -webkit-transform .2s ease-out; }
    .nav--breadcrumb a:not(.active):hover:after {
      -webkit-transform: scaleX(1);
              transform: scaleX(1);
      -webkit-transform-origin: 0 50%;
              transform-origin: 0 50%; }
  .nav--breadcrumb .item-separator {
    margin: 0 .4em; }
    .nav--breadcrumb .item-separator:before {
      content: "";
      width: 10px;
      height: 10px;
      background: #4C1E5C;
      border-radius: 50%; }
  .nav--breadcrumb li:last-of-type {
    color: #2B2929;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif; }
  @media all and (max-width: 1279px) {
    .nav--breadcrumb li:last-of-type {
      display: none; }
    .nav--breadcrumb li:nth-last-child(2) .item-separator {
      display: none; } }

/*
Pagination classique

Markup: url()->find(.nav--pager)

Styleguide Navigation - 40.nav--pager
*/
.pager,
.nav--pager {
  margin: 18px auto;
  text-align: center; }
  .pager a,
  .nav--pager a {
    min-width: 57px; }
  .pager .pager__items,
  .pager .pager-items,
  .nav--pager .pager__items,
  .nav--pager .pager-items {
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none; }
  .pager .pager__item,
  .nav--pager .pager__item {
    flex-shrink: 0; }
    .pager .pager__item + .pager__item,
    .nav--pager .pager__item + .pager__item {
      margin-left: 12px; }

/*
Menu tableau de bord

Markup: url()->find(.nav--dashboard)

Styleguide Navigation - 50.nav--dashboard
*/
.nav--dashboard {
  /* Toggle
       ========================================================================== */
  /* Menu
       ========================================================================== */ }
  .nav--dashboard .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 10px 0;
    width: 100%;
    color: #000;
    font-size: 1.25rem;
    line-height: 1;
    background: none;
    opacity: .3;
    transition: all .2s ease-in-out, width 0s; }
    .nav--dashboard .nav-toggle:active, .nav--dashboard .nav-toggle.is-active, .nav--dashboard .nav-toggle:focus, .nav--dashboard .nav-toggle:hover {
      opacity: .6; }
    .l-menu-dashboard-open .nav--dashboard .nav-toggle {
      -webkit-transform: rotateY(180deg);
              transform: rotateY(180deg);
      width: 54px; }
  .nav--dashboard .nav-menu {
    display: block; }
    .nav--dashboard .nav-menu a {
      height: 72px;
      color: rgba(255, 255, 255, 0.5); }
      .nav--dashboard .nav-menu a:active, .nav--dashboard .nav-menu a.is-active, .nav--dashboard .nav-menu a:focus, .nav--dashboard .nav-menu a:hover {
        color: #fff; }
      .nav--dashboard .nav-menu a > span {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 100%; }
        .l-menu-dashboard-open .nav--dashboard .nav-menu a > span {
          justify-content: normal;
          padding: 0 10px; }
    .nav--dashboard .nav-menu .icon:before {
      font-size: 2rem; }
    .l-menu-dashboard-open .nav--dashboard .nav-menu .icon {
      padding-right: 10px; }
    .nav--dashboard .nav-menu .item-title {
      position: absolute;
      left: 54px;
      width: 130px;
      font-weight: normal;
      font-family: "kanit--semibold", Arial, sans-serif;
      visibility: hidden;
      opacity: 0;
      transition: all .2s, color 0s; }
      .l-menu-dashboard-open .nav--dashboard .nav-menu .item-title {
        visibility: visible;
        opacity: 1; }

/*
Liens frères/soeurs

Markup: url()->find(.nav--siblings)

Styleguide Navigation - 60.nav--siblings
*/
@media all and (min-width: 768px) {
  .nav--siblings .nav-menu {
    flex-wrap: nowrap; } }

.nav--siblings .nav-item {
  margin: 10px 0; }
  .nav--siblings .nav-item .btn, .nav--siblings .nav-item .pager a, .pager .nav--siblings .nav-item a,
  .nav--siblings .nav-item .nav--pager a, .nav--pager .nav--siblings .nav-item a {
    display: inline-flex;
    line-height: 1.5; }

.nav--siblings .prev {
  margin-right: 24px; }

.nav--siblings .next {
  margin-left: auto; }

/*
Barre d'outils

Markup: url()->find(.nav--toolbar)

Styleguide Navigation - 70.nav--toolbar
*/
.nav--toolbar {
  /* Admin toolbar.
       ========================================================================== */
  /* Print
       ========================================================================== */
  /* Share
       ========================================================================== */ }
  .content-before .nav--toolbar {
    padding-left: 24px; }
  .nav--toolbar .nav-item {
    position: relative;
    flex-shrink: 0; }
    .nav--toolbar .nav-item.is-open > a .icon:before {
      color: #2B2929; }
  .nav--toolbar a {
    padding: 0 6px;
    line-height: 1; }
    .nav--toolbar a:hover .icon:before, .nav--toolbar a:focus .icon:before {
      color: #2B2929; }
  .nav--toolbar .icon:before {
    color: #4C1E5C;
    font-size: 1.125rem;
    transition: .3s; }
  .print-page-header > .nav--toolbar, .nav--toolbar.print-quick-layout-actions {
    position: absolute;
    z-index: 20;
    display: inline-block;
    margin: 0;
    padding: 10px;
    background: rgba(255, 255, 255, 0.75);
    border: 1px dashed #8e929c;
    border-radius: 2px; }
    .print-page-header > .nav--toolbar .nav-menu, .nav--toolbar.print-quick-layout-actions .nav-menu {
      margin: 0; }
  .print-page-header > .nav--toolbar {
    top: 0;
    right: -170px; }
  .nav--toolbar.print-quick-layout-actions {
    right: -110px;
    bottom: 0; }
  .nav--toolbar .toolbar-social-share {
    position: absolute;
    right: -2px;
    bottom: -52px;
    z-index: 50;
    display: flex;
    padding: 8px 12px;
    background: #fff;
    box-shadow: 0 7px 25px 0 rgba(0, 0, 0, 0.15);
    opacity: 0;
    visibility: hidden;
    transition: .3s; }
    .nav--toolbar .toolbar-social-share:before {
      content: "";
      position: absolute;
      top: -8px;
      right: 12px;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 6px 8px 6px;
      border-color: transparent transparent #fff; }
    .nav--toolbar .toolbar-social-share .icon:before {
      font-size: 1.375rem; }
    .nav--toolbar .toolbar-social-share .icon--facebook:before {
      color: #4267b2; }
    .nav--toolbar .toolbar-social-share .icon--twitter:before {
      color: #55acee; }
    .nav--toolbar .toolbar-social-share .icon--linkedin:before {
      color: #007ab9; }
  .nav--toolbar .is-open .toolbar-social-share {
    opacity: 1;
    visibility: visible; }

/*
Nav dropdown (icon + menu caché) via ToggleMenu

Markup: url()->find(.nav--toolbar)

Styleguide Navigation - 80.nav--dropdown
*/
.nav--dropdown {
  position: relative;
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  /* states
       ========================================================================== */ }
  .nav--dropdown .nav-toggle {
    position: relative;
    z-index: 5;
    padding: 0;
    background: #fff;
    border: 1px solid #4C1E5C;
    border-radius: 50%; }
    .nav--dropdown .nav-toggle .icon {
      display: block;
      width: 42px;
      height: 42px;
      color: #4C1E5C;
      font-size: 1.25rem;
      line-height: 42px;
      text-align: center;
      border-radius: 50%;
      transition: .1s; }
  .nav--dropdown .nav-content {
    position: absolute;
    z-index: 10;
    top: 100%;
    right: 50%;
    -webkit-transform: translate(0, -10px);
            transform: translate(0, -10px);
    display: block;
    padding: 15px 0 10px;
    width: 200px;
    max-height: 68vh;
    overflow: auto;
    background-color: #fff;
    box-shadow: 0 7px 25px 0 rgba(0, 0, 0, 0.1);
    opacity: 0;
    visibility: hidden;
    transition: .3s; }
  .nav--dropdown .nav-item {
    width: 100%; }
    .nav--dropdown .nav-item .item-content {
      display: block;
      padding: 6px 20px; }
      .nav--dropdown .nav-item .item-content span {
        display: inherit; }
    .nav--dropdown .nav-item a {
      color: #959595;
      font-size: 1.125rem; }
      .nav--dropdown .nav-item a:hover, .nav--dropdown .nav-item a:focus {
        color: #4C1E5C;
        background-color: rgba(76, 30, 92, 0.1); }
    .nav--dropdown .nav-item .item-username {
      color: #2B2929;
      font-size: 1.1em; }
    .nav--dropdown .nav-item .item-usermail {
      color: #969CA1; }
  .nav--dropdown.is-open .nav-toggle .icon,
  .nav--dropdown .nav-toggle:hover .icon,
  .nav--dropdown .nav-toggle:focus .icon {
    color: #fff;
    background-color: #4C1E5C; }
  .nav--dropdown.is-open .nav-toggle {
    z-index: 15; }
  .nav--dropdown.is-open .nav-content {
    visibility: visible;
    opacity: 1; }

/*
Navigation des éléments enfants d'une page

Markup: url()->find(.nav--children)

Styleguide Navigation - 80.nav--children
*/
.nav--children {
  /* Graphique
       ========================================================================== */
  /* Image de fond
       ========================================================================== */
  /* Contenu libre
       ========================================================================== */ }
  .nav--children .nav-menu {
    display: grid;
    grid-gap: 48px;
    grid-template-columns: 1fr;
    align-items: initial; }
  @media all and (min-width: 768px) {
    .nav--children .nav-menu {
      grid-template-columns: 1fr 1fr; }
    .nav--children .l-2-rows {
      grid-row-end: span 2; } }
  @media all and (min-width: 1441px) {
    .nav--children .nav-menu {
      grid-template-columns: 1fr 1fr 1fr; } }
  .nav--children a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    overflow: hidden;
    border-radius: 30px;
    text-align: center;
    color: #2B2929;
    background: rgba(76, 30, 92, 0.1) no-repeat center;
    background-size: cover;
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
    box-sizing: border-box;
    -webkit-font-smoothing: subpixel-antialiased;
    transition: .2s ease-in-out; }
    .nav--children a:hover, .nav--children a:focus {
      color: #fff;
      background-color: #4C1E5C; }
      .nav--children a:hover .item-title, .nav--children a:focus .item-title {
        color: inherit; }
  .nav--children .item-wrapper {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px; }
  .nav--children .item-title {
    max-width: 380px;
    margin: 1em auto;
    color: #4C1E5C;
    font-size: 1.25rem;
    font-weight: normal;
    font-family: "kanit--semibold", Arial, sans-serif;
    transition: .2s; }
  .nav--children .item-content {
    margin: 1em auto; }
  .nav--children .item-type--dataviz a {
    background-color: #F6F6F6; }
  .nav--children .item-type--dataviz .item-title:after {
    content: none; }
  .nav--children .item-type--thumbnail a {
    border-width: 0; }
    .nav--children .item-type--thumbnail a:before {
      content: "";
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      background: #000;
      opacity: .4; }
  .nav--children .item-type--thumbnail .item-title {
    color: #fff; }
    .nav--children .item-type--thumbnail .item-title:after {
      content: none; }
  .nav--children .item-type--content .item-keyfacts {
    display: flex;
    align-items: center;
    margin-bottom: -1em;
    text-align: left;
    font-size: 1.125rem; }
    .nav--children .item-type--content .item-keyfacts strong,
    .nav--children .item-type--content .item-keyfacts b {
      margin-right: .25em;
      font-size: 3em;
      font-weight: normal;
      font-family: Arial, sans-serif;
      white-space: nowrap; }

/* ==========================================================================
   Sitemap
   ========================================================================== */
.sitemap-item {
  margin-bottom: 36px; }

/*
Nav sommaire de page.

Markup: url()->find(.nav--summary)

Styleguide Navigation - 90.nav--summary
*/
.nav--summary .nav-item {
  width: 100%;
  margin-bottom: 9px;
  cursor: pointer;
  transition: .3s; }
  .nav--summary .nav-item.is-active {
    font-weight: bold; }
  .nav--summary .nav-item:not(.l-accordion):hover, .nav--summary .nav-item:not(.l-accordion):focus {
    color: #4C1E5C; }

.nav--summary .nav-menu-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
  width: inherit;
  background: none;
  color: #959595;
  text-align: left;
  transition: .3s; }
  .nav--summary .nav-menu-trigger:after {
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding-left: 4px;
    color: inherit; }
  .nav--summary .nav-menu-trigger:hover, .nav--summary .nav-menu-trigger:focus {
    color: #4C1E5C; }
  .nav--summary .nav-menu-trigger + .nav-menu {
    display: none;
    margin-top: 9px;
    margin-left: 12px; }

.nav--summary .is-open .nav-menu-trigger:after {
  -webkit-transform: rotateX(180deg);
          transform: rotateX(180deg); }

/*
Nav des utilisateurs

Markup: url()->find(.nav--users)

Styleguide Navigation - 100.nav--users
*/
.nav--users {
  max-height: 30vh;
  overflow-y: auto;
  background: #fff;
  box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.25);
  border: 1px solid #4C1E5C;
  border-top: 0; }
  .nav--users .nav-item {
    padding: 9px 32px;
    cursor: pointer; }
    .nav--users .nav-item:hover, .nav--users .nav-item:focus {
      background-color: #F6F6F6; }
    .nav--users .nav-item p {
      margin: 0; }
  .nav--users .item-display-name {
    font-weight: bold; }
  .nav--users .item-name {
    font-size: 0.938rem; }

/*
Simple navigation inline with icon.

Markup: url()->find(.nav--simple)

Styleguide Navigation - 110.nav--simple
*/
.nav--simple {
  /* Responsive
       ========================================================================== */ }
  .nav--simple .nav-menu {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    margin: 0;
    list-style: none; }
  .nav--simple .nav-item {
    margin-bottom: .7rem; }
    .nav--simple .nav-item a {
      display: inline-flex;
      align-items: center;
      width: 100%;
      height: 100%;
      padding: 27px 48px;
      background: rgba(76, 30, 92, 0.1);
      box-sizing: border-box; }
      .nav--simple .nav-item a:not(.btn) {
        text-decoration: none; }
      .nav--simple .nav-item a:hover, .nav--simple .nav-item a:focus {
        color: #fff;
        background-color: #4C1E5C; }
    .nav--simple .nav-item .item-title {
      font-weight: bold;
      font-size: 1.125rem; }
    .nav--simple .nav-item .icon {
      margin-right: 24px;
      order: -1; }
      .nav--simple .nav-item .icon:before {
        font-size: 2.5rem;
        line-height: 40px; }
  @media all and (min-width: 768px) {
    .nav--simple .nav-menu {
      flex-direction: row;
      margin-left: -.5%;
      margin-right: -.5%; }
    .nav--simple .nav-item {
      padding: 0 .5%;
      width: 24%; } }

/*
Detailed navigation with multiple depths.

Markup: url()->find(.nav--detail)

Styleguide Navigation - 120.nav--detail
*/
.nav--detail {
  /* Accordion.
       ========================================================================== */
  /* Responsive.
       ========================================================================== */ }
  .nav--detail .nav-menu {
    flex-direction: column;
    margin: 0; }
    .nav--detail .nav-menu .nav-menu:after {
      content: "";
      padding-bottom: 9px;
      width: 100%;
      background: rgba(76, 30, 92, 0.1); }
  .nav--detail .nav-item {
    width: 100%; }
    .nav--detail .nav-item a {
      display: inline-flex;
      align-items: center;
      width: inherit;
      height: 100%;
      padding: 9px 48px;
      background: rgba(76, 30, 92, 0.1);
      box-sizing: border-box; }
      .nav--detail .nav-item a:not(.btn) {
        text-decoration: none; }
    .nav--detail .nav-item .item-title {
      font-weight: bold;
      font-size: 1.125rem; }
    .nav--detail .nav-item .icon {
      display: none;
      margin-right: 24px;
      order: -1; }
      .nav--detail .nav-item .icon:before {
        font-size: 2.5rem;
        line-height: 40px; }
    .nav--detail .nav-item.is-active-trail > a,
    .nav--detail .nav-item a:hover,
    .nav--detail .nav-item a:focus {
      color: #fff;
      background-color: #4C1E5C; }
      .nav--detail .nav-item.is-active-trail > a:after,
      .nav--detail .nav-item a:hover:after,
      .nav--detail .nav-item a:focus:after {
        color: inherit; }
  .nav--detail .level-2.is-parent a {
    padding-top: 4.5px;
    padding-bottom: 4.5px; }
    .nav--detail .level-2.is-parent a:before {
      content: "-";
      margin-right: 12px; }
  .nav--detail .level-3 a {
    padding-left: 72px; }
  .nav--detail .level-4 a {
    padding-left: 96px; }
  .nav--detail .level-5 a {
    padding-left: 120px; }
  .nav--detail .l-accordion {
    cursor: pointer; }
    .nav--detail .l-accordion span {
      position: relative; }
    .nav--detail .l-accordion > a:after,
    .nav--detail .l-accordion > span:after {
      display: inline-block;
      font-family: "icons-1712325806";
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      speak: none;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      position: absolute;
      top: 50%;
      right: 24px;
      -webkit-transform: rotateY(0) translateY(-50%);
              transform: rotateY(0) translateY(-50%);
      -webkit-transform-origin: 50% 0;
              transform-origin: 50% 0;
      color: #4C1E5C;
      transition: .2s; }
    .nav--detail .l-accordion.is-open > a:after,
    .nav--detail .l-accordion.is-open > span:after {
      -webkit-transform: rotateX(180deg) translateY(-50%);
              transform: rotateX(180deg) translateY(-50%); }
  @media all and (min-width: 768px) {
    .nav--detail .nav-item.level-1 + .nav-item.level-1 {
      border-top: 1px solid #4C1E5C; } }

/* ==========================================================================
   Togglemenu push
   ========================================================================== */
/* Contexte de page
   ========================================================================== */
body {
  overflow-x: hidden; }
  body .page {
    transition: .3s; }
  body.is-togglemenu-open .page {
    position: fixed;
    width: 100vw;
    -webkit-transform: translateX(280px);
            transform: translateX(280px); }
  body.is-togglemenu-open .togglemenu--push {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    box-shadow: -5px 0 24px rgba(0, 0, 0, 0.24); }

/* Menu
   ========================================================================== */
.togglemenu--push {
  position: absolute;
  z-index: 50;
  top: 0;
  left: 0;
  width: 280px;
  height: 100vh;
  background: #fff;
  overflow: auto;
  overflow-x: hidden;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  font-size: 1.125rem;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
  box-sizing: border-box;
  /* Close
   ========================================================================== */
  /* Layout accordéon
	   ========================================================================== */
  /* Layout panel
	   ========================================================================== */ }
  .toolbar-vertical .togglemenu--push,
  .toolbar-fixed .togglemenu--push {
    margin-top: 39px; }
  .toolbar-fixed.toolbar-horizontal.toolbar-tray-open .togglemenu--push {
    margin-top: 78px; }
  .togglemenu--push .nav-menu {
    margin: 0;
    padding: 0;
    overflow: hidden; }
  .togglemenu--push li {
    list-style: none; }
    .togglemenu--push li a {
      position: relative;
      display: block;
      padding: 16px 20px;
      border-bottom: 1px solid rgba(0, 0, 0, 0.1);
      line-height: 1.3;
      color: #2B2929; }
  .togglemenu--push .is-parent > a {
    padding-right: 40px; }
  .togglemenu--push .togglemenu-close button, .togglemenu--push .l-panel .item-back button {
    position: relative;
    display: inline-block;
    padding: 0;
    width: 44px;
    height: 44px;
    color: #fff;
    background: #4C1E5C;
    text-indent: -9999px;
    border: 0;
    cursor: pointer;
    transition: background-color .3s; }
    .togglemenu--push .togglemenu-close button:before, .togglemenu--push .l-panel .item-back button:before, .togglemenu--push .togglemenu-close button:after, .togglemenu--push .l-panel .item-back button:after {
      content: "";
      position: absolute;
      top: 50%;
      left: 50%;
      width: 40%;
      height: 2px;
      background-color: #fff;
      -webkit-transform: rotate(45deg) translate(-50%, -50%);
              transform: rotate(45deg) translate(-50%, -50%);
      -webkit-transform-origin: 0 0;
              transform-origin: 0 0; }
    .togglemenu--push .togglemenu-close button:after, .togglemenu--push .l-panel .item-back button:after {
      -webkit-transform: rotate(-45deg) translate(-50%, -50%);
              transform: rotate(-45deg) translate(-50%, -50%); }
  .togglemenu--push .l-accordion > .nav-menu {
    padding-left: 20px;
    overflow: hidden; }
    .togglemenu--push .l-accordion > .nav-menu > .nav-item > a {
      padding-top: 10px;
      padding-bottom: 10px; }
    .togglemenu--push .l-accordion > .nav-menu > .nav-item:last-of-type {
      padding-bottom: 10px; }
    .togglemenu--push .l-accordion > .nav-menu > .nav-item + .nav-item > a {
      border: 0; }
  .togglemenu--push .l-accordion > a:before, .togglemenu--push .l-accordion > a:after {
    content: "";
    position: absolute;
    bottom: 48%;
    right: 20px;
    width: 10px;
    height: 2px;
    background: #4C1E5C;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: center -3px;
            transform-origin: center -3px;
    transition: .3s; }
  .togglemenu--push .l-accordion > a:after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg); }
  .togglemenu--push .l-accordion.is-active > .nav-menu {
    z-index: 50;
    overflow: visible; }
  .togglemenu--push .l-accordion.is-active > a:before, .togglemenu--push .l-accordion.is-active > a:after {
    -webkit-transform-origin: center 5px;
            transform-origin: center 5px; }
  .togglemenu--push .l-panel {
    /* Header (retour, item de menu courant)
		   ========================================================================== */ }
    .togglemenu--push .l-panel > a:before, .togglemenu--push .l-panel > a:after {
      content: "";
      position: absolute;
      bottom: 48%;
      right: 20px;
      width: 10px;
      height: 2px;
      background: #4C1E5C;
      -webkit-transform: rotate(45deg);
              transform: rotate(45deg);
      -webkit-transform-origin: right center;
              transform-origin: right center;
      transition: .3s; }
    .togglemenu--push .l-panel > a:after {
      -webkit-transform: rotate(-45deg);
              transform: rotate(-45deg); }
    .togglemenu--push .l-panel > .nav-menu {
      position: absolute;
      top: 0;
      left: 0;
      z-index: 55;
      width: 280px;
      height: 100%;
      background: #fff;
      -webkit-transform: translateX(-100%);
              transform: translateX(-100%);
      transition: -webkit-transform .3s;
      transition: transform .3s;
      transition: transform .3s, -webkit-transform .3s; }
    .togglemenu--push .l-panel.is-active > .nav-menu {
      -webkit-transform: translateX(0);
              transform: translateX(0); }
    .togglemenu--push .l-panel .item-back {
      background-color: #4C1E5C; }
      .togglemenu--push .l-panel .item-back .item-btn {
        margin-top: 15px;
        margin-left: 6px;
        flex-shrink: 0;
        text-indent: 0;
        opacity: .7; }
        .togglemenu--push .l-panel .item-back .item-btn:before, .togglemenu--push .l-panel .item-back .item-btn:after {
          width: 20%;
          -webkit-transform-origin: -46% 0;
                  transform-origin: -46% 0; }
        .togglemenu--push .l-panel .item-back .item-btn span {
          margin-left: 100%;
          text-transform: uppercase; }
        .togglemenu--push .l-panel .item-back .item-btn:hover, .togglemenu--push .l-panel .item-back .item-btn:focus {
          opacity: 1; }
      .togglemenu--push .l-panel .item-back .item-title,
      .togglemenu--push .l-panel .item-back .item-title a {
        color: #fff; }
      .togglemenu--push .l-panel .item-back .item-title a {
        padding-top: 5px;
        font-size: 1.1em; }
  .togglemenu--push .togglemenu-menu a:hover, .togglemenu--push .togglemenu-menu a:focus {
    background-color: rgba(76, 30, 92, 0.1);
    color: #4C1E5C; }
  .togglemenu--push .togglemenu-menu .l-dashboard > a {
    color: #4C1E5C; }
  .togglemenu--push .togglemenu-menu .l-dashboard .level-2 a > span {
    display: inline-flex;
    align-items: center; }
  .togglemenu--push .togglemenu-menu .l-dashboard .level-2 .icon {
    margin-top: 2px;
    margin-right: .75em;
    flex-shrink: 0;
    color: #4C1E5C; }
  .togglemenu--push > .togglemenu-close button, .togglemenu--push .l-panel .togglemenu--push > .item-back button {
    position: absolute;
    top: 0;
    right: 0;
    background-color: transparent; }
    .togglemenu--push > .togglemenu-close button:before, .togglemenu--push .l-panel .togglemenu--push > .item-back button:before, .togglemenu--push > .togglemenu-close button:after, .togglemenu--push .l-panel .togglemenu--push > .item-back button:after {
      background-color: #959595; }
  .togglemenu--push .togglemenu-logo {
    padding: 0 20px;
    height: 70px;
    border-bottom: 1px solid #4C1E5C; }
    .togglemenu--push .togglemenu-logo img {
      margin-top: 15px;
      height: 40px; }
  .togglemenu--push .togglemenu-menu-footer {
    margin-top: 30px;
    font-weight: normal;
    font-family: "kanit--regular", Arial, sans-serif;
    font-size: 1.063rem; }
    .togglemenu--push .togglemenu-menu-footer li a {
      padding-top: 6px;
      padding-bottom: 6px;
      border: 0; }
      .togglemenu--push .togglemenu-menu-footer li a:hover, .togglemenu--push .togglemenu-menu-footer li a:focus {
        color: #4C1E5C; }

/* States
   ========================================================================== */
.is-togglemenu-submenu-open .togglemenu--push {
  overflow: hidden; }
  .is-togglemenu-submenu-open .togglemenu--push .l-panel > .nav-menu {
    overflow-y: auto; }

.slider {
  position: relative; }
  .slider .slider-item {
    position: relative;
    width: 100%; }
    .slider .slider-item img {
      width: auto; }
    .slider .slider-item > a {
      display: block; }

/* ==========================================================================
   Slideshow.
   ========================================================================== */
.slider--slideshow .row {
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  height: 100%; }

.slider--slideshow .item-media {
  height: 100%; }

.slider--slideshow .item-bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 422px;
  height: 100%; }

.slider--slideshow .item-bg-inner {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  width: 1000px;
  height: 100%;
  overflow: hidden; }
  .slider--slideshow .item-bg-inner .bg-1 {
    position: absolute;
    top: -30%;
    right: 0;
    z-index: 2;
    width: 120px;
    height: 50%;
    background: rgba(76, 30, 92, 0.1);
    -webkit-transform: skew(45deg);
            transform: skew(45deg); }
  .slider--slideshow .item-bg-inner .bg-2 {
    position: absolute;
    top: -160px;
    right: 0;
    z-index: 2;
    width: 300px;
    height: 100%;
    background: rgba(76, 30, 92, 0.1);
    -webkit-transform: skew(45deg);
            transform: skew(45deg); }
  .slider--slideshow .item-bg-inner .bg-3 {
    position: absolute;
    top: 0;
    right: 180px;
    z-index: 2;
    width: 300px;
    height: 100%;
    background: rgba(76, 30, 92, 0.1);
    -webkit-transform: skew(45deg);
            transform: skew(45deg); }

.slider--slideshow .splide__arrows {
  position: absolute;
  left: 50%;
  bottom: 36px;
  z-index: 5;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%); }

.slider--slideshow .splide__arrow {
  position: static;
  opacity: 1;
  border-radius: 50%;
  -webkit-transform: none;
          transform: none; }
  .slider--slideshow .splide__arrow:disabled {
    opacity: .7; }
  .slider--slideshow .splide__arrow + .splide__arrow {
    margin-left: 6px; }

.slider--slideshow .slider-item:first-child .arrow-previous {
  opacity: .5;
  pointer-events: none; }

.slider--slideshow .slider-item:last-child .arrow-next {
  opacity: .5;
  pointer-events: none; }

.slider--slideshow .item-content {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 5;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  padding: 18px 48px;
  width: 422px;
  color: #fff;
  background: rgba(43, 41, 41, 0.45);
  border-top: 9px solid #4C1E5C;
  box-sizing: border-box;
  -webkit-backdrop-filter: blur(19px);
          backdrop-filter: blur(19px); }
  .slider--slideshow .item-content h2,
  .slider--slideshow .item-content h3,
  .slider--slideshow .item-content h4 {
    margin: 0 0 18px;
    color: inherit; }
    .slider--slideshow .item-content h2:not(:first-child),
    .slider--slideshow .item-content h3:not(:first-child),
    .slider--slideshow .item-content h4:not(:first-child) {
      margin-top: 0; }
  .slider--slideshow .item-content a {
    color: inherit; }
  .slider--slideshow .item-content h2 {
    font-size: 1.5rem; }
  .slider--slideshow .item-content h3 {
    font-size: 1.125rem; }

/* ==========================================================================
   Dataviz
   ========================================================================== */
.dataviz-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 6px 10px;
  margin-bottom: 18px;
  background: rgba(76, 30, 92, 0.1);
  border-radius: 4px; }
  .dataviz-header .nav--toolbar {
    margin: 0;
    margin-left: auto; }

.route--datagone-dataviz-tools-expand .dataviz-container {
  padding: 0 48px 18px; }

/* ==========================================================================
   Contenu
   ========================================================================== */
.sitemap-item .block,
.node-body .block {
  padding: 0; }

/* ==========================================================================
   Align
   ========================================================================== */
.text-align-center {
  display: block; }

/* ==========================================================================
   Sidebar(s)
   ========================================================================== */
.node {
  /* Responsive
       ========================================================================== */ }
  .node.l-sidebar > .builder {
    display: flex;
    flex-direction: column; }
  .node .layout--sidebar {
    width: 100%;
    box-sizing: border-box; }
  .node .layout--sidebar--left {
    order: -1;
    margin-left: -10px;
    margin-right: -10px; }
  .node .layout--sidebar--right {
    margin-left: -10px;
    margin-right: -10px; }
  @media all and (min-width: 1280px) {
    .node.l-sidebar > .builder {
      flex-direction: row; }
    .node .layout--sidebar {
      flex-shrink: 0;
      width: 300px; }
    .node .layout--sidebar--left {
      margin-right: 24px; }
    .node .layout--sidebar--right {
      margin-left: 24px; } }

/* ==========================================================================
   Event
   ========================================================================== */
.node--event {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px; }
  .node--event .item-media,
  .node--event .node-body {
    position: relative;
    width: 100%;
    max-width: 100%;
    min-height: 1px;
    box-sizing: border-box;
    margin-bottom: 24px;
    padding-left: 12px;
    padding-right: 12px;
    flex: 0 0 auto;
    max-width: 100%; }
    @media all and (min-width: 768px) {
      .node--event .item-media,
      .node--event .node-body {
        margin-bottom: 24px;
        padding-left: 12px;
        padding-right: 12px;
        flex: 0 0 auto;
        max-width: 50%; } }
  .node--event .item-location {
    display: flex;
    align-items: center; }
    .node--event .item-location .icon {
      margin-right: 8px; }
  .node--event .item-footer {
    flex: 1;
    margin: 18px 0;
    text-align: center; }

/* ==========================================================================
   Comments
   ========================================================================== */
.node-comments-container {
  margin-top: 18px;
  background: #F6F6F6;
  border-radius: 4px; }
  .node-comments-container.is-open .node-comments-content {
    min-height: 70px;
    border-top: 2px solid #fff; }
  .node-comments-container.is-open .list {
    overflow-y: auto; }

.node-comments-header {
  display: flex;
  justify-content: space-between;
  padding: 9px;
  align-items: center;
  /* Responsive
       ========================================================================== */ }
  .node-comments-header .icon {
    margin: 0 19px 0 10px; }
    .node-comments-header .icon:before {
      font-size: 1.25rem; }
  .node-comments-header .form-text {
    display: none;
    margin-right: auto; }
    .node-comments-header .form-text:focus {
      outline: 0;
      border-color: #2B2929;
      box-shadow: inset 0 0 0 1px #2B2929; }
  .node-comments-header .btn, .node-comments-header .pager a, .pager .node-comments-header a,
  .node-comments-header .nav--pager a, .nav--pager .node-comments-header a {
    justify-self: flex-end;
    flex-shrink: 0;
    margin: 0 10px 0 19px; }
    .node-comments-header .btn .item-number, .node-comments-header .pager a .item-number, .pager .node-comments-header a .item-number, .node-comments-header .nav--pager a .item-number, .nav--pager .node-comments-header a .item-number {
      display: inline-block;
      margin-left: 10px;
      padding: 0 6px;
      background: rgba(76, 30, 92, 0.1);
      color: #4C1E5C;
      border-radius: 4px; }
  @media all and (min-width: 500px) {
    .node-comments-header .form-text {
      display: block; } }

.node-comments-content .list {
  max-height: 30vh; }

.node-comments-form-container {
  padding: 18px 48px 1px;
  border-top: 2px solid #fff; }
  .node-comments-form-container .title {
    margin-bottom: 1rem; }

/* ==========================================================================
   Accordion
   ========================================================================== */
.view-mode--accordion {
  padding-bottom: 36px; }
  .view-mode--accordion:empty {
    padding-bottom: 0; }

/* ==========================================================================
   Admin toolbar.
   ========================================================================== */
.node-admin {
  display: flex; }
  .accordion-content > .node-admin {
    margin-top: 18px; }

.node--admin-toolbar,
.datagone-debug {
  position: relative;
  margin: 0 6px 4px 0;
  padding: 10px;
  background: rgba(255, 255, 255, 0.75);
  border: 1px dashed #8e929c;
  border-radius: 2px; }

/* ==========================================================================
   Debug.
   ========================================================================== */
.datagone-debug {
  font-family: monospace;
  font-size: 0.938rem; }
  .datagone-debug:before {
    content: attr(data-label);
    position: absolute;
    top: -8px;
    left: 5px;
    padding: 0 2px;
    font-size: .75em;
    line-height: 1.5em;
    background: #fff;
    border: 1px dotted #8e929c;
    border-radius: 2px; }

/* ==========================================================================
   Tippy
   ========================================================================== */
.tippy-tooltip {
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  color: #959595;
  background: none; }

.tippy-content {
  background-color: #fff;
  border: 1px solid #959595;
  border-radius: 20px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1); }

/* ==========================================================================
   CustomFormSelect
   ========================================================================== */
.customform--select {
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: 100%; }
  .customform--select .customform-select-option-input {
    display: none; }

.customform-select-label {
  position: relative; }

.customform-select-toggle {
  display: block;
  width: 100%;
  padding: 3px 50px 3px 32px;
  text-align: left;
  text-overflow: ellipsis;
  line-height: 63px;
  color: #2B2929;
  font-size: 1.063rem;
  border: 1px solid #4C1E5C;
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
  white-space: nowrap;
  box-sizing: border-box;
  transition: .2s; }
  .customform-select-toggle:after {
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 21px;
    color: #4C1E5C;
    font-size: 0.688rem;
    transition: .2s; }

.customform-select-options {
  position: absolute;
  z-index: -1;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  max-height: 0;
  overflow: hidden;
  background: #fff;
  border: 1px solid #4C1E5C;
  border-top: 0;
  border-radius: 0 0 10px 10px;
  opacity: 0;
  transition: .2s;
  box-sizing: border-box; }

.customform-select-optiongroup-label,
.customform-select-optiongroup,
.customform-select-option {
  display: block; }

.customform-select-option {
  padding: 11px 32px;
  color: #2B2929;
  transition: .2s;
  outline: 0; }
  .customform-select-option:not(.is-disabled):not(.is-selected):hover {
    color: #4C1E5C;
    background-color: rgba(76, 30, 92, 0.1); }
  .customform-select-option.is-selected {
    color: #4C1E5C;
    background-color: rgba(76, 30, 92, 0.1); }

.customform-select-option-label {
  margin: 0;
  color: inherit;
  font-size: 1.063rem;
  cursor: inherit;
  white-space: nowrap; }

.customform-select-optiongroup {
  padding: 0; }

.customform-select-optiongroup-label {
  padding: 22px 32px;
  font-style: italic;
  background-color: #f2f2f2;
  cursor: default; }

.customform-select-optiongroup .customform-select-option {
  padding-left: 42px; }

/* Main states
   ========================================================================== */
.customform--select.is-open .customform-select-toggle,
.customform--select:not(.is-disabled):hover .customform-select-toggle {
  cursor: pointer; }

.customform--select.is-open .customform-select-toggle {
  color: #fff;
  background-color: #4C1E5C;
  border-radius: 10px 10px 0 0; }
  .customform--select.is-open .customform-select-toggle:after {
    color: inherit;
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }

.customform--select.is-open .customform-select-options {
  z-index: 50;
  max-height: 280px;
  opacity: 1;
  overflow-y: auto; }

.customform--select.is-multiple .customform-select-option {
  display: flex;
  align-items: center;
  padding-left: 32px;
  padding-right: 32px; }
  .customform--select.is-multiple .customform-select-option:before {
    content: "\2714";
    flex-shrink: 0;
    width: 12px;
    height: 12px;
    line-height: 12px;
    margin-right: 21px;
    border: 1px solid #4C1E5C;
    color: transparent; }
  .customform--select.is-multiple .customform-select-option.is-selected {
    color: #4C1E5C;
    background: transparent; }
    .customform--select.is-multiple .customform-select-option.is-selected .customform-select-option-label {
      font-weight: normal;
      font-family: "kanit--semibold", Arial, sans-serif; }
    .customform--select.is-multiple .customform-select-option.is-selected:before {
      color: #4C1E5C; }
  .customform--select.is-multiple .customform-select-option.is-focused {
    color: #4C1E5C; }
  .customform--select.is-multiple .customform-select-option.is-first {
    display: none; }

/* ==========================================================================
   OVERRIDES
   ========================================================================== */
/* ==========================================================================
   GLOBAL
   ========================================================================== */
.cke_editable {
  margin: 0;
  padding: 24px;
  max-width: none;
  background-color: #fff;
  box-sizing: border-box; }

.cke_reset_all.cke_dialog_container .cke_dialog_body {
  width: 400px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%); }

.cke_reset_all.cke_dialog_container .cke_dialog_contents tr:nth-of-type(2n) td {
  background: none; }

.cke_reset_all.cke_dialog_container .cke_dialog_contents #icon-preview {
  position: absolute;
  right: 30px;
  top: 100px; }

#skip-link {
  margin: 0; }

.ajax-progress {
  display: none; }

/* ==========================================================================
   TABS PRIMARY + SECONDARY
   ========================================================================== */
.tabs-wrapper {
  position: fixed;
  width: 120px;
  height: 120px;
  z-index: 125;
  left: 0;
  bottom: 0;
  transition: left .2s; }
  .tabs-wrapper:focus .tabs--primary, .tabs-wrapper:hover .tabs--primary {
    opacity: 1;
    visibility: visible; }
  @media all and (min-width: 768px) {
    .l-menu-dashboard .tabs-wrapper {
      left: 72px; }
    .l-menu-dashboard-open .tabs-wrapper {
      left: 192px; } }
  .route--user-login .tabs-wrapper,
  .route--user-pass .tabs-wrapper {
    display: none; }

.tabs--primary-toggle {
  position: absolute;
  z-index: 25;
  left: 24px;
  bottom: 24px;
  padding: 15px;
  width: 60px;
  height: 60px;
  background: #4C1E5C;
  border-radius: 50%;
  text-align: center;
  box-sizing: border-box;
  box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.15);
  transition: .2s; }
  .tabs--primary-toggle:before {
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #fff;
    font-size: 1.25rem; }

.tabs--primary {
  position: absolute;
  z-index: 5;
  bottom: 68px;
  left: 58px;
  display: flex;
  flex-direction: column-reverse;
  margin: 0;
  padding: 9px 0;
  min-width: 150px;
  font-weight: normal;
  font-family: "kanit--semibold", Arial, sans-serif;
  background: #fff;
  border-radius: 4px;
  font-size: 1.125rem;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);
  opacity: 0;
  visibility: hidden;
  transition: .3s; }
  .tabs--primary li {
    display: block;
    float: none;
    width: 100%;
    margin-bottom: -1px;
    background: none; }
    .tabs--primary li a {
      display: block;
      padding: 8px 20px;
      color: #959595;
      line-height: 1.3;
      background: none;
      transition: .3s; }
      .tabs--primary li a:focus, .tabs--primary li a:hover, .tabs--primary li a.is-active {
        color: #4C1E5C; }
      .tabs--primary li a:focus, .tabs--primary li a:hover {
        background-color: rgba(76, 30, 92, 0.1); }

/* ==========================================================================
   BLOC ADMIN
   ========================================================================== */
.block-form .form-item-settings-admin-label,
.block-form .form-item-settings-label,
.block-form .form-item-settings-label-display,
.block-form .js-form-type-vertical-tabs,
.block-form .js-form-type-machine-name,
.block-form .form-item-region {
  display: none; }

.block-form .form-wrapper .form-wrapper {
  background-color: #fff; }

.block-form details.form-wrapper {
  border: 1px solid #8e929c;
  border-radius: 4px; }
  .block-form details.form-wrapper summary {
    padding: 10px 24px;
    font-weight: bold;
    cursor: pointer;
    transition: background-color .2s; }
  .block-form details.form-wrapper[open] summary {
    margin-bottom: 10px; }
  .block-form details.form-wrapper[open] summary,
  .block-form details.form-wrapper summary:hover {
    background-color: #fff; }
  .block-form details.form-wrapper > .form-item {
    margin-left: 24px;
    margin-right: 24px; }

.btn--block-admin {
  background-color: transparent;
  color: #4C1E5C; }
  .btn--block-admin:after {
    display: inline-block;
    font-family: "icons-1712325806";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-left: .8em; }

/* ==========================================================================
   DEBUG DRUPAL
   ========================================================================== */
pre.sf-dump,
pre.sf-dump .sf-dump-default {
  text-align: left;
  z-index: 0; }

/* ==========================================================================
   FORM PREVIEW
   ========================================================================== */
.node-preview-container {
  bottom: 0;
  background-color: #4C1E5C; }
  .node-preview-container a {
    padding: 6px;
    color: #fff; }

.node-preview-form-select {
  margin: 0; }
  .node-preview-form-select .js-form-item-view-mode {
    display: none; }

/* ==========================================================================
   Contextual links
   ========================================================================== */
.toolbar .toolbar-tab.contextual-toolbar-tab,
.contextual {
  display: none; }

.layout-builder .contextual {
  display: inline; }

.clearfix::after {
  display: block;
  clear: both;
  content: ""; }

.is-visually-hidden,
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  border: 0; }

.sr-only-focusable:active, .sr-only-focusable:focus {
  position: static;
  width: auto;
  height: auto;
  overflow: visible;
  clip: auto;
  white-space: normal;
  -webkit-clip-path: none;
          clip-path: none; }

/* ==========================================================================
   Saut de page
   ========================================================================== */
.block--space:before, .block--space:after {
  display: none; }

.page--print .block--space:before, .page--print .block--space:after,
.layout-builder__section .block--space:before,
.layout-builder__section .block--space:after {
  display: block; }

/* ==========================================================================
   Sidebar
   ========================================================================== */
.fixer-sidebar-container.is-fixed .fixer-sidebar-element, .fixer-sidebar-container.is-bottom .fixer-sidebar-element {
  position: fixed;
  top: 190px;
  border-radius: 0; }

.fixer-sidebar-container.is-fixed.toolbar-fixed .fixer-sidebar-element, .fixer-sidebar-container.is-bottom.toolbar-fixed .fixer-sidebar-element {
  top: 229px; }

.fixer-sidebar-container.is-fixed.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .fixer-sidebar-element, .fixer-sidebar-container.is-bottom.toolbar-fixed.toolbar-horizontal.toolbar-tray-open .fixer-sidebar-element {
  top: 268px; }

/* ==========================================================================
   Comments
   ========================================================================== */
.is-comments-hidden .node-comments-container {
  display: none; }

/* ==========================================================================
   Primary
   ========================================================================== */
.cke_dialog_ui_html .icon.theme-primary .icon:before, .cke_dialog_ui_html .icon.theme-primary,
.theme-primary .icon:before,
.theme-primary {
  color: #4C1E5C; }

path.theme-primary {
  fill: #4C1E5C; }

/* ==========================================================================
   Bannière
   ========================================================================== */
.l-banner .nav--main,
.l-banner .nav--main a {
  color: #fff; }

.l-banner .nav--main .nav-item.level-1 > a span:after {
  background: #fff; }

.l-banner .nav--dropdown .nav-toggle {
  background: none; }
  .l-banner .nav--dropdown .nav-toggle .icon {
    color: #fff; }

.l-banner .nav--dropdown.is-open .nav-toggle .icon,
.l-banner .nav--dropdown .nav-toggle:hover .icon,
.l-banner .nav--dropdown .nav-toggle:focus .icon {
  color: #fff;
  background-color: rgba(255, 255, 255, 0.25); }

.l-banner .btn--togglemenu:active, .l-banner .btn--togglemenu.is-active, .l-banner .btn--togglemenu:focus, .l-banner .btn--togglemenu:hover,
a:focus .l-banner .btn--togglemenu,
a:hover .l-banner .btn--togglemenu {
  background-color: rgba(255, 255, 255, 0.25); }

.l-banner .btn--togglemenu .part {
  background: #fff; }

/* ==========================================================================
   Background primary
   ========================================================================== */
.spinner--overlay.l-spinner .spinner-wrapper-inner,
.spinner--inline.l-spinner .spinner-wrapper-inner,
.theme-bg-primary {
  background-color: #4C1E5C; }
  .spinner--overlay.l-spinner .spinner-wrapper-inner,
  .spinner--overlay.l-spinner .spinner-wrapper-inner a,
  .spinner--inline.l-spinner .spinner-wrapper-inner,
  .spinner--inline.l-spinner .spinner-wrapper-inner a,
  .theme-bg-primary,
  .theme-bg-primary a {
    color: #fff; }

.nav--children .theme-bg-primary {
  background-color: #4C1E5C;
  border-color: #4C1E5C; }
  .nav--children .theme-bg-primary,
  .nav--children .theme-bg-primary .item-title,
  .nav--children .theme-bg-primary a {
    color: #fff; }
    .nav--children .theme-bg-primary:hover, .nav--children .theme-bg-primary:focus,
    .nav--children .theme-bg-primary .item-title:hover,
    .nav--children .theme-bg-primary .item-title:focus,
    .nav--children .theme-bg-primary a:hover,
    .nav--children .theme-bg-primary a:focus {
      color: #fff; }
  .nav--children .theme-bg-primary .item-title:after {
    background-color: #fff; }

/* ==========================================================================
   Background secondary
   ========================================================================== */
.theme-bg-secondary {
  background-color: rgba(76, 30, 92, 0.1); }
  .theme-bg-secondary,
  .theme-bg-secondary a {
    color: #4C1E5C; }

.nav--children .theme-bg-secondary .item-keyfacts b,
.nav--children .theme-bg-secondary .item-keyfacts strong {
  color: #4C1E5C; }

/* Background gray
   ========================================================================== */
.theme-bg-muted {
  background: no-repeat url("/themes/custom/frontend_tertiary/images/pattern-white.svg") right bottom #F6F6F6; }

.theme-bg-tertiary {
  background-color: #2B2929; }
  .theme-bg-tertiary h2,
  .theme-bg-tertiary h3,
  .theme-bg-tertiary h4,
  .theme-bg-tertiary p {
    color: #fff; }
  .theme-bg-tertiary .list--primary .item-title {
    color: #fff; }
  .theme-bg-tertiary .btn, .theme-bg-tertiary .pager a, .pager .theme-bg-tertiary a,
  .theme-bg-tertiary .nav--pager a, .nav--pager .theme-bg-tertiary a {
    color: #fff; }

/* ==========================================================================
   Background dark.
   ========================================================================== */
.theme-dark .btn, .theme-dark .pager a, .pager .theme-dark a,
.theme-dark .nav--pager a, .nav--pager .theme-dark a,
.main-footer .btn,
.main-footer .pager a,
.pager .main-footer a,
.main-footer .nav--pager a,
.nav--pager .main-footer a {
  color: #fff; }

/* ==========================================================================
   Font DataGone générée par Gulp
========================================================================== */
@font-face {
  font-family: "icons-1749032404";
  font-weight: normal;
  font-style: normal;
  src: url("../../config/icons/font/icons-1749032404.woff2?v=1749032404") format("woff2"), url("../../config/icons/font/icons-1749032404.woff?v=1749032404") format("woff"), url("../../config/icons/font/icons-1749032404.svg?v=1749032404") format("svg"); }

.icon,
.icon:before {
  display: inline-block;
  font-family: "icons-1749032404";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.icon--ampoule:before, .node-body .item-keyfacts.pour_comprendre:before {
  content: "\EA01"; }

.icon--autre:before {
  content: "\EA02"; }

.icon--bus:before {
  content: "\EA03"; }

.icon--caret-square-left:before {
  content: "\EA04"; }

.icon--caret-square-right:before {
  content: "\EA05"; }

.icon--checked:before, .dataviz-form .radioFilter.icon-button input[type="radio"]:checked + label:before, .dataviz-form .radioFilter.icon-button input[type="checkbox"]:checked + label:before {
  content: "\EA06"; }

.icon--chrono:before {
  content: "\EA07"; }

.icon--co2:before {
  content: "\EA08"; }

.icon--day_time:before {
  content: "\EA09"; }

.icon--default:before {
  content: "\EA0A"; }

.icon--default1:before {
  content: "\EA0B"; }

.icon--default2:before {
  content: "\EA0C"; }

.icon--deplacement:before {
  content: "\EA0D"; }

.icon--deplacement_domicile_travail:before {
  content: "\EA0E"; }

.icon--deplacement_interne:before {
  content: "\EA0F"; }

.icon--deplacement_one_pers:before {
  content: "\EA10"; }

.icon--deplacement_primaire:before {
  content: "\EA11"; }

.icon--diesel:before {
  content: "\EA12"; }

.icon--distance:before {
  content: "\EA13"; }

.icon--driver:before {
  content: "\EA14"; }

.icon--en_savoir_plus:before {
  content: "\EA15"; }

.icon--equipement_2rm:before {
  content: "\EA16"; }

.icon--equipement_velo:before {
  content: "\EA17"; }

.icon--fleche_down:before {
  content: "\EA18"; }

.icon--fleche_up:before {
  content: "\EA19"; }

.icon--home:before {
  content: "\EA1A"; }

.icon--information:before {
  content: "\EA1B"; }

.icon--livre:before, .node-body .item-keyfacts.definition:before {
  content: "\EA1C"; }

.icon--map-signs:before {
  content: "\EA1D"; }

.icon--menage:before {
  content: "\EA1E"; }

.icon--menage_one_pers:before {
  content: "\EA1F"; }

.icon--modes-motorise:before {
  content: "\EA20"; }

.icon--modes_actifs:before {
  content: "\EA21"; }

.icon--modes_marche:before {
  content: "\EA22"; }

.icon--no_car:before {
  content: "\EA23"; }

.icon--no_velo:before {
  content: "\EA24"; }

.icon--permis_de_conduire:before {
  content: "\EA25"; }

.icon--population:before {
  content: "\EA26"; }

.icon--rythme:before {
  content: "\EA27"; }

.icon--taux_motorisation:before {
  content: "\EA28"; }

.icon--tramway:before {
  content: "\EA29"; }

.icon--unchecked:before, .dataviz-form .radioFilter.icon-button input[type="radio"] + label:before, .dataviz-form .radioFilter.icon-button .dataviz-form input[type="checkbox"] + label:before {
  content: "\EA2A"; }

.icon--velo:before {
  content: "\EA2B"; }

.icon--voiture-conducteur:before {
  content: "\EA2C"; }

.icon--voiture:before {
  content: "\EA2D"; }

.icon--voiture_conducteur:before {
  content: "\EA2E"; }

.icon--voiture_passager:before {
  content: "\EA2F"; }

.icon--warning:before {
  content: "\EA30"; }

.icon--window-close:before {
  content: "\EA31"; }

@font-face {
  font-family: "gotham-book";
  src: url("/sites/emc2-smtcac/files/fonts/gotham-book-webfont.woff2"); }

@font-face {
  font-family: "MonumentExtended-Ultrabold";
  src: url("/sites/emc2-smtcac/files/fonts/MonumentExtended-Ultrabold.woff2"); }

.node-body {
  font-family: "Poppins";
  font-size: 0.875rem;
  color: black; }

body {
  font-family: "Poppins"; }

.logo--primary {
  margin: 0; }
  .logo--primary img[src*=".svg"] {
    height: 150px;
    max-height: 150px; }

.content-body {
  margin-bottom: 0;
  min-height: 800px; }

.cookienotice-btn {
  background: #4C1E5C;
  color: white; }

.node-comments-container .node-comments-header {
  padding: 0; }

.node-comments-container .node-comments-header .form-text {
  font-size: 0.875rem; }

.node-comments-container .item-title {
  font-size: 0.875rem; }

.node-comments-container .form-text {
  height: 30px;
  padding: 10px; }

.node.node--page.node--1 h2 {
  margin-top: 30px; }

.node.node--page.node--1 .layout {
  background: #efeef3; }

.node.node--page.node--1 .layout.entete {
  padding: 20px 50px; }

.node.node--page.node--1 .layout.fond {
  background-image: url("/sites/emc2-smtcac/files/svgs/fond.svg"); }

.layout.mise-en-avant {
  background: #efeef3;
  background-image: url("/sites/emc2-smtcac/files/svgs/fond.svg");
  color: #4C1E5C;
  padding: 50px;
  font-weight: bold; }

.main-header-navigation .row--full {
  background: #4C1E5C; }

.nav--main .nav-menu.level-1 {
  justify-content: center; }

.nav--main .nav-item.level-1 > a {
  background: #4C1E5C;
  color: #ffffff; }

.nav--main .nav-item.level-1 {
  border-right: 1px solid #fff;
  border-left: 1px solid #fff;
  margin-left: 0;
  color: white; }
  .nav--main .nav-item.level-1 span {
    padding: 10px 20px; }

.nav--detail .nav-item.is-active-trail > a {
  background: #D4E868;
  color: #000000; }

.nav--main .nav-item.level-1:hover > a, .nav--main .nav-item.level-1.is-active-trail > a,
.nav--main .nav-item.level-1:hover > span, .nav--main .nav-item.level-1.is-active-trail > span {
  background: #D4E868;
  color: #000000; }

.nav--main .nav-menu.level-2, .nav--main .nav-menu.level-3 {
  display: block;
  border: 1px solid white;
  background: #4C1E5C; }
  .nav--main .nav-menu.level-2 a, .nav--main .nav-menu.level-3 a {
    color: white; }

.nav--main .nav-menu.level-2 a.edito {
  display: none; }

.nav--main .nav-menu.level-3 {
  width: 450px; }

.nav--main .nav-item.level-2:hover > a, .nav--main .nav-item.level-2.is-active-trail > a,
.nav--main .nav-item.level-3:hover > a, .nav--main .nav-item.level-3.is-active-trail > a,
.nav--main .nav-item.level-4:hover > a, .nav--main .nav-item.level-4.is-active-trail > a {
  background: #D4E868;
  color: #000000; }

.nav--main .nav-menu.level-2::before {
  border-color: transparent transparent #4C1E5C; }

.content-builder-sidebar {
  background: none; }

@media (min-width: 768px) {
  .content-builder-sidebar-inner {
    position: fixed;
    height: 90%;
    margin-top: 18px;
    padding-right: 12px;
    width: 280px;
    overflow-y: auto;
    overflow-x: hidden; } }

.btn--togglemenu .part {
  background-color: white; }

.togglemenu--push .l-panel .item-back .item-title a {
  background: #D4E868;
  color: #4C1E5C; }

.nav--detail .nav-item a {
  background: #E4DDE7; }

.nav--detail .nav-menu .nav-menu::after {
  display: none; }

.nav--detail .nav-item a:hover,
.nav--detail .nav-item a:focus {
  color: #4C1E5C;
  background: #D4E868; }

.block--menu-reference.nav .nav-item.level-1 .edito {
  display: none; }

.block--menu-reference.nav .item-title {
  display: inline-flex;
  align-items: center;
  width: inherit;
  height: 100%;
  box-sizing: border-box;
  line-height: 1;
  color: #4C1E5C;
  font-size: 1em;
  font-weight: normal; }

.block--menu-reference.nav .l-accordion.nav-item.level-2 > span > .item-title, .block--menu-reference.nav .l-accordion.nav-item.level-1 > span > .item-title {
  padding: 9px 48px;
  background: #E4DDE7; }

.block--menu-reference.nav .is-active {
  color: #4C1E5C;
  background: #D4E868; }

.block.block--image::before {
  display: none; }

.node-body .item-keyfacts.definition {
  display: flex;
  flex-direction: row;
  align-items: center;
  min-height: 40px;
  background: none;
  color: #C92E56;
  padding: 5px;
  text-align: left;
  font-size: 1.1em; }
  .node-body .item-keyfacts.definition:before {
    display: inline-block;
    font-family: "icons-1749032404";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "icons-1749032404";
    font-size: 2em;
    margin-right: 10px; }

.dataviz .dataviz-footer .dataviz-body {
  padding-left: 80px;
  margin-top: 15px; }

.node-body .item-keyfacts.pour_comprendre {
  margin-top: 10px;
  line-height: 1;
  color: #4C1E5C;
  display: contents;
  margin-left: 35px; }
  .node-body .item-keyfacts.pour_comprendre:before {
    display: block;
    position: absolute;
    margin-left: -35px;
    display: inline-block;
    font-family: "icons-1749032404";
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    speak: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "icons-1749032404";
    font-size: 2em;
    margin-right: 10px;
    vertical-align: middle;
    color: #4C1E5C; }
  .node-body .item-keyfacts.pour_comprendre p {
    margin: 0; }

.node-body .item-keyfacts.warning-text {
  display: flow-root;
  background: #ffe6d5;
  color: #ff9955;
  padding: 5px;
  text-align: left;
  font-style: italic;
  min-height: 50px; }
  .node-body .item-keyfacts.warning-text strong {
    display: contents;
    font-size: 1em; }
  .node-body .item-keyfacts.warning-text strong::after {
    display: none; }
  .node-body .item-keyfacts.warning-text .icon {
    margin: 0px 15px; }

.node-body .item-keyfacts.graph-text-value {
  min-height: 40px;
  background: #E4DDE7;
  color: #4C1E5C;
  padding: 5px;
  text-align: left; }
  .node-body .item-keyfacts.graph-text-value strong {
    display: contents;
    font-size: 1em; }
  .node-body .item-keyfacts.graph-text-value strong::after {
    display: none; }

.node-body .item-push.push--secondary {
  background: #E4DDE7;
  color: #4C1E5C;
  padding: 20px;
  text-align: left; }

.builder-row.l-background.page-acceuil .block--richtext {
  margin: 216px 96px 50px;
  padding: 20px 48px 20px;
  width: 600px; }

.list.list--page-selection .item-header {
  min-height: 50px; }

.list.list--page-selection .item-title {
  font-family: "Poppins"; }

.list.list--page-selection .item-content {
  padding: 50px 0 0; }

.list.list--page-selection .dataviz {
  margin: 0; }

.list.list--page-selection .icon::before {
  font-size: 5em; }

.list.list--page-selection .item-footer {
  height: 385px; }
  .list.list--page-selection .item-footer .btn, .list.list--page-selection .item-footer .pager a, .pager .list.list--page-selection .item-footer a,
  .list.list--page-selection .item-footer .nav--pager a, .nav--pager .list.list--page-selection .item-footer a {
    top: 0; }

.page .builder-row {
  margin-top: 0;
  margin-bottom: 0; }

.page .content-header .content-titles .content-title {
  font-family: "Poppins";
  font-size: 2em;
  font-weight: bold;
  color: #4C1E5C; }

.page .content-title::before {
  display: none; }

.page .field-body p {
  margin: 0px; }

.page .field-body .content-title {
  font-size: 2em;
  font-weight: bold;
  color: #4C1E5C; }

.page .field-body .content-title::before {
  display: none; }

.page .field-body h2 {
  margin-top: 60px;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column-reverse;
  font-family: "Poppins";
  font-size: 1.8em;
  color: #4C1E5C;
  font-weight: bold; }

.page .field-body h2::before {
  display: none; }

.page .field-body h3 {
  font-family: "Poppins";
  font-size: 1.4em;
  color: #4C1E5C;
  font-weight: bold; }

.page .field-body h3::before {
  display: none; }

.page .field-body h4 {
  font-family: "Poppins";
  font-size: 1.2em;
  margin: 0 0 1em; }
  .page .field-body h4:after {
    display: inline-block;
    margin: 0 0 0px 0px;
    height: 1px;
    content: " ";
    text-shadow: none;
    background-color: #656A6E;
    width: 100%; }

.page .layout.color-primary {
  background: #E4DDE7;
  color: #4C1E5C;
  padding: 25px 0; }

strong {
  font-family: "Poppins";
  font-weight: bold; }

.block.block--nav-summary {
  font-family: "Poppins";
  font-size: 1em; }
  .block.block--nav-summary .nav-item.is-active {
    font-weight: bold;
    color: #4C1E5C; }
  .block.block--nav-summary .nav-item:not(.l-accordion):hover, .block.block--nav-summary .nav--summary .nav-item:not(.l-accordion):focus {
    text-decoration: underline;
    color: #000000; }

.nav--children .item-title {
  font-family: "Poppins";
  font-size: 1.7em;
  margin: 0; }

.dataviz .select-secteur p {
  margin: 0.5em 0;
  color: white; }

.dataviz {
  margin: 18px auto; }

.dataviz.category--modeles header {
  margin-bottom: 24px; }

.dataviz.category--modeles .dataviz-header {
  background: none;
  border-bottom: 3px solid #4C1E5C;
  border-radius: 0;
  font-weight: bold; }

.dataviz.category--modeles .title--dataviz {
  font-size: 1.35em; }

.dataviz.category--modele-2 .dataviz-sidebar-container {
  display: flex;
  flex-direction: row; }

.dataviz.category--modele-2 .dataviz-container {
  width: 75%; }

.dataviz.category--modele-2 .dataviz-sidebar {
  padding: 6px; }

.dataviz.category--modele-3 .dataviz-sidebar-container {
  display: flex;
  flex-direction: row-reverse; }

.dataviz.category--modele-3 .dataviz-container {
  width: 75%; }

.dataviz.category--modele-3 .dataviz-sidebar {
  padding: 6px; }

.dataviz.category--modele-1-1 .dataviz-sidebar-container {
  display: flex;
  flex-direction: column; }

.dataviz.category--modele-1-1 .dataviz-container {
  width: 100%; }

.dataviz.category--modele-1-1 .dataviz-sidebar {
  padding: 6px;
  width: 100%; }

.dataviz.category--modele-1-2 .dataviz-sidebar-container {
  display: flex;
  flex-direction: column-reverse; }

.dataviz.category--modele-1-2 .dataviz-container {
  width: 100%; }

.dataviz.category--modele-1-2 .dataviz-sidebar {
  padding: 6px;
  width: 100%; }

.dataviz-sub-container .dataviz header {
  display: none; }

p.dataviz_source {
  color: #000000;
  width: 100%; }

.dataviz p.not-representative {
  color: #ff9955;
  font-style: italic;
  font-size: 0.8em; }

.dataviz text.not-representative {
  fill: #ff9955;
  font-style: italic;
  font-size: 0.8em; }

.layout--onecol .dataviz.category--chiffre-cle {
  margin: 0; }

.dataviz .keynumber.style1 {
  background: #E4DDE7;
  color: #4C1E5C;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: center; }
  .dataviz .keynumber.style1 .prefixtext {
    font-size: 1.3em; }
  .dataviz .keynumber.style1 .text {
    font-family: "Poppins";
    text-align: center;
    font-size: 0.938rem; }
    .dataviz .keynumber.style1 .text .title {
      font-size: 1.2em;
      font-weight: bold; }
    .dataviz .keynumber.style1 .text strong {
      font-family: "Poppins";
      display: block;
      font-size: 3em;
      font-weight: bold; }
    .dataviz .keynumber.style1 .text b {
      font-family: "Poppins";
      font-weight: bold; }
    .dataviz .keynumber.style1 .text .icon {
      font-size: 1.8em;
      vertical-align: middle; }
  .dataviz .keynumber.style1 .title {
    margin-top: 25px;
    font-weight: bold; }
  .dataviz .keynumber.style1 .sufixtext {
    margin-bottom: 25px;
    font-family: "Poppins"; }
    .dataviz .keynumber.style1 .sufixtext b {
      font-family: "Poppins";
      font-weight: bold; }

.dataviz.category--menu {
  z-index: 50;
  position: inherit; }
  .dataviz.category--menu .title {
    font-family: "Poppins";
    font-weight: bold;
    line-height: 1.1;
    color: #4C1E5C;
    text-transform: uppercase; }
    .dataviz.category--menu .title .sub-title {
      text-transform: initial;
      font-style: italic;
      font-size: 0.8em; }
  .dataviz.category--menu .menu-secteur {
    color: #4C1E5C;
    font-weight: bold; }
  .dataviz.category--menu .typeahead__filter-button {
    color: #4C1E5C; }
  .dataviz.category--menu .lib-search-epci {
    color: #4C1E5C;
    font-style: italic;
    cursor: pointer;
    font-size: 0.8em; }
  .dataviz.category--menu .btn.icon, .dataviz.category--menu .pager a.icon, .pager .dataviz.category--menu a.icon,
  .dataviz.category--menu .nav--pager a.icon, .nav--pager .dataviz.category--menu a.icon {
    font-size: 2.5em;
    color: #4C1E5C;
    line-height: 1;
    background: none;
    padding: 0; }
  .dataviz.category--menu .btn:hover, .dataviz.category--menu .pager a:hover, .pager .dataviz.category--menu a:hover,
  .dataviz.category--menu .nav--pager a:hover, .nav--pager .dataviz.category--menu a:hover {
    background: #4C1E5C; }
  .dataviz.category--menu .btn.icon:hover, .dataviz.category--menu .pager a.icon:hover, .pager .dataviz.category--menu a.icon:hover,
  .dataviz.category--menu .nav--pager a.icon:hover, .nav--pager .dataviz.category--menu a.icon:hover {
    color: #ffffff; }

.dataviz .keynumber.style1 {
  margin: 8px; }
  .dataviz .keynumber.style1 strong {
    font-size: 2em;
    font-weight: bold; }

.keynumber.text.style1 {
  padding: 25px 0 25px 0;
  background: #4C1E5C;
  display: flex;
  flex-direction: column;
  text-align: center;
  color: white; }
  .keynumber.text.style1 .title {
    margin-bottom: 15px;
    color: white; }
  .keynumber.text.style1 .icon {
    background-color: white;
    border-radius: 50%;
    color: #4C1E5C;
    width: 100px; }
  .keynumber.text.style1 .icon::before {
    -webkit-transform: translateX(9px);
            transform: translateX(9px); }
  .keynumber.text.style1 .number {
    font-size: 1.8em;
    font-weight: bold;
    color: white; }
  .keynumber.text.style1 .text {
    font-weight: bold;
    margin-bottom: 15px;
    color: white; }
  .keynumber.text.style1 .sufixtext {
    color: white; }

.dataviz-header .title.title--dataviz .replace--text.icon {
  font-size: 2em;
  line-height: 0.75; }

.dataviz-sidebar-container {
  display: flex; }
  .dataviz-sidebar-container .dataviz-container {
    flex: 1;
    width: 75%; }
  .dataviz-sidebar-container .dataviz-sidebar {
    width: 25%;
    padding: 0px 0 0 24px; }

.dataviz.category--dataviz-modele-2 .dataviz-sidebar-container {
  flex-direction: column-reverse; }

.dataviz.category--dataviz-modele-2 .dataviz-container {
  width: 100%; }

.dataviz.category--dataviz-modele-2 .dataviz-sidebar {
  width: 100%; }

.dataviz.category--dataviz-modele-3 .dataviz-sidebar-container {
  flex-direction: column; }

.dataviz.category--dataviz-modele-3 .dataviz-container {
  width: 100%; }

.dataviz.category--dataviz-modele-3 .dataviz-sidebar {
  width: 100%; }

.dataviz.category--dataviz-modele-1 .dataviz-sidebar {
  display: flex;
  flex-direction: column;
  justify-content: space-between; }

.dataviz.category--dataviz-modele-1 .dataviz-form--prefix {
  display: none; }

.dataviz .source {
  font-size: 0.8em;
  font-style: italic;
  fill: #000000; }

.dataviz .dataviz-form--suffix {
  margin-top: 10px; }

.dataviz .legend .legend-icon, .dataviz .legend-div .legend-icon {
  font-size: 1.5rem; }

.dataviz .legend .legend-text, .dataviz .legend-div .legend-text {
  font-size: 1em;
  fill: #000000; }

.dataviz .legend .legend-value, .dataviz .legend-div .legend-value {
  font-size: 0.9em;
  dominant-baseline: auto;
  font-style: italic; }

.dataviz .legend .legend-title, .dataviz .legend-div .legend-title {
  font-style: italic;
  font-size: 0.8em;
  fill: #cccccc; }

.dataviz-form .form-align, .dataviz-form .first, .dataviz-form .second {
  display: block; }
  .dataviz-form .form-align .buttonFilter, .dataviz-form .first .buttonFilter, .dataviz-form .second .buttonFilter {
    margin-right: 10px; }

.dataviz-form .form-align, .dataviz-form .first-align {
  display: flex;
  flex-direction: row;
  justify-content: space-between; }

.buttonFilter.radioFilter .radioFilter--label {
  margin: 0px; }

.buttonFilter.radioFilter .radioFilter--groupcontent {
  display: flex; }

.buttonFilter.radioFilter .radioFilter--content {
  display: block ruby; }

.dataviz-form.top {
  display: flex;
  justify-content: space-between; }
  .dataviz-form.top .topleft {
    display: flex; }
    .dataviz-form.top .topleft .buttonFilter {
      margin-right: 10px; }
  .dataviz-form.top .topright {
    display: flex; }
    .dataviz-form.top .topright .buttonFilter {
      margin-right: 10px; }

.dataviz-form .buttonFilter.dropdownFilter {
  margin-top: 5px;
  margin-bottom: 10px; }
  .dataviz-form .buttonFilter.dropdownFilter select {
    background: none;
    border: none;
    color: #4C1E5C;
    padding: 5px;
    border-top: 1px solid #4C1E5C; }
  .dataviz-form .buttonFilter.dropdownFilter label {
    font-family: "Poppins";
    color: #4C1E5C;
    font-weight: bold;
    font-size: 1em;
    margin-bottom: 0px; }

.dataviz-sidebar .dataviz-form .buttonFilter.dropdownFilter select {
  max-width: 250px; }

.dataviz-form .select_type_motif {
  width: 100%;
  padding: 0px;
  background: none;
  color: #4C1E5C;
  display: flex;
  flex-direction: row;
  justify-content: right; }

.dataviz-form .buttonFilter.radioFilter--label {
  margin: 0 0 0px; }

.dataviz-form .radioFilter.tabs {
  margin: 0 10px 0 0px; }
  .dataviz-form .radioFilter.tabs .radioFilter--groupcontent {
    display: flex;
    padding-left: 0px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content; }
  .dataviz-form .radioFilter.tabs .radioFilter--content {
    display: flex;
    overflow: hidden;
    border-radius: 0em 15px 0 0em;
    background: #E4DDE7;
    border: 1px solid #4C1E5C; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(1) {
    z-index: 6; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(2) {
    -webkit-transform: translateX(-12.5px);
            transform: translateX(-12.5px);
    z-index: 5; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(3) {
    -webkit-transform: translateX(-25px);
            transform: translateX(-25px);
    z-index: 4; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(4) {
    -webkit-transform: translateX(-37.5px);
            transform: translateX(-37.5px);
    z-index: 3; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(5) {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    z-index: 2; }
  .dataviz-form .radioFilter.tabs .radioFilter--content:nth-child(6) {
    -webkit-transform: translateX(-62.5px);
            transform: translateX(-62.5px);
    z-index: 1; }
  .dataviz-form .radioFilter.tabs input {
    position: absolute !important;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    width: 1px;
    border: 0;
    overflow: hidden; }
  .dataviz-form .radioFilter.tabs label {
    margin: 12px 15px 12px 25px;
    color: #4C1E5C;
    font-size: 0.95em;
    font-weight: normal;
    line-height: 1;
    text-align: center;
    transition: all 0.1s ease-in-out; }
  .dataviz-form .radioFilter.tabs label:hover {
    cursor: pointer; }
  .dataviz-form .radioFilter.tabs .radioFilter--content.selected {
    background-color: #4C1E5C; }
  .dataviz-form .radioFilter.tabs input:checked + label {
    color: white;
    font-weight: bold;
    box-shadow: none; }

.dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical {
  margin-top: 0px;
  margin-bottom: 20px; }
  .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--label {
    font-weight: bold; }
  .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--groupcontent {
    line-height: 1;
    display: block; }
  .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--content {
    display: flex;
    margin-bottom: 5px; }
    .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--content input {
      accent-color: #4C1E5C; }
    .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--content label {
      font-family: "Poppins";
      color: #4C1E5C;
      font-size: 0.813rem;
      margin: 0 0 0 5px; }
    .dataviz-form .buttonFilter.buttonFilter.radioFilter.vertical .radioFilter--content label.selected {
      font-weight: bold; }

.dataviz-form .radioFilter.icon-button input[type="radio"], .dataviz-form .radioFilter.icon-button .dataviz-form input[type="checkbox"] {
  display: none; }

.dataviz-form .radioFilter.icon-button input[type="radio"] + label:before, .dataviz-form .radioFilter.icon-button .dataviz-form input[type="checkbox"] + label:before {
  display: inline-block;
  font-family: "icons-1749032404";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "icons-1749032404";
  font-size: 1.8em;
  color: #4C1E5C;
  padding: 0px 5px 0 0;
  vertical-align: -15%; }

.dataviz-form .radioFilter.icon-button input[type="radio"]:checked + label:before, .dataviz-form .radioFilter.icon-button input[type="checkbox"]:checked + label:before {
  display: inline-block;
  font-family: "icons-1749032404";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.dataviz .radioFilter.switch {
  margin: 0 10px 10px 0px; }
  .dataviz .radioFilter.switch .radioFilter--label {
    display: none; }
  .dataviz .radioFilter.switch .radioFilter--groupcontent {
    display: flex;
    border: 1px solid #4C1E5C;
    padding-left: 0px;
    border-radius: 50em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content; }
  .dataviz .radioFilter.switch .radioFilter--content {
    display: flex;
    overflow: hidden; }
  .dataviz .radioFilter.switch .radioFilter--content > * {
    border-left: 1px solid #4C1E5C; }
  .dataviz .radioFilter.switch .radioFilter--content:first-child {
    border-radius: 50em 0em 0 50em; }
    .dataviz .radioFilter.switch .radioFilter--content:first-child label {
      border-left: none; }
  .dataviz .radioFilter.switch .radioFilter--content:last-child {
    border-radius: 0em 50em 50em 0em; }
    .dataviz .radioFilter.switch .radioFilter--content:last-child label {
      border-right: none; }
  .dataviz .radioFilter.switch input {
    position: absolute !important;
    clip: rect(0, 0, 0, 0);
    height: 1px;
    width: 1px;
    border: 0;
    overflow: hidden; }
  .dataviz .radioFilter.switch label {
    margin: 0;
    background-color: #E4DDE7;
    color: #4C1E5C;
    font-size: 0.75rem;
    font-weight: normal;
    line-height: 1;
    text-align: center;
    padding: 8px 16px;
    transition: all 0.1s ease-in-out; }
  .dataviz .radioFilter.switch label:hover {
    cursor: pointer; }
  .dataviz .radioFilter.switch input:checked + label {
    background-color: #4C1E5C;
    color: white;
    font-weight: bold;
    box-shadow: none; }

.dataviz .tooltip.pie, .dataviz .tooltip.plotBar, .dataviz .tooltip.treemap--tooltip, .tooltip.Heatmap--tooltip, .tooltip.area--tooltip,
.voronoi--tooltip, .waffle--tooltip, .specialBubble--tooltip, .bubble--tooltip, .barlink--tooltip {
  background: #E4DDE7;
  color: #000000;
  border-radius: 5px;
  font-size: 0.9em;
  font-family: "Poppins";
  max-width: 500px;
  padding: 10px;
  pointer-events: none; }

.dataviz .tooltip.plotBar tr.content {
  text-align: left; }

.dataviz .tooltip.plotBar tr.content.isActive {
  font-weight: bold; }

.dataviz .tooltip.plotBar tr.content.not-representative {
  color: #ff9955;
  font-size: 0.8em; }

.dataviz .scan.bubble foreignObject {
  color: white; }

.dataviz .scan--bar .axis.xaxis, .dataviz .scan--bar .axis.yaxis {
  font-size: 0.85em;
  font-family: "Poppins"; }

.dataviz .scan--bar .axis.yaxis {
  font-family: "Poppins";
  fill: #000000;
  font-size: 0.85em; }

.dataviz .graphBar .svg-fond-line {
  stroke: #000000;
  stroke-dasharray: 4; }

.svg-fond-line {
  stroke: #000000;
  stroke-dasharray: 4; }

.dataviz .graphBar text.bar_label {
  font-size: 0.8em; }
  .dataviz .graphBar text.bar_label[defy="equip0"] {
    fill: #000000; }
  .dataviz .graphBar text.bar_label[defy="freq_4"] {
    fill: #000000; }

.dataviz .graphBar text.bar_label.not-representative {
  fill: #ff9955; }

.dataviz .graphBar text.stagger-label {
  font-size: 1em; }

.dataviz .scan--bar .bar.grouped {
  stroke: white;
  stroke-width: 2px; }

.dataviz .scan.mapflow path.secteur_geo {
  stroke: #4C1E5C; }

.dataviz .plotMarimekko .text_colomn {
  font-weight: bold; }

.dataviz .plotMarimekko .text_cell {
  font-size: 0.9em;
  fill: white; }

.dataviz .treemap .points_g text {
  font-family: "Poppins"; }

.dataviz .scan.heatmap .label--voronoi {
  fill: #000000;
  font-family: "Poppins"; }

.dataviz .scan.heatmap .axis.xaxis {
  font-size: 0.75rem;
  font-family: "Poppins"; }

.dataviz .scan.heatmap .axis.yaxis {
  font-size: 0.75rem;
  font-family: "Poppins"; }

.dataviz .scan.specialBubble .bubble-circle {
  stroke: white; }

.dataviz .scan.plotBarLink .text-xLabel, .dataviz .scan.plotBarLink .text-yLabel {
  font-size: 1.2em; }

.dataviz .leaflet-control-container > * {
  z-index: 0; }

.dataviz .leaflet-control-layers .leaflet-control-layers-toggle {
  background-image: url(/sites/observatoires-normandie/files/imgs/layers.png); }

.dataviz .leaflet-control-layers-base label {
  font-family: "Poppins"; }

.dataviz .leaflet-bottom.leaflet-left {
  width: 50%; }

.dataviz .leaflet-control.leaflet-control-graphicscale {
  margin-bottom: 0;
  color: #000000; }

.leaflet-container {
  background: #ffffff; }

.leaflet-legend {
  background: #ffffff;
  padding: 10px; }

.dataviz .leaflet-container {
  font-family: "Poppins"; }

.dataviz .leaflet-pane.leaflet-contour-parent-pane > svg path.leaflet-interactive {
  fill: none;
  pointer-events: none;
  stroke: #D4E868;
  stroke-width: 2px; }

.dataviz .leaflet-contour-epci-pane > svg path.leaflet-interactive {
  stroke: #808080;
  stroke-width: 2px; }

.dataviz path.static {
  stroke: #ffffff;
  stroke-width: 1px; }

.dataviz path.applat {
  stroke: #ffffff;
  stroke-width: 1px; }

.dataviz .legend-container .icon-group .legend-block[select="unchecked"] {
  opacity: 0.3; }

.dataviz .text-legend-map .tick {
  font-family: "Poppins";
  font-size: 0.875rem;
  fill: #000000; }
  .dataviz .text-legend-map .tick text {
    fill: #000000; }

.dataviz .tooltip.scan.map {
  background: #E4DDE7;
  color: #000000;
  border-radius: 5px;
  font-size: 0.9em;
  font-family: "Poppins";
  max-width: 200px;
  padding: 10px; }
  .dataviz .tooltip.scan.map .tooltip-title {
    font-weight: bold;
    font-family: "Poppins";
    color: #4C1E5C;
    text-align: center; }
  .dataviz .tooltip.scan.map .tooltip-content {
    font-family: "Poppins";
    text-align: center; }
    .dataviz .tooltip.scan.map .tooltip-content b {
      font-family: "Poppins";
      font-weight: bold; }
  .dataviz .tooltip.scan.map .tooltip-suffix {
    font-style: italic;
    font-weight: lighter;
    text-align: center; }
  .dataviz .tooltip.scan.map .dataviz {
    font-size: 0.8em; }

.fancybox-infobar, .fancybox-button {
  color: white;
  background: #4C1E5C; }
