@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide__track--draggable{-webkit-touch-callout:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide__track--fade>.splide__list>.splide__slide{margin:0!important;opacity:0;z-index:0}.splide__track--fade>.splide__list>.splide__slide.is-active{opacity:1;z-index:1}.splide--rtl{direction:rtl}.splide__track--ttb>.splide__list{display:block}.splide__container{box-sizing:border-box;position:relative}.splide__list{backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important}.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:not(.is-overflow) .splide__pagination{display:none}.splide__progress__bar{width:0}.splide{position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;position:relative}.splide__slide img{vertical-align:bottom}.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__sr{clip:rect(0 0 0 0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.splide__toggle.is-active .splide__toggle__play,.splide__toggle__pause{display:none}.splide__toggle.is-active .splide__toggle__pause{display:inline}.splide__track{overflow:hidden;position:relative;z-index:0}@font-face {
  font-family: 'fontello';
  src: url('/content/themes/suprema/fontello/font/fontello.eot?28302404&x86169');
  src: url('/content/themes/suprema/fontello/font/fontello.eot?28302404#iefix&x86169') format('embedded-opentype'),
       url('/content/themes/suprema/fontello/font/fontello.woff2?28302404') format('woff2'),
       url('/content/themes/suprema/fontello/font/fontello.woff?28302404&x86169') format('woff'),
       url('/content/themes/suprema/fontello/font/fontello.ttf?28302404&x86169') format('truetype'),
       url('/content/themes/suprema/fontello/font/fontello.svg?28302404#fontello&x86169') 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/suprema/fontello/font/fontello.svg?28302404#fontello&x86169') 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:"Matter SQ Light";
    src:url("/content/themes/suprema/webfonts/MatterSQ-Light.woff2") format("woff2"),url("/content/themes/suprema/webfonts/MatterSQ-Light.woff?x86169") format("woff"),url("/content/themes/suprema/webfonts/MatterSQ-Light.otf?x86169") format("opentype");
    font-style:normal;font-weight:400;
    font-display: swap;
}
        
@font-face {
    font-family:"Matter SQ Medium";
    src:url("/content/themes/suprema/webfonts/MatterSQ-Medium.woff2") format("woff2"),url("/content/themes/suprema/webfonts/MatterSQ-Medium.woff?x86169") format("woff"),url("/content/themes/suprema/webfonts/MatterSQ-Medium.otf?x86169") format("opentype");
    font-style:normal;font-weight:400;
    font-display: swap;
}
        
@font-face {
    font-family:"Matter SQ Regular";
    src:url("/content/themes/suprema/webfonts/MatterSQ-Regular.woff2") format("woff2"),url("/content/themes/suprema/webfonts/MatterSQ-Regular.woff?x86169") format("woff"),url("/content/themes/suprema/webfonts/MatterSQ-Regular.otf?x86169") format("opentype");
    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;
}

.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;
  word-break: break-word;
}


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

[data-kinetic].sn-kinetic-ready,
[data-kinetic].sn-kinetic-ready * {
  cursor: grab;
}

[data-kinetic].sn-kinetic-ready.sn-kinetic-mousedown,
[data-kinetic].sn-kinetic-ready.sn-kinetic-mousedown * {
  cursor: grabbing;
}

[data-kinetic] :is(area, a, input, button),
[data-kinetic] :is(area, a, input, button) * {
  cursor: pointer !important;
}



summary {
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}









	/* ROOT */

	:root {
    
    --base-font-1-light: "Matter SQ Light", sans-serif;
    --base-font-1-medium: "Matter SQ Medium", sans-serif;
    --base-font-1-regular: "Matter SQ Regular", sans-serif;
    
    --min-vw: 380;
    --max-vw: 1670;
    
    --px: min(1px, calc((100 / 1670) * 1vw));
    --px-mobile: calc((100 / 380) * 1vw);
    --base-unit: var(--px);
	
		--ttf: var(--ttf-1);
    --ttf-1: 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);
    --ttf-9: cubic-bezier(.47, 3.64, .41, .8);
    
    --page-padding-top: 0;
    
    --page-padding-left: max(16px, calc(65 * var(--px)));
    --page-padding-right: var(--page-padding-left);
    
    --page-padding-left-l: max(16px, calc(198 * var(--px)));
    --page-padding-right-l: var(--page-padding-left-l);
    
    --header-padding-top: max(64px, calc(90 * var(--px)));
    
    --page-offset-top: max(180px, calc(380 * var(--px)));
    
    --offset-348: calc(348 * var(--px));
  
		--base-color-black: #000;
    --base-color-white: #fff;
    
    --base-color-red: #D93830;
    --base-color-light-gray: #DADADA;
    --base-color-off-white: #f3f1f0;
    --base-color-light-gray: #dadada;
    --base-color-gray: #a9a9a9;
	
	}



  @media (max-width: 750px) {
    
    :root {
      --page-padding-left-l: var(--page-padding-left);
    }
    
  }












 
 
	/* BASE */

	html {
		scroll-behavior: smooth;
	}

	html.is-transitioning,
	html.is-forced-scrolling,
  html.lenis-scrolling {
		scroll-behavior: auto;
	}
  
  .lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain;
  }
  
  .lenis.lenis-stopped {
    overflow: hidden;
  }

  .lenis.lenis-scrolling iframe {
    pointer-events: none;
  }

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

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

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

	*:not(.has-component-inner) .module-inner,
	header.main > .inner,
  footer.main > .inner,
	.cookie-bar > .inner,
  div.flyout > .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;
	}

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

	.load-more {
	  text-align: center;
	}
  
  .wysiwyg {
    -webkit-hyphens: auto;
    -webkit-hyphenate-limit-after: 8;
    -webkit-hyphenate-limit-before: 8;
    hyphens: auto;
    hyphenate-limit-chars: 15;
    text-wrap: pretty;
  }

	.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 {
	}

	.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;
	}

  .skip-link {
    position: absolute;
    top: 0;
    left: -10000em;
    background: #000;
    color: #fff;
    padding: 1rem;
    z-index: 10000;
  }
  
  .skip-link:focus {
    left: 0;
  }
  
  nav button[aria-haspopup] {
    position: absolute;
    top: 0;
    right: 10000em;
  }
  
  nav button[aria-haspopup] span[aria-hidden="true"] {
    display: none;
  }
  
  nav button[aria-haspopup]:focus {
    right: 0;
  }
  
  nav button[aria-haspopup]:focus span[aria-hidden="true"] {
    display: block;
  }




  *[class*="hdln-"] {
  
  	font-family: var(--base-font-1-regular);
  
    --rise: calc(var(--max-font-size, 16) - var(--min-font-size, 16));
    --run: calc(var(--max-vw) - var(--min-vw));
    --slope: calc(var(--rise) / var(--run));
  
    --min-vw-px: calc(var(--min-vw) * 1px);
    --min-font-size-px: calc(var(--min-font-size) * 1px);

    --fluid-font-size-px:
      calc(
        var(--slope) * (100vw - var(--min-vw-px)) + var(--min-font-size-px)
      );

    --max-font-size-px: calc(var(--max-font-size) * 1px);

    font-size:
      clamp(
        var(--min-font-size-px),
        var(--fluid-font-size-px),
        var(--max-font-size-px)
      );
  
  }
  
  *[class*="hdln-"][class*="hdln-l"] {
    font-family: var(--base-font-1-light);
  }

  *[class*="hdln-"][class*="hdln-m"] {
    font-family: var(--base-font-1-medium);
  }
  
  
  
  
  .hdln-250 {
    --min-font-size: 70;
    --max-font-size: 250;
    /*line-height: .74;*/
    line-height: 1.1;
    letter-spacing: -0.04em;
  }

  .hdln-187 {
    --min-font-size: 70;
    --max-font-size: 187;
    line-height: 1.1;
    letter-spacing: -.03150000000000000000em;
  }
  
  .hdln-155 {
    --min-font-size: 53;
    --max-font-size: 155;
    line-height: 1;
  }

  .hdln-31 {
    --min-font-size: 21;
    --max-font-size: 31;
  }
  
  
  
  
  
  :is(.headline, .outer-headline).animated > span {
    overflow: hidden;
    position: relative;
    display: block;
    margin-bottom: -0.2em;
  }
  
  :is(.headline, .outer-headline).animated > span:nth-child(2) { --index: 1; }
  :is(.headline, .outer-headline).animated > span:nth-child(3) { --index: 2; }
  :is(.headline, .outer-headline).animated > span:nth-child(4) { --index: 3; }
  :is(.headline, .outer-headline).animated > span:nth-child(5) { --index: 4; }
  :is(.headline, .outer-headline).animated > span:nth-child(6) { --index: 5; }
  
  :is(.headline, .outer-headline).animated > span > span {
    display: inline-block;
    position: relative;
    transform: rotate(3deg) translateY(100%);
    transform-origin: left top;
    opacity: 0;
    transition: 1750ms var(--ttf-7) calc((var(--index, 0) * 150ms) + var(--initial-delay, 0ms));
    transition-property: opacity, transform;
  }
  
  .is-on-screen :is(.headline, .outer-headline).animated > span > span {
    opacity: 1;
    transform: none;
  }
  
  @media (max-width: 500px) {
    
    :is(.headline, .outer-headline).animated > span {
      margin-bottom: -0.1em;
    }
    
  }

	
	
  *[class*="cpy-"] {
  
  	font-family: var(--base-font-1-regular);
  
    --rise: calc(var(--max-font-size, 16) - var(--min-font-size, 16));
    --run: calc(var(--max-vw) - var(--min-vw));
    --slope: calc(var(--rise) / var(--run));
  
    --min-vw-px: calc(var(--min-vw) * 1px);
    --min-font-size-px: calc(var(--min-font-size) * 1px);

    --fluid-font-size-px:
      calc(
        var(--slope) * (100vw - var(--min-vw-px)) + var(--min-font-size-px)
      );

    --max-font-size-px: calc(var(--max-font-size) * 1px);

    font-size:
      clamp(
        var(--min-font-size-px),
        var(--fluid-font-size-px),
        var(--max-font-size-px)
      );
  
  }

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

  *[class*="cpy-"][class*="cpy-m"] {
    font-family: var(--base-font-1-medium);
  }
  
  
  
  .cpy-31 {
    --min-font-size: 17;
    --max-font-size: 31;
    line-height: 1.45161290322580645161;
  }
  
  .intro-copy.cpy-31 strong {
    font-family: var(--base-font-1-medium);
    font-weight: normal;
    color: var(--base-color-red);
  }
  
  .cpy-22 {
    --min-font-size: 14;
    --max-font-size: 22;
    line-height: 1.40909090909090909090;
  }

  .cpy-18 {
    --min-font-size: 14;
    --max-font-size: 18;
    line-height: 1.72222222222222222222;
  }
  
  .cpy-10 {
    --min-font-size: 9;
    --max-font-size: 10;
  }




  @media (max-width: 500px) {
    
    .cpy-31 {
      line-height: 1.529;
    }
    
    .cpy-22,
    .cpy-18 {
      line-height: 1.5;
    }
    
  }





	/* 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: #fff;
		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 1s, transform 1s;
		transition-timing-function: cubic-bezier(0.19,1,.22,1);
	}

	.sn-pt-leave-active .transitioner::before,
	.sn-pt-enter-active .transitioner::before,
	.barba-once-active .transition::before {
		transition: opacity .75s;
		transition-timing-function: cubic-bezier(0.19,1,.22,1);
	}	
	.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(80px);*/
	}
	.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 {
		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;
    
  	font-family: var(--base-font-1-regular);
  
    --rise: calc(var(--max-font-size, 16) - var(--min-font-size, 16));
    --run: calc(var(--max-vw) - var(--min-vw));
    --slope: calc(var(--rise) / var(--run));
  
    --min-vw-px: calc(var(--min-vw) * 1px);
    --min-font-size-px: calc(var(--min-font-size) * 1px);

    --fluid-font-size-px:
      calc(
        var(--slope) * (100vw - var(--min-vw-px)) + var(--min-font-size-px)
      );

    --max-font-size-px: calc(var(--max-font-size) * 1px);

    font-size:
      clamp(
        var(--min-font-size-px),
        var(--fluid-font-size-px),
        var(--max-font-size-px)
      );
    
	}
	









  div.load-more {
    margin-top: max(100px, calc(125 * var(--px)));
  }

  .btn-load-more {
    --min-font-size: 16;
    --max-font-size: 18;
    display: inline-block;
    position: relative;
  }
  
  .btn-load-more span.wrap {
    display: block;
    position: relative;
  }
  
  .btn-load-more span.wrap::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 1px;
    background: var(--base-color-white);
    height: 2.66666666666666666666em;
  }

  .btn-load-more span.label {
    display: block;
    text-align: center;
    padding-bottom: 3.88888888888888888888em;
  }











  .btn-icon-only {
    position: relative;
  }
  
  .btn-icon-only span.label {
    display: block;
    position: absolute;
    left: -1000000em;
    width: 1px;
    height: 1px;
    overflow: hidden;
  }
  
  .btn-icon-only svg {
    display: block;
    height: auto;
  }

  .btn-icon-only[data-icon="arrow--right"] svg {
    width: max(28px, calc(28 * var(--px)));
  }








  header.main nav.header .menu > li > a {
  }

  header.main nav.header .menu > li > a:is(:hover, :focus),
  header.main nav.header .menu > li:is(:hover, :focus-within, .current-menu-any) > a {
  }

  header.main nav.header li.has-sub-menu {
    position: relative;
  }

  header.main nav.header li.has-sub-menu .sub-menu-wrapper {
    position: absolute;
    top: 100%;
    left: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-3px);
    transition: 250ms var(--ttf-7);
    transition-property: opacity, transform;
    will-change: transform;
    z-index: 2;
    interactivity: inert;
  }

  body:not(.is-tabbing) header.main nav.header li.has-sub-menu:is(:hover, :focus-within) .sub-menu-wrapper,
  body.is-tabbing header.main nav.header li.has-sub-menu:has(button[aria-expanded="true"]) .sub-menu-wrapper {
    opacity: 1;
    transform: none;
    pointer-events: all;
    interactivity: auto;
  }
  
  
  
  
  
  
  
  
  header.main {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    color: var(--base-color-white);
  }
  
  :is(header.main, div.flyout) > .inner {
    padding-top: var(--header-padding-top);
  }
  
  :is(header.main, div.flyout) .col-set {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
  }
  
  :is(header.main, div.flyout) .col-1 {
    width: var(--offset-348);
  }
  
  :is(header.main, div.flyout) .col-3 {
    margin-left: auto;
  }
  
  @media (max-width: 750px) {
    
    :is(header.main, div.flyout) .col-1 {
      width: auto;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  
  
  .site-title a {
    display: block;
    width: fit-content;
  }
  
  .site-title img {
    display: block;
    width: max(105px, calc(141 * var(--px)));
    height: auto;
  }
  
  
  
  
  
  
  
  
  
  nav.header {
    text-transform: uppercase;
  }
  
  nav.header .menu {
    display: flex;
    flex-flow: row nowrap;
    gap: 0 2em;
  }
  
  @media (max-width: 750px) {
    
    nav.header {
      display: none;
    }
    
  }
  
  
  
  
  
  
  
  
  
  
  
  :is(header.main, div.flyout) .languages a {
    display: inline-block;
    position: relative;
  }
  
  @media (max-width: 750px) {
    
    :is(header.main, div.flyout) .languages {
      padding-right: 60px;
    }
    
  }
  
  @media (min-width: 751px) {
    
    :is(header.main, div.flyout) .languages a::before {
      content: '';
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      border-radius: 50%;
      border: 1px solid currentColor;
      width: 3.38888888888888888888em;
      height: 3.38888888888888888888em;
    }
  
  }
  
  
  
  
  
  
  
  
  
  
  
  
  .btn-menu {
    display: none;
    width: 33px;
    height: 33px;
    position: relative;
    margin-top: -7px;
  }
  
  .btn-menu .bar {
    display: block;
    position: absolute;
    left: 0;
    height: 2px;
    width: 100%;
    background: var(--base-color-white);
    top: 50%;
    transform-origin: center center;
    transition: transform 500ms var(--ttf-2);
    z-index: 2;
  }
  
  .btn-menu .bar-1 {
    transform: translateY(-4px);
  }
  
  .btn-menu .bar-2 {
    transform: translateY(4px);
  }
  
  .btn-menu .bar-3 {
    display: none;
  }

  
  @media (max-width: 750px) {
    
    .btn-menu {
      display: block;
      position: fixed;
      top: var(--header-padding-top);
      right: var(--page-padding-right);
      z-index: 1002;
    }
    
    body.menu .btn-menu .bar-1 {
      transform: rotate(-45deg);
    }
    
    body.menu .btn-menu .bar-2 {
      transform: rotate(45deg);
    }
    
    .btn-menu::before {
      opacity: 0;
      content: '';
      display: block;
      position: absolute;
      inset: -3px -50px -5px -12px;
      background: var(--base-color-red);
      z-index: 1;
      transition: opacity 250ms var(--ttf-2);
    }
    
    body.scrolled-more .btn-menu::before {
      opacity: 1;
    }
    
  }
  
  
  
  
  
  
  
  
  
  div.flyout {
    position: fixed;
    inset: 0;
    z-index: 1001;
    visibility: hidden;
    color: var(--base-color-white);
    opacity: 0;
    transition: opacity 150ms 0ms, visibility 0ms 150ms;
  }
  
  @media (max-width: 750px) {
  
    body.menu div.flyout {
      visibility: visible;
      opacity: 1;
      transition: opacity 0ms 0ms, visibility 0ms 0ms;
    }
  
    div.flyout::before {
      content: '';
      display: block;
      position: absolute;
      inset: 0;
      background: var(--base-color-red);
      z-index: 1;
      transform: scaleX(0);
      transform-origin: right center;
      transition-delay: 150ms;
    }
  
    body.menu div.flyout::before {
      transform: none;
      transition: transform 500ms var(--ttf-7);
    }
  
    div.flyout > .inner {
      position: relative;
      z-index: 2;
      display: flex;
      flex-flow: column nowrap;
      min-height: 100%;
      box-sizing: border-box;
      padding-bottom: 56px;
    }
  
    div.flyout .row-2 {
      padding-top: 85px;
      padding-left: 120px;
    }
  
    nav.flyout .cpy-18 {
      --min-font-size: 23;
      --max-font-size: 46;
      text-transform: uppercase;
    }
  
    nav.flyout .menu {
      display: flex;
      flex-flow: column nowrap;
      gap: 20px 0;
    }
    
    div.flyout .row-3 {
      margin-top: auto;
      padding-top: 30px;
      padding-left: 120px;
      --index: 4;
    }
    
    nav.flyout .menu > li,
    div.flyout .row-3 {
      transform: translateX(30px);
      opacity: 0;
      transition-delay: 150ms;
    }
    
    body.menu nav.flyout .menu > li,
    body.menu div.flyout .row-3 {
      transform: none;
      opacity: 1;
      transition: 500ms var(--ttf-7);
      transition-delay: calc((var(--index, 0) * 50ms) + 100ms);
      transition-property: opacity, transform;
    }
    
  }





  footer.main {
    background: var(--base-color-red);
    color: var(--base-color-white);
  }
  
  footer.main > .inner {
    padding-block: max(45px, calc(82 * var(--px)));
  }
  
  
  
  
  footer.main :is(.row-1, .row-2) {
    --gap-x: calc(78 * var(--px));
    display: flex;
    flex-flow: row nowrap;
    gap: 0 var(--gap-x);
  }
  
  footer.main .row-2 {
    margin-top: max(209px, calc(340 * var(--px)));
  }
  
  footer.main .col-1 {
    width: calc(var(--offset-348) - var(--gap-x));
    flex-shrink: 0;
  }
  
  
  
  
  footer.main .row-1 .col-2 {
    display: flex;
    flex-flow: row wrap;
    width: 100%;
    gap: 40px calc(20 * var(--px));
  }
  
  footer.main .row-1 .col-2 address {
    width: 100%;
    max-width: 23.05555555555555555555em;
  }
  
  address abbr {
    text-decoration: none !important;
    display: inline-block;
    width: 1.5em;
  }
  
  footer.main .row-1 > * {
    position: relative;
    border-top: 1px solid var(--base-color-white);
    padding-top: max(45px, calc(82 * var(--px)));
  }
  
  
  
  
  
  nav.footer .menu {
    display: flex;
    flex-flow: row nowrap;
    gap: 0 3.88888888888888888888em;
  }
  
  footer.main .row-2 .col-2 {
    display: flex;
    flex-flow: row nowrap;
    width: 100%;
    justify-content: space-between;
  }
  
  
  
  
  
  
  @media (max-width: 750px) {
    
    footer.main .row-1 > * {
      border-top: 0;
    }
    
    footer.main .row-1 {
      border-top: 1px solid var(--base-color-white);
      flex-flow: column nowrap;
      gap: 40px 0;
    }
    
    footer.main .col-1 {
      width: auto;
    }
    
    footer.main .row-1 .col-2 {
      padding-top: 0;
      margin-left: calc((153 * var(--px-mobile)) - var(--page-padding-left));
      width: auto;
    }
    
    footer.main .row-2 {
      position: relative;
    }
    
    nav.footer .menu {
      flex-flow: column nowrap;
      gap: 0;
      position: absolute;
      left: calc((153 * var(--px-mobile)) - var(--page-padding-left));
      top: -120px;
    }
    
  }/*
Theme Name: Suprema
Author: SUPERNOVÆ
Author URI: https://www.supernov.ae/
Version: 2025
*/





@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;
  }







  #gallery-overlay,
  #floorplan-overlay,
  #meta-overlay {
    --max-width: 100%;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: var(--max-width);
    overflow: hidden;
    pointer-events: none;
    --padding-top: 52px;
    --padding-bottom: 56px;
  }

  #gallery-overlay.shown-3,
  #floorplan-overlay.shown-3,
  #meta-overlay.shown-3 {
    pointer-events: all;
  }

  #gallery-overlay,
  #floorplan-overlay,
  #meta-overlay {
    z-index: 10002;
    color: var(--base-color-white);
  }

  #gallery-overlay::after,
  #floorplan-overlay::after,
  #meta-overlay::after {
    content: '';
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: var(--max-width);
    background: var(--base-color-black);
    z-index: 2;
    opacity: 0;
    transition: 1000ms var(--ttf-6);
    transition-property: opacity;
  }

  #gallery-overlay.shown::after,
  #floorplan-overlay.shown::after,
  #meta-overlay.shown::after {
    opacity: 0.85;
    transform: none;
  }

  #gallery-overlay > .inner,
  #floorplan-overlay > .inner,
  #meta-overlay > .inner {
    position: relative;
    z-index: 3;
  }

  #gallery-overlay .overlay-body,
  #floorplan-overlay .overlay-body,
  #meta-overlay .overlay-body {
    position: relative;
    opacity: 0;
    padding-block: var(--padding-top) var(--padding-bottom);
  }

  #gallery-overlay.shown-2 .overlay-body,
  #floorplan-overlay.shown-2 .overlay-body,
  #meta-overlay.shown-2 .overlay-body {
    opacity: 1;
    transition: 1000ms var(--ttf-2);
    transition-property: opacity;
    transition-delay: 75ms;
  }

  #gallery-overlay.is-fading-out .overlay-body,
  #floorplan-overlay.is-fading-out .overlay-body,
  #meta-overlay.is-fading-out .overlay-body {
    opacity: 0 !important;
    transition: none !important;
  }

  #gallery-overlay .btn-close-contact-overlay,
  #floorplan-overlay .btn-close-floorplan-overlay,
  #meta-overlay .btn-close-meta-overlay {
    opacity: 0; 
  }

  #gallery-overlay.shown-2 .btn-close-contact-overlay,
  #floorplan-overlay.shown-2 .btn-close-floorplan-overlay,
  #meta-overlay.shown-2 .btn-close-meta-overlay {
    opacity: 1;
    transition: opacity 1000ms 150ms var(--ttf-2);
  }

  #gallery-overlay.is-fading-out .btn-close-contact-overlay,
  #floorplan-overlay.is-fading-out .btn-close-floorplan-overlay,
  #meta-overlay.is-fading-out .btn-close-meta-overlay {
    opacity: 0 !important;
    transition: none !important;
  }

  #floorplan-overlay .floorplan-image {
    padding-inline: var(--page-padding-left);
  }

  #floorplan-overlay .floorplan-image img {
    display: block;
    max-width: none;
    width: 100%;
    height: calc(100vh - var(--padding-top) - var(--padding-bottom));
    object-fit: contain;
  }








  #gallery-overlay .overlay-header,
  #floorplan-overlay .overlay-header,
  #meta-overlay .overlay-header {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    padding-top: 0;
    height: var(--padding-top);
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
  }

  #gallery-overlay .overlay-header .header-buttons,
  #floorplan-overlay .overlay-header .header-buttons,
  #meta-overlay .overlay-header .header-buttons {
    
  }









  #gallery-overlay .sn-slider {
    --inner-width: calc(100vw - 200px);
    --gap: var(--page-padding-left);
    --inner-height: calc(100vh - var(--padding-top) - var(--padding-bottom));
    height: var(--inner-height);
  }

  #gallery-overlay .sn-slider-slides {
    opacity: 0;
    transition: opacity 1000ms 1000ms var(--ttf-7);
    padding-left: var(--page-padding-left);
  }

  #gallery-overlay.shown-2 .sn-slider-slides {
    opacity: 1;
  }

  #gallery-overlay .sn-slider-slide {
    width: calc(100vw - var(--scrollbar-width, 0) - (var(--gap) * 2));
  }

  #gallery-overlay .sn-slider-slide img {
    height: var(--inner-height);
    width: 100%;
    max-width: calc(var(--inner-width) - (150 * var(--px)));
    display: block;
    object-fit: contain;
    margin-inline: auto;
  }

  #gallery-overlay .sn-slider-progress {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 16px;
  }

  #gallery-overlay .sn-slider-progress span {
    background: var(--base-color-light-green);
  }

  @media (max-width: 500px) {
  
    #gallery-overlay .prev-next {
      display: none;
    }
  
    #gallery-overlay .sn-slider-slide {
      width: auto;
    }
  
    #gallery-overlay .sn-slider-slide img {
      width: auto;
      max-width: none;
    }
  
  }






  .btn-close-gallery-overlay,
  .btn-close-floorplan-overlay,
  .btn-close-meta-overlay {
    text-transform: uppercase;
  }







  #meta-overlay {
    --padding-bottom: var(--page-padding-left);
  }

  #meta-overlay .overlay-body {
    position: absolute;
    top: var(--padding-top);
    left: var(--page-padding-left);
    right: var(--page-padding-right);
    height: calc(100vh - var(--padding-top) - var(--padding-bottom));
    padding-block: 0;
    overflow: auto;
  }







  @media (max-width: 500px) {
  
    #gallery-overlay,
    #floorplan-overlay,
    #meta-overlay {
      --padding-top: 65px;
      --padding-bottom: 20px;
    }
  
    #gallery-overlay .overlay-header,
    #floorplan-overlay .overlay-header,
    #meta-overlay .overlay-header {
      height: auto;
      padding-top: 21px;
    }
  
    #gallery-overlay .sn-slider-progress {
      height: 10px;
    }
  
    #gallery-overlay .sn-slider {
      --gap: 10px;
      --inner-height: calc(100vh - var(--padding-top) - var(--padding-bottom));
    }
  
    #gallery-overlay .sn-slider-slide {
      scroll-margin-inline-start: 10px;
    }
  
    #gallery-overlay .sn-slider-slides {
      padding-left: 10px;
      padding-right: 10px;
    }
  
  }













  .media-item {
    position: relative;
    width: fit-content;
  }

  .media-item .btn-zoom {
    position: absolute;
    z-index: 2;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    --size: max(30px, calc(46 * var(--px)));
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    background: var(--base-color-white);
  }

  .media-item .btn-zoom svg {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 16px;
  }


  :root {
    --module-margin-200: max(100px, calc(200 * var(--px)));
  }
  
  .module.mrgn-200 {
    margin-bottom: var(--module-margin-200);
  }
  
  .module.mrgn-0-if-last:last-child {
    margin-bottom: 0;
  }




  html.overlay-shown {
    overflow: hidden !important;
  }

  #overlay,
  #contact-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10001;
    overflow: auto;
  }
  
  #contact-overlay {
    z-index: 10002;
  }
  
  #overlay::after,
  #contact-overlay::after {
    content: '';
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--base-color-off-black);
    z-index: 1;
    opacity: 0;
    transform: scaleY(0);
    transform-origin: center bottom;
    transition: 1000ms var(--ttf-6);
    transition-property: opacity, transform;
  }
  
  #overlay.shown::after,
  #contact-overlay.shown::after {
    opacity: 1;
    transform: none;
  }
  
  #overlay > .inner,
  #contact-overlay > .inner {
    position: relative;
    z-index: 2;
  }
  
  #overlay .overlay-body,
  #contact-overlay .overlay-body {
    position: relative;
    opacity: 0;
    color: var(--base-color-white);
  }
  
  #overlay.shown-2 .overlay-body,
  #contact-overlay.shown-2 .overlay-body {
    opacity: 1;
    transition: 1000ms var(--ttf-2);
    transition-property: opacity, transform;
    transition-delay: 75ms;
  }
  
  #contact-overlay.is-fading-out .overlay-body {
    opacity: 0 !important;
    transition: none !important;
  }

  #contact-overlay .overlay-header {
    opacity: 0; 
  }
  
  #contact-overlay.shown-2 .overlay-header {
    opacity: 1;
    transition: opacity 1000ms 150ms var(--ttf-2);
  }
  
  #contact-overlay.is-fading-out .overlay-header {
    opacity: 0 !important;
    transition: none !important;
  }
  
  #contact-overlay .overlay-header {
    position: relative;
  }
  
  #contact-overlay .overlay-header .site-title--overlay {
    position: fixed;
    top: var(--page-padding-top);
    left: var(--page-padding-left);
    z-index: 10;
  }
  
  #contact-overlay .overlay-header .site-title--overlay svg path {
    fill: var(--base-color-white);
  }
  
  
  
  
  
  
  
  #contact-overlay .btn-close-contact-overlay {
    position: fixed;
    top: var(--page-padding-top);
    right: var(--page-padding-left);
    z-index: 10;
    --size: max(56px, calc(67 * var(--px)));
    width: var(--size);
    height: var(--size);
    border: 1px solid var(--base-color-white);
    border-radius: 50%;
  }
  
  #contact-overlay .btn-close-contact-overlay svg {
    display: block;
    width: calc(var(--size) * .37313432835820895522);
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  
  #contact-overlay .btn-close-contact-overlay svg path {
    fill: var(--base-color-white);
  }
  
  #contact-overlay .btn-close-contact-overlay span.label {
    position: absolute;
    top: -10000px;
    left: -10000px;
    width: 0;
    height: 0;
    overflow: hidden;
  }


  .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;
    padding-left: var(--page-padding-left);
    padding-right: var(--page-padding-right);
    gap: 0px var(--gap);
  }
  
  .sn-slider-slide {
    width: max(312px, calc(540 * var(--px)));
    scroll-margin-inline-start: var(--page-padding-left);
  }
  
  .sn-slider:not(.is-scrolling) .sn-slider-slide {
    scroll-snap-align: start;
  }
  
  .sn-slider:not(.is-scrolling) .sn-slider-track {
    scroll-snap-type: x mandatory;
  }
  
  
  
  
  .sn-slider-progress {
    display: none;
  }
  
  .sn-slider-progress span {
    display: block;
    position: absolute;
    left: 0;
    height: 100%;
    width: var(--progress, 0%);
    background: var(--base-color-black);
  }
  
  
  


  
  .sn-slider-wrap {
    position: relative;
    --transition-duration: 1000;
  }
  
  .sn-slider:not(.sn-slider-ghost) {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    overflow-x: hidden;
    overflow-x: clip;
  }
  
  .sn-slider:not(.sn-slider-ghost) .sn-slider-track {
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateX(var(--sn-slider-scroll-left, 0px));
    width: auto;
    will-change: transform;
    transition: transform calc(var(--transition-duration, 0) * 1ms) var(--ttf-5);
  }
  
  @media (hover: none) {
    .sn-slider:not(.sn-slider-ghost) .sn-slider-track {
      transition: none;
    }
  }
  
  .sn-slider-wrap.is-wheeling .sn-slider:not(.sn-slider-ghost) .sn-slider-track {
    --transition-duration: 500;
    transition: transform calc(var(--transition-duration, 0) * 1ms) var(--ttf-5);
  }
  
  .sn-slider-ghost {
    position: relative;
    z-index: 2;
    opacity: 0;
  }
  
  
  
  
  
  
  
  
  nav.sn-slider-pagination {
    position: absolute;
    top: calc(100% + (25 * var(--px)));
    left: 0;
    width: 100%;
  }
  
  nav.sn-slider-pagination ul {
    display: flex;
    flex-flow: row nowrap;
    gap: 0 9px;
    justify-content: center;
  }
  
  nav.sn-slider-pagination button {
    display: block;
    background: currentColor;
    width: 10px;
    height: 10px;
    border-radius: 5px;
    transition: width calc(var(--transition-duration, 0) * 1ms) var(--ttf-2);
  }
  
  nav.sn-slider-pagination button[aria-current="true"] {
    width: 40px;
    interactivity: inert;
  }
  
  
  
  
  
  
  
  
  
  
  
  
  
  .sn-slider-wrap .prev-next {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
  } 
  
  .sn-slider-wrap .prev-next button {
    display: block;
    position: absolute;
    top: 50%;
    left: calc(var(--page-padding-left) * 2);
    width: 50px;
    z-index: 5;
    cursor: pointer;
    transform: translateY(-50%);
    pointer-events: all;
    transition: opacity 500ms var(--ttf-2);
  }
  
  .sn-slider-wrap .prev-next button.btn-next {
    left: auto;
    right: calc(var(--page-padding-left) * 2);
  }
  
  .sn-slider-wrap:is([style*=": 0%"], [style*=": 0."]) .prev-next button.btn-prev,
  .sn-slider-wrap:is([style*="100%"], [style*="99."]) .prev-next button.btn-next {
    opacity: 0;
    pointer-events: none;
  }
  
  .sn-slider-wrap .prev-next button svg {
    display: block;
    width: 100%;
    height: auto;
  }
  
  .sn-slider-wrap .prev-next button.btn-prev svg {
    rotate: -180deg;
  }
  
  .gallery-overlay-shown .sn-slider-wrap .prev-next button svg path {
    fill: var(--base-color-white);
  }


  .zoom-image {
    position: relative;
    overflow: hidden;
    display: block;
  }
  
  .zoom-image img,
  .zoom-image video {
    scale: 1.4;
    opacity: 0;
    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);
  }
  
  .is-on-screen .zoom-image img,
  .is-on-screen .zoom-image video {
    scale: 1.2;
    opacity: 1;
  }
  
  
  @media (max-width: 500px) {
    .is-on-screen .zoom-image img,
    .is-on-screen .zoom-image video {
      translate: 0px 0px;
      scale: 1;
    }
  }



  .module-about .module-inner {
    padding-inline: var(--page-padding-left-l);
  }
  
  .module-about .outer-headline {
    color: var(--base-color-light-gray);
  }
  
  .module-about .col-set {
    display: flex;
    flex-flow: row nowrap;
    gap: 0 calc(132 * var(--px));
    margin-right: calc(var(--page-padding-right-l) * -1);
  }
  
  .module-about .col-1 {
    width: calc(929 * var(--px));
    flex-shrink: 0;
  }
  
  .module-about .col-2 {
    padding-top: calc(60 * var(--px));
    width: 100%;
    transform: translateY(calc(var(--parallax-y, 0) * 150px));
  }
  
  
  
  *[data-component="intro-copy"] {
    
    display: flex;
    flex-flow: column nowrap;
    gap: max(30px, calc(60 * var(--px))) 0;
    
    .intro-copy {
      max-width: 28.22580645161290322580em;
    }
    
    .copy {
      max-width: 36.83333333333333333333em;
      margin-left: auto;
    }
    
    .copy-wrap {
      position: relative;
    }
    
    .copy-wrap figure {
      margin-top: calc(-132 * var(--px));
      margin-left: calc(var(--page-padding-left-l) * -1);
      width: max(260px, calc(332 * var(--px)));
      transform: translateY(calc(var(--parallax-y, 0) * 25px));
    }
    
    
    
    @media (max-width: 1400px) {
      
      .copy-wrap figure {
        margin-top: 50px;
        margin-left: 0;
      }
      
    }
    
    
    @media (max-width: 750px) {
      
      .copy {
        margin-left: 0;
      }
      
    }
    
  }
  
  
  
  
  
  
  
  .module-about [data-view="mobile"] {
    display: none;
  }
  
  @media (max-width: 750px) {
    
    .module-about [data-view="mobile"] {
      display: block;
      width: calc(260 * var(--px-mobile));
      margin-block: 60px;
      margin-left: auto;
    }
    
    .module-about .col-set {
      display: block;
      margin-right: 0;
    }
    
    .module-about .col-1 {
      width: 100%;
    }
    
    .module-about .col-2 {
      display: none;
    }
    
  }



  body.view--standalone {
    background: var(--base-color-red);
    color: var(--base-color-white);
  }

  .module-copy .module-inner {
    padding-top: var(--page-offset-top);
  }
  
  .module-copy .module-wrap {
    padding-left: var(--offset-348);
  }
  
  .module-copy .wysiwyg {
    max-width: 41.27777777777777777777em;
  }
  
  .wysiwyg .headline {
    margin-bottom: 0.15em;
  }
  
  .wysiwyg .subheadline {
    text-transform: uppercase;
    margin-bottom: 0.75em;
  }
  
  .wysiwyg .subheadline:not(:first-child) {
    margin-top: 5em;
  }
  
  
  
  @media (max-width: 500px) {
    
    .module-copy .module-wrap {
      padding-left: 0;
    }
    
  }



  .module-home {
    position: relative;
    color: var(--base-color-white);
    overflow: hidden;
    background: var(--base-color-red);
  }
  
  .module-home .module-inner {
    z-index: 2;
    box-sizing: border-box;
    padding-inline: var(--page-padding-left);
  }
  
  .module-home .module-wrap {
    padding-top: var(--page-offset-top);
    padding-bottom: max(50px, calc(195 * var(--px)));
    padding-left: var(--offset-348);
  }
  
  .module-home .headline {
    --initial-delay: 500ms;
    --min-font-size: 55;
  }
  
  .module-home .wysiwyg {
    max-width: 34.59090909090909090909em;
    margin-top: 3.18181818181818181818em;
    opacity: 0;
    transform: rotate(1deg) translateY(50%);
    transform-origin: left top;
    transition: 1750ms var(--ttf-7) 750ms;
    transition-property: opacity, transform;
  }
  
  .module-home.is-on-screen .wysiwyg {
    opacity: 1;
    transform: none;
  }
  
  .module-home figure {
    position: absolute;
    inset: 0;
    z-index: 1;
    transform: translateY(calc(var(--parallax-y-from-0) * -50%));
  }
  
  .module-home figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: rotate(3deg) scale(1.2) translateY(20%);
    transform-origin: left top;
    transition: 1750ms var(--ttf-7) 250ms;
    transition-property: transform;
  }
  
  .module-home.is-on-screen figure img {
    transform: none;
  }
  
  .module-home::before {
    content: '';
    display: block;
    position: fixed;
    inset: 0;
    background: var(--base-color-red);
    z-index: 10000;
    transform-origin: left top;
    transition: 1750ms var(--ttf-7) 250ms;
    transition-property: transform;
    transform: scaleY(1);
  }
  
  .module-home.is-on-screen::before {
    transform: scaleY(0);
  }
  
  
  
  
  
  
  
  
  @media (max-width: 750px) {
    
    .module-home .module-wrap {
      padding-left: 0;
    }
    
  }
  
  
  
  
  
  @media (max-width: 500px) {
    
    .module-home figure img {
      object-position: left center;
    }
    
  }







  .module-image-ticker .module-inner {
    padding-inline: var(--page-padding-left-l);
  }
  
  .module-image-ticker .module-wrap {
    position: relative;
  }
  
  




  .module-image-ticker .tickers {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    text-transform: uppercase;
    color: var(--base-color-red);
  }
  
  .module-image-ticker .ticker {
    margin-inline: calc(var(--page-padding-left-l) * -1);
  }

  .marquee .marquee-wrap {
    position: relative;
    overflow: hidden;
    overflow-x: auto;
  	-ms-overflow-style: none;
  	scrollbar-width: none;
  	-webkit-overflow-scrolling: touch;
    pointer-events: none;
    --gap-x: max(26px, calc(120 * var(--px)));
  }

  .marquee .marquee-wrap::-webkit-scrollbar {
    display: none;
  }

  .marquee .ticker-copy {
    display: flex;
    flex-flow: row nowrap;
    width: max-content;
    gap: 0 var(--gap-x);
  }

  .marquee .ticker-copy > * {
    flex-shrink: 0;
  }

  .marquee .scroll-wrap {
    width: fit-content;
    display: flex;
    flex-flow: row nowrap;
    gap: 0 var(--gap-x);
    width: fit-content;
  }

  .marquee .ticker-copy.clone {
    width: var(--marquee-width, 100vw); 
    overflow: hidden;
  }


  .module-projects {
    background: var(--base-color-red);
    color: var(--base-color-white);
  }
  
  .module-projects .module-inner {
    padding-block: max(30px, calc(80 * var(--px))) max(80px, calc(200 * var(--px)));
  }
  
  
  
  
  
  
  
  
  
  .module-projects .row--ticker {
    margin-bottom: max(60px, calc(170 * var(--px)));
    margin-inline: calc(var(--page-padding-left) * -1);
    text-transform: uppercase;
  }
  
  
  
  
  
  
  
  
  
  
  .module-projects .row--intro {
    margin-bottom: calc(180 * var(--px));
    padding-inline: calc(var(--page-padding-left-l) - var(--page-padding-left));
  }
  
  .module-projects [data-component="intro-copy"] {
  
    .copy {
      margin-left: calc(266 * var(--px));
    }
  
  }
  
  
  
  
  
  
  
  
  
  .module-projects .projects-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: calc(160 * var(--px)) calc(210 * var(--px));
  }
  
  .module-projects article {
    display: flex;
    flex-flow: column nowrap;
    gap: max(20px, calc(27 * var(--px)));
  }
  
  .module-projects article .cpy-18 {
    line-height: 1.3;
    --min-font-size: 16;
  }
  
  .module-projects article .row--image {
    overflow: hidden;
  }
  
  .module-projects article .row--image img {
    transition: transform 10s var(--ttf-2);
  }
  
  @media (hover: hover) {
    .module-projects article:has(a:hover) .row--image img {
      transform: scale(1.035);
      transition-duration: 1250ms;
    }
  }
  
  .module-projects article .row--image {
    display: block;
    position: relative;
  }
  
  .module-projects article .row--image .icon {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 2;
    --size: max(35px, calc(45 * var(--px)));
    width: var(--size);
    height: auto;
    aspect-ratio: 1;
    background: var(--base-color-red);
  }
  
  .module-projects article .row--image .icon svg {
    position: absolute;
    width: calc(var(--size) * .55555555555555555555);
    height: auto;
    display: block;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  
  .module-projects .row--details {
    position: relative;
  }
  
  .module-projects .row--details .button {
    position: absolute;
    right: 0;
    top: 0.15em;
    z-index: 2;
  }
  
  .module-projects .row--details .headline {
    margin-bottom: .48387096774193548387em;
  }
  
  .module-projects .row--details .list-wrap {
    position: relative;
  }
  
  .module-projects .row--details ul {
    display: flex;
    flex-flow: row wrap;
    gap: calc(40 * var(--px));
  }
  
  .module-projects .row--details ul > li {
    flex-shrink: 0;
    overflow: hidden;
  }
  
  .module-projects .row--details span.label {
    display: block;
    text-transform: uppercase;
  }
  
  .module-projects .row--details span.value {
    display: block;
/*    white-space: nowrap;
    text-overflow: ellipsis;
    height: 1.2em;
    overflow: hidden;*/
  }
  
  @media (max-width: 1300px) {
    
    .module-projects .projects-grid {
      gap: max(60px, calc(90 * var(--px))) var(--page-padding-left);
    }
    
    .module-projects .row--details {
      padding-right: 40px;
    }
    
    .module-projects .row--details > .list-wrap {
      position: static;
    }
    
    .module-projects .row--details ul {
      flex-flow: row wrap;
      gap: 10px 20px;
    }
    
  }
  
  
  @media (max-width: 750px) {
    
    .module-projects .projects-grid {
      grid-template-columns: 1fr;
    }
    
  }
  
  
  
  
  
  
  
  .module-projects nav.pagination :is(.col-prev, .col-pages) {
    display: none;
  }
  
  
  
  



  .module-services .module-inner {
    padding-inline: var(--page-padding-left-l);
  }
  
  .module-services .outer-headline {
    color: var(--base-color-light-gray);
    width: fit-content;
  }
  
  .module-services .col-set {
    display: flex;
    flex-flow: row nowrap;
    gap: 0 calc(132 * var(--px));
    margin-right: calc(var(--page-padding-right-l) * -1);
  }
  
  .module-services .col-1 {
    width: calc(929 * var(--px));
    flex-shrink: 0;
    position: relative;
    z-index: 2;
  }
  
  .module-services .col-2 {
    padding-top: calc(150 * var(--px));
    width: 100%;
    transform: translateY(calc(var(--parallax-y, 0) * 150px));
  }
  
  .module-services [data-component="intro-copy"] {
  
    .copy {
      margin-left: calc(130 * var(--px));
    }
    
    @media (max-width: 750px) {
      
      .copy {
        margin-left: 0;
      }
      
    }
  
  }
  
  .module-services .services-wrap {
    margin-top: max(50px, calc(80 * var(--px)));
    max-width: 56em;
    margin-left: calc(130 * var(--px));
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 var(--page-padding-left);
  }
  
  .module-services .services-wrap {
  	counter-reset: supernovae;
  }
  
  .module-services ol.services > li {
    border-top: 1px solid var(--base-color-gray);
    position: relative;
    padding-block: .51612903225806451612em;
    line-height: 1.29032258064516129032;
    min-height: 2.58064516129032258064em;
    opacity: 0;
    transform: translateY(-30%);
    transition: 500ms var(--ttf-7) calc(var(--ios-item-index, 0) * 50ms);
    transition-property: opacity, transform;
  }
  
  .module-services .is-on-screen ol.services > li {
    opacity: 1;
    transform: none;
  }
  
  .module-services ol.services > li > span {
    display: block;
    position: relative;
    padding-left: 1.29032258064516129032em;
  }
  
  .module-services ol.services > li > span::before {
		content: counter(supernovae, decimal-leading-zero);
		counter-increment: supernovae;
    display: block;
    position: absolute;
    color: var(--base-color-red);
    left: 0;
    top: 0.2em;
    font-size: .58064516129032258064em;
  }
  
  .module-services [data-view="mobile"] {
    display: none;
  }
  
  
  
  
  
  @media (max-width: 750px) {
    
    .module-services [data-view="mobile"] {
      display: block;
      width: calc(260 * var(--px-mobile));
      margin-block: 60px;
      margin-left: auto;
    }
    
    .module-services .col-set {
      display: block;
      margin-right: 0;
    }
    
    .module-services .col-1 {
      width: 100%;
    }
    
    .module-services .col-2 {
      display: none;
    }
    
    .module-services .services-wrap {
      margin-left: 0;
    }
    
  }
  
  
  
  
  
  @media (max-width: 500px) {
    
    .module-services .services-wrap {
      display: block;
    }
    
    .module-services ol.services > li {
      min-height: 0;
      padding-block: 0.75em;
    }
    
  }