/*******************************************************************************
 * Reset CSS                                                                   *
 *******************************************************************************/
a, abbr, acronym, address, area, b, bdo, big, blockquote, body, br, button,
caption, cite, code, col, dd, del, dfn, div, dl, dt, em,
fieldset, form, frame, framsset, h1, h2, h3, h4, h5, h6, hr, html,
i, iframe, img, input, ins, kbd, label, legend, li, map, noframe, noscript,
object, ol, p, pre, q, samp, select, small, span, strong, sub, sup,
table, tbody, td, textarea, tfoot, th, thead, tr, tt, ul, var,
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav,
section, summary, time, mark, audio, video { font-size:100%; margin:0; padding:0; }
html, body { height:100%; }
body { line-height:1; }
article, aside, details, figcaption, figure, footer, header, hgroup, menu,
nav, section { display:block; }
ol, ul { list-style:none; }
blockquote, q { quotes:none; }
blockquote:before, blockquote:after, q:before, q:after { content:''; content:none; }
table { border-collapse:collapse; border-spacing:0; }
hr { display:block; height:1px; border:0; border-top:1px solid #000; }
label { cursor:pointer; }
input, select { vertical-align:middle; }
abbr[title] acronym[title], dfn[title] { border-bottom:1px dotted; cursor:help; }
img, a img, input[type="image"] { border:0; vertical-align:middle; }
kbd { font-family:monospace; }
textarea, input:not([type="radio"]):not([type="checkbox"]) { -webkit-appearance: none; border-radius: 0; }
a[href^="tel"] { color:inherit; text-decoration:none; }



/*******************************************************************************
 * Fonts                                                                       *
 *******************************************************************************/
@font-face {
  font-family: 'DINProCondMedium';
  src: url('../fonts/DINPro-CondMedium.woff') format('woff');
}



/*******************************************************************************
 * Gabarit                                                                     *
 *******************************************************************************/
body { background: #a99d97; width: 100%; max-width: 1920px; margin: 0 auto; }
body.specific { background: #eaeaea; }
body.homepage .ro-container {  }
body.specific .ro-container { min-height: 100%; }
.ro-container {  position: relative; }
.ro-container * { font-family: 'Muli', sans-serif; font-size: 1rem; }

/* Titles */
.ro-container h3 { color: #f5f2ef; font-family: 'DINProCondMedium', sans-serif; font-size: 65px; letter-spacing: .05em; position: relative; text-align: center; text-transform: uppercase; transform: translateY(50px); opacity: 0; transition: all .4s ease-in-out; }
.ro-container h3.shown { transform: translateY(0); opacity: 1; }
.ro-container h3:after { background: #f5f2ef; content: ''; display: block; height: 2px; margin: 5px auto 0; width: 138px; }
.ro-container h3:before { color: #fe5016; content: '+'; font-size: 30px; position: absolute; bottom: -11px; left: calc(50% - 7px); }
/* Titles : Black version */
.ro-container h3.black { color: #292929; }
.ro-container h3.black:after { background: #292929; }
.ro-container h3.black:before { color: #fe5016; }

@media only screen and (max-width: 480px) {
  .ro-container h3 { font-size: 40px; }
}


/*******************************************************************************
 * Menu                                                                        *
 *******************************************************************************/
#ro-menu { position: fixed; left: 0; top: 0; right: 0; width: 100%; height: 60px; z-index: 10; background: rgba(231, 226, 223, 1); }
.ro-menu--container { margin: 0 auto; max-width: 1200px; text-align: right; }
  .ro-menu--title { display: inline-block; float: left; padding: 19px 0; margin-left: 10px; vertical-align: top; }
  .ro-menu--title img { width: 100%; }
  .ro-menu--nav { display: inline-block; vertical-align: top; }
    .ro-menu--mobile { display: none; }
    .ro-menu--nav ul { height: 60px; }
    .ro-menu--nav ul li { display: inline-block; line-height: 60px; margin: 0 7px; vertical-align: top; }
    .ro-menu--nav ul li a { border-bottom: 0px solid #ffa787; color: #242321; font-family: 'DINProCondMedium', sans-serif; font-size: 23px; padding: 0; text-align: center; text-decoration: none; text-transform: uppercase; transition: border .1s linear; }
    .ro-menu--nav ul li a span { display: block; font-size: 12px; line-height: 0; margin-top: -12px; }
    .ro-menu--nav ul li a:hover { border-bottom: 2px solid #ff5517; }
    .ro-menu--nav ul li a.ro-menu--active { border-bottom: 4px solid #ff5517; }
    .ro-menu--lang { display: inline-block; margin: 19px 10px 0 10px; }

.ro-menu--nav ul li:last-child { background: #595959; border-radius: 0 0 5px 5px; display: inline-block; height: 65px; margin: 0; padding: 0 15px; }
.ro-menu--nav ul li:last-child a { color: #ff6717; }
.ro-menu--nav ul li:last-child a span { color: #959494; }


.ro-menu--mobile { height: 50px; padding-top: 10px; position: relative; transition: -webkit-transform .1s linear; transition: transform .1s linear; width: 54px; cursor: pointer; display: none; }
.ro-menu--mobile span { background-color: #242321; display: block; height: 2px; left: 50%; position: absolute; top: 50%; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%);  transition: background .1s linear; width: 22px; }
.ro-menu--mobile span::before,
.ro-menu--mobile span::after { background-color: #242321; content: ''; display: block; height: 2px; left: 0; position: absolute; top: 0; -webkit-transform: translateY(-6px); transform: translateY(-6px); transition: -webkit-transform .1s linear; transition: transform .1s linear; width: 22px; }
.ro-menu--mobile span::after { -webkit-transform: translateY(6px); transform: translateY(6px); }
.nav-open .ro-menu--mobile span { background: transparent; }
.nav-open .ro-menu--mobile span::before { -webkit-transform: translateY(0) rotate(45deg); transform: translateY(0) rotate(45deg); }
.nav-open .ro-menu--mobile span::after  { -webkit-transform: translateY(0) rotate(-45deg); transform: translateY(0) rotate(-45deg); }
.nav-open .ro-menu--mobile { -webkit-transform: rotate(180deg); transform: rotate(180deg); }

@media only screen and (max-width: 1140px) {
  .ro-menu--title { width: 28.4%; }
  .ro-menu--nav ul li { margin: 0 4px; }
  .ro-menu--nav ul li a { font-size: 18px; }
}

@media only screen and (max-width: 900px) {
  .ro-menu--title { width: auto; }
  .ro-menu--mobile { display: block; }
  .ro-menu--lang { margin-right: 20px; }
  .ro-menu--nav { float: right; }
    .ro-menu--nav nav { position: absolute; left: -100vw; width: 100%; top: 60px; padding-bottom: 10px; background: rgba(231, 226, 223, .73); transition: transform .2s ease-in-out; }
    .ro-menu--nav nav ul { height: auto; }
    .ro-menu--nav nav li { display: block; line-height: 22px; margin: 0; padding: 5px 5px 5px 15px; text-align: left; }
    .ro-menu--nav nav li a { font-size: 18px; }

    .ro-menu--nav ul li:last-child { background: none; display: block; height: auto; margin: 0; padding: 5px 5px 5px 15px; }
    .ro-menu--nav ul li:last-child a span { color: #242321; display: inline-block; }

    .nav-open nav { transform: translateX(100vw); }
}

@media only screen and (max-width: 475px) {
  .ro-menu--title { width: 55%; }
}

@media only screen and (max-width: 320px) {
  .ro-menu--lang {  }
    .ro-menu--lang img { width: 100%; }
}


/*******************************************************************************
 * Home                                                                        *
 *******************************************************************************/
#ro-home {  }
.ro-home-video { margin-top: 60px; position: relative; padding-top: 56.25%; }
.ro-home-video #homePlayer { position: absolute; left: 0; bottom: 0; width: 100%; height: 100%; }
.ro-home-container { position: relative; font-size: 0; z-index: 2; height: calc(100vw * 0.62); max-height: 100vh; }
.ro-home--baseline { position: absolute; left: 50%; margin-top: 24%; width: 27.206%; z-index: 3; }
  .ro-home--baseline img { width: 100%; margin-left: -50%; margin-top: -50%; }
.ro-home--title { position: absolute; left: 50%; margin-top: 31%; width: 27.206%; z-index: 3; }
  .ro-home--title img { width: 100%; margin-left: -50%; margin-top: -50%; }
.ro-home--title-prerender { position: absolute; left: 50%; margin-top: 31%; width: 27.206%; z-index: 1; }
  .ro-home--title-prerender img { width: 100%; margin-left: -50%; margin-top: -50%; }
.ro-home--epv      { position: absolute; left: 50%; transform: translateX(calc(-100% - 7vw)); margin-top: 31.5%; width: 13.543vw; mix-blend-mode: lighten; z-index: 3; }
.ro-home--artisans { position: absolute; left: 50%; transform: translateX(calc(-100% + 4vw)); margin-top: 31.5%; width: 9.115vw;  mix-blend-mode: lighten; z-index: 3; }
.ro-home--medaille { position: absolute; left: 50%; transform: translateX(calc(-100% + 18.9vw)); margin-top: 31%; width: 13.543vw;  z-index: 3; }
.ro-home-social { padding: 15px 10px; position: absolute; right: 0; top: 85px; width: 24px; background: rgba(255, 255, 255, .5); z-index: 3; }
  .ro-home-social a { display: block; padding: 10px 0; }
.ro-home--background { position: relative; z-index: 2; }
  .ro-home--background img { width: 100%; height: auto; }


/* Preloading */
.ro-home--loader { position: absolute; left: 0; top: 0; background: #595959; height: 4px; width: 100%; pointer-events: none; z-index: 1; transition: opacity .2s ease-in-out; opacity: 0; }
.ro-home--loader .percent { position: absolute; left: 0; top: 0; background: #fe5016; height: 4px; transition: all .2s ease-in-out; box-shadow: 0 1px 5px 0px rgba(254, 80, 22, .75); content: ''; z-index: 2; }
.ro-home--loader.non-loaded { opacity: 1; }

.homepage *[data-animation-keyframe] { opacity: 0; }


@supports (object-fit: cover) {
  .ro-home--background img { object-fit: cover; object-position: 50% 30%; max-height: 100vh; }
}

@media only screen and (max-width: 450px) {
  .ro-home-social { padding: 10px 5px; top: unset; bottom: 0; }
    .ro-home-social a { padding: 5px 0; }
}



/*******************************************************************************
 * Activity                                                                    *
 *******************************************************************************/
#ro-activity { position: relative; display: table; font-size: 0; z-index: 2; background: #e3e0de; }
.ro-activity--left  { display: table-cell; vertical-align: top; width: 33.33%; overflow: hidden; max-height: 930px; }
.ro-activity--right { display: table-cell; vertical-align: top; width: 33.33%; overflow: hidden; max-height: 930px; }
  .ro-activity--left-visuel  { width: 100%; height: auto; }
  .ro-activity--right-visuel { width: 100%; height: auto; }
.ro-activity--container { display: table-cell; width: 33.34%; padding-bottom: 20px; top: 0; background: #a99d97; }
  .ro-activity--container h3 { margin: 90px 0 70px; }
  .ro-activity--listing { color: #f6f4f2; font-size: 18px; line-height: 33px; margin: 0 65px 30px; }
  .ro-activity--listing ul li:before { content: '- '; }
  .ro-activity--text { color: #292929; font-size: 17px; line-height: 1em; margin: 0 65px; }
  .ro-activity--text p { margin-top: 20px; line-height: 1em; }

@media only screen and (max-width: 1660px) {
  .ro-activity--listing { font-size: 1.09vw; line-height: 2.2vw; margin: 0 30px 30px; }
  .ro-activity--text { font-size: 1.025vw; margin: 0 30px; }
}

@media only screen and (max-width: 1090px) {
  .ro-activity--right { display: none; }
  .ro-activity--container { padding: 45px 0; width: 66.66%; }
  .ro-activity--container h3 { margin-top: 0; }
}

@media only screen and (max-width: 768px) {
  .ro-activity--left { display: none; }
  .ro-activity--container { position: relative; left: 0; display: block; width: 100%; }
  .ro-activity--container h3 { margin-top: 0; }
}

@media only screen and (max-width: 560px) {
  .ro-activity--listing { font-size: 16px; line-height: 22px; margin: 0 20px 30px; }
  .ro-activity--text { font-size: 14px; line-height: 1em; margin: 0 20px; }
}



/*******************************************************************************
 * Team                                                                        *
 *******************************************************************************/
#ro-team { position: relative; font-size: 0; z-index: 2; background: #e3e0de; }
#ro-team h3 { margin-bottom: 30px; padding-top: 70px; }
.ro-team--container { margin: 0 auto; max-width: 1046px; font-size: 0; }
  .ro-team--person { display: inline-block; margin: 0 1.5% 30px; width: 30.03%; text-align: center; vertical-align: top; }
    .ro-team--picture { width: calc(100% - 40px); margin:0 auto; height: auto; }
    .ro-team--name { color: #f3812b; font-family: 'DINProCondMedium', sans-serif; font-size: 54px; text-align: left; text-transform: uppercase; margin-top: -54px; }
    .ro-team--role { font-style: italic; font-weight: 600; letter-spacing: .07em; text-align: left; }

@media only screen and (max-width: 1060px) {
  .ro-team--name { font-size: 5.095vw; }
}

@media only screen and (max-width: 768px) {
  .ro-team--container { text-align: center; }
    .ro-team--person { width: 47% !important; }
      .ro-team--name { font-size: 8vw; }
}

@media only screen and (max-width: 380px) {
      .ro-team--name { margin-top: -30px; }
}



/*******************************************************************************
 * Customers                                                                   *
 *******************************************************************************/
#ro-customers { position: relative; font-size: 0; z-index: 2; padding: 110px 0; background: #a99d97 url('../images/customers/background.jpg'); background-size: auto 100%; background-attachment: fixed; }
.ro-customers--container { margin: 0 auto; max-width: 1110px; padding: 60px 50px; position: relative; z-index: 4; background: rgba(188, 186, 193, .66); }
.ro-customers--container h3 { display: inline-block; }
.ro-customers--container .ro-customers--preamble { color: #f5f2ef; display: inline-block; font-size: 18px; font-weight: bold; line-height: 22px; margin-left: 75px; }
  .ro-customers--listing {  }
    .ro-customers--listing p { font-size: 18px; line-height: 24px; margin-top: 60px; }
    .ro-customers--listing p { -webkit-column-width: 240px; -moz-column-width: 240px; column-width: 240px; -webkit-column-count: 4; -moz-column-count: 4; column-count: 4; -webkit-column-gap: 10px; -moz-column-gap: 10px; column-gap: 10px; }
    .ro-customers--listing p a { color: #000; font-size: 18px; line-height: 24px; text-decoration: none; }
    .ro-customers--listing p a:hover { text-decoration: underline; }


@media only screen and (min-aspect-ratio: 10/8) {
  #ro-customers { background-size: 100% auto; }
}

@media only screen and (max-width: 1010px) {
  .ro-customers--container .ro-customers--preamble { display: block; margin: 15px auto 0; font-size: 16px; }
}

@media only screen and (max-width: 767px) {
  #ro-customers { background-attachment: scroll; }
}

@media only screen and (max-width: 590px) {
  .ro-customers--container { padding: 30px 20px; }
    .ro-customers--listing p { font-size: 12px; line-height: 18px; }
    .ro-customers--listing p { -webkit-column-width: 100px; -moz-column-width: 100px; column-width: 100px; }
    .ro-customers--listing p a { font-size: 12px; line-height: 18px; }
}


@media only screen and (orientation: landscape) and (max-width: 767px) {
  #ro-customers { background-size: 100% auto; }
}


/*******************************************************************************
 * Contact                                                                     *
 *******************************************************************************/
#ro-contact { position: relative; font-size: 0; z-index: 2; min-height: 1010px; overflow: hidden; }
.ro-contact--container { position: absolute; left: 0; top: 0; bottom: 0; width: 50%; min-width: 735px; background: rgba(176, 151, 124, .64); }
  .ro-contact--container h3 { margin-bottom: 40px; padding-top: 75px; }
  .ro-contact-social { display: inline-block; left: calc(50% + 130px); position: absolute; top: 95px; }
  .ro-contact-social a { display: inline-block; margin: 0 6px; }

  .ro-contact--description { margin: 0 auto; max-width: 575px; }
  .ro-contact--preamble { color: #000; font-size: 18px; font-weight: 600; }
  .ro-contact--preamble p { margin-bottom: 15px; }
  .ro-contact--left { float: left; color: #000; display: inline-block; font-size: 16px; font-weight: 600; line-height: 1.3em; margin-top: 25px; width: 44%; }
  .ro-contact--right { float: right; color: #000; display: inline-block; font-size: 16px; font-weight: 600; line-height: 1.3em; margin-top: 25px; width: 53%; }
  .ro-contact--left img,
  .ro-contact--right img { float: left; }
  .ro-contact--left a,
  .ro-contact--right a { color: #000; font-size: 14px; font-style: italic; text-decoration: none; }
  .ro-contact--form { clear: both; margin: 0 auto; max-width: 485px; padding-top: 40px; }
    .ro-contact--form * { box-sizing: border-box; }
    .ro-contact--line { display: block; margin: 10px 0; }
      .ro-contact--label { color: #000; display: inline-block; font-size: 18px; line-height: 31px; padding-right: 10px; text-align: right; vertical-align: top; width: 100px; }
      .ro-contact--input { display: inline-block; background: #FFF; border: 0; padding: 5px 10px; width: 380px; border-radius: 0; }
      .ro-contact--line.error {  }
      .ro-contact--line.error .ro-contact--label { padding-right: 0; }
      .ro-contact--line.error .ro-contact--label:after { content: '*'; color: #FF0000; }
      .ro-contact--textarea { display: inline-block; background: #FFF; border: 0; padding: 5px 10px; width: 380px; min-width: 380px; max-width: 380px; min-height: 200px; }
    .ro-contact--submit { background: #122227; border: 0; color: #FFF; cursor: pointer; float: right; font-family: 'DINProCondMedium', sans-serif; font-size: 22px; padding: 8px 30px; text-transform: uppercase; transition: all .2s linear; }
    .ro-contact--submit:hover { background: #23414b; }
    .ro-contact--submit:active { transform: scale(.9); }
  .ro-contact--epv { margin-top: 40px; }
  .ro-contact--artisans { margin-top: 40px; margin-left: 10px; }
.ro-contact--background { }
  .ro-contact--background img { width: 100%; height: auto; }

.g-recaptcha { display: flex; justify-content: flex-end; margin-bottom: 10px; }

.uniform-errors { padding-left: 100px; color: #D8000C; background-color: #FFBABA; border: 1px solid; padding: 10px; margin-left: 104px; }
.uniform-errors .uniform-errors__item { line-height: 15px; font-size: 12px; }
.uniform-errors .uniform-errors__item:before { content: '-'; }
.uniform-success { padding-left: 100px; color: #4F8A10; background-color: #DFF2BF; border: 1px solid; padding: 10px; margin-left: 104px; }
.uniform-success .uniform-success__item { line-height: 15px; font-size: 12px; }
.uniform-success .uniform-success__item:before { content: '✔ '; }

@media only screen and (max-width: 1530px) {
  #ro-contact { min-height: 1100px; }
  .ro-contact--background img { width: auto; height: 100%; }
}

@media only screen and (max-width: 768px) {
  #ro-contact { min-height: inherit; }
  .ro-contact--container { position: relative; width: 100%; min-width: inherit; background: #b0977c; padding-bottom: 40px; }
    .ro-contact--container h3 { padding-top: 30px; }
  .ro-contact--background img { display: none; }
}

@media only screen and (max-width: 660px) {
  .ro-contact-social { left: calc(50% - 58px); top: 125px; }
  .ro-contact--description { margin: 0 20px; max-width: 100%; padding-top: 25px; }
  .ro-contact--left,
  .ro-contact--right { float: inherit; display: block; width: 100%; }
}

@media only screen and (max-width: 560px) {
  .ro-contact--form { max-width: inherit; width: 90%; }
    .ro-contact--line { margin: 10px 0; }
      .ro-contact--label { display: block; line-height: 31px; text-align: left; }
      .ro-contact--input { display: block; width: 100%; }
      .ro-contact--textarea { display: block; width: 100%; min-width: inherit; max-width: inherit; min-height: 200px; }

  .uniform-errors,
  .uniform-success { margin-left: 0; }
}

@media only screen and (max-width: 480px) {
  .ro-contact-social { top: 100px; }
  .ro-contact--artisans { display: block; margin-top: 20px; margin-left: 0; }
}


/*******************************************************************************
 * Photos (Carousel)                                                           *
 *******************************************************************************/
#ro-photos { background: #000; position: relative; font-size: 0; z-index: 2; height: 100vh; }
#ro-photos h3 { display: inline-block; position: absolute; left: 15.1vw; top: 75px; z-index: 2; }
.ro-carousel { background: #000; }


.Carousel-nav { position: absolute; left: 0; top: 0; right: 0; bottom: 0; z-index: 2; }
  .Carousel-nav-prev { cursor: pointer; display:inline-block; float: left; height: 100%; position: relative; text-align: center; width: 70px; transition: all .5s ease-in-out; }
  .Carousel-nav-prev.disabled { opacity: 0; pointer-events: none; transform: scale(0); }
  .Carousel-nav-prev .arrow { display: inline-block; height: 53px; position: absolute; right: 0; top: calc(50% - 26px); text-indent: -99999px; transition: all .1s linear; width: 20px; background: url('../images/photos/navigation.png') no-repeat left top; }
  .Carousel-nav-prev:hover .arrow { transform: translateX(-15px); }
  .Carousel-nav-next { cursor: pointer; display:inline-block; float: right; height: 100%; position: relative; text-align: center; width: 70px; transition: all .5s ease-in-out; }
  .Carousel-nav-next.disabled { opacity: 0; pointer-events: none; transform: scale(0); }
  .Carousel-nav-next .arrow { display: inline-block; height: 53px; position: absolute; left: 0; top: calc(50% - 26px); text-indent: -99999px; transition: all .1s linear; width: 20px; background: url('../images/photos/navigation.png') no-repeat right top; }
  .Carousel-nav-next:hover .arrow { transform: translateX(15px); }


.Carousel-nav-pagin { position: absolute; left: calc(50% - 240px); bottom: 32px; z-index: 3; width: 480px; height: 49px; }
  .Carousel-nav-pagin .Carousel-nav-prev { width: 20px; }
  .Carousel-nav-pagin .Carousel-nav-prev .arrow { transform: scale(.6); }
  .Carousel-nav-pagin .Carousel-nav-prev:hover .arrow { transform: scale(.6) translateX(-15px); }
  .Carousel-nav-pagin .Carousel-nav-next { width: 20px; }
  .Carousel-nav-pagin .Carousel-nav-next .arrow { transform: scale(.6); }
  .Carousel-nav-pagin .Carousel-nav-next:hover .arrow { transform: scale(.6) translateX(15px); }


.Carousel-pagin { font-size: 0; height: 51px; text-align: center; max-width: 460px; overflow: hidden; position: absolute; left: calc(50% - 230px); bottom: 30px; z-index: 4; }
  .Carousel-pagin-container { transition: transform .5s ease-in-out; }
    .Carousel-pagin .Carousel-pagin-item { background: #eee; border: 2px solid #FFF; cursor: pointer; display: inline-block; height: 45px; overflow: hidden; margin: 0 10px; vertical-align: top; transition: border .5s ease-in-out; }
    .Carousel-pagin .Carousel-pagin-item img { width: 68px; height: auto; }
    .Carousel-pagin .Carousel-pagin-item.Carousel-pagin-active { border: 2px solid #fe5016; }
    .Carousel-pagin .Carousel-pagin-item:hover {  }
    .Carousel-pagin .Carousel-pagin-item:active {  }

.ro-carousel--photos { height: 100%; overflow: hidden; width: 100%; }

.Carousel-mask { overflow: hidden; width: 100%; height: 100%; }
.Carousel-item-container { font-size: 0; width: 99999%; height: 100%; }
  .ro-carousel--item { display: inline-block; margin: 0; padding: 0; position: relative; text-align: center; vertical-align: top; width: 100%; max-width: 100vw; height: 100%; }
    .ro-carousel--loading { display: inline-block; margin: 0; padding: 0; position: relative; vertical-align: top; width: 100%; max-width: 100vw; height: 100%; }
    .ro-carousel--loading strong { position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); font-size: 30px; letter-spacing: .1em; color: #867369; }
    .ro-carousel--item picture img { height: 100%; width: auto; }
    .ro-carousel--item-description { color: #eaeaea; font-size: 20px; text-align: center; position: absolute; left: 0; right: 0; bottom: 95px; }

.ro-carousel--fullscreen { position: absolute; right: 15px; top: 75px; display: block; width: 25px; height: 25px; cursor: pointer; z-index: 3; background: url('../images/photos/fullscreen.png') no-repeat left center; background-size: auto 100%; }


.ro-carousel:-moz-full-screen .ro-carousel--fullscreen    { top: 15px; background-position: right top; }
.ro-carousel:-ms-fullscreen .ro-carousel--fullscreen      { top: 15px; background-position: right top; }
.ro-carousel:-webkit-full-screen .ro-carousel--fullscreen { top: 15px; background-position: right top; }
.ro-carousel:fullscreen .ro-carousel--fullscreen          { top: 15px; background-position: right top; }

@media only screen and (max-aspect-ratio: 320/213) {
  #ro-photos { height: auto; }
    .ro-carousel--item { vertical-align: middle; }
      .ro-carousel--item picture img { height: auto; width: 100%; }
}

@media only screen and (max-width: 590px) {
  #ro-photos { padding-top: 100px; padding-bottom: 75px; }
  #ro-photos h3 { left: 0; right: 0; top: 10px; }
  .Carousel-pagin { max-width: 276px; left: calc(50% - 138px); bottom: 10px; }
  .ro-carousel--item-description { font-size: 12px; text-align: left; left: 5px; bottom: 7px; }

  .Carousel-nav-prev { width: 30px; }
  .Carousel-nav-prev .arrow { height: 27px; top: calc(50% - 13px); width: 10px; background-size: auto 100%; }
  .Carousel-nav-prev:hover .arrow { transform: translateX(-7px); }
  .Carousel-nav-next { width: 30px; }
  .Carousel-nav-next .arrow { height: 27px; top: calc(50% - 13px); width: 10px; background-size: auto 100%; }
  .Carousel-nav-next:hover .arrow { transform: translateX(7px); }

  .Carousel-nav-pagin { display: none; }
}


/*******************************************************************************
 * Video                                                                       *
 *******************************************************************************/
#ro-video { background: #000; position: relative; font-size: 0; z-index: 2; }
#ro-video h3 { margin-bottom: 40px; padding-top: 75px; }
#ro-video #VideoEmbed { align-items: center; background: #000; cursor: pointer; display: flex; width: 100%; height: auto; justify-content: center; padding-bottom: 40px; position: relative; }
#ro-video #VideoEmbed .ro-video--play { background: #ff0000; border-radius: 50% / 10%; color: #fff; font-size: 1em;  height: 3em; margin: 0 auto; padding: 0; position: absolute; text-align: center; text-indent: 0.1em; transition: all 150ms ease-out; width: 4em; top: calc(50% - 2.5em); }
#ro-video #VideoEmbed .ro-video--play:before { background: inherit; border-radius: 5% / 50%; bottom: 9%; content: ''; left: -5%; position: absolute; right: -5%; top: 9%; }
#ro-video #VideoEmbed .ro-video--play:after { border-style: solid; border-width: 1em 0 1em 1.732em; border-color: transparent transparent transparent #fff; content: ' '; font-size: 0.75em; height: 0; margin: -1em 0 0 -0.75em; top: 50%; position: absolute; width: 0; }
#ro-video #VideoEmbed .ro-video--thumbnail { height: auto; max-width: 1280px; width: 100%; }
#ro-video #VideoEmbed .ro-video--container { display: none; width: 1280px; height: 0; position: relative; padding-bottom: 56.25%; }
#ro-video #VideoEmbed .ro-video--container iframe { position: absolute; left: 0; top: 0; width: 100%; height: 100%; max-height: 720px; }


#ro-video #VideoEmbed.is-loading { cursor: default; }
#ro-video #VideoEmbed.is-loading .ro-video--play { display: none; }

#ro-video #VideoEmbed.is-playing { cursor: default; }
#ro-video #VideoEmbed.is-playing .ro-video--play { display: none; }
#ro-video #VideoEmbed.is-playing .ro-video--thumbnail { display: none; }
#ro-video #VideoEmbed.is-playing .ro-video--container { display: inline-block; }



/*******************************************************************************
 * Blog                                                                        *
 *******************************************************************************/
#ro-blog { position: relative; font-size: 0; z-index: 2; background: #eaeaea; padding: 70px 0 110px; }
.ro-blog--container { margin: 0 auto; max-width: 1200px; width: 100%; }
.ro-blog--container h3 { box-sizing: border-box; max-width: 435px; padding-right: 4.5%; width: 36.25%; }
  .ro-blog--container h3:before { left: calc(50% - 4.5% - 7px); }
  .ro-blog--listing { box-sizing: border-box; display: inline-block; font-size: 0; text-align: center; padding-right: 4.5%; vertical-align: top; width: 36.25%; }
    .ro-blog--listing-title { color: #1e1e20; display: block; padding: 25px 0 10px 5px; text-align: left; }
    .ro-blog--listing ul {  }
      .ro-blog--listing ul li {  }
        .ro-blog--listing-article { border-bottom: 1px solid #646e75; color: #1e1e20; display: block; font-size: 16px; text-align: left; text-decoration: none; padding: 7px 70px 7px 5px; position: relative; transition: all .2s linear; }
        .ro-blog--listing-article:hover { background: rgba(0, 0, 0, .05); }
          .ro-blog--listing-article span { color: #cf6e32; float: right; font-size: 12px; position: absolute; right: 5px; top: 9px; }
    .ro-blog--pagin { background: #000; color: #FFF; display: inline-block; font-size: 14px; height: 45px; line-height: 45px; margin-top: 10px; margin-bottom: 20px; text-align: center; text-decoration: none; transition: all .2s linear; width: 49%; }
    .ro-blog--pagin:hover { background-color: #111717; }
    .ro-blog--pagin:active { transform: scale(.9); }

    .ro-blog--pagin-prev { float: left; }
    .ro-blog--pagin-next { float: right; }
    .ro-blog--pagin-disabled { opacity: 0; pointer-events: none; }

    .ro-blog-social { display: block; text-align: center; margin:20px auto ; }
      .ro-blog-social a { margin: 0 6px; }

    .ro-blog--listing > a { font-size: 0; }
    .ro-blog--epv,
    .ro-blog--artisans { margin: 0px 5px 0; }
    .ro-blog--medaille { margin: 0px 5px 0; max-height: 90px; }


  .ro-blog--article { box-sizing: border-box; display: inline-block; width: 63%; }
    .ro-blog--article-title { color: #211c18; font-size: 28px; text-decoration: none; text-transform: uppercase; }
    .ro-blog--article-title span { color: #cf6e32; float: right; font-size: 14px; line-height: 38px; }
    .ro-blog--article-picture { display: block; margin: 0 auto; position: relative; text-align: center; }
    .ro-blog--article-picture img { max-width: 100%; }
    .ro-blog--article-picture span { color: #FFF; font-size: 14px; text-align: right; position: absolute; right: 5px; left: 5px; bottom: 5px; }
    .ro-blog--article-content { color: #211c18; font-size: 17px; line-height: 1em; }
      .ro-blog--article-content iframe { max-width: 100%; }
      .ro-blog--article-content img { max-width: 100%; display: block; }
      .ro-blog--article-content p { margin-top: 20px; }
      .ro-blog--article-content p a { color: #cf6e32; text-decoration: none; }
      .ro-blog--article-content p a:hover { text-decoration: underline; }


body.specific .ro-blog--container { margin-top: 100px; }

@media only screen and (max-width: 767px) {
  #ro-blog { padding: 25px 0 50px; }
  .ro-blog--container { display: flex; flex-direction: column; }
    .ro-blog--container h3 { order: 1; margin-bottom: 25px; width: 100%; padding: 0; max-width: inherit; }
      .ro-blog--container h3:before { left: calc(50% - 7px); }
    .ro-blog--listing { order: 3; display: block; padding: 0 20px; width: 100%; }
    .ro-blog--article { order: 2; display: block; padding: 0 20px; width: 100%; }
      .ro-blog--article-title { font-size: 22px; }
      .ro-blog--article-title span { display: block; float: inherit; text-align: right; line-height: 24px; }
      .ro-blog--article-picture span { font-size: 12px; text-align: left; line-height: 1.2em; }
    .ro-blog--medaille { margin-top: 10px; }
}


/*******************************************************************************
 * Instagram                                                                   *
 *******************************************************************************/
#ro-instagram { position: relative; font-size: 0; z-index: 2; background: #eaeaea; padding: 70px 0 110px; }
.ro-instagram--container { margin: 0 auto; max-width: 1200px; width: 100%; }
.ro-instagram--container h3 { box-sizing: border-box; text-align: center; width: 100%; }


.ro-instagram--container #instagram-feed { display: flex; flex-wrap: wrap; margin: 20px auto; padding: 0 20px; max-width: 100vw; width: 975px; box-sizing: border-box; }
.ro-instagram--container #instagram-feed .instagram-loading { display: inline-block; margin: 0; padding: 0; position: relative; vertical-align: top; width: 100%; max-width: 100vw; height: 150px; }
.ro-instagram--container #instagram-feed .instagram-loading strong { position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); font-size: 30px; letter-spacing: .1em; color: #867369; }
.ro-instagram--container #instagram-feed .instagram-item { display: inline-block; position: relative; margin-right: 28px; margin-bottom: 28px; flex: 1 0 0%; min-width: calc(33.33% - 19px); max-width: calc(33.33% - 19px); padding-top: calc(33.33% - 19px); }
.ro-instagram--container #instagram-feed .instagram-item:nth-child(3n+3) { margin-right: 0; }
.ro-instagram--container #instagram-feed .instagram-item svg { position: absolute; right: 0; top: 0; margin: 8px; }
.ro-instagram--container #instagram-feed .instagram-item picture { position: absolute; left: 0; top: 0; right: 0; bottom: 0; }
.ro-instagram--container #instagram-feed .instagram-item picture img { width: 100%; height: 100%; object-fit: cover; }

@media only screen and (max-width: 735px) {
  .ro-instagram--container #instagram-feed { padding: 0; }
  .ro-instagram--container #instagram-feed .instagram-item { margin-right: 3px; margin-bottom: 3px; min-width: calc(33.33% - 2px); max-width: calc(33.33% - 2px); }
}

/*******************************************************************************
 * Footer                                                                      *
 *******************************************************************************/
.ro-credits,
.ro-mentions { max-width: 1220px; margin: 0 auto; padding: 90px 10px; }
.ro-credits h3,
.ro-mentions h3 { margin-bottom: 30px; transform: translateY(0); opacity: 1; }
.ro-credits p,
.ro-mentions p { color: #000; font-size: 16px; line-height: 20px; margin: 15px 0 0; }
.ro-credits p a,
.ro-mentions p a { color: #cf6e32; text-decoration: none; }
.ro-credits p a:hover,
.ro-mentions p a:hover { text-decoration: underline; }


/*******************************************************************************
 * Footer                                                                      *
 *******************************************************************************/
#ro-footer { position: relative; font-size: 0; height: 50px; z-index: 2; background: #595959; }
body.specific #ro-footer { position: absolute; left: 0; right: 0; bottom: 0; }
.ro-footer--container { color: #FFF; line-height: 48px; margin: 0 auto; padding: 0 10px; max-width: 1220px; text-align: left; }
  .ro-footer--container a { color: #FFF; line-height: 48px; margin-left: 40px; transition: color .1s linear; text-transform: lowercase; text-decoration: underline; float: right; }
  .ro-footer--container a:hover { color: #fe5016; }

@media only screen and (max-width: 500px) {
  #ro-footer { height: 60px; }
  .ro-footer--container { text-align: center; line-height: 30px; }
  .ro-footer--container span { display: block; }
  .ro-footer--container a { display: inline-block; float: inherit; line-height: 30px; margin: 0 20px; }
}

.uniform__potty {
    position: absolute;
    left: -9999px;
}

.ro-blog-instagram .ro-blog--listing { display: flex; flex-direction: row; flex-wrap: wrap; width: 100%; padding: 0; gap: 10px; }
.ro-blog-instagram .ro-blog--listing .ro-blog--listing-left { /*width: 36%;*/ max-width: 425px; }
.ro-blog-instagram .ro-blog--listing .ro-blog--listing-right { width: 57%; margin-top: 50px; }

.ro-blog-actions { margin-right: 10px;}
.ro-blog-actions .ro-blog--pagin { padding: 0 20px; cursor: pointer; width: 40%;}


.ro-blog-instagram .ro-blog--posts { width: 100%; height: 530px; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; gap: 14px; overflow-y: auto; overflow-x: hidden; scroll-behavior: smooth;}

@media only screen and (max-width:420px ) {
  .ro-blog-instagram .ro-blog--posts { gap: 10px; }
}

.ro-blog-instagram .ro-blog--posts .ro-blog--post { width: 31%; overflow: hidden; height: 170px; cursor: pointer; }
.ro-blog-instagram .ro-blog--posts .ro-blog--post video,
.ro-blog-instagram .ro-blog--posts .ro-blog--post img { width: 100%; height: 100%; object-fit: cover; }

.ro-blog-instagram .ro-blog--article-instagram-row .ro-blog--article-instagram-col .contentVideoMedia.video-paused::after { content: '||'; font-size: 40px; font-family: Arial, sans-serif; color: white; display: flex; align-items: center; justify-content: center; background: rgba(0, 0, 0, .60); width: 100%; height: 100%; position: absolute; top: 0; left: 0; right: 0; z-index: 2 }

.ro-blog-instagram .ro-blog--listing .ro-blog--listing-right .ro-blog--article-instagram { display: flex; flex-direction: row; justify-content: center;}
.ro-blog--article-instagram-row { display:flex; max-width: 640px; }
.ro-blog--article-instagram-col { width:50%; position:relative; }
.ro-blog--article-instagram-col img { width:100%; height:auto; }
.ro-blog--article-instagram-col .text { position:absolute; inset:0; overflow: auto; padding: 20px;}
.ro-blog--article-instagram-col .btSound { cursor: pointer; font-size: 0; position: absolute; bottom: 10px; right: 10px; z-index: 3; border: 0; background: url('../images/sound-off.svg') no-repeat center center grey; background-size: 20px;  border-radius: 50%; height: 30px; width: 30px; padding:5px }
.ro-blog--article-instagram-col .btSound.video-unmuted { background-image: url('../images/sound.svg'); }

.ro-blog--article-instagram-content {  background-color: #fff; padding: 20px; overflow-y: auto; font-size: 14px; line-height: 20px; font-weight: 400; width: 50%; text-align: left; display: flex; flex-direction: column; }
.ro-blog--article-instagram-content .ro-blog--pagin {  margin-top: 20px;  margin-bottom: 10px; width: 100%; cursor: pointer;}
.ro-blog--article-instagram-content .ro-blog--article-instagram-content--header { margin-bottom: 20px; }
.ro-blog--article-instagram-content .ro-blog--article-instagram-content--header img { width: 30px; height: 30px; border-radius: 50%; margin-right: 10px; }
.ro-blog--article-instagram-content .ro-blog--article-instagram-content--header span { display: inline; color: #000; text-decoration: none; font-weight: bold; margin-bottom: 20px;}
.ro-blog--article-instagram-content .ro-blog--article-instagram-content--header a { color: #000; text-decoration: none; font-weight: bold; }
.ro-blog--article-instagram-content p { padding-left: 40px; }

.ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post { background: rgba(231, 226, 223, 1); position: relative;  display: flex; flex-direction: column; align-items: center; justify-content: center; }
.ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post img {  width: 60px; height: 60px; border-radius: 50%; margin-bottom: 25px; margin-bottom: 10px;}
@media only screen and (max-width: 680px) {
  .ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post img { margin-bottom: 35px; }
}
.ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post img {  width: 60px; height: 60px; border-radius: 50%; margin-bottom: 35px;}
.ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post p {  color: #1e1e20; }
.ro-blog-instagram .ro-blog--posts .ro-blog--post.last-post .full-link {  position: absolute; top: 0; bottom: 0; left: 0; right: 0; } 

@media only screen and (max-width: 1024px) {
.ro-blog--article-instagram-row { max-width: initial; }
  .ro-blog-instagram .ro-blog--listing .ro-blog--listing-left { width: 100%; max-width: initial;}
  .ro-blog-instagram .ro-blog--listing .ro-blog--listing-right { width: 100%; }
  .ro-blog-instagram .ro-blog--posts { margin-left: 10px; width: calc(100% - 10px);}
  .ro-blog-instagram .ro-blog--posts .ro-blog--post { height: 300px; }
}

@media only screen and (max-width: 680px) {
  .ro-blog-actions { display: flex; align-items: flex-start; justify-content: space-between; margin: 0 10px; gap:10px}
  .ro-blog--article-instagram-row { flex-direction: column; }
  .ro-blog--article-instagram-col { width: 100%;}
  .ro-blog--article-instagram-col .text { position:relative; padding: 0;}
  .ro-blog-instagram .ro-blog--listing .ro-blog--listing-right { width: calc(100% - 40px); margin: 0 auto;}
  .ro-blog--article-instagram-content { width: calc(100% - 40px); max-height: 250px;}
  .ro-blog--article-instagram-content p { padding-left: 0; }
  .ro-blog-instagram .ro-blog--posts { width: calc(100% - 20px);}
  .ro-blog-instagram .ro-blog--posts .ro-blog--post { height: 170px; }
}




