@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide--draggable>.splide__slider>.splide__track,.splide--draggable>.splide__track{-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide--fade>.splide__slider>.splide__track>.splide__list,.splide--fade>.splide__track>.splide__list{display:block}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide,.splide--fade>.splide__track>.splide__list>.splide__slide{left:0;opacity:0;position:absolute;top:0;z-index:0}.splide--fade>.splide__slider>.splide__track>.splide__list>.splide__slide.is-active,.splide--fade>.splide__track>.splide__list>.splide__slide.is-active{opacity:1;position:relative;z-index:1}.splide--rtl{direction:rtl}.splide--ttb.is-active>.splide__slider>.splide__track>.splide__list,.splide--ttb.is-active>.splide__track>.splide__list{display:block}.splide__container{box-sizing:border-box;position:relative}.splide__list{-webkit-backface-visibility:hidden;backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important;transform-style:preserve-3d}.splide.is-initialized:not(.is-active) .splide__list{display:block}.splide__pagination{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;margin:0;pointer-events:none}.splide__pagination li{display:inline-block;line-height:1;list-style-type:none;margin:0;pointer-events:auto}.splide__progress__bar{width:0}.splide{outline:none;position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{-webkit-backface-visibility:hidden;backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;outline:none;position:relative}.splide__slide img{vertical-align:bottom}.splide__slider{position:relative}.splide__spinner{animation:splide-loading 1s linear infinite;border:2px solid #999;border-left-color:transparent;border-radius:50%;bottom:0;contain:strict;display:inline-block;height:20px;left:0;margin:auto;position:absolute;right:0;top:0;width:20px}.splide__track{overflow:hidden;position:relative;z-index:0}@font-face {
  font-family: 'fontello';
  src: url('/content/themes/rof-living/fontello/font/fontello.eot?28302404&x21021');
  src: url('/content/themes/rof-living/fontello/font/fontello.eot?28302404#iefix&x21021') format('embedded-opentype'),
       url('/content/themes/rof-living/fontello/font/fontello.woff2?28302404') format('woff2'),
       url('/content/themes/rof-living/fontello/font/fontello.woff?28302404&x21021') format('woff'),
       url('/content/themes/rof-living/fontello/font/fontello.ttf?28302404&x21021') format('truetype'),
       url('/content/themes/rof-living/fontello/font/fontello.svg?28302404#fontello&x21021') format('svg');
  font-weight: normal;
  font-style: normal;
}
/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */
/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */
/*
@media screen and (-webkit-min-device-pixel-ratio:0) {
  @font-face {
    font-family: 'fontello';
    src: url('/content/themes/rof-living/fontello/font/fontello.svg?28302404#fontello&x21021') format('svg');
  }
}
*/
 
 [class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  speak: none;
 
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  /* opacity: .8; */
 
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
 
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
 
  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: .2em;
 
  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */
 
  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
 
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}
 
.icon-wp-edit:before { content: '\e811'; } /* '' */


@font-face {
    font-family:"RecifeDisplay-Regular";
    src:url("/content/themes/rof-living/webfonts/RecifeDisplay-Regular.woff2") format("woff2"),url("/content/themes/rof-living/webfonts/RecifeDisplay-Regular.woff?x21021") format("woff");
    font-style:normal;font-weight:400;
    font-display: swap;
}
        
@font-face {
    font-family:"Sora Regular";
    src:url("/content/themes/rof-living/webfonts/Sora-Regular.woff2") format("woff2"),url("/content/themes/rof-living/webfonts/Sora-Regular.woff?x21021") format("woff");
    font-style:normal;font-weight:400;
    font-display: swap;
}
        
@font-face {
    font-family:"Sora SemiBold";
    src:url("/content/themes/rof-living/webfonts/Sora-SemiBold.woff2") format("woff2"),url("/content/themes/rof-living/webfonts/Sora-SemiBold.woff?x21021") format("woff");
    font-style:normal;font-weight:400;
    font-display: swap;
}
        /*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */

/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */

/* Document
   ========================================================================== */

html {
  font-family: sans-serif; /* 1 */
  line-height: 1.15; /* 2 */
  -ms-text-size-adjust: 100%; /* 3 */
  -webkit-text-size-adjust: 100%; /* 3 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

a, button {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */

a:active,
a:hover {
  outline-width: 0;
}

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details, /* 1 */
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}





html,
button,
input,
select,
textarea {
    color: #222;
}

body {
    font-size: 1em;
    line-height: 1.4;
}

::-moz-selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}

::selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

img {
    vertical-align: middle;
}

fieldset, iframe, figure, blockquote {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: vertical;
}

.chromeframe {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

ul, ol, h1, h2, h3, h4, h5, h6, p {
  margin: 0;
  padding: 0;
  list-style: none;
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: normal;
}

a {
  text-decoration: none;
  color: inherit;
}

[class^="icon-"]:before, [class*=" icon-"]:before {
  width: auto;
  margin-right: 0;
  margin-left: 0;
}

select::-ms-expand {
    display: none;
}






/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}

.slick-slide {
  outline: 0;
}


.btn-wp-edit {
  display: block;
  float: left;
  position: fixed;
  bottom: 1rem;
  left: 1rem;
  z-index: 10000;
  color: #fff;
  background: #222;
  min-width: 1.875rem;
  height: 1.875rem;
  line-height: 1.875rem;
  text-align: center;
  border-radius: .9375rem;
  white-space: nowrap;
  font-family: Arial;
  text-transform: uppercase;
}

.btn-wp-edit i {
  position: absolute;
  top: 0;
  left: 0.55rem;
}

.btn-wp-edit > span {
  display: inline-block;
  position: relative;
  overflow: hidden;
  max-width: 0;
  -webkit-transition: max-width 150ms;
  -moz-transition: max-width 150ms;
  -ms-transition: max-width 150ms;
  -o-transition: max-width 150ms;
  transition: max-width 150ms;
  margin-left: 1.875rem;
}

.btn-wp-edit:hover > span {
  max-width: 12.5rem;
}

.btn-wp-edit > span > span {
  display: inline-block;
  padding-right: 0.55rem;
  font-size: .75rem;
}

.btn-wp-edit {
	font-size: 16px;
	bottom: 0;
	left: 0;
	min-width: 2.275em;
	height: 2.275em;
	line-height: 2.275em;
	border-radius: 0;
}

.btn-wp-edit i {
	left: 0.65em;
}

.btn-wp-edit > span {
	margin-left: 2.275em;
}

.btn-wp-edit > span > span {
	font-size: .75em;
	padding-right: .65em;
}

.btn-wp-edit:hover > span {
	max-width: 12.5em;
}

.sn-col-set {
  letter-spacing:-.31em;
  *letter-spacing:normal;
  *word-spacing:-.43em;
  text-rendering:optimizespeed;
  display:-webkit-flex;
  display: flex;
  -webkit-flex-flow:row wrap;
  display:-ms-flexbox;
  -ms-flex-flow:row wrap;
  flex-flow: row wrap;
  -ms-align-content:flex-start;
  -webkit-align-content:flex-start;
  align-content:flex-start;
}

.sn-col-set-nowrap {
  -webkit-flex-flow: row nowrap;
      -ms-flex-flow: row nowrap;
          flex-flow: row nowrap;
}

.sn-col-set > * {
  display:inline-block;
  *display:inline;
  zoom:1;
  letter-spacing:normal;
  word-spacing:normal;
  vertical-align:top;
  text-rendering:auto;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  background-clip: padding-box;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
          
}

.sn-col-set-1 > * {
  width: 100%;
  margin-right: 0;
}

.sn-col-set-2 > * {
  width: 50%;
}

.sn-col-set-3 > * {
  width: 33.33333333333333333333%;
}

.sn-col-set-4 > * {
  width: 25%;
}

.sn-col-set-5 > * {
  width: 20%;
}

.sn-col-set-6 > * {
  width: 16.66666666666666666666%;
}

.sn-col-set > .sn-col-auto,
.sn-col-set-footer > * {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

html:not(.explorer) .sn-col-set .sn-col-equal-height {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
}

.sn-col-set .sn-col-space-between {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-flex-flow: column nowrap;
      -ms-flex-flow: column nowrap;
          flex-flow: column nowrap;
}

.sn-col-set .sn-col-valigned {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-flex-flow: column nowrap;
      -ms-flex-flow: column nowrap;
          flex-flow: column nowrap;
}

.pull-left {
  float: left;
}

.pull-right {
  float: right;
}

.btn {
  border: 0;
  border-radius: 0;
  display: inline-block;
  white-space: nowrap;
  font-size: 1rem;
  background: transparent;
  position: relative;
}

button.btn {
  -webkit-appearance: none;
  appearance: none;
}

.btn-set {
  margin-top: 1.2em;
}

span.loading {
  height: 0;
  width: 0;
  display: inline-block;
  vertical-align: bottom;
  position: relative;
  transition: all 150ms;
  transform: scale(0);
}

span.loading img {
  width: 100%;
  padding: 0.75rem;
  position: absolute;
  top: -0.9rem;
  left: 0;
  animation: spin .4s infinite linear;
}

span.loading.now {
  height: 1.3rem;
  width: 1.3rem;
  transform: scale(1);
}

img.ajax-loader {
  display: none !important;
}

button.btn {
  -webkit-appearance: none;
  appearance: none;
  outline: 0;
  box-shadow: none;
}

.lnk {
  display: inline-block;
  transition: opacity 250ms;
}

.btn:hover,
.lnk:hover,
a:hover span.btn {
}

.btn span.icon {
  margin: 0 .875rem;
}

.btn span.icon,
.btn span.label,
.lnk span.icon,
.lnk span.label {
  display: inline-block;
  line-height: 1.4;
  vertical-align: top;
  white-space: normal;
}

.lnk span.icon {
  margin: 0 .875em;
}

.btn span.icon:last-child,
.lnk span.icon:last-child {
  margin-right: 0;
}

.btn span.icon:first-child,
.lnk span.icon:first-child {
  margin-left: 0;
}

.spanned > span {
  display: block;
}

.figure-cover {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.figure-contain {
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}

.figure-cover img,
.figure-contain img {
  display: none;
}

img.rounded {
  display: inline-block;
  border-radius: 50%;
}

.to-be-added {
	transform: translateY(60px);
  opacity: 0;
  transition: transform 1.2s, opacity 1.2s;
	transition-timing-function: cubic-bezier(0.19,1,.22,1);
}

.just-added {
	transform: translateY(0px);
	opacity: 1;
}

button.link {
	all: inherit;
	cursor: pointer;
}










address {
  font-style: normal;
}

a {
	text-decoration-skip: ink;
}

:focus:not(:focus-visible) { outline: none }

html {
  overflow-y: scroll;
  -webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.wysiwyg a {
  word-wrap: break-word;
}


select option {
  background: #fff;
  color: #000;
}








	/* ROOT */

	:root {
    
    --base-font-1-regular: "Sora Regular", sans-serif;
    --base-font-1-semibold: "Sora SemiBold", sans-serif;
    --base-font-2-regular: "RecifeDisplay-Regular", serif;
    
    --px-mobile: calc((100 / 375) * 1vw);
    --px: calc((100 / 1670) * 1vw);
    --base-unit: var(--px);
	
		--ttf: cubic-bezier(0.19, 1, 0.22, 1);
    --ttf-2: cubic-bezier(0.075, 0.820, 0.165, 1);
    --ttf-3: cubic-bezier(0.64, 0, 0.78, 0);
    --ttf-4: cubic-bezier(0.8, 0, 0.2, 1);
    --ttf-5: cubic-bezier(0.165, 0.84, 0.4, 1);
    --ttf-6: cubic-bezier(0.6, 0.07, 0.17, 1);
    --ttf-7: cubic-bezier(0.247, 0.75, 0.187, 1);
    --ttf-8: cubic-bezier(1, 0, 0, 1);
    
    --header-padding-top: max(48px, calc(100 * var(--px)));
    
    --page-padding-top: max(230px, calc(316 * var(--px)));
    --page-padding-left: calc(100 * var(--px));
    --page-padding-right: var(--page-padding-left);
  
		--base-color-black: #000;
    --base-color-white: #fff;
    
    --base-color-anthracite: #212119;
    --base-color-cold-anthracite: #1D1D1E;
    --base-color-warm-gray: #b6b4a2;
    --base-color-light-gray: #eaeaea;
	
	}



  @media (min-width: 2200px) {
      
    :root {
      --px: 1.317px;
    }
    
  }



  @media (max-width: 500px) {
    
    :root {
      --page-padding-left: 20px;
      --page-padding-right: 20px;
    }
    
  }











 
 
	/* BASE */

	body {
	  font-size: 100%;
		font-family: var(--base-font-1-regular);
		font-weight: 400;
	  color: var(--base-color-anthracite);
	  line-height: 1.3;
	  background: var(--base-color-white);
	}

	input, textarea, select, button {
		font-family: var(--base-font-1-regular);
		font-weight: 400;
	  color: var(--base-color-anthracite);
	}

	img {
	  max-width: 100%;
    height: auto;
	}  

	*:not(.has-component-inner) .module-inner,
	header.main > .inner,
  footer.main > .inner,
	.cookie-bar > .inner,
	*.has-component-inner .component-inner {
	  position: relative;
	  margin: 0 auto;
	  padding-left: var(--page-padding-left);
	  padding-right: var(--page-padding-right);
	  box-sizing: border-box;
	}

	.module-full-width .module-inner {
	  max-width: none;
	  padding-left: 0;
	  padding-right: 0;
	}

	.load-more {
	  text-align: center;
	}

	.wysiwyg a {
	  text-decoration: underline;
	}

  @media (hover: hover) {
  	.wysiwyg a:is(:hover, :focus) {
  	  text-decoration: none;
  	}
  }

	.wysiwyg > *:not(:last-child) {
	  margin-bottom: 1em;
	}

	.wysiwyg strong {
    font-weight: normal;
    font-family: var(--base-font-1-semibold);
	}

	.wysiwyg > ul:not(.plain),
	.wysiwyg > ol:not(.plain) {
	  counter-reset: supernovae;
	}

	.wysiwyg > ul:not(.plain) li,
	.wysiwyg > ol:not(.plain) li {
	  position: relative;
	  padding-left: 1.5em;
	}

	.wysiwyg > ul:not(.plain) li:not(:last-child),
	.wysiwyg > ol:not(.plain) li:not(:last-child) {
	}

	.wysiwyg > ul:not(.plain) li::before {
	  content: '—';
	  position: absolute;
	  left: 0;
	}

	.wysiwyg > ol:not(.plain) li::before {
		content: counter(supernovae) '.';
		counter-increment: supernovae;
	  position: absolute;
	  left: 0;
	}

	.wysiwyg > ul ul li::before {
	}

	.wysiwyg > ul ul,
	.wysiwyg > ol ol {
	}

	.wysiwyg table {
	  width: auto !important;
	}

	.wysiwyg table td {
	  width: auto !important;
	  height: auto !important;
	}

	@keyframes spin {
	    from {transform:rotate(0deg);}
	    to {transform:rotate(360deg);}
	}

	span.loading img {
		top: -12px;
	}

	span.loading {
		vertical-align: middle;
	}

	.btn-menu {
		appearance: none;
		-webkit-appearance: none;
		-moz-appearance: none;
		margin: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
		cursor: pointer;
		color: inherit;
	}






  /* HEADLINES */

  *[class*="hdln-"] {
  	font-family: var(--base-font-2-regular);
    font-size: max(var(--min-font-size, 1rem), min(var(--this-font-size), var(--max-font-size, var(--this-font-size))));
    --this-font-size: calc(var(--font-size) * (100 / var(--scale-breakpoint)) * 1vw);
    --scale-breakpoint: 1670;
  }
  
  /* factor: 1.317 */
  
  .hdln-155 {
  	--font-size: 155;
    --min-font-size: 3.125rem;
    --max-font-size: 12.75rem;
    line-height: 1.03225806451612903225;
  }
  
  @media (max-width: 500px) {
    .hdln-155 {
      line-height: 1.2;
    }
  }
  
  .hdln-100 {
  	--font-size: 100;
    --min-font-size: 4.0625rem;
    --max-font-size: 8.1875rem;
    line-height: 1;
  }
  
  .hdln-70 {
  	--font-size: 70;
    --min-font-size: 1.75rem;
    --max-font-size: 5.761875rem;
    line-height: 1.2;
  }

  .hdln-65 {
  	--font-size: 65;
    --min-font-size: 1.6875rem;
    --max-font-size: 5.3503125rem;
    line-height: 1.2;
  }
  
  @media (max-width: 500px) {
    .hdln-65 {
      line-height: 1.44444444444444444444;
    }
  }
  
  .hdln-45 {
  	--font-size: 45;
    --min-font-size: .9375rem;
    --max-font-size: 3.7040625rem;
    line-height: 1.2;
  }

  .hdln-40 {
  	--font-size: 40;
    --min-font-size: 1.4375rem;
    --max-font-size: 3.2925rem;
    line-height: 1.425;
  }
  
  @media (max-width: 500px) {
    .hdln-40 {
      line-height: 1.52;
    }
  }

  .hdln-30 {
  	--font-size: 30;
    --min-font-size: 1.125rem;
    --max-font-size: 2.469375rem;
    line-height: 1.46666666666666666666;
  }
  
  @media (max-width: 500px) {
    .hdln-30 {
      line-height: 1.72222222222222222222;
    }
  }

  .hdln-25 {
  	--font-size: 25;
    --min-font-size: 1.25rem;
    --max-font-size: 2.0578125rem;
    line-height: 1.2;
  }

	
	
	/* COPIES */

	*[class*="cpy-"] {
		font-family: var(--base-font-1-regular);
    font-size: max(var(--min-font-size, 1rem), min(var(--this-font-size), var(--max-font-size, var(--this-font-size))));
    --this-font-size: calc(var(--font-size) * (100 / var(--scale-breakpoint)) * 1vw);
    --scale-breakpoint: 1670;
	}
  
  /* factor: 1.317 */

	*[class*="cpy-"][class*="cpy-b"] {
		font-family: var(--base-font-1-semibold);
	}

	.cpy-45 {
		--font-size: 45;
    --min-font-size: 1rem;
    --max-font-size: 3.7040625rem;
	}
  
	.cpy-20 {
		--font-size: 20;
    --min-font-size: .9375rem;
    --max-font-size: 1.64625rem;
    line-height: 1.7;
	}
  
  @media (max-width: 500px) {
    .cpy-20 {
      line-height: 1.8;
    }
  }
  
	.cpy-16 {
		--font-size: 16;
    --min-font-size: .875rem;
    --max-font-size: 1.317rem;
    line-height: 1.6875;
	}

	.cpy-14 {
		--font-size: 14;
    --min-font-size: .75rem;
    --max-font-size: 1.152375rem;
	}
  
  @media (max-width: 500px) {
    .cpy-14 {
      line-height: 1.66666666666666666666 !important;
    }
  }





	/* PAGE TRANSITIONS */

	.transitioner {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		pointer-events: none;
		z-index: 998;
	}

	.transitioner::before {
		content: '';
		position: absolute;
		display: block;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background: #b6b4a2;
		opacity: 0;
		z-index: 1;
		will-change: transform;
	}

	.barba-outer,
	.sn-pt-leave-active,
	.sn-pt-enter-active {
		transition: opacity;
		transition-duration: 1.2s;
		opacity: 1;
	}

	.sn-pt-leave-active .module,
	.sn-pt-enter-active .module,
	.barba-once-active .module {
		transition: opacity 2s, transform 2s;
		transition-timing-function: var(--ttf-7);
	}

	.sn-pt-leave-active .transitioner::before,
	.sn-pt-enter-active .transitioner::before,
	.barba-once-active .transition::before {
		transition: opacity .75s;
		transition-timing-function: var(--ttf-7);
	}	
	.sn-pt-enter-active .transitioner::before {
		transition-delay: .15s;
	}

	/* Starting state for leave */
	.sn-pt-leave .module {
		opacity: 1;
	}
	.sn-pt-leave .transitioner::before {
		opacity: 0;
	}

	/* Ending state for leave */
	.sn-pt-leave-to .module {
		opacity: 1;
	}
	.sn-pt-leave-to .transitioner::before {
		opacity: 1;
	}

	/* Starting state for enter */
	.sn-pt-enter .module,
	.barba-once .module {
		/*opacity: 0;*/
		transform: translateY(20vh);
	}
	.sn-pt-enter .transitioner::before,
	.barba-once .transitioner::before {
		opacity: 1;
	}

	/* Ending state for enter */
	.sn-pt-enter-to .module,
	.barba-once-to .module {
		opacity: 1;
		transform: none;
	}
	.sn-pt-enter-to .transitioner::before,
	.barba-once-to .transitioner::before {
		opacity: 0;
	}













	/* ON SCREEN */


	/* clip left to right */
	*[data-ios] *[data-ios-item="a"] {
		opacity: 0;
		-webkit-clip-path: inset(0% 100% 0% 0%);
		clip-path: inset(0% 100% 0% 0%);
		transition: clip-path 1.5s, -webkit-clip-path 1.5s, opacity 1.5s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-item-index) * 100ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="a"] {
		opacity: 1;
		-webkit-clip-path: inset(0% 0% 0% 0%);
		clip-path: inset(0% 0% 0% 0%);
	}


	/* clip top to bottom */
	*[data-ios] *[data-ios-item="b"] {
		opacity: 0;
		-webkit-clip-path: inset(0% 0% 100% 0%);
		clip-path: inset(0% 0% 100% 0%);
		transition: clip-path 1.5s, -webkit-clip-path 1.5s, opacity 1.5s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-item-index) * 100ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="b"] {
		opacity: 1;
		-webkit-clip-path: inset(0% 0% 0% 0%);
		clip-path: inset(0% 0% 0% 0%);
	}


	/* pop randomly */
	*[data-ios] *[data-ios-item="c"] {
		transform: scale(0.8);
		opacity: 0;
		transition: transform 1s, opacity 1s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-random) * 30ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="c"] {
		opacity: 1;
		transform: none;
	}


	/* clip vertically from center */
	*[data-ios] *[data-ios-item="d"] {
		opacity: 0;
		-webkit-clip-path: inset(50% 0% 50% 0%);
		clip-path: inset(50% 0% 50% 0%);
		transition: clip-path 1.5s, -webkit-clip-path 1.5s, opacity 1.5s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-item-index) * 100ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="d"] {
		opacity: 1;
		-webkit-clip-path: inset(0% 0% 0% 0%);
		clip-path: inset(0% 0% 0% 0%);
	}


	/* move in from bottom */
	*[data-ios] *[data-ios-item="e"] {
		opacity: 0;
		transform: translateY(2vw);
		transition: opacity 1.5s, transform 1.5s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-item-index) * 100ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="e"] {
		opacity: 1;
		transform: none;
	}


	/* move in from right */
	*[data-ios] *[data-ios-item="f"] {
		opacity: 0;
		transform: translateX(20vw);
		transition: opacity 1.5s, transform 1.5s;
		transition-timing-function: cubic-bezier(.075, .82, .165, 1);
		transition-delay: calc((var(--ios-item-index) * 100ms) + var(--ios-delay, 0ms));
		will-change: opacity;
	}

	*[data-ios].is-on-screen *[data-ios-item="f"] {
		opacity: 1;
		transform: none;
	}





	button, .btn, .lnk {
    
		font-family: var(--base-font-1-semibold);
    font-size: max(var(--min-font-size, 1rem), min(var(--this-font-size), var(--max-font-size, var(--this-font-size))));
    --this-font-size: calc(var(--font-size) * (100 / var(--scale-breakpoint)) * 1vw);
    --scale-breakpoint: 1670;
    
		margin: 0;
		border: 0;
		padding: 0;
		border-radius: 0;
		box-shadow: none;
		background: transparent;
		display: inline-block;
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		cursor: pointer;
    
	}
  
  
  
  .btn-a {
    --font-size: 15;
    --min-font-size: .8125rem;
    --max-font-size: 1.2346875rem;
    text-transform: uppercase;
    color: var(--base-color-warm-gray);
    border: 1px solid currentColor;
    border-radius: .26666666666666666666em;
    padding: 1.15em 5.5em 1.25em;
  }
  
  @media (max-width: 500px) {
    
    .btn-a {
      padding-inline: 3.5em;
    }
    
  }
	




  .btn-icon-only {
    --size: max(36px, calc(49 * var(--px)));
    width: var(--size);
    height: var(--size);
    display: block;
    border: 1px solid var(--base-color-warm-gray);
    border-radius: 50%;
    box-sizing: content-box;
    position: relative;
  }
  
  .btn-icon-only .icon {
    margin: 0 !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  
  .btn-icon-only .icon svg {
    display: block;
    width: calc(.24489795918367346938 * var(--size));
    height: auto;
  }
  
  .btn-icon-only .label {
    position: absolute;
    top: -10000px;
    left: -10000px;
    width: 0;
    height: 0;
    overflow: hidden;
  }







  header.main {
    position: absolute;
    top: 0;
    left: 0;
    padding-top: var(--header-padding-top);
    width: 100%;
  }
  
  .site-title--header {
    position: relative;
    z-index: 2;
  }
  
  .site-title a {
    display: inline-block;
  }
  
  .site-title svg {
    width: max(180px, calc(280 * var(--px)));
    height: auto;
    display: block;
  }
  
  body.view-subpage .site-title svg path {
    fill: var(--base-color-warm-gray);
  }
  
  
  
  
  
  header.main .languages {
    position: absolute;
    top: min(-20px, calc(-30 * var(--px)));
    right: calc(var(--page-padding-right) * 0.6);
    color: var(--base-color-white);
    z-index: 2;
  }
  
  @media (max-width: 500px) {
    
    header.main .languages {
      right: var(--page-padding-right);
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  .btn-menu {
    position: fixed;
    top: calc(var(--header-padding-top) + (var(--size) / 2));
    right: calc(var(--page-padding-right) * 0.6);
    z-index: 102;
    --size: 48px;
    width: var(--size);
    height: var(--size);
    mix-blend-mode: difference;
  }
  
  .btn-menu .bar {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    height: 4px;
    width: 100%;
    background: var(--base-color-white);
    transition: 500ms var(--ttf-2);
    transition-property: translate, rotate, top, right, width;
  }
  
  .btn-menu .bar-1 {
    top: calc(.33333333333333333333 * var(--size));
  }
  
  .btn-menu .bar-2 {
    top: calc(.58333333333333333333 * var(--size));
    width: 65%;
  }
  
  .btn-menu .bar-3 {
    display: none;
  }
  
  body.menu .btn-menu .bar-1,
  body.menu .btn-menu .bar-2 {
    top: 50%;
    right: 50%;
    translate: 50% -50%;
    width: 100%;
  }
  
  body.menu .btn-menu .bar-1 {
    rotate: -45deg;
  }
  
  body.menu .btn-menu .bar-2 {
    rotate: 45deg;
  }
  
  
  @media (max-width: 500px) {
    
    .btn-menu {
      --size: 30px;
      top: 72px;
      right: var(--page-padding-right);
    }
    
    .btn-menu .bar {
      height: 3px;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  div.flyout {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 101;
    overflow: auto;
    opacity: 0;
    pointer-events: none;
    transition: opacity 500ms var(--ttf-2);
  }
  
  body.menu div.flyout {
    opacity: 1;
    pointer-events: all;
    transition-duration: 0ms;
  }
  
  div.flyout::before {
    content: '';
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #111111;
    z-index: 1;
    transform: scaleX(0);
    transform-origin: right top;
    transition: 1s var(--ttf-4);
    transition-property: transform;
  }
  
  body.menu div.flyout::before {
    transform: none;
  }
  
  body.menu-closing div.flyout::before {
    transition-delay: 1s;
    transition-duration: 0s;
  }
  
  div.flyout > .inner {
    position: relative;
    z-index: 2;
    color: var(--base-color-white);
    padding-inline: var(--page-padding-left);
    padding-bottom: var(--page-padding-left);
  }
  
  .site-title--flyout {
    position: absolute;
    top: var(--header-padding-top);
    opacity: 0;
    transition: opacity 1s var(--ttf-7) 600ms;
  }
  
  .site-title--flyout svg path {
    fill: var(--base-color-white) !important;
  }
  
  body.menu .site-title--flyout {
    opacity: 1;
  }
  
  body.menu-closing .site-title--flyout {
    transition-delay: 1s;
    transition-duration: 0s;
  }
  
  nav.header {
    padding-top: var(--page-padding-top);
  }
  
  nav.header .menu {
    display: flex;
    flex-flow: row nowrap;
  }
  
  nav.header .sub-menu li + li {
    margin-top: max(20px, 0.35em);
  }
  
  nav.header .menu > li > a {
    display: none;
  }
  
  nav.header .menu > li:first-child {
    margin-right: calc(250 * var(--px));
  }
  
  nav.header .sub-menu li {
    position: relative;
    transform: translateX(100px);
    opacity: 0;
    transition: 1.5s var(--ttf-7) calc((50ms * var(--index, 0)) + 400ms);
    transition-property: transform, opacity;
  }
  
  body.menu nav.header .sub-menu li {
    opacity: 1;
    transform: none;
  }
  
  body.menu-closing nav.header .sub-menu li {
    transition-delay: 1s;
    transition-duration: 0s;
  }
  
  
  @media (max-width: 500px) {
    
    nav.header .menu > li:first-child {
      margin-right: 40px;
    }
    
  }
  
  
  
  
  
  
  
  
  
  body:not(.view-subpage, .view-meta) header.main [data-ios-item] {
    transform: translateY(-10vh);
    opacity: 0;
    transition: 2s var(--ttf-7);
    transition-property: opacity, transform;
  }
  
  body:not(.view-subpage, .view-meta) header.main.is-on-screen [data-ios-item] {
    opacity: 1;
    transform: none;
  }





  footer.main {
    background: var(--base-color-cold-anthracite);
    color: var(--base-color-white);
    padding-block: max(75px, calc(192 * var(--px))) max(60px, calc(140 * var(--px)));
    position: relative;
    overflow: hidden;
  }
  
  footer.main > .inner {
    padding-inline: calc(270 * var(--px)) var(--page-padding-right);
    position: relative;
    z-index: 2;
  }
  
  footer.main .hdln-30 {
    color: var(--base-color-warm-gray);
    margin-bottom: 1.2em;
    --min-font-size: 1.75rem;
  }
  
  footer.main .signet {
    position: absolute;
    top: calc(68 * var(--px));
    left: calc(-200 * var(--px));
    width: calc(744 * var(--px));
    opacity: 0.06;
    pointer-events: none;
    z-index: 1;
  }
  
  footer.main .signet img {
    display: block;
    width: 100%;
    height: auto;
  }
  
  
  @media (max-width: 1200px) {
    
    footer.main > .inner {
      padding-left: var(--page-padding-left);
      max-width: 1100px;
      margin-right: 0;
    }
    
  }
  
  
  @media (max-width: 700px) {
    
    footer.main .signet {
      top: auto;
      bottom: -50px;
      left: -50px;
      width: 100vw;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  
  footer.main .row-1 {
    display: flex;
    flex-flow: row nowrap;
    --gap: 0px calc(60 * var(--px));
    gap: var(--gap);
    max-width: calc(1130 * var(--px));
  }
  
  footer.main .row-1 .col-1 {
    width: 100%;
  }
  
  footer.main .row-1 .col-2 {
    flex-shrink: 0;
  }
  
  footer.main .headline:not(:first-child) {
    margin-top: 2em;
  }
  
  footer.main span.label {
    display: inline-block;
    width: 1.75em;
  }
  
  nav.footer .menu {
    display: flex;
    flex-flow: row nowrap;
    gap: var(--gap);
  }
  
  nav.footer .menu > li {
    min-width: calc(280 * var(--px));
    width: 100%;
  }
  
  nav.footer .menu > li > a {
    display: block;
    font-family: var(--base-font-2-regular);
    font-size: 1.5em;
    margin-bottom: 1em;
  }
  
  nav.footer .sub-menu {
    border-top: 1px solid #979797;
  }
  
  nav.footer .sub-menu > li {
    border-bottom: 1px solid #979797;
  }
  
  nav.footer .sub-menu a {
    display: block;
    padding: 0.45em 0;
  }
  
  
  
  
  @media (max-width: 950px) {
    
    footer.main .row-1 .col-2 {
      margin-left: auto;
    }
    
    footer.main .row-1 {
      max-width: none;
    }
    
    nav.footer .menu > li {
      min-width: fit-content;
    }
    
  }
  
  
  
  @media (max-width: 700px) {
    
    footer.main .row-1 {
      flex-flow: column nowrap;
      gap: 70px;
    }
    
    footer.main .row-1 .col-2 {
      width: 100%;
    }
    
  }
  
  
  
  @media (max-width: 500px) {
    
    nav.footer .menu {
      flex-flow: column nowrap;
      gap: 30px;
    }
    
    footer.main .col-2 .hdln-30 {
      margin-bottom: 0.6em;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  
  
  footer.main .row-2 {
    margin-top: max(90px, calc(310 * var(--px)));
    display: flex;
    flex-flow: row nowrap;
  }
  
  footer.main .row-2 .back-to-top {
    margin-left: auto;
  }
  
  nav.legal .menu {
    display: flex;
    flex-flow: row wrap;
    gap: 0px 6.4em;
  }
  
  @media (max-width: 750px) {
    
    nav.legal .menu {
      gap: 0px 1.5em;
    }
    
  }
  
  
  
  
  
/*
Theme Name: ROF Living
Author: SUPERNOVÆ
Author URI: https://www.supernov.ae/
Version: 2023
*/





@media print,
       (-o-min-device-pixel-ratio: 5/4),
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 120dpi) {

}

/* ==========================================================================
   Helper classes
   ========================================================================== */

.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    *text-indent: -9999px;
}

.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 150%;
}

.hidden {
    display: none !important;
    visibility: hidden;
}

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

.invisible {
    visibility: hidden;
}

.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    *zoom: 1;
}

/* ==========================================================================
   Print styles
   ========================================================================== */

@media print {

  * {
      background: transparent !important;
      color: #000 !important;
      box-shadow: none !important;
      text-shadow: none !important;
  }

  a,
  a:visited {
      text-decoration: underline;
  }

  .ir a:after,
  a[href^="javascript:"]:after,
  a[href^="#"]:after {
      content: "";
  }

  pre,
  blockquote {
      border: 1px solid #999;
      page-break-inside: avoid;
  }

  thead {
      display: table-header-group;
  }

  tr,
  img {
      page-break-inside: avoid;
  }

  img {
      max-width: 100% !important;
  }

  @page {
      margin: 1cm;
  }

  p,
  h2,
  h3 {
      orphans: 3;
      widows: 3;
  }

  h2,
  h3 {
      page-break-after: avoid;
  }
  
  .cookie-bar,
  .btn-wp-edit {
    display: none !important;
  }
  
  header.main,
  footer.main {
    display: none;
  }
    
}




  /* CUSTOM POINTER */

  *[data-custom-pointer] {
  	cursor: none;
  }

  #pointer-overlay {
  	position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    pointer-events: none;
    --pointer-size: min(218px, calc(218 * var(--base-unit)));
  }

  #pointer-overlay[data-pointer-type="close"] {
    --pointer-size: min(70px, calc(70 * var(--base-unit)));
  }

  #pointer-overlay svg {
    display: block;
  	width: var(--pointer-size);
  	height: var(--pointer-size);
  }

  #pointer-overlay svg path {
    fill: var(--base-color-white);
  }

  #pointer-overlay > div {
  	position: absolute;
  	top: calc(var(--pointer-size) / -2);
  	left: calc(var(--pointer-size) / -2);
  	width: var(--pointer-size);
  	height: var(--pointer-size);
  	cursor: none;
  	transform: translate(var(--pointer-left, 0px), var(--pointer-top, 0px)) rotate(var(--pointer-angle, 0deg));
  	transition: transform 75ms, opacity 250ms;
  }

  #pointer-overlay[data-pointer-type="close"] > div {
    transform: translate(var(--pointer-left, 0px), var(--pointer-top, 0px));
  }

  #pointer-overlay > div > div {
  	width: 100%;
  	height: 100%;
  	transition: transform 250ms, opacity 250ms;
  	transition-timing-function: var(--ttf);
  	opacity: 0;
  	transform: scale(0.5);
  }

  #pointer-overlay > div > div > div {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    transition: transform 150ms;
  }

  #pointer-overlay[data-pointer-type="arrow-left"] > div > div .arrow,
  #pointer-overlay[data-pointer-type="arrow-right"] > div > div .arrow {
    opacity: 1;
  }

  #pointer-overlay[data-pointer-type="arrow-left"] > div > div .arrow {
    transform: rotateY(-180deg);
  }

  #pointer-overlay[data-pointer-type="close"] > div > div .close {
    opacity: 1;
  }

  #pointer-overlay[data-state="on"] > div > div {
  	opacity: 1;
  	transform: none;
  }






  body.view-meta {
    background: var(--base-color-cold-anthracite);
    color: var(--base-color-white);
  }
  
  body.view-meta footer.main {
    display: none;
  }


  :root {
    --module-margin-200: max(110px, calc(200 * var(--px)));
    --module-margin-80: max(44px, calc(80 * var(--px)));
  }
  
  .module.mrgn-200 {
    margin-bottom: var(--module-margin-200);
  }
  
  .module.mrgn-80 {
    margin-bottom: var(--module-margin-80);
  }
  
  .module.mrgn-0-if-last:last-child {
    margin-bottom: 0;
  }
  
  
  
  
  
  
  
  
  .image-caption {
    position: relative;
    padding-bottom: 1.33333333333333333333em;
    line-height: 1.5;
    margin-top: 2em;
  }
  
  .image-caption > * {
    display: block;
  }
  
  .image-caption strong {
    font-weight: normal;
    font-family: var(--base-font-1-semibold);
  }
  
  .image-caption::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(94 * var(--px));
    height: 3px;
    background: var(--base-color-warm-gray);
  }


  .module-section-teaser .row--headline {
    position: relative;
    border-left: 16px solid var(--base-color-warm-gray);
    margin-bottom: max(40px, calc(50 * var(--px)));
    transform: translateY(calc(8vh * var(--parallax-y, 0)));
  }
  
  .module-section-teaser .row--headline .headline {
    padding-left: .51612903225806451612em;
  }
  
  .module-section-teaser .module-inner {
    padding-block: max(70px, calc(230 * var(--px)));
  }
  
  
  
  @media (max-width: 500px) {
    
    .module-section-teaser .row--headline {
      transform: none;
      border-left-width: 10px;
    }
    
    .module-section-teaser .row--headline .headline {
      padding-left: .35em;
    }
    
  }
  
  
  
  
  
  
  
  
  
  .module-section-teaser .row--copy,
  .module-section-teaser .section-copy {
    max-width: max(640px, calc(850 * var(--px)));
    margin-left: auto;
    margin-right: calc(170 * var(--px));
  }
  
  .module-section-teaser .wysiwyg > * {
    max-width: max(595px, calc(790 * var(--px)));
  }
  
  .module-section-teaser .wysiwyg p.intro {
    color: var(--base-color-warm-gray);
    max-width: none;
  }

  .module-section-teaser .row--copy .btn-set {
    margin-top: max(30px, calc(58 * var(--px)));
  }
  
  
  @media (max-width: 500px) {
    
    .module-section-teaser .row--copy,
    .module-section-teaser .section-copy {
      margin-right: 0;
    }
    
  }


  .sn-slider {
    --gap: calc(40 * var(--px));
    user-select: none;
  }
  
  .sn-slider-track {
    width: 100%;
    position: relative;
		overflow: hidden;
		overflow-x: scroll;
		-ms-overflow-style: none;
		scrollbar-width: none;
		-webkit-overflow-scrolling: touch;
  }
  
	.sn-slider-track::-webkit-scrollbar {
		display: none;
	}
  
  
  
  
  .sn-slider-slides {
    display: flex;
    flex-flow: row nowrap;
    width: max-content;
  }
  
  .sn-slider-slide {
    margin-right: var(--gap);
  }
  
  
  
  
  .sn-slider-progress {
    position: relative;
    height: 14px;
    pointer-events: none;
  }
  
  .sn-slider-progress span {
    display: block;
    position: absolute;
    left: 0;
    height: 100%;
    width: var(--progress, 0%);
    background: var(--base-color-black);
  }


  .zoom-image {
    position: relative;
    overflow: hidden;
    display: block;
    clip-path: inset(0 100% 100% 0);
    transition: clip-path 2s var(--ttf-4) 250ms;
  }
  
  .is-on-screen .zoom-image {
    clip-path: inset(0 0 0 0);
  }
  
  .zoom-image img,
  .zoom-image video {
    scale: 1.2;
    opacity: 1;
    translate: 0px calc(var(--parallax-y, 0) * 10%);
    transition: scale 5s 0s var(--ttf-7), opacity 5s 0s var(--ttf-7), translate .5s 0s var(--ttf-7);
  }
  
  
  @media (max-width: 500px) {
    .is-on-screen .zoom-image img,
    .is-on-screen .zoom-image video {
      translate: 0px 0px;
      scale: 1;
    }
  }



  .module-copy .module-wrap {
    max-width: max(620px, calc(790 * var(--px)));
    margin-inline: auto;
  }
  
  .module-copy .wysiwyg p.intro,
  .module-copy .wysiwyg .headline {
    color: var(--base-color-warm-gray);
  }
  
  .module-copy .wysiwyg .headline:not(:first-child) {
    margin-top: 2.5em;
  }
  
  .module-copy .signet {
    margin-top: max(26px, calc(49 * var(--px)));
  }
  
  .module-copy .signet svg {
    width: max(26px, calc(39 * var(--px)));
    height: auto;
    display: block;
  }
  
  
  
  
  
  body.view-meta .module-copy .module-inner {
    padding-top: var(--page-padding-top);
  }
  
  body.view-meta .module-copy .module-wrap > .headline {
    margin-bottom: .3em;
  }
  
  body.view-meta .module-copy .wysiwyg p.intro,
  body.view-meta .module-copy .wysiwyg .headline {
    color: var(--base-color-white);
  }
  
  
  
  
  
  @media (max-width: 500px) {
    
    body.view-meta .module-copy .module-wrap > .headline {
      --min-font-size: 1.875rem;
      margin-bottom: 1em;
    }
    
    .module-copy .wysiwyg p.intro {
      --min-font-size: 1.4375rem;
    }
    
  }



  .module-intro {
    background: var(--base-color-cold-anthracite);
    color: var(--base-color-white);
    padding-top: var(--page-padding-top);
  }
  
  .module-intro .intro-copy {
    max-width: max(510px, calc(1250 * var(--px)));
  }
  
  .module-intro .btn-set {
    margin-top: max(30px, calc(65 * var(--px)));
  }
  
  
  
  
  
  .module-intro .row-2 {
    position: relative;
    margin-top: max(75px, calc(107 * var(--px)));
    margin-inline: calc(var(--page-padding-left) * -1);
  }
  
  .module-intro .row-2 .shade {
    display: none;
  }
  
  .module-intro video {
    display: block;
    width: 100%;
    height: auto;
  }
  
  @media (max-width: 500px) {
    
    .module-intro video {
      aspect-ratio: 375 / 340;
      object-fit: cover;
    }
    
  }
  
  
  
  
  
  
  
  .module-intro .row-3 {
    margin-top: max(60px, calc(170 * var(--px)));
  }
  
  .module-intro .copy {
    max-width: max(710px, calc(1250 * var(--px)));
  }
  
  .module-intro .signet {
    margin-top: max(20px, calc(25 * var(--px)));
  }
  
  .module-intro .signet img {
    width: max(27px, calc(37 * var(--px)));
    height: auto;
    display: block;
  }
  
  
  
  
  
  .module-intro .row-4 {
    position: relative;
    margin-top: max(40px, calc(40 * var(--px)));
    margin-inline: calc(var(--page-padding-left) * -1);
  }
  
  .module-intro .row-4 > div {
    position: relative;
    z-index: 2;
    display: flex;
    flex-flow: row wrap;
    margin-inline: var(--page-padding-left);
  }
  
  .module-intro .row-4::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: max(150px, calc(280 * var(--px)));
    background: var(--base-color-white);
    z-index: 1;
  }
  
  .module-intro .image-1 {
    width: calc(500 * var(--px));
    margin-inline: auto calc(100 * var(--px));
    margin-top: calc(197 * var(--px));
  }
  
  .module-intro .image-2 {
    width: calc(790 * var(--px));
  }
  
  .module-intro .image-3 {
    margin-top: calc(109 * var(--px));
    width: calc(555 * var(--px));
    margin-left: calc(510 * var(--px));
  }
  
  .module-intro .image-caption {
    color: var(--base-color-anthracite);
  }
  
  
  @media (max-width: 500px) {
    
    .module-intro .row-4 {
      margin-top: 80px;
    }
    
    .module-intro .row-4 > div {
      flex-flow: column nowrap;
    }
    
    .module-intro .image-1 {
      width: calc(233 * var(--px-mobile));
      margin: 0;
      margin-bottom: 40px;
    }
    
    .module-intro .image-2 {
      width: auto;
      margin: 0;
      margin-right: calc(var(--page-padding-left) * -1);
      margin-bottom: 40px;
    }
    
    .module-intro .image-3 {
      width: calc(310 * var(--px-mobile));
      margin: 0;
    }
    
    .module-intro .row-4::before {
      height: 200px;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  .module-intro .upper-wrap [data-ios-item] {
    transform: translateY(20vh);
    opacity: 0;
    transition: 2s var(--ttf-7) calc(var(--ios-item-index, 0) * 100ms);
    transition-property: opacity, transform;
  }
  
  .module-intro .upper-wrap.is-on-screen [data-ios-item] {
    opacity: 1;
    transform: none;
  }

  @media (max-width: 500px) {
  
    .module-large-image .image {
      margin-inline: calc(var(--page-padding-left) * -1);
    }
  
    .module-large-image .image img {
      aspect-ratio: 375 / 315 !important;
      object-fit: cover;
      height: auto;
    }
  
  }




  .module-page-title .module-inner {
    padding-top: var(--page-padding-top);
  }
  
  .module-page-title .hdln-155 {
    --min-font-size: 1.875rem;
    hyphens: auto;
  }





  .module-related-services .row--headline {
    margin-bottom: max(35px, calc(70 * var(--px)));
  }

  .related-services-list {
    --base-width: 100%;
    --columns: 3;
    --column-width: calc((var(--base-width) - (var(--column-gap) * var(--columns))) / var(--columns));
    --column-gap: calc(59 * var(--px));
    --row-gap: max(23px, calc(55 * var(--px)));
    margin-right: calc(var(--column-gap) * -1);
    margin-bottom: calc(var(--row-gap) * -1);
    display: flex;
    flex-flow: row wrap;
  }

  .related-services-list > * {
    width: var(--column-width);
    margin-right: var(--column-gap);
    margin-bottom: var(--row-gap);
  }
  
  .related-services-list a {
    border: 1px solid #979797;
    border-radius: 6px;
    box-sizing: border-box;
    padding: max(16px, calc(20 * var(--px)));
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    color: var(--base-color-warm-gray);
  }
  
  .module-related-services .btn-icon-only {
    --size: max(27px, calc(36 * var(--px)));
  }
  
  
  
  @media (max-width: 900px) {
    
    .related-services-list {
      --columns: 2;
    }
    
  }
  
  
  
  
  @media (max-width: 650px) {
    
    .related-services-list {
      --columns: 1;
    }
    
    .related-services-list a {
      padding-block: 10px;
      padding-right: 10px;
    }
    
  }

  .module-what-we-offer .row--sections {
    margin-top: max(60px, calc(150 * var(--px)));
  }
  
  .module-what-we-offer .row--sections section + section {
    margin-top: max(120px, calc(150 * var(--px)));
  }
  
  .module-what-we-offer .section-copy {
    margin-bottom: max(42px, calc(90 * var(--px)));
  }
  
  .module-what-we-offer .section-copy .headline {
    margin-bottom: .42857142857142857142em;
  }
  
  .module-what-we-offer .services {
    overflow: hidden;
  }
  
  .module-what-we-offer .services-list {
    --base-width: 100%;
    --columns: 3;
    --column-width: calc((var(--base-width) - (var(--column-gap) * var(--columns))) / var(--columns));
    --column-gap: calc(62 * var(--px));
    --row-gap: calc(54 * var(--px));
    margin-right: calc(var(--column-gap) * -1);
    margin-bottom: calc(var(--row-gap) * -1);
    display: flex;
    flex-flow: row wrap;
  }
  
  .module-what-we-offer .services-list > * {
    width: var(--column-width);
    margin-right: var(--column-gap);
    margin-bottom: var(--row-gap);
  }
  
  .services-list > * {
    box-sizing: border-box;
    border: 1px solid #979797;
    border-radius: 6px;
    padding-block: max(20px, calc(65 * var(--px))) max(25px, calc(43 * var(--px)));
    padding-inline: max(18px, calc(30 * var(--px)));
    display: flex;
    flex-flow: column nowrap;
    opacity: 0;
    transform: scale(0.98); 
    transition: 1s var(--ttf-7) calc((var(--ios-item-index, 0) * 200ms) + 500ms);
    transition-property: opacity, transform;
  }
  
  .services.is-on-screen .services-list > * {
    opacity: 1;
    transform: none;
  }
  
  .services-list .number {
    color: var(--base-color-light-gray);
  }
  
  .services-list .headline {
    color: var(--base-color-warm-gray);
    margin-bottom: .66666666666666666666em;
  }
  
  .services-list .btn-set {
    margin-top: auto;
    padding-top: max(15px, calc(27 * var(--px)));
  }
  
  
  
  
  @media (max-width: 900px) {
    
    .module-what-we-offer .services-list {
      --columns: 2;
    }
    
  }
  
  
  
  
  @media (max-width: 500px) {
    
    .module-what-we-offer .services-list {
      --columns: 1;
    }
    
  }



  .module-who-we-are {
    background: var(--base-color-light-gray);
  }
  
  .module-who-we-are .module-inner {
    padding-bottom: calc(370 * var(--px));
  }



  .module-why {
    background: var(--base-color-cold-anthracite);
    color: var(--base-color-white);
    z-index: 2;
    position: relative;
  }
  
  .module-why .module-inner {
    padding-top: 0;
  }
  
  .module-why .row--images {
    margin-inline: calc(var(--page-padding-left) * -1);
    position: relative;
    height: calc(823 * var(--px));
    top: calc(-180 * var(--px));
    margin-bottom: calc(-100 * var(--px));
  }
  
  .module-why .row--images img {
    display: block;
    width: 100%;
    height: auto;
  }
  
  .module-why .row--images .image-1 {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(787 * var(--px));
  }
  
  .module-why .row--images .image-2 {
    position: absolute;
    top: calc(372 * var(--px));
    right: calc(252 * var(--px));
    width: calc(530 * var(--px));
  }
  
  .module-why .read-more-copy {
    max-height: 0px;
    position: relative;
    overflow: hidden;
    transform: translateY(-5px);
    opacity: 0;
    transition: 1s var(--ttf-7);
    transition-property: opacity, transform, max-height;
  }
  
  .module-why.is-expanded .read-more-copy {
    max-height: var(--max-height, 2000px);
    transform: none;
    opacity: 1;
  }
  
  .module-why .read-more-copy .wysiwyg {
    margin-top: 1em;
  }
  
  .module-why .btn-set {
    transition: opacity 1s var(--ttf-2) 0s;
  }
  
  .module-why.is-expanded .btn-set {
    opacity: 0;
    pointer-events: none;
  }
  
  
  
  @media (max-width: 500px) {
    
    .module-why .row--images {
      height: auto;
      flex-flow: column nowrap;
      display: flex;
      margin-bottom: 75px;
    }
    
    .module-why .row--images .image-1 {
      position: static;
      width: calc(350 * var(--px-mobile));
      margin-bottom: 75px;
    }
    
    .module-why .row--images .image-2 {
      position: static;
      width: calc(245 * var(--px-mobile));
      margin-left: calc(82 * var(--px-mobile));
    }
    
  }/* These styles are used in the backend editor AND in the Theme (frontend) */

/* Most themes nowadays provide an extra stylesheet of classes which WordPress itself then */
/* applies to the backend editor TinyMCE. However, custom CSS - set in Plugins, in the WP  */
/* Customizer or in Theme options, will normally not be reflected to TinyMCE. So better to */
/* put such styles all here, where they will apply to TinyMCE *and* the frontend.          */

/* The goal is not only to make the visual editor display look as much like the frontend as    */
/* possible, but also to make sure that all important CSS classes are available for convenient */
/* selection in TinyMCEs "Formats" dropdown - so do not forget to configure the TinyMCE styles */
/* dropdown with elements to match those here.                                                 */

/* If you do not need this file then upload an empty one (zero bytes) which will not be loaded at all. */

/* Suggested general non-tag-specific visual styles */



/* Append your site-specific styles here */
