@charset "UTF-8";
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
} /*!normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css*/
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}
body {
  margin: 0;
}
main {
  display: block;
}
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}
pre {
  font-family: monospace, monospace;
  font-size: 1em;
}
a {
  background-color: transparent;
}
abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}
b,
strong {
  font-weight: bolder;
}
code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
small {
  font-size: 80%;
}
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
img {
  border-style: none;
}
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}
button,
input {
  overflow: visible;
}
button,
select {
  text-transform: none;
}
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
fieldset {
  padding: 0.35em 0.75em 0.625em;
}
legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
details {
  display: block;
}
summary {
  display: list-item;
}
template {
  display: none;
}
[hidden] {
  display: none;
}
.bg {
  background-color: #fff;
}
.chroma {
  background-color: #fff;
}
.chroma .err {
  color: #a61717;
  background-color: #e3d2d2;
}
.chroma .lnlinks {
  outline: none;
  text-decoration: none;
  color: inherit;
}
.chroma .lntd {
  vertical-align: top;
  padding: 0;
  margin: 0;
  border: 0;
}
.chroma .lntable {
  border-spacing: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
.chroma .hl {
  background-color: #ffc;
}
.chroma .lnt {
  white-space: pre;
  user-select: none;
  margin-right: 0.4em;
  padding: 0 0.4em;
  color: #7f7f7f;
}
.chroma .ln {
  white-space: pre;
  user-select: none;
  margin-right: 0.4em;
  padding: 0 0.4em;
  color: #7f7f7f;
}
.chroma .line {
  display: flex;
}
.chroma .k {
  color: #000;
  font-weight: 700;
}
.chroma .kc {
  color: #000;
  font-weight: 700;
}
.chroma .kd {
  color: #000;
  font-weight: 700;
}
.chroma .kn {
  color: #000;
  font-weight: 700;
}
.chroma .kp {
  color: #000;
  font-weight: 700;
}
.chroma .kr {
  color: #000;
  font-weight: 700;
}
.chroma .kt {
  color: #458;
  font-weight: 700;
}
.chroma .na {
  color: teal;
}
.chroma .nb {
  color: #0086b3;
}
.chroma .bp {
  color: #999;
}
.chroma .nc {
  color: #458;
  font-weight: 700;
}
.chroma .no {
  color: teal;
}
.chroma .nd {
  color: #3c5d5d;
  font-weight: 700;
}
.chroma .ni {
  color: purple;
}
.chroma .ne {
  color: #900;
  font-weight: 700;
}
.chroma .nf {
  color: #900;
  font-weight: 700;
}
.chroma .nl {
  color: #900;
  font-weight: 700;
}
.chroma .nn {
  color: #555;
}
.chroma .nt {
  color: navy;
}
.chroma .nv {
  color: teal;
}
.chroma .vc {
  color: teal;
}
.chroma .vg {
  color: teal;
}
.chroma .vi {
  color: teal;
}
.chroma .s {
  color: #d14;
}
.chroma .sa {
  color: #d14;
}
.chroma .sb {
  color: #d14;
}
.chroma .sc {
  color: #d14;
}
.chroma .dl {
  color: #d14;
}
.chroma .sd {
  color: #d14;
}
.chroma .s2 {
  color: #d14;
}
.chroma .se {
  color: #d14;
}
.chroma .sh {
  color: #d14;
}
.chroma .si {
  color: #d14;
}
.chroma .sx {
  color: #d14;
}
.chroma .sr {
  color: #009926;
}
.chroma .s1 {
  color: #d14;
}
.chroma .ss {
  color: #990073;
}
.chroma .m {
  color: #099;
}
.chroma .mb {
  color: #099;
}
.chroma .mf {
  color: #099;
}
.chroma .mh {
  color: #099;
}
.chroma .mi {
  color: #099;
}
.chroma .il {
  color: #099;
}
.chroma .mo {
  color: #099;
}
.chroma .o {
  color: #000;
  font-weight: 700;
}
.chroma .ow {
  color: #000;
  font-weight: 700;
}
.chroma .c {
  color: #998;
  font-style: italic;
}
.chroma .ch {
  color: #998;
  font-style: italic;
}
.chroma .cm {
  color: #998;
  font-style: italic;
}
.chroma .c1 {
  color: #998;
  font-style: italic;
}
.chroma .cs {
  color: #999;
  font-weight: 700;
  font-style: italic;
}
.chroma .cp {
  color: #999;
  font-weight: 700;
  font-style: italic;
}
.chroma .cpf {
  color: #999;
  font-weight: 700;
  font-style: italic;
}
.chroma .gd {
  color: #000;
  background-color: #fdd;
}
.chroma .ge {
  color: #000;
  font-style: italic;
}
.chroma .gr {
  color: #a00;
}
.chroma .gh {
  color: #999;
}
.chroma .gi {
  color: #000;
  background-color: #dfd;
}
.chroma .go {
  color: #888;
}
.chroma .gp {
  color: #555;
}
.chroma .gs {
  font-weight: 700;
}
.chroma .gu {
  color: #aaa;
}
.chroma .gt {
  color: #a00;
}
.chroma .gl {
  text-decoration: underline;
}
.chroma .w {
  color: #bbb;
} /*!loconative-scroll v1.0.2 | MIT License | https://github.com/quentinhocde/loconative-scroll*/
html {
  scroll-behavior: initial;
}
html.has-scroll-dragging {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
html,
body {
  width: 100%;
  min-height: 100%;
}
body {
  opacity: 0;
}
[data-scroll-disable] {
  opacity: 1 !important;
  scroll-behavior: smooth;
}
.has-scroll-init body {
  opacity: 1;
}
[data-scroll-direction="vertical"] [data-scroll-wrapper] {
  height: 100vh;
  overflow-x: hidden;
  overflow-y: scroll;
}
[data-scroll-direction="horizontal"] [data-scroll-wrapper] {
  width: 100vw;
  height: 100vh;
  overflow-x: scroll;
}
.has-scroll-smooth [data-scroll-container] {
  min-height: 100vh;
}
[data-scroll-direction="horizontal"] [data-scroll-container] {
  height: 100%;
  display: inline-flex;
  min-width: var(--scrollContainerWidth);
}
[data-scroll-direction="horizontal"] [data-scroll-section] {
  flex-shrink: 0;
  height: 100vh;
}
html {
  scroll-behavior: initial;
  box-sizing: border-box;
}
* {
  box-sizing: inherit;
}
html,
body {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  font-family: plus jakarta sans, -apple-system, BlinkMacSystemFont, segoe ui,
    Roboto, Helvetica, Arial, sans-serif, apple color emoji, segoe ui emoji,
    segoe ui symbol;
  font-size: 1rem;
  line-height: 1.6;
  font-kerning: normal;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}
.no-js * {
  transition: none !important;
}
html.touchevents {
  scroll-behavior: smooth;
}
html.touchevents * {
  scroll-behavior: smooth !important;
}
body {
  background-color: #0a0a0a;
}
main {
  flex-grow: 2;
}
.content-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100vh;
}
*,
*::before,
*::after {
  box-sizing: inherit;
}
figure {
  vertical-align: baseline;
  margin: 0;
}
img,
source,
picture,
figure {
  vertical-align: top;
  border: none;
  outline: none;
  color: transparent;
}
ul,
menu {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
fieldset {
  border: none;
  padding: 0;
}
details summary::-webkit-details-marker {
  display: none !important;
}
::backdrop {
  background: #0a0a0a !important;
}
.no-js .js-hide {
  display: none !important;
}
.no-js .lazy {
  display: none !important;
}
.tf-v1-popup {
  z-index: 100000 !important;
}
@font-face {
  font-family: plus jakarta sans;
  src: local("Plus Jakarta Sans Regular"), local("PlusJakartaSans-Regular"),
    url() format("woff2"),
    url() format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: plus jakarta sans;
  src: local("Plus Jakarta Sans Medium"), local("PlusJakartaSans-Medium"),
    url() format("woff2"),
    url() format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: plus jakarta sans;
  src: local("Plus Jakarta Sans Bold"), local("PlusJakartaSans-Bold"),
    url() format("woff2"),
    url() format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
html,
body {
  font-size: 90%;
  font-weight: 400;
}
@media (max-width: 350px) {
  html,
  body {
    font-size: 85%;
  }
}
@media (min-width: 768px) {
  html,
  body {
    font-size: 95%;
  }
}
@media (min-width: 1024px) {
  html,
  body {
    font-size: 100%;
  }
}
@media (min-width: 1600px) {
  html,
  body {
    font-size: 102.5%;
  }
}
main {
  font-size: 1.1rem;
}
h1,
h2,
h3,
h4,
h5,
h6,
p {
  position: relative;
  margin: 0;
  color: var(--colour-foreground);
}
h1,
.heading-1,
h2,
.heading-2,
h3,
.heading-3,
h4,
.heading-4,
h5 {
  display: block;
  color: var(--colour-foreground);
  font-weight: 700;
}
h1,
.heading-1 {
  margin-bottom: 1.8rem;
  line-height: 1.03;
  letter-spacing: -1px;
}
h1,
.heading-1 {
  font-size: 36px;
}
@media screen and (min-width: 400px) {
  h1,
  .heading-1 {
    font-size: calc(36px + 32 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h1,
  .heading-1 {
    font-size: 68px;
  }
}
h1 .type-serif,
.heading-1 .type-serif {
  font-size: 44px;
}
@media screen and (min-width: 400px) {
  h1 .type-serif,
  .heading-1 .type-serif {
    font-size: calc(44px + 36 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h1 .type-serif,
  .heading-1 .type-serif {
    font-size: 80px;
  }
}
@media (max-width: 767px) {
  h1 .type-serif.small-mob,
  .heading-1 .type-serif.small-mob {
    font-size: 47px;
  }
}
@media screen and (max-width: 767px) and (min-width: 400px) {
  h1 .type-serif.small-mob,
  .heading-1 .type-serif.small-mob {
    font-size: calc(47px + 33 * ((100vw - 400px) / 1200));
  }
}
@media screen and (max-width: 767px) and (min-width: 1600px) {
  h1 .type-serif.small-mob,
  .heading-1 .type-serif.small-mob {
    font-size: 80px;
  }
}
h1-small,
.heading-1-small {
  font-size: 40px;
}
@media screen and (min-width: 400px) {
  h1-small,
  .heading-1-small {
    font-size: calc(40px + 20 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h1-small,
  .heading-1-small {
    font-size: 60px;
  }
}
h2,
.heading-2 {
  margin-bottom: 1.3rem;
  line-height: 1.2;
  letter-spacing: -1px;
}
h2,
.heading-2 {
  font-size: 34px;
}
@media screen and (min-width: 400px) {
  h2,
  .heading-2 {
    font-size: calc(34px + 16 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h2,
  .heading-2 {
    font-size: 50px;
  }
}
h3,
.heading-3 {
  margin-bottom: 1rem;
  line-height: 1.3;
  letter-spacing: -1px;
}
h3,
.heading-3 {
  font-size: 23px;
}
@media screen and (min-width: 400px) {
  h3,
  .heading-3 {
    font-size: calc(23px + 14 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h3,
  .heading-3 {
    font-size: 37px;
  }
}
h3.big-line-height,
.heading-3.big-line-height {
  line-height: 1.6;
}
h4,
.heading-4 {
  margin-bottom: 1rem;
  line-height: 1.55;
  letter-spacing: -1px;
}
h4,
.heading-4 {
  font-size: 21px;
}
@media screen and (min-width: 400px) {
  h4,
  .heading-4 {
    font-size: calc(21px + 8 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h4,
  .heading-4 {
    font-size: 29px;
  }
}
h5,
.heading-5 {
  margin-bottom: 0.9rem;
  line-height: 1.36;
  letter-spacing: -1px;
}
h5,
.heading-5 {
  font-size: 19px;
}
@media screen and (min-width: 400px) {
  h5,
  .heading-5 {
    font-size: calc(19px + 2.5 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  h5,
  .heading-5 {
    font-size: 21.5px;
  }
}
h6,
.heading-6 {
  display: block;
  color: var(--colour-paragraph);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 0.9rem;
}
p {
  color: var(--colour-paragraph);
  font-size: 1.1rem;
  margin-bottom: 1rem;
  line-height: 1.8;
}
p.lead {
  font-size: 1.2rem;
  line-height: 1.8;
}
p.lead-max-width {
  max-width: 580px;
}
p.lead-large {
  font-size: 1.4rem;
  line-height: 1.7;
}
a {
  font-size: 1.1rem;
  color: var(--colour-foreground);
  font-weight: 700;
  text-decoration: underline;
}
a.no-line {
  text-decoration: none;
}
small {
  display: inline-block;
  font-size: 0.85rem;
  line-height: 1.6;
}
.type-serif {
  font-family: TimesNewRoman, times new roman, Times, Baskerville, Georgia,
    serif;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -2px;
  line-height: 1;
}
.type-code {
  font-family: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas,
    Liberation Mono, monospace;
  font-weight: 400;
}
.type-weight-normal {
  font-weight: 400;
}
strong {
  font-weight: 700;
}
.number {
  display: block;
  font-family: times new roman, serif;
  font-size: 7.5rem;
  color: var(--colour-foreground);
  letter-spacing: -4px;
  font-style: italic;
  line-height: 1;
}
.type-uppercase {
  text-transform: uppercase;
}
.type-lowercase {
  text-transform: lowercase;
}
.type-heading {
  color: var(--colour-paragraph);
  font-weight: 400;
  margin-bottom: 1.8rem;
}
@media (min-width: 1024px) {
  .type-heading {
    margin-bottom: 3rem;
  }
}
::selection {
  background: #fff;
  color: #0a0a0a;
}
::-moz-selection {
  background: #fff;
  color: #0a0a0a;
}
.theme-white ::selection {
  background: #0a0a0a;
  color: #fff;
}
.theme-white ::-moz-selection {
  background: #0a0a0a;
  color: #fff;
}
.cursor {
  position: fixed;
  display: none;
  z-index: 9999999;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0);
  border: 1px solid transparent;
  background-color: transparent;
  transition: transform 250ms linear, background-color 300ms ease,
    border-color 300ms ease;
  will-change: transform, background-color, border-color;
}
.cursor-active {
  cursor: none !important;
}
.cursor-element {
  display: inline-block;
}
.cursor-invert {
  mix-blend-mode: difference;
  cursor: none;
}
.cursor-invert-black {
  background-color: #fff;
}
.cursor-invert-white {
  background-color: #fff;
}
.cursor-border {
  border-color: var(--colour-foreground);
}
.cursor-border-black {
  border-color: #0a0a0a;
}
.cursor-border-white {
  border-color: #fff;
}
.cursor-circle {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  transform-origin: center;
  background-color: #0a0a0a;
  aspect-ratio: 1/1;
  clip-path: circle(20%);
}
.cursor-circle-black {
  z-index: 100009;
}
.cursor-circle-white {
  z-index: 100008;
  background-color: #fff;
  mix-blend-mode: difference;
  backdrop-filter: grayscale(100%);
}
html.no-touchevents .cursor {
  display: block;
}
.scroll {
  opacity: 1;
  transition: transform 300ms ease, opacity 300ms ease;
  will-change: transform, opacity;
}
@media (min-width: 1024px) {
  html.scrolled .scroll {
    opacity: 0;
    transform: translateY(-50px);
  }
}
.skew {
  z-index: 1;
  transform-style: preserve-3d;
  backface-visibility: hidden;
  will-change: transform;
}
html.touchevents .skew {
  transform: none !important;
}
.char,
.word,
.line {
  opacity: 0;
  transform: none;
}
.underline {
  position: absolute;
  display: inline-block;
  left: 0;
  bottom: -1px;
  margin: auto;
  height: 3px;
  width: 100%;
  background-color: var(--colour-foreground);
  transform-origin: left;
}
@media (min-width: 568px) {
  .underline {
    bottom: 2%;
    height: 4px;
  }
}
.mark {
  transform-origin: 60% 35%;
}
.toastify {
  position: fixed;
  display: inline-flex;
  align-items: center;
  max-width: 80vw;
  padding: 12px 30px;
  background-color: var(--colour-foreground);
  color: var(--colour-background);
  border-radius: 4px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  z-index: 100999;
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
  will-change: transform, opacity;
}
.toastify-close {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 0;
  opacity: 1;
  margin-left: 10px;
  color: var(--colour-background);
  font-size: 1.6rem;
  line-height: 0;
  transform: translateY(-3px);
}
.toastify.on {
  opacity: 1;
}
.toastify-right {
  right: 5vw;
}
.toastify-left {
  left: 5vw;
}
.toastify-top {
  top: -150px;
}
.toastify-bottom {
  bottom: -150px;
}
.toastify .toast-close {
  display: none;
}
@media (min-width: 1024px) {
  .toastify {
    max-width: 450px;
  }
}
.transition {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: transparent;
  z-index: -99;
}
.transition-logo {
  display: block;
  width: 45vw;
  min-width: 200px;
  max-width: 500px;
  opacity: 0;
  z-index: 10;
}
.transition-logo svg path {
  fill: #fff;
}
.zoom {
  overflow: clip;
}
.zoom-element {
  transition: transform 400ms ease;
  will-change: transform;
}
.zoom-overflow {
  overflow: clip;
}
.zoom html.touchevents:hover .zoom-element {
  transform: scale(1.1);
}
.container {
  position: relative;
  display: block;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  max-width: 1600px;
  padding: 0 7vw;
}
@media (min-width: 1700px) {
  .container {
    padding: 0;
  }
}
.row {
  display: flex;
  flex-wrap: wrap;
  margin-left: -15px;
  margin-right: -15px;
}
@media (max-width: 567px) {
  .row-small-gap-mob > [class*="col-"]:nth-child(odd) {
    padding-right: 7.5px;
  }
  .row-small-gap-mob > [class*="col-"]:nth-child(even) {
    padding-left: 7.5px;
  }
}
.no-gaps {
  margin-right: 0;
  margin-left: 0;
}
.no-gaps > .col,
.no-gaps > [class*="col-"] {
  padding-right: 0;
  padding-left: 0;
}
.col-hd-12,
.col-hd-11,
.col-hd-10,
.col-hd-9,
.col-hd-8,
.col-hd-7,
.col-hd-6,
.col-hd-5,
.col-hd-4,
.col-hd-3,
.col-hd-2,
.col-hd-1,
.col-hd-auto,
.col-desk-large-12,
.col-desk-large-11,
.col-desk-large-10,
.col-desk-large-9,
.col-desk-large-8,
.col-desk-large-7,
.col-desk-large-6,
.col-desk-large-5,
.col-desk-large-4,
.col-desk-large-3,
.col-desk-large-2,
.col-desk-large-1,
.col-desk-large-auto,
.col-desk-12,
.col-desk-11,
.col-desk-10,
.col-desk-9,
.col-desk-8,
.col-desk-7,
.col-desk-6,
.col-desk-5,
.col-desk-4,
.col-desk-3,
.col-desk-2,
.col-desk-1,
.col-desk-auto,
.col-tab-12,
.col-tab-11,
.col-tab-10,
.col-tab-9,
.col-tab-8,
.col-tab-7,
.col-tab-6,
.col-tab-5,
.col-tab-4,
.col-tab-3,
.col-tab-2,
.col-tab-1,
.col-tab-auto,
.col-mob-12,
.col-mob-11,
.col-mob-10,
.col-mob-9,
.col-mob-8,
.col-mob-7,
.col-mob-6,
.col-mob-5,
.col-mob-4,
.col-mob-3,
.col-mob-2,
.col-mob-1,
.col-mob-auto,
.col-12,
.col-11,
.col-10,
.col-9,
.col-8,
.col-7,
.col-6,
.col-5,
.col-4,
.col-3,
.col-2,
.col-1,
.col-auto {
  position: relative;
  width: 100%;
  padding-left: 15px;
  padding-right: 15px;
}
å .col-auto {
  flex: none;
  width: auto;
  max-width: 100%;
}
.col-1 {
  width: 8.33333333%;
}
.col-2 {
  width: 16.66666667%;
}
.col-3 {
  width: 25%;
}
.col-4 {
  width: 33.33333333%;
}
.col-5 {
  width: 41.66666667%;
}
.col-6 {
  width: 50%;
}
.col-7 {
  width: 58.33333333%;
}
.col-8 {
  width: 66.66666667%;
}
.col-9 {
  width: 75%;
}
.col-10 {
  width: 83.33333333%;
}
.col-11 {
  width: 91.66666667%;
}
.col-12 {
  width: 100%;
}
.offset-0 {
  margin-left: 0;
}
.offset-1 {
  margin-left: 8.33333333%;
}
.offset-2 {
  margin-left: 16.66666667%;
}
.offset-3 {
  margin-left: 25%;
}
.offset-4 {
  margin-left: 33.33333333%;
}
.offset-5 {
  margin-left: 41.66666667%;
}
.offset-6 {
  margin-left: 50%;
}
.offset-7 {
  margin-left: 58.33333333%;
}
.offset-8 {
  margin-left: 66.66666667%;
}
.offset-9 {
  margin-left: 75%;
}
.offset-10 {
  margin-left: 83.33333333%;
}
.offset-11 {
  margin-left: 91.66666667%;
}
.offset-12 {
  margin-left: 100%;
}
@media (min-width: 568px) {
  å .col-mob-auto {
    flex: none;
    width: auto;
    max-width: 100%;
  }
  .col-mob-1 {
    width: 8.33333333%;
  }
  .col-mob-2 {
    width: 16.66666667%;
  }
  .col-mob-3 {
    width: 25%;
  }
  .col-mob-4 {
    width: 33.33333333%;
  }
  .col-mob-5 {
    width: 41.66666667%;
  }
  .col-mob-6 {
    width: 50%;
  }
  .col-mob-7 {
    width: 58.33333333%;
  }
  .col-mob-8 {
    width: 66.66666667%;
  }
  .col-mob-9 {
    width: 75%;
  }
  .col-mob-10 {
    width: 83.33333333%;
  }
  .col-mob-11 {
    width: 91.66666667%;
  }
  .col-mob-12 {
    width: 100%;
  }
  .offset-mob-0 {
    margin-left: 0;
  }
  .offset-mob-1 {
    margin-left: 8.33333333%;
  }
  .offset-mob-2 {
    margin-left: 16.66666667%;
  }
  .offset-mob-3 {
    margin-left: 25%;
  }
  .offset-mob-4 {
    margin-left: 33.33333333%;
  }
  .offset-mob-5 {
    margin-left: 41.66666667%;
  }
  .offset-mob-6 {
    margin-left: 50%;
  }
  .offset-mob-7 {
    margin-left: 58.33333333%;
  }
  .offset-mob-8 {
    margin-left: 66.66666667%;
  }
  .offset-mob-9 {
    margin-left: 75%;
  }
  .offset-mob-10 {
    margin-left: 83.33333333%;
  }
  .offset-mob-11 {
    margin-left: 91.66666667%;
  }
  .offset-mob-12 {
    margin-left: 100%;
  }
}
@media (min-width: 768px) {
  å .col-tab-auto {
    flex: none;
    width: auto;
    max-width: 100%;
  }
  .col-tab-1 {
    width: 8.33333333%;
  }
  .col-tab-2 {
    width: 16.66666667%;
  }
  .col-tab-3 {
    width: 25%;
  }
  .col-tab-4 {
    width: 33.33333333%;
  }
  .col-tab-5 {
    width: 41.66666667%;
  }
  .col-tab-6 {
    width: 50%;
  }
  .col-tab-7 {
    width: 58.33333333%;
  }
  .col-tab-8 {
    width: 66.66666667%;
  }
  .col-tab-9 {
    width: 75%;
  }
  .col-tab-10 {
    width: 83.33333333%;
  }
  .col-tab-11 {
    width: 91.66666667%;
  }
  .col-tab-12 {
    width: 100%;
  }
  .offset-tab-0 {
    margin-left: 0;
  }
  .offset-tab-1 {
    margin-left: 8.33333333%;
  }
  .offset-tab-2 {
    margin-left: 16.66666667%;
  }
  .offset-tab-3 {
    margin-left: 25%;
  }
  .offset-tab-4 {
    margin-left: 33.33333333%;
  }
  .offset-tab-5 {
    margin-left: 41.66666667%;
  }
  .offset-tab-6 {
    margin-left: 50%;
  }
  .offset-tab-7 {
    margin-left: 58.33333333%;
  }
  .offset-tab-8 {
    margin-left: 66.66666667%;
  }
  .offset-tab-9 {
    margin-left: 75%;
  }
  .offset-tab-10 {
    margin-left: 83.33333333%;
  }
  .offset-tab-11 {
    margin-left: 91.66666667%;
  }
  .offset-tab-12 {
    margin-left: 100%;
  }
}
@media (min-width: 1024px) {
  å .col-desk-auto {
    flex: none;
    width: auto;
    max-width: 100%;
  }
  .col-desk-1 {
    width: 8.33333333%;
  }
  .col-desk-2 {
    width: 16.66666667%;
  }
  .col-desk-3 {
    width: 25%;
  }
  .col-desk-4 {
    width: 33.33333333%;
  }
  .col-desk-5 {
    width: 41.66666667%;
  }
  .col-desk-6 {
    width: 50%;
  }
  .col-desk-7 {
    width: 58.33333333%;
  }
  .col-desk-8 {
    width: 66.66666667%;
  }
  .col-desk-9 {
    width: 75%;
  }
  .col-desk-10 {
    width: 83.33333333%;
  }
  .col-desk-11 {
    width: 91.66666667%;
  }
  .col-desk-12 {
    width: 100%;
  }
  .offset-desk-0 {
    margin-left: 0;
  }
  .offset-desk-1 {
    margin-left: 8.33333333%;
  }
  .offset-desk-2 {
    margin-left: 16.66666667%;
  }
  .offset-desk-3 {
    margin-left: 25%;
  }
  .offset-desk-4 {
    margin-left: 33.33333333%;
  }
  .offset-desk-5 {
    margin-left: 41.66666667%;
  }
  .offset-desk-6 {
    margin-left: 50%;
  }
  .offset-desk-7 {
    margin-left: 58.33333333%;
  }
  .offset-desk-8 {
    margin-left: 66.66666667%;
  }
  .offset-desk-9 {
    margin-left: 75%;
  }
  .offset-desk-10 {
    margin-left: 83.33333333%;
  }
  .offset-desk-11 {
    margin-left: 91.66666667%;
  }
  .offset-desk-12 {
    margin-left: 100%;
  }
}
@media (min-width: 1408px) {
  å .col-desk-large-auto {
    flex: none;
    width: auto;
    max-width: 100%;
  }
  .col-desk-large-1 {
    width: 8.33333333%;
  }
  .col-desk-large-2 {
    width: 16.66666667%;
  }
  .col-desk-large-3 {
    width: 25%;
  }
  .col-desk-large-4 {
    width: 33.33333333%;
  }
  .col-desk-large-5 {
    width: 41.66666667%;
  }
  .col-desk-large-6 {
    width: 50%;
  }
  .col-desk-large-7 {
    width: 58.33333333%;
  }
  .col-desk-large-8 {
    width: 66.66666667%;
  }
  .col-desk-large-9 {
    width: 75%;
  }
  .col-desk-large-10 {
    width: 83.33333333%;
  }
  .col-desk-large-11 {
    width: 91.66666667%;
  }
  .col-desk-large-12 {
    width: 100%;
  }
  .offset-desk-large-0 {
    margin-left: 0;
  }
  .offset-desk-large-1 {
    margin-left: 8.33333333%;
  }
  .offset-desk-large-2 {
    margin-left: 16.66666667%;
  }
  .offset-desk-large-3 {
    margin-left: 25%;
  }
  .offset-desk-large-4 {
    margin-left: 33.33333333%;
  }
  .offset-desk-large-5 {
    margin-left: 41.66666667%;
  }
  .offset-desk-large-6 {
    margin-left: 50%;
  }
  .offset-desk-large-7 {
    margin-left: 58.33333333%;
  }
  .offset-desk-large-8 {
    margin-left: 66.66666667%;
  }
  .offset-desk-large-9 {
    margin-left: 75%;
  }
  .offset-desk-large-10 {
    margin-left: 83.33333333%;
  }
  .offset-desk-large-11 {
    margin-left: 91.66666667%;
  }
  .offset-desk-large-12 {
    margin-left: 100%;
  }
}
@media (min-width: 1600px) {
  å .col-hd-auto {
    flex: none;
    width: auto;
    max-width: 100%;
  }
  .col-hd-1 {
    width: 8.33333333%;
  }
  .col-hd-2 {
    width: 16.66666667%;
  }
  .col-hd-3 {
    width: 25%;
  }
  .col-hd-4 {
    width: 33.33333333%;
  }
  .col-hd-5 {
    width: 41.66666667%;
  }
  .col-hd-6 {
    width: 50%;
  }
  .col-hd-7 {
    width: 58.33333333%;
  }
  .col-hd-8 {
    width: 66.66666667%;
  }
  .col-hd-9 {
    width: 75%;
  }
  .col-hd-10 {
    width: 83.33333333%;
  }
  .col-hd-11 {
    width: 91.66666667%;
  }
  .col-hd-12 {
    width: 100%;
  }
  .offset-hd-0 {
    margin-left: 0;
  }
  .offset-hd-1 {
    margin-left: 8.33333333%;
  }
  .offset-hd-2 {
    margin-left: 16.66666667%;
  }
  .offset-hd-3 {
    margin-left: 25%;
  }
  .offset-hd-4 {
    margin-left: 33.33333333%;
  }
  .offset-hd-5 {
    margin-left: 41.66666667%;
  }
  .offset-hd-6 {
    margin-left: 50%;
  }
  .offset-hd-7 {
    margin-left: 58.33333333%;
  }
  .offset-hd-8 {
    margin-left: 66.66666667%;
  }
  .offset-hd-9 {
    margin-left: 75%;
  }
  .offset-hd-10 {
    margin-left: 83.33333333%;
  }
  .offset-hd-11 {
    margin-left: 91.66666667%;
  }
  .offset-hd-12 {
    margin-left: 100%;
  }
}
.flex-row {
  flex-direction: row !important;
}
.flex-row-reverse {
  flex-direction: row-reverse !important;
}
.flex-column {
  flex-direction: column !important;
}
.flex-column-reverse {
  flex-direction: column-reverse !important;
}
.justify-content-start {
  justify-content: flex-start !important;
}
.justify-content-end {
  justify-content: flex-end !important;
}
.justify-content-center {
  justify-content: center !important;
}
.justify-content-between {
  justify-content: space-between !important;
}
.justify-content-around {
  justify-content: space-around !important;
}
.justify-content-evenly {
  justify-content: space-evenly !important;
}
.align-self-start {
  align-self: flex-start !important;
}
.align-self-end {
  align-self: flex-end !important;
}
.align-self-center {
  align-self: center !important;
}
.align-self-baseline {
  align-self: baseline !important;
}
.align-self-stretch {
  align-self: stretch !important;
}
.align-items-start {
  align-items: flex-start !important;
}
.align-items-end {
  align-items: flex-end !important;
}
.align-items-center {
  align-items: center !important;
}
.align-items-baseline {
  align-items: baseline !important;
}
.align-items-stretch {
  align-items: stretch !important;
}
.align-content-start {
  align-content: flex-start !important;
}
.align-content-end {
  align-content: flex-end !important;
}
.align-content-center {
  align-content: center !important;
}
.align-content-stretch {
  align-content: stretch !important;
}
.align-content-between {
  align-content: space-between !important;
}
.align-content-around {
  align-content: space-around !important;
}
.flex-wrap {
  flex-wrap: wrap !important;
}
.flex-nowrap {
  flex-wrap: nowrap !important;
}
.flex-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}
.flex-fill {
  flex: auto !important;
}
.flex-grow-0 {
  flex-grow: 0 !important;
}
.flex-grow-1 {
  flex-grow: 1 !important;
}
.flex-shrink-0 {
  flex-shrink: 0 !important;
}
.flex-shrink-1 {
  flex-shrink: 1 !important;
}
@media (min-width: 568px) {
  .flex-mob-row {
    flex-direction: row !important;
  }
  .flex-mob-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-mob-column {
    flex-direction: column !important;
  }
  .flex-mob-column-reverse {
    flex-direction: column-reverse !important;
  }
  .justify-content-mob-start {
    justify-content: flex-start !important;
  }
  .justify-content-mob-end {
    justify-content: flex-end !important;
  }
  .justify-content-mob-center {
    justify-content: center !important;
  }
  .justify-content-mob-between {
    justify-content: space-between !important;
  }
  .justify-content-mob-around {
    justify-content: space-around !important;
  }
  .justify-content-mob-evenly {
    justify-content: space-evenly !important;
  }
  .align-self-mob-start {
    align-self: flex-start !important;
  }
  .align-self-mob-end {
    align-self: flex-end !important;
  }
  .align-self-mob-center {
    align-self: center !important;
  }
  .align-self-mob-baseline {
    align-self: baseline !important;
  }
  .align-self-mob-stretch {
    align-self: stretch !important;
  }
  .align-items-mob-start {
    align-items: flex-start !important;
  }
  .align-items-mob-end {
    align-items: flex-end !important;
  }
  .align-items-mob-center {
    align-items: center !important;
  }
  .align-items-mob-baseline {
    align-items: baseline !important;
  }
  .align-items-mob-stretch {
    align-items: stretch !important;
  }
  .align-content-mob-start {
    align-content: flex-start !important;
  }
  .align-content-mob-end {
    align-content: flex-end !important;
  }
  .align-content-mob-center {
    align-content: center !important;
  }
  .align-content-mob-stretch {
    align-content: stretch !important;
  }
  .align-content-mob-between {
    align-content: space-between !important;
  }
  .align-content-mob-around {
    align-content: space-around !important;
  }
  .flex-mob-wrap {
    flex-wrap: wrap !important;
  }
  .flex-mob-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-mob-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-mob-fill {
    flex: auto !important;
  }
  .flex-mob-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-mob-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-mob-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-mob-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 768px) {
  .flex-tab-row {
    flex-direction: row !important;
  }
  .flex-tab-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-tab-column {
    flex-direction: column !important;
  }
  .flex-tab-column-reverse {
    flex-direction: column-reverse !important;
  }
  .justify-content-tab-start {
    justify-content: flex-start !important;
  }
  .justify-content-tab-end {
    justify-content: flex-end !important;
  }
  .justify-content-tab-center {
    justify-content: center !important;
  }
  .justify-content-tab-between {
    justify-content: space-between !important;
  }
  .justify-content-tab-around {
    justify-content: space-around !important;
  }
  .justify-content-tab-evenly {
    justify-content: space-evenly !important;
  }
  .align-self-tab-start {
    align-self: flex-start !important;
  }
  .align-self-tab-end {
    align-self: flex-end !important;
  }
  .align-self-tab-center {
    align-self: center !important;
  }
  .align-self-tab-baseline {
    align-self: baseline !important;
  }
  .align-self-tab-stretch {
    align-self: stretch !important;
  }
  .align-items-tab-start {
    align-items: flex-start !important;
  }
  .align-items-tab-end {
    align-items: flex-end !important;
  }
  .align-items-tab-center {
    align-items: center !important;
  }
  .align-items-tab-baseline {
    align-items: baseline !important;
  }
  .align-items-tab-stretch {
    align-items: stretch !important;
  }
  .align-content-tab-start {
    align-content: flex-start !important;
  }
  .align-content-tab-end {
    align-content: flex-end !important;
  }
  .align-content-tab-center {
    align-content: center !important;
  }
  .align-content-tab-stretch {
    align-content: stretch !important;
  }
  .align-content-tab-between {
    align-content: space-between !important;
  }
  .align-content-tab-around {
    align-content: space-around !important;
  }
  .flex-tab-wrap {
    flex-wrap: wrap !important;
  }
  .flex-tab-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-tab-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-tab-fill {
    flex: auto !important;
  }
  .flex-tab-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-tab-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-tab-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-tab-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 1024px) {
  .flex-desk-row {
    flex-direction: row !important;
  }
  .flex-desk-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-desk-column {
    flex-direction: column !important;
  }
  .flex-desk-column-reverse {
    flex-direction: column-reverse !important;
  }
  .justify-content-desk-start {
    justify-content: flex-start !important;
  }
  .justify-content-desk-end {
    justify-content: flex-end !important;
  }
  .justify-content-desk-center {
    justify-content: center !important;
  }
  .justify-content-desk-between {
    justify-content: space-between !important;
  }
  .justify-content-desk-around {
    justify-content: space-around !important;
  }
  .justify-content-desk-evenly {
    justify-content: space-evenly !important;
  }
  .align-self-desk-start {
    align-self: flex-start !important;
  }
  .align-self-desk-end {
    align-self: flex-end !important;
  }
  .align-self-desk-center {
    align-self: center !important;
  }
  .align-self-desk-baseline {
    align-self: baseline !important;
  }
  .align-self-desk-stretch {
    align-self: stretch !important;
  }
  .align-items-desk-start {
    align-items: flex-start !important;
  }
  .align-items-desk-end {
    align-items: flex-end !important;
  }
  .align-items-desk-center {
    align-items: center !important;
  }
  .align-items-desk-baseline {
    align-items: baseline !important;
  }
  .align-items-desk-stretch {
    align-items: stretch !important;
  }
  .align-content-desk-start {
    align-content: flex-start !important;
  }
  .align-content-desk-end {
    align-content: flex-end !important;
  }
  .align-content-desk-center {
    align-content: center !important;
  }
  .align-content-desk-stretch {
    align-content: stretch !important;
  }
  .align-content-desk-between {
    align-content: space-between !important;
  }
  .align-content-desk-around {
    align-content: space-around !important;
  }
  .flex-desk-wrap {
    flex-wrap: wrap !important;
  }
  .flex-desk-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-desk-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-desk-fill {
    flex: auto !important;
  }
  .flex-desk-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-desk-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-desk-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-desk-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 1408px) {
  .flex-desk-large-row {
    flex-direction: row !important;
  }
  .flex-desk-large-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-desk-large-column {
    flex-direction: column !important;
  }
  .flex-desk-large-column-reverse {
    flex-direction: column-reverse !important;
  }
  .justify-content-desk-large-start {
    justify-content: flex-start !important;
  }
  .justify-content-desk-large-end {
    justify-content: flex-end !important;
  }
  .justify-content-desk-large-center {
    justify-content: center !important;
  }
  .justify-content-desk-large-between {
    justify-content: space-between !important;
  }
  .justify-content-desk-large-around {
    justify-content: space-around !important;
  }
  .justify-content-desk-large-evenly {
    justify-content: space-evenly !important;
  }
  .align-self-desk-large-start {
    align-self: flex-start !important;
  }
  .align-self-desk-large-end {
    align-self: flex-end !important;
  }
  .align-self-desk-large-center {
    align-self: center !important;
  }
  .align-self-desk-large-baseline {
    align-self: baseline !important;
  }
  .align-self-desk-large-stretch {
    align-self: stretch !important;
  }
  .align-items-desk-large-start {
    align-items: flex-start !important;
  }
  .align-items-desk-large-end {
    align-items: flex-end !important;
  }
  .align-items-desk-large-center {
    align-items: center !important;
  }
  .align-items-desk-large-baseline {
    align-items: baseline !important;
  }
  .align-items-desk-large-stretch {
    align-items: stretch !important;
  }
  .align-content-desk-large-start {
    align-content: flex-start !important;
  }
  .align-content-desk-large-end {
    align-content: flex-end !important;
  }
  .align-content-desk-large-center {
    align-content: center !important;
  }
  .align-content-desk-large-stretch {
    align-content: stretch !important;
  }
  .align-content-desk-large-between {
    align-content: space-between !important;
  }
  .align-content-desk-large-around {
    align-content: space-around !important;
  }
  .flex-desk-large-wrap {
    flex-wrap: wrap !important;
  }
  .flex-desk-large-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-desk-large-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-desk-large-fill {
    flex: auto !important;
  }
  .flex-desk-large-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-desk-large-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-desk-large-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-desk-large-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 1600px) {
  .flex-hd-row {
    flex-direction: row !important;
  }
  .flex-hd-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-hd-column {
    flex-direction: column !important;
  }
  .flex-hd-column-reverse {
    flex-direction: column-reverse !important;
  }
  .justify-content-hd-start {
    justify-content: flex-start !important;
  }
  .justify-content-hd-end {
    justify-content: flex-end !important;
  }
  .justify-content-hd-center {
    justify-content: center !important;
  }
  .justify-content-hd-between {
    justify-content: space-between !important;
  }
  .justify-content-hd-around {
    justify-content: space-around !important;
  }
  .justify-content-hd-evenly {
    justify-content: space-evenly !important;
  }
  .align-self-hd-start {
    align-self: flex-start !important;
  }
  .align-self-hd-end {
    align-self: flex-end !important;
  }
  .align-self-hd-center {
    align-self: center !important;
  }
  .align-self-hd-baseline {
    align-self: baseline !important;
  }
  .align-self-hd-stretch {
    align-self: stretch !important;
  }
  .align-items-hd-start {
    align-items: flex-start !important;
  }
  .align-items-hd-end {
    align-items: flex-end !important;
  }
  .align-items-hd-center {
    align-items: center !important;
  }
  .align-items-hd-baseline {
    align-items: baseline !important;
  }
  .align-items-hd-stretch {
    align-items: stretch !important;
  }
  .align-content-hd-start {
    align-content: flex-start !important;
  }
  .align-content-hd-end {
    align-content: flex-end !important;
  }
  .align-content-hd-center {
    align-content: center !important;
  }
  .align-content-hd-stretch {
    align-content: stretch !important;
  }
  .align-content-hd-between {
    align-content: space-between !important;
  }
  .align-content-hd-around {
    align-content: space-around !important;
  }
  .flex-hd-wrap {
    flex-wrap: wrap !important;
  }
  .flex-hd-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-hd-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .flex-hd-fill {
    flex: auto !important;
  }
  .flex-hd-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-hd-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-hd-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-hd-shrink-1 {
    flex-shrink: 1 !important;
  }
}
.order-first {
  order: -1 !important;
}
.order-last {
  order: 13 !important;
}
.order-1 {
  order: 1 !important;
}
.order-2 {
  order: 2 !important;
}
.order-3 {
  order: 3 !important;
}
.order-4 {
  order: 4 !important;
}
.order-5 {
  order: 5 !important;
}
.order-6 {
  order: 6 !important;
}
.order-7 {
  order: 7 !important;
}
.order-8 {
  order: 8 !important;
}
.order-9 {
  order: 9 !important;
}
.order-10 {
  order: 10 !important;
}
.order-11 {
  order: 11 !important;
}
.order-12 {
  order: 12 !important;
}
@media (min-width: 568px) {
  .order-mob-first {
    order: -1 !important;
  }
  .order-mob-last {
    order: 13 !important;
  }
  .order-mob-1 {
    order: 1 !important;
  }
  .order-mob-2 {
    order: 2 !important;
  }
  .order-mob-3 {
    order: 3 !important;
  }
  .order-mob-4 {
    order: 4 !important;
  }
  .order-mob-5 {
    order: 5 !important;
  }
  .order-mob-6 {
    order: 6 !important;
  }
  .order-mob-7 {
    order: 7 !important;
  }
  .order-mob-8 {
    order: 8 !important;
  }
  .order-mob-9 {
    order: 9 !important;
  }
  .order-mob-10 {
    order: 10 !important;
  }
  .order-mob-11 {
    order: 11 !important;
  }
  .order-mob-12 {
    order: 12 !important;
  }
}
@media (min-width: 768px) {
  .order-tab-first {
    order: -1 !important;
  }
  .order-tab-last {
    order: 13 !important;
  }
  .order-tab-1 {
    order: 1 !important;
  }
  .order-tab-2 {
    order: 2 !important;
  }
  .order-tab-3 {
    order: 3 !important;
  }
  .order-tab-4 {
    order: 4 !important;
  }
  .order-tab-5 {
    order: 5 !important;
  }
  .order-tab-6 {
    order: 6 !important;
  }
  .order-tab-7 {
    order: 7 !important;
  }
  .order-tab-8 {
    order: 8 !important;
  }
  .order-tab-9 {
    order: 9 !important;
  }
  .order-tab-10 {
    order: 10 !important;
  }
  .order-tab-11 {
    order: 11 !important;
  }
  .order-tab-12 {
    order: 12 !important;
  }
}
@media (min-width: 1024px) {
  .order-desk-first {
    order: -1 !important;
  }
  .order-desk-last {
    order: 13 !important;
  }
  .order-desk-1 {
    order: 1 !important;
  }
  .order-desk-2 {
    order: 2 !important;
  }
  .order-desk-3 {
    order: 3 !important;
  }
  .order-desk-4 {
    order: 4 !important;
  }
  .order-desk-5 {
    order: 5 !important;
  }
  .order-desk-6 {
    order: 6 !important;
  }
  .order-desk-7 {
    order: 7 !important;
  }
  .order-desk-8 {
    order: 8 !important;
  }
  .order-desk-9 {
    order: 9 !important;
  }
  .order-desk-10 {
    order: 10 !important;
  }
  .order-desk-11 {
    order: 11 !important;
  }
  .order-desk-12 {
    order: 12 !important;
  }
}
@media (min-width: 1408px) {
  .order-desk-large-first {
    order: -1 !important;
  }
  .order-desk-large-last {
    order: 13 !important;
  }
  .order-desk-large-1 {
    order: 1 !important;
  }
  .order-desk-large-2 {
    order: 2 !important;
  }
  .order-desk-large-3 {
    order: 3 !important;
  }
  .order-desk-large-4 {
    order: 4 !important;
  }
  .order-desk-large-5 {
    order: 5 !important;
  }
  .order-desk-large-6 {
    order: 6 !important;
  }
  .order-desk-large-7 {
    order: 7 !important;
  }
  .order-desk-large-8 {
    order: 8 !important;
  }
  .order-desk-large-9 {
    order: 9 !important;
  }
  .order-desk-large-10 {
    order: 10 !important;
  }
  .order-desk-large-11 {
    order: 11 !important;
  }
  .order-desk-large-12 {
    order: 12 !important;
  }
}
@media (min-width: 1600px) {
  .order-hd-first {
    order: -1 !important;
  }
  .order-hd-last {
    order: 13 !important;
  }
  .order-hd-1 {
    order: 1 !important;
  }
  .order-hd-2 {
    order: 2 !important;
  }
  .order-hd-3 {
    order: 3 !important;
  }
  .order-hd-4 {
    order: 4 !important;
  }
  .order-hd-5 {
    order: 5 !important;
  }
  .order-hd-6 {
    order: 6 !important;
  }
  .order-hd-7 {
    order: 7 !important;
  }
  .order-hd-8 {
    order: 8 !important;
  }
  .order-hd-9 {
    order: 9 !important;
  }
  .order-hd-10 {
    order: 10 !important;
  }
  .order-hd-11 {
    order: 11 !important;
  }
  .order-hd-12 {
    order: 12 !important;
  }
}
.d-none {
  display: none !important;
}
.d-inline {
  display: inline !important;
}
.d-inline-block {
  display: inline-block !important;
}
.d-block {
  display: block !important;
}
.d-flex {
  display: flex !important;
}
.d-inline-flex {
  display: inline-flex !important;
}
.d-table {
  display: table !important;
}
.d-table-row {
  display: table-row !important;
}
.d-table-cell {
  display: table-cell !important;
}
@media (min-width: 568px) {
  .d-mob-none {
    display: none !important;
  }
  .d-mob-inline {
    display: inline !important;
  }
  .d-mob-inline-block {
    display: inline-block !important;
  }
  .d-mob-block {
    display: block !important;
  }
  .d-mob-flex {
    display: flex !important;
  }
  .d-mob-inline-flex {
    display: inline-flex !important;
  }
  .d-mob-table {
    display: table !important;
  }
  .d-mob-table-row {
    display: table-row !important;
  }
  .d-mob-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 768px) {
  .d-tab-none {
    display: none !important;
  }
  .d-tab-inline {
    display: inline !important;
  }
  .d-tab-inline-block {
    display: inline-block !important;
  }
  .d-tab-block {
    display: block !important;
  }
  .d-tab-flex {
    display: flex !important;
  }
  .d-tab-inline-flex {
    display: inline-flex !important;
  }
  .d-tab-table {
    display: table !important;
  }
  .d-tab-table-row {
    display: table-row !important;
  }
  .d-tab-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 1024px) {
  .d-desk-none {
    display: none !important;
  }
  .d-desk-inline {
    display: inline !important;
  }
  .d-desk-inline-block {
    display: inline-block !important;
  }
  .d-desk-block {
    display: block !important;
  }
  .d-desk-flex {
    display: flex !important;
  }
  .d-desk-inline-flex {
    display: inline-flex !important;
  }
  .d-desk-table {
    display: table !important;
  }
  .d-desk-table-row {
    display: table-row !important;
  }
  .d-desk-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 1408px) {
  .d-desk-large-none {
    display: none !important;
  }
  .d-desk-large-inline {
    display: inline !important;
  }
  .d-desk-large-inline-block {
    display: inline-block !important;
  }
  .d-desk-large-block {
    display: block !important;
  }
  .d-desk-large-flex {
    display: flex !important;
  }
  .d-desk-large-inline-flex {
    display: inline-flex !important;
  }
  .d-desk-large-table {
    display: table !important;
  }
  .d-desk-large-table-row {
    display: table-row !important;
  }
  .d-desk-large-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 1600px) {
  .d-hd-none {
    display: none !important;
  }
  .d-hd-inline {
    display: inline !important;
  }
  .d-hd-inline-block {
    display: inline-block !important;
  }
  .d-hd-block {
    display: block !important;
  }
  .d-hd-flex {
    display: flex !important;
  }
  .d-hd-inline-flex {
    display: inline-flex !important;
  }
  .d-hd-table {
    display: table !important;
  }
  .d-hd-table-row {
    display: table-row !important;
  }
  .d-hd-table-cell {
    display: table-cell !important;
  }
}
.c-white {
  color: #fff !important;
}
.bg-white {
  background-color: #fff !important;
}
.c-black {
  color: #0a0a0a !important;
}
.bg-black {
  background-color: #0a0a0a !important;
}
.c-orange {
  color: #ff5043 !important;
}
.bg-orange {
  background-color: #ff5043 !important;
}
.c-blue {
  color: #70cbce !important;
}
.bg-blue {
  background-color: #70cbce !important;
}
.c-copy {
  color: #0a0a0a !important;
}
.bg-copy {
  background-color: #0a0a0a !important;
}
.c-grey-dark {
  color: #0f0f0f !important;
}
.bg-grey-dark {
  background-color: #0f0f0f !important;
}
.c-grey-light {
  color: #171717 !important;
}
.bg-grey-light {
  background-color: #171717 !important;
}
.c-off-white {
  color: #f2f2f2 !important;
}
.bg-off-white {
  background-color: #f2f2f2 !important;
}
.colour-foreground {
  color: var(--colour-foreground);
}
.colour-foreground * {
  color: var(--colour-foreground);
}
.colour-white {
  color: #fff;
}
.colour-white * {
  color: #fff;
}
.brightness-0 {
  filter: brightness(0);
}
.brightness-5 {
  filter: brightness(0.05);
}
.brightness-10 {
  filter: brightness(0.1);
}
.brightness-15 {
  filter: brightness(0.15);
}
.brightness-20 {
  filter: brightness(0.2);
}
.brightness-25 {
  filter: brightness(0.25);
}
.brightness-30 {
  filter: brightness(0.3);
}
.brightness-35 {
  filter: brightness(0.35);
}
.brightness-40 {
  filter: brightness(0.4);
}
.brightness-45 {
  filter: brightness(0.45);
}
.brightness-50 {
  filter: brightness(0.5);
}
.brightness-55 {
  filter: brightness(0.55);
}
.brightness-60 {
  filter: brightness(0.6);
}
.brightness-65 {
  filter: brightness(0.65);
}
.brightness-70 {
  filter: brightness(0.7);
}
.brightness-75 {
  filter: brightness(0.75);
}
.brightness-80 {
  filter: brightness(0.8);
}
.brightness-85 {
  filter: brightness(0.85);
}
.brightness-90 {
  filter: brightness(0.9);
}
.brightness-95 {
  filter: brightness(0.95);
}
.brightness-100 {
  filter: brightness(1);
}
.gradient {
  position: relative;
}
.gradient::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 0;
  width: 100%;
  background: linear-gradient(180deg, rgba(10, 10, 10, 0) 0%, #0a0a0a 100%);
  z-index: 1;
}
.gradient-height-0:after {
  height: 0%;
}
.gradient-height-10:after {
  height: 10%;
}
.gradient-height-20:after {
  height: 20%;
}
.gradient-height-30:after {
  height: 30%;
}
.gradient-height-40:after {
  height: 40%;
}
.gradient-height-50:after {
  height: 50%;
}
.gradient-height-60:after {
  height: 60%;
}
.gradient-height-70:after {
  height: 70%;
}
.gradient-height-80:after {
  height: 80%;
}
.gradient-height-90:after {
  height: 90%;
}
.gradient-height-100:after {
  height: 100%;
}
.gradient-full {
  height: 100%;
}
.margin {
  margin-bottom: 1.8rem;
}
.margin p:last-of-type {
  margin-bottom: 0;
}
.margin-none {
  margin-bottom: 0 !important;
}
.margin-tiny {
  margin-bottom: 0.6rem;
}
.margin-small {
  margin-bottom: 1rem;
}
.margin-large {
  margin-bottom: 3rem;
}
.margin-title {
  margin-bottom: clamp(50px, 10vw, 100px);
}
.margin-top {
  margin-top: 1.8rem;
}
.margin-top .margin-tiny {
  margin-top: 0.6rem;
}
.margin-top .margin-small {
  margin-top: 1rem;
}
.margin-top .margin-large {
  margin-top: 3rem;
}
.margin-top .margin-title {
  margin-top: clamp(50px, 10vw, 100px);
}
.m-0 {
  margin: 0 !important;
}
.mt-0,
.my-0 {
  margin-top: 0 !important;
}
.mr-0,
.mx-0 {
  margin-right: 0 !important;
}
.mb-0,
.my-0 {
  margin-bottom: 0 !important;
}
.ml-0,
.mx-0 {
  margin-left: 0 !important;
}
.p-0 {
  padding: 0 !important;
}
.pt-0,
.py-0 {
  padding-top: 0 !important;
}
.pr-0,
.px-0 {
  padding-right: 0 !important;
}
.pb-0,
.py-0 {
  padding-bottom: 0 !important;
}
.pl-0,
.px-0 {
  padding-left: 0 !important;
}
@media (min-width: 568px) {
  .m-mob-0 {
    margin: 0 !important;
  }
  .mt-mob-0,
  .my-mob-0 {
    margin-top: 0 !important;
  }
  .mr-mob-0,
  .mx-mob-0 {
    margin-right: 0 !important;
  }
  .mb-mob-0,
  .my-mob-0 {
    margin-bottom: 0 !important;
  }
  .ml-mob-0,
  .mx-mob-0 {
    margin-left: 0 !important;
  }
}
@media (min-width: 568px) {
  .p-mob-0 {
    padding: 0 !important;
  }
  .pt-mob-0,
  .py-mob-0 {
    padding-top: 0 !important;
  }
  .pr-mob-0,
  .px-mob-0 {
    padding-right: 0 !important;
  }
  .pb-mob-0,
  .py-mob-0 {
    padding-bottom: 0 !important;
  }
  .pl-mob-0,
  .px-mob-0 {
    padding-left: 0 !important;
  }
}
@media (min-width: 768px) {
  .m-tab-0 {
    margin: 0 !important;
  }
  .mt-tab-0,
  .my-tab-0 {
    margin-top: 0 !important;
  }
  .mr-tab-0,
  .mx-tab-0 {
    margin-right: 0 !important;
  }
  .mb-tab-0,
  .my-tab-0 {
    margin-bottom: 0 !important;
  }
  .ml-tab-0,
  .mx-tab-0 {
    margin-left: 0 !important;
  }
}
@media (min-width: 768px) {
  .p-tab-0 {
    padding: 0 !important;
  }
  .pt-tab-0,
  .py-tab-0 {
    padding-top: 0 !important;
  }
  .pr-tab-0,
  .px-tab-0 {
    padding-right: 0 !important;
  }
  .pb-tab-0,
  .py-tab-0 {
    padding-bottom: 0 !important;
  }
  .pl-tab-0,
  .px-tab-0 {
    padding-left: 0 !important;
  }
}
@media (min-width: 1024px) {
  .m-desk-0 {
    margin: 0 !important;
  }
  .mt-desk-0,
  .my-desk-0 {
    margin-top: 0 !important;
  }
  .mr-desk-0,
  .mx-desk-0 {
    margin-right: 0 !important;
  }
  .mb-desk-0,
  .my-desk-0 {
    margin-bottom: 0 !important;
  }
  .ml-desk-0,
  .mx-desk-0 {
    margin-left: 0 !important;
  }
}
@media (min-width: 1024px) {
  .p-desk-0 {
    padding: 0 !important;
  }
  .pt-desk-0,
  .py-desk-0 {
    padding-top: 0 !important;
  }
  .pr-desk-0,
  .px-desk-0 {
    padding-right: 0 !important;
  }
  .pb-desk-0,
  .py-desk-0 {
    padding-bottom: 0 !important;
  }
  .pl-desk-0,
  .px-desk-0 {
    padding-left: 0 !important;
  }
}
@media (min-width: 1408px) {
  .m-desk-large-0 {
    margin: 0 !important;
  }
  .mt-desk-large-0,
  .my-desk-large-0 {
    margin-top: 0 !important;
  }
  .mr-desk-large-0,
  .mx-desk-large-0 {
    margin-right: 0 !important;
  }
  .mb-desk-large-0,
  .my-desk-large-0 {
    margin-bottom: 0 !important;
  }
  .ml-desk-large-0,
  .mx-desk-large-0 {
    margin-left: 0 !important;
  }
}
@media (min-width: 1408px) {
  .p-desk-large-0 {
    padding: 0 !important;
  }
  .pt-desk-large-0,
  .py-desk-large-0 {
    padding-top: 0 !important;
  }
  .pr-desk-large-0,
  .px-desk-large-0 {
    padding-right: 0 !important;
  }
  .pb-desk-large-0,
  .py-desk-large-0 {
    padding-bottom: 0 !important;
  }
  .pl-desk-large-0,
  .px-desk-large-0 {
    padding-left: 0 !important;
  }
}
@media (min-width: 1600px) {
  .m-hd-0 {
    margin: 0 !important;
  }
  .mt-hd-0,
  .my-hd-0 {
    margin-top: 0 !important;
  }
  .mr-hd-0,
  .mx-hd-0 {
    margin-right: 0 !important;
  }
  .mb-hd-0,
  .my-hd-0 {
    margin-bottom: 0 !important;
  }
  .ml-hd-0,
  .mx-hd-0 {
    margin-left: 0 !important;
  }
}
@media (min-width: 1600px) {
  .p-hd-0 {
    padding: 0 !important;
  }
  .pt-hd-0,
  .py-hd-0 {
    padding-top: 0 !important;
  }
  .pr-hd-0,
  .px-hd-0 {
    padding-right: 0 !important;
  }
  .pb-hd-0,
  .py-hd-0 {
    padding-bottom: 0 !important;
  }
  .pl-hd-0,
  .px-hd-0 {
    padding-left: 0 !important;
  }
}
@media (max-width: 767px) {
  .p-no-mob-down {
    padding-bottom: 0 !important;
  }
}
@media (max-width: 1023px) {
  .p-no-tab-down {
    padding-bottom: 0 !important;
  }
}
@media (max-width: 767px) {
  .m-no-mob-down {
    margin-bottom: 0 !important;
  }
}
@media (max-width: 1023px) {
  .m-no-tab-down {
    margin-bottom: 0 !important;
  }
}
.accordion {
  position: relative;
  display: flex;
  flex-direction: column;
}
.accordion-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  position: relative;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  outline: none;
}
.accordion-item ::marker {
  content: "";
  display: none;
}
.accordion-item::after {
  content: "";
}
.accordion-item:first-of-type .accordion-header {
  padding-top: 0;
}
.accordion-item-active .accordion-header:after {
  transform: rotate(-135deg);
}
.accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem 0;
  user-select: none;
  outline: none;
}
.accordion-header * {
  margin-bottom: 0;
}
.accordion-header::after {
  content: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'%3e%3cpath d='M17.941%2c0V13.433H16.449V2.546L1.055%2c17.91%2c0%2c16.853%2c15.391%2c1.492H4.475V0Z' transform='translate(17.91) rotate(90)' fill='%239a9a9a'/%3e%3c/svg%3e");
  display: block;
  width: 1.3rem;
  height: 1.3rem;
  min-width: 1.3rem;
  min-height: 1.3rem;
  margin-left: 1.6rem;
  transform-origin: 50% 50%;
  transition: transform 200ms ease;
  will-change: transform;
  transform-style: preserve-3d;
}
.accordion-content {
  display: block;
  max-height: 0;
  transition: 0.5s;
  will-change: max-height;
  overflow: hidden;
}
.accordion-content p:last-child {
  margin-bottom: 0;
  padding-bottom: 1.2rem;
}
@media (min-width: 768px) {
  .accordion-item {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
.alert {
  position: relative;
  width: 100%;
  padding: 1rem;
  background-color: #ff5043;
  border-radius: 4px;
}
.alert-text {
  color: #fff;
  margin-bottom: 0;
  line-height: 1.3;
}
.all-articles {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.all-articles * {
  margin: 0;
}
.all-articles-wrapper {
  width: 100%;
}
.all-articles-small {
  order: 100;
  margin-top: 1.8rem;
}
.all-articles-small .all-articles-wrapper {
  display: flex;
  justify-content: flex-end;
}
.all-articles-large {
  display: none;
  order: -1;
}
.all-articles-large .all-articles-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.all-articles-sub {
  display: none;
}
.all-articles-border.all-articles-large .all-articles-wrapper {
  padding-bottom: 3rem;
  margin-bottom: 3rem;
  border-bottom: var(--card-border);
}
.all-articles-border.all-articles-small .all-articles-wrapper {
  padding-top: 3rem;
  margin-top: 3rem;
  border-top: var(--card-border);
}
.all-articles-order-last {
  order: 9999;
}
.all-articles-wrapper-end {
  justify-content: flex-end !important;
}
.all-articles-wrapper-start {
  justify-content: flex-start !important;
}
@media (min-width: 768px) {
  .all-articles-small {
    display: none;
  }
  .all-articles-large {
    display: flex;
  }
  .all-articles-sub {
    display: block;
  }
}
.arrow {
  position: relative;
  display: inline-block;
  width: clamp(50px, 5vw, 66px);
  height: clamp(50px, 5vw, 66px);
  transform-origin: center;
  transform: rotate(var(--arrow-rotation));
  margin: 0;
}
.arrow-hover {
  position: relative;
  text-decoration: none;
  transition: none;
}
.arrow-hover-hidden,
.arrow-hover-visible {
  pointer-events: none;
  transition: all 300ms;
}
.arrow-hover-hidden {
  position: absolute;
  top: 0;
  left: 0;
}
.arrow-text {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
}
.arrow-text * {
  margin-bottom: 0;
}
.arrow-text-image {
  position: relative;
  transform: translateY(-20%);
  margin-left: 1.6rem;
}
.arrow-text-small .arrow-text-image {
  transform: scale(0.7) translateY(-20%);
  margin-left: 0;
  margin-right: -10px;
}
html.js-hover {
  display: inline-block;
  transition: all 300ms;
}
html.touchevents .arrow-hover-hidden,
html.touchevents .arrow-hover-visible {
  transition: none;
  opacity: 1 !important;
}
html.touchevents .arrow-hover-hidden {
  display: none;
}
.before-after {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
}
.before-after-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden;
}
.before-after-aspect {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
.before-after-foreground,
.before-after-background {
  width: 100%;
  z-index: 2;
}
.before-after-foreground img,
.before-after-foreground source,
.before-after-background img,
.before-after-background source {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
}
.before-after-background {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  will-change: width;
}
.before-after-text {
  display: flex;
  align-items: center;
  width: 100%;
  margin-top: 1.8rem;
}
.before-after-text * {
  width: 50%;
  margin-bottom: 0;
}
.before-after-slider {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  top: 0;
  outline: none;
  margin: 0;
  z-index: 10;
  transition: all 0.3s;
  background-color: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.before-after-slider::-webkit-slider-thumb {
  width: 6px;
  height: 100vh;
  height: 100svh;
  background: #0a0a0a;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
}
.before-after-slider::-moz-range-thumb {
  width: 6px;
  height: clamp(250px, 32vw, 900px);
  background: 100vh;
  cursor: pointer;
}
.before-after-line {
  position: absolute;
  display: block;
  top: 0;
  left: 50%;
  width: 6px;
  height: 100%;
  background-color: #0a0a0a;
  cursor: pointer;
  z-index: 10;
  transform: translateX(-50%);
}
.before-after-thumb {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 100;
  pointer-events: none;
  will-change: left;
  bottom: 0;
  right: 0;
}
.before-after-thumb:before,
.before-after-thumb:after {
  content: "";
  padding: 1rem;
  display: inline-block;
  border: solid #0a0a0a;
  margin: 0;
  border-width: 0 0.3rem 0.3rem 0;
}
.before-after-thumb:after {
  transform: rotate(-45deg);
}
.before-after-thumb:before {
  transform: rotate(135deg);
}
.before-after-white .before-after-slider::-webkit-slider-thumb {
  background: #fff;
}
.before-after-white .before-after-slider::-moz-range-thumb {
  background: #fff;
}
.before-after-white .before-after-thumb:before,
.before-after-white .before-after-thumb:after {
  border-color: #fff;
}
@media (min-width: 1024px) {
  .before-after-wrapper {
    min-height: 0;
  }
  .before-after-thumb::before,
  .before-after-thumb::after {
    margin: 0 10px;
    padding: 20px;
  }
}
html.no-touchevents .before-after-slider {
  background-color: rgba(10, 10, 10, 0.5);
}
html.no-touchevents .before-after-slider:hover {
  background: 0 0;
}
html.no-touchevents .before-after-line {
  display: none;
}
html.touchevents .before-after-slider {
  opacity: 0;
}
.breadcrumbs {
  position: relative;
  overflow: clip;
}
.breadcrumbs ::-webkit-scrollbar {
  display: none;
}
.breadcrumbs-list {
  width: 100%;
  display: flex;
  flex-wrap: nowrap;
  margin-bottom: 0;
  overflow-x: scroll;
}
.breadcrumbs-item {
  display: flex;
  align-items: center;
  padding: 6px 0;
}
.breadcrumbs-item:not(:first-child)::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11.483' height='10.022' viewBox='0 0 11.483 10.022'%3E%3Cpath d='M0,11.483,4.182,0H5.832l4.19,11.483H8.278L5.019,1.7l-3.3,9.779Z' transform='translate(11.483) rotate(90)' fill='%23595959' opacity='0.6'/%3E%3C/svg%3E%0A");
  display: inline-block;
  margin-left: 10px;
  margin-right: 10px;
}
.breadcrumbs-item:first-child {
  margin-left: 0;
}
.breadcrumbs-link {
  white-space: nowrap;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--colour-paragraph);
}
@media (min-width: 768px) {
  .breadcrumbs-item {
    padding: 0;
  }
  .breadcrumbs-link {
    max-width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
button,
a.btn {
  border-radius: 4px;
  cursor: pointer;
  outline: none;
  user-select: none;
  text-decoration: none;
  border: none;
}
.btn {
  position: relative;
  display: inline-block;
  height: auto;
  padding: 1rem 1.9rem;
  background-color: var(--colour-foreground);
  color: var(--colour-background);
  border: none;
  transition: transform 100ms linear, color 100ms linear,
    background 100ms linear;
  will-change: transform, color, background;
}
.btn:active {
  background-color: #0a0a0a;
  color: #fff;
}
.btn:active-text {
  color: #fff;
}
.btn:active svg path {
  stroke: #fff;
  fill: #fff;
}
.btn-wrapper {
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto;
}
.btn-multiple .btn {
  width: 100%;
}
.btn-multiple .btn:last-child {
  margin-top: 1rem;
}
.btn-text {
  display: inline-block;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.btn-colour-white {
  background-color: #fff;
  color: #0a0a0a;
}
.btn-colour-white svg path {
  stroke: #0a0a0a;
  fill: #0a0a0a;
}
.btn-colour-white:hover {
  color: #0a0a0a;
}
.btn-colour-white:active,
.btn-colour-white.btn-active {
  background-color: #0a0a0a;
  color: #fff;
}
.btn-colour-white:active svg path,
.btn-colour-white.btn-active svg path {
  stroke: #fff;
  fill: #fff;
}
.btn-colour-grey,
.btn-colour-black {
  background-color: #0a0a0a;
  color: #fff;
}
.btn-colour-grey svg path,
.btn-colour-black svg path {
  stroke: #fff;
  fill: #fff;
}
.btn-colour-grey:hover,
.btn-colour-black:hover {
  color: #fff;
}
.btn-colour-grey:active,
.btn-colour-grey.btn-active,
.btn-colour-black:active,
.btn-colour-black.btn-active {
  background-color: #fff;
  color: #0a0a0a;
}
.btn-colour-grey:active svg path,
.btn-colour-grey.btn-active svg path,
.btn-colour-black:active svg path,
.btn-colour-black.btn-active svg path {
  stroke: #0a0a0a;
  fill: #0a0a0a;
}
.btn-colour-grey {
  background-color: #171717;
}
.btn-size-tiny {
  padding: 0.6rem 1.4rem;
  font-size: 0.8rem;
}
.btn-size-tiny * {
  font-size: 0.8rem;
}
.btn-size-small {
  padding: 0.8rem 1.6rem;
}
.btn-size-large {
  padding: 1.2rem 3.2rem;
}
.btn-size-large .btn-text {
  font-size: 1.2rem;
}
.btn-block {
  width: 100%;
}
.btn-max-width {
  max-width: 220px;
}
.btn-arrow-image {
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
  transform-style: preserve-3d;
  transform-origin: 50% 50%;
}
.btn-arrow-image,
.btn-arrow .btn-text {
  transition: transform 200ms ease;
  will-change: transform;
}
.btn-arrow-left {
  position: absolute;
  top: 50%;
  left: 0;
  opacity: 0;
  transform: translate(calc(-50% - 30px), -50%) rotate(90deg);
}
.btn-arrow-right {
  position: relative;
  margin-left: 10px;
}
@media (hover: hover) {
  .btn-arrow:hover .btn-text {
    transform: translateX(30px);
    color: inherit;
  }
  .btn-arrow:hover .btn-arrow-right {
    opacity: 0;
  }
  .btn-arrow:hover .btn-arrow-left {
    opacity: 1;
    transform: translate(0, -50%) rotate(90deg);
  }
}
.btn-loading {
  transition: none;
  pointer-events: none;
  color: transparent !important;
}
.btn-loading * {
  opacity: 0;
}
.btn-loading::after {
  content: "";
  width: 1.4rem;
  height: 1.4rem;
  border: 3px solid #fff;
  border-right-color: transparent !important;
  border-radius: 50%;
  display: inline-block;
  animation-duration: 0.75s;
  animation-iteration-count: infinite;
  animation-name: spinner;
  animation-timing-function: linear;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -0.7rem;
  margin-top: -0.7rem;
}
@keyframes spinner {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
.btn-loading:hover {
  box-shadow: none;
}
@media (min-width: 768px) {
  .btn-multiple .btn {
    width: auto;
  }
  .btn-multiple .btn:not(:last-child) {
    margin-right: 1rem;
  }
}
@media (hover: none) {
  .btn[data-bookmark] {
    display: none;
  }
}
.card {
  position: relative;
  display: block;
  text-decoration: none;
  margin-bottom: 3.75rem;
  user-select: none;
}
.card-col {
  position: relative;
}
.card-col.col-12:last-child .card {
  margin-bottom: 0;
}
.card-col-first .card-basic,
.card-col:first-child .card-basic {
  padding-top: 0;
}
.card-col-last .card-basic,
.card-col:last-child .card-basic {
  padding-bottom: 0;
  border: none !important;
}
.card-image {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  object-fit: cover;
}
.card-image-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card-text {
  margin-top: 1.8rem;
}
.card-text * {
  text-decoration: none;
}
.card-text-title {
  margin-bottom: 0;
}
.card-text-lead {
  font-weight: 400;
  margin-top: 1rem;
}
.card-basic {
  margin-bottom: 0;
  padding-top: 3rem;
  padding-bottom: 3rem;
  border-bottom: var(--card-border);
}
.card-basic .card-text-title {
  margin-top: -14px;
}
.card-basic .card-text-lead {
  margin-bottom: 0;
}
.card-basic .card-tags {
  margin-top: calc(1.8rem - 10px);
  margin-right: 10px;
}
.card-basic .card-tags-reading-time {
  display: none;
  font-weight: 500;
}
.card-vertical .card-image-wrapper {
  padding-top: 145%;
}
.card-horizontal .card-image-wrapper {
  padding-top: 65%;
}
.card-clip {
  position: relative;
}
.card-clip .card-image,
.card-clip .card-image-clip {
  display: block;
}
.card-clip .card-image source,
.card-clip .card-image img,
.card-clip .card-image-clip source,
.card-clip .card-image-clip img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card-clip .card-image-clip {
  position: absolute;
  z-index: 10;
  pointer-events: none;
  clip-path: circle(0%);
  transform-origin: center;
}
@media (min-width: 568px) and (max-width: 1024px) {
  .card-col-mob-no-margin .card {
    margin-top: 0 !important;
    margin-bottom: 3.75rem;
  }
}
@media (min-width: 568px) {
  .card-col:nth-child(even) .card-half-margin {
    margin-top: clamp(120px, 30vw, 240px);
  }
  .card-tags-item {
    transform: none;
  }
  .card-tags .card-tags-reading-time {
    display: inline;
    margin-top: 0;
    margin-left: 10px;
  }
  .card-half-margin {
    margin-bottom: 0;
  }
}
@media (min-width: 768px) {
  .card-tags-reading-time {
    display: inline-block;
  }
}
@media (min-width: 1024px) {
  .card-col-padding.card-col-left {
    padding-right: 3rem;
  }
  .card-col-padding.card-col-right {
    padding-left: 3rem;
  }
}
code {
  display: inline-flex;
  max-width: 100%;
  overflow-x: auto;
  padding: 0.2em 0.4em;
  font-family: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas,
    Liberation Mono, monospace;
  background-color: #f2f2f2;
  color: #0a0a0a;
  margin: 0;
  font-size: 13px;
  white-space: nowrap;
  border-radius: 4px;
  line-height: 1.5;
}
.highlight {
  position: relative;
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 1.8rem;
  background-color: #fdfdfd;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid rgba(10, 10, 10, 0.15);
}
.highlight:last-of-type {
  margin-bottom: 0;
}
.highlight ::-webkit-scrollbar {
  display: none;
}
.highlight pre,
.highlight code {
  word-break: normal;
  word-wrap: normal;
  white-space: pre;
  background-color: #fdfdfd;
}
.highlight pre {
  max-width: 100%;
  overflow: scroll;
  margin: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  tab-size: 4;
}
.highlight code {
  display: block;
  width: 100%;
  font-family: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas,
    Liberation Mono, monospace;
  font-size: 14px;
  padding: 0;
  border-radius: 0;
  overflow-x: auto;
}
.highlight .line {
  opacity: 1;
  margin: 0;
  border: none;
}
.image {
  position: relative;
  display: block;
  height: auto;
}
.image img,
.image source {
  width: 100%;
  height: auto;
}
.image-split {
  position: relative;
  width: 80vw;
  max-height: 960px;
  max-width: 640px;
  margin-bottom: clamp(80px, 20vw, 200px);
  aspect-ratio: 2/3;
}
.image-split img,
.image-split source {
  height: 100%;
  object-fit: cover;
}
.image-split-right {
  margin-right: 0;
  margin-left: auto;
}
.image-split-section {
  margin-bottom: clamp(80px, 20vw, 200px);
  z-index: 10;
}
@media (min-width: 1024px) {
  .image-split {
    width: 40vw;
    max-width: 40vw;
    margin-bottom: 0;
    max-height: 100vh;
  }
  .image-split-section {
    display: flex;
    align-items: center;
    overflow: hidden;
  }
  .image-split-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
.richtext ul,
ul.list {
  margin-left: 16px;
}
.richtext ul li,
ul.list li {
  list-style-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11.483' height='10.022' viewBox='0 0 11.483 10.022'%3E%3Cpath d='M0,11.483,4.182,0H5.832l4.19,11.483H8.278L5.019,1.7l-3.3,9.779Z' transform='translate(11.483) rotate(90)' fill='%239a9a9a' opacity='0.6'/%3E%3C/svg%3E%0A");
}
.richtext ol,
.footnotes ol,
ol.list {
  margin-left: 18px;
}
.list,
.richtext ul,
.richtext ol,
.footnotes ul,
.footnotes ol {
  margin-top: 0;
  margin-bottom: 1rem;
  padding: 0;
  list-style-position: outside;
}
.list li,
.richtext ul li,
.richtext ol li,
.footnotes ul li,
.footnotes ol li {
  color: var(--colour-list);
  margin-bottom: 10px;
  padding: 0 0 0 12px;
  font-size: 1.1rem;
}
.list li:last-child,
.list li p,
.richtext ul li:last-child,
.richtext ul li p,
.richtext ol li:last-child,
.richtext ol li p,
.footnotes ul li:last-child,
.footnotes ul li p,
.footnotes ol li:last-child,
.footnotes ol li p {
  margin-bottom: 0;
}
.list ul,
.list ol,
.richtext ul ul,
.richtext ul ol,
.richtext ol ul,
.richtext ol ol,
.footnotes ul ul,
.footnotes ul ol,
.footnotes ol ul,
.footnotes ol ol {
  margin-top: 14px;
  margin-left: 1rem;
  padding: 0;
}
.list ::marker,
.richtext ul ::marker,
.richtext ol ::marker,
.footnotes ul ::marker,
.footnotes ol ::marker {
  margin: 0;
  padding: 0;
}
.theme-white .richtext ul li,
.theme-white ul.list li {
  list-style-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11.483' height='10.022' viewBox='0 0 11.483 10.022'%3E%3Cpath d='M0,11.483,4.182,0H5.832l4.19,11.483H8.278L5.019,1.7l-3.3,9.779Z' transform='translate(11.483) rotate(90)' fill='%23595959' opacity='0.6'/%3E%3C/svg%3E%0A");
}
.marquee {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  overflow: hidden;
  transform: rotate(-3deg) skew(-5deg);
  height: 100px;
}
.marquee-inner {
  display: flex;
  position: absolute;
  width: 200%;
  will-change: left;
  animation: marquee 10s linear infinite;
}
.marquee-inner:hover {
  animation-play-state: paused;
}
.marquee-wrapper {
  display: flex;
  align-items: center;
  overflow: hidden;
  width: 50%;
}
.marquee-text {
  display: flex;
  align-items: center;
  margin-bottom: 0;
  user-select: none;
  width: 20%;
  max-width: 20%;
  font-size: 6.5vw !important;
}
.marquee-text:before {
  content: "";
  display: none;
  position: relative;
  width: 20%;
  margin-right: 20px;
  transform: translateY(4px);
  height: 4px;
  background-color: #fff;
}
@keyframes marquee {
  0% {
    left: 0;
  }
  100% {
    left: -100%;
  }
}
@media (max-width: 1023px) {
  .marquee-text {
    width: 33.3%;
    max-width: 33.3%;
  }
  .marquee-text:nth-last-child(2),
  .marquee-text:last-child {
    display: none;
  }
}
@media (min-width: 768px) {
  .marquee-inner {
    animation: marquee 15s linear infinite;
  }
}
@media (min-width: 1024px) {
  .marquee-text {
    font-size: 3vw !important;
  }
  .marquee-text:before {
    margin-left: 20px;
    display: inline-block;
  }
}
.pagination {
  padding-top: clamp(50px, 10vw, 100px);
}
.placeholder {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 20vh;
  min-height: 160px;
  max-height: 250px;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 18px,
    rgba(255, 255, 255, 0.1) 20px
  );
  border: 2px solid #464646;
}
.placeholder-white {
  background: #fff
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 18px,
      rgba(10, 10, 10, 0.1) 20px
    );
}
.placeholder-auto-height {
  height: auto;
  min-height: 0;
  max-height: none;
}
.placeholder-aspect {
  width: 100%;
  padding-top: 56.25%;
  height: 0;
  max-height: none;
}
.placeholder-aspect-item {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.placeholder-margin-large {
  height: 3rem;
}
.placeholder-margin-regular {
  height: 1.8rem;
}
blockquote {
  position: relative;
  display: flex;
  align-items: stretch;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  padding: 0;
  font-size: 1.2rem;
  font-style: italic;
}
blockquote p:last-of-type {
  margin: 0;
}
blockquote::before {
  content: "";
  position: relative;
  display: block;
  width: 4px;
  min-width: 4px;
  margin-right: 1.8rem;
  background-color: var(--colour-blue);
}
.social {
  position: relative;
  display: flex;
  align-items: center;
}
.social-link {
  display: flex;
  text-decoration: none;
  margin-right: 1.6rem;
}
.social-link:last-child {
  margin-right: 0;
}
.social-icon {
  height: 25px;
}
@media (max-width: 350px) {
  .social-icon {
    height: 20px;
  }
}
@media (min-width: 1024px) {
  .social-link {
    margin-right: 1.8rem;
  }
}
table {
  position: relative;
  display: block;
  max-width: fit-content;
  overflow-x: auto;
  white-space: nowrap;
  border-spacing: 0;
  border-collapse: collapse;
  box-sizing: border-box;
}
table th,
table td {
  padding: 0.6rem 0.9rem;
  color: var(--table-cell-colour);
  border: 1.6px solid var(--table-border-colour);
}
table thead {
  font-weight: 700;
}
table thead tr th {
  color: var(--colour-foreground);
  font-size: 18px;
}
table tbody {
  font-size: 1rem;
}
table tbody tr:nth-child(2n) {
  background-color: var(--table-stripe-colour);
}
hr,
.rule {
  display: block;
  border-width: 2px;
  border-color: var(--colour-foreground);
  border-style: solid;
  padding: 0;
  margin: 1.8rem 0;
}
hr-vertical,
.rule-vertical {
  width: auto;
  border-style: none;
  border-left-width: 4px;
  border-left-style: solid;
  height: 100%;
  margin: 0;
}
hr-medium,
.rule-medium {
  border-width: 3px;
}
hr-thick,
.rule-thick {
  border-width: 4px;
}
hr-opaque,
.rule-opaque {
  opacity: 0.15;
}
.tag {
  position: relative;
  display: inline-flex;
  margin: 0 4px;
  padding: 2px 10px;
  background-color: #f2f2f2;
  color: #595959;
  font-size: 0.9rem;
  border-radius: 4px;
  user-select: none;
  font-weight: 500;
  white-space: nowrap;
}
.tag:first-of-type {
  margin-left: 0;
}
.tag:last-of-type {
  margin-left: 0;
  margin-right: 0;
}
.tag-black {
  background-color: #0f0f0f;
  color: #fff;
}
.tag-margin-top {
  margin-top: 10px;
}
.bg-off-white .tag {
  background-color: #fff;
}
input[type="checkbox"]:disabled {
  appearance: none;
  border: none;
  color: var(--colour-foreground);
  background-color: var(--colour-foreground);
  width: 24px;
  height: 24px;
  border-radius: 0;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22,2V22H2V2Zm2-2H0V24H24Z' /%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22,2V22H2V2Zm2-2H0V24H24Z' /%3E%3C/svg%3E");
}
input[type="checkbox"]:disabled:checked {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 2v20h-20v-20h20zm2-2h-24v24h24v-24zm-5.541 8.409l-1.422-1.409-7.021 7.183-3.08-2.937-1.395 1.435 4.5 4.319 8.418-8.591z' /%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 2v20h-20v-20h20zm2-2h-24v24h24v-24zm-5.541 8.409l-1.422-1.409-7.021 7.183-3.08-2.937-1.395 1.435 4.5 4.319 8.418-8.591z' /%3E%3C/svg%3E");
}
.vertical {
  position: relative;
  width: 100%;
  z-index: 999;
}
.vertical * {
  display: block;
  line-height: 1;
  color: var(--colour-foreground);
}
.vertical-container {
  display: flex;
  width: 100%;
  height: 100%;
}
.vertical-text {
  margin-bottom: 1.3rem;
  line-height: 1.2;
  letter-spacing: -1px;
  font-weight: 700;
  margin-bottom: 0;
}
.vertical-text {
  font-size: 34px;
}
@media screen and (min-width: 400px) {
  .vertical-text {
    font-size: calc(34px + 16 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  .vertical-text {
    font-size: 50px;
  }
}
.vertical-line {
  content: "";
  position: relative;
  display: block;
  height: 3px;
  width: 100%;
  margin-top: 1.8rem;
  margin-bottom: 3rem;
  background-color: var(--colour-foreground);
}
.vertical-number {
  display: block;
  margin-bottom: 6px;
}
@media (min-width: 568px) {
  .vertical {
    display: flex;
    position: relative;
    flex-direction: row-reverse;
    align-items: flex-start;
    margin-top: 1rem;
    writing-mode: vertical-rl;
    transform: scale(-1);
    width: auto;
  }
  .vertical-text {
    margin-bottom: 1.8rem;
    line-height: 1.03;
    letter-spacing: -1px;
    margin-bottom: 0;
  }
  .vertical-text {
    font-size: 36px;
  }
}
@media screen and (min-width: 568px) and (min-width: 400px) {
  .vertical-text {
    font-size: calc(36px + 32 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 568px) and (min-width: 1600px) {
  .vertical-text {
    font-size: 68px;
  }
}
@media (min-width: 568px) {
  .vertical-text .type-serif {
    font-size: 44px;
  }
}
@media screen and (min-width: 568px) and (min-width: 400px) {
  .vertical-text .type-serif {
    font-size: calc(44px + 36 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 568px) and (min-width: 1600px) {
  .vertical-text .type-serif {
    font-size: 80px;
  }
}
@media (min-width: 568px) and (max-width: 767px) {
  .vertical-text .type-serif.small-mob {
    font-size: 47px;
  }
}
@media screen and (min-width: 568px) and (max-width: 767px) and (min-width: 400px) {
  .vertical-text .type-serif.small-mob {
    font-size: calc(47px + 33 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 568px) and (max-width: 767px) and (min-width: 1600px) {
  .vertical-text .type-serif.small-mob {
    font-size: 80px;
  }
}
@media (min-width: 568px) {
  .vertical-line {
    height: 30vh;
    min-height: 130px;
    max-height: 220px;
    width: 5px;
    min-width: 5px;
    margin: 0 1.6rem 1.8rem 0;
  }
  .vertical-word {
    line-height: 0.9;
  }
  .vertical-number {
    margin-bottom: 0;
    height: 60px;
  }
  .vertical-with-number {
    align-items: flex-end;
  }
  .vertical-with-number .vertical-line {
    margin: 0 0 1.8rem clamp(16px, 2vw, 27px);
  }
  .vertical-fill {
    margin-top: 0;
  }
  .vertical-fill .vertical-line {
    flex-grow: 2;
    height: 100%;
    min-height: 0;
    max-height: 400px;
  }
}
.vertical-section-vertical-line {
  display: none;
}
.vertical-section-horizontal-line {
  margin-bottom: 0;
}
@media (min-width: 568px) and (max-width: 568px -1px) {
  .vertical-section .vertical-number {
    margin-left: 0 !important;
  }
}
@media (min-width: 568px) {
  .vertical-section-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .vertical-section-vertical-line {
    display: block;
    margin: 0 0 0 clamp(56px, 7vw, 80px);
  }
}
@media (min-width: 1024px) {
  .vertical-section-vertical-line {
    margin: 0 0 0 clamp(68px, 5vw, 80px);
  }
}
.video {
  width: 100%;
}
.video-container {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: auto;
  max-width: 100vw;
  background-color: transparent;
  z-index: 100099;
}
.video-contain {
  object-fit: contain !important;
}
.video-full {
  display: none;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100svh;
  max-width: 100%;
  max-height: 100%;
  z-index: 100998;
  background-color: #0a0a0a;
}
.video-full video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
}
.video-full-active {
  display: flex;
}
.video-button {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10vw 0 10vw 16vw;
  border-color: transparent transparent transparent rgba(10, 10, 10, 0.6);
  cursor: pointer;
  transition: opacity 300ms ease;
  z-index: 999;
  will-change: opacity;
  pointer-events: none;
}
.video-playing ~ .video-button {
  opacity: 0;
}
.video-close {
  position: absolute;
  top: 10px;
  right: 10px;
  margin: 0;
  z-index: 100;
}
.video-controls {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  justify-content: space-between;
  padding: 0 20px;
  color: #fff;
}
.video-controls-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 10px 0;
}
.video-play-pause {
  position: relative;
  margin-right: 1rem;
}
.video-play-pause .video-play,
.video-play-pause .video-pause {
  display: flex;
  justify-content: center;
  align-items: center;
}
.video-playing .video-play {
  opacity: 0;
}
.video-playing .video-pause {
  opacity: 1;
}
.video-volume-muted .video-volume-slider {
  background: #0a0a0a;
}
.video-volume-muted .video-icon-loud {
  opacity: 0;
}
.video-volume-muted .video-icon-mute {
  opacity: 1;
}
.video-left {
  display: flex;
  align-items: center;
}
.video-time {
  display: flex;
  align-items: center;
  width: 100%;
  margin-bottom: 0;
}
.video-time .video-current-time,
.video-time .video-duration {
  display: block;
  color: var(--colour-paragraph);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 0.9rem;
  color: #fff;
  margin: 0;
  font-weight: 700;
  width: 70px;
  user-select: none;
}
.video-time .video-duration {
  text-align: right;
}
.video-pause,
.video-icon-mute {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
}
.video-icon-mute {
  top: calc(50% - 2px);
}
.video svg {
  transition: opacity 200ms ease;
  will-change: opacity;
}
.video-progress-bar {
  width: 100%;
  height: 12px;
  margin: 0 10px;
  padding: 5px;
  border: solid 1px #fff;
  position: relative;
  cursor: pointer;
}
.video-progress-bar .video-progress {
  height: calc(100% - 5px);
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.video-volume {
  display: flex;
  align-items: center;
}
.video-volume-icon {
  position: relative;
  margin-right: 10px;
}
.video-volume-slider {
  background: #fff;
  border: solid 1px #fff;
  height: 4px;
  width: 8rem;
  outline: none;
  transition: background 50ms ease;
  -webkit-appearance: none;
}
.video-volume ::-webkit-slider-thumb {
  width: 8px;
  height: 20px;
  cursor: ew-resize;
  -webkit-appearance: none;
  background: #fff;
}
.video-fullscreen {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.video-fullscreen svg {
  width: 26px;
  height: 26px;
}
@media (min-width: 1024px) {
  .video-button {
    border-width: 4vw 0 4vw 5vw;
  }
  .video-full-close {
    top: 1.6rem;
    right: 1.6rem;
  }
}
html.touchevents .video-volume {
  display: none;
}
html.touchevents .video-controls {
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1rem 1.4rem;
}
html.touchevents .video-controls-container {
  padding: 0;
}
html.touchevents .video-fullscreen {
  margin-right: 1.4rem;
}
html.touchevents .video-fullscreen svg {
  width: 26px;
  height: 26px;
}
html.touchevents .video-play-pause {
  margin-right: 1.4rem;
}
html.touchevents .video-play-pause svg {
  transform: scale(1.2);
}
html.touchevents .video-controls-container {
  justify-content: flex-start;
  width: auto;
}
.aside {
  position: fixed;
  top: 0;
  left: 0;
  width: 70vw;
  height: 100vh;
  max-width: 340px;
  background-color: #fff;
  display: block;
  margin: 0;
  padding: 76px 20px 0;
  z-index: 100009;
  transform: translateX(-100%);
}
.aside-link {
  display: block;
  text-decoration: none;
  padding: 1rem 0;
  border-bottom: 2px solid rgba(10, 10, 10, 0.1);
}
.aside-link:first-child {
  padding-top: 0;
}
.aside-link:last-of-type {
  margin-bottom: 0;
  border-bottom: 0;
}
.aside-text {
  text-decoration: none;
  margin: 0;
  color: var(--colour-copy-light);
  font-size: 1.1rem;
}
.aside-checkbox {
  position: absolute;
  top: -9999px;
  left: -9999px;
  display: none;
}
.aside-checkbox:checked ~ .aside-overlay {
  z-index: 100000;
}
.aside-btn {
  position: absolute;
  bottom: 0;
  right: 2px;
  border-radius: 10px 10px 0 0;
  background-color: #fff;
  padding: 10px 24px;
  transform-origin: right bottom;
  transform: rotate(90deg) translateX(-50%);
}
.aside-btn-text {
  margin: 0;
  color: #0a0a0a;
  font-weight: 500;
}
.aside-desk {
  display: none;
}
.aside-close {
  position: absolute;
  top: 20px;
  right: 20px;
}
.aside-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(10, 10, 10, 0.6);
  z-index: -1;
  opacity: 0;
  transition: opacity 200ms ease;
  will-change: opacity;
}
.aside-active {
  color: var(--link-hover-colour) !important;
}
@media (min-width: 1024px) {
  .aside {
    position: sticky;
    width: auto;
    height: auto;
    top: 100px;
    padding: 0;
    transform: none;
    background-color: transparent;
    max-width: none;
    transition: none;
    z-index: 99989;
  }
  .aside-link {
    border-bottom: 2px solid rgba(255, 255, 255, 0.1);
  }
  .aside-link:hover * {
    color: #fff;
  }
  .aside-text {
    color: var(--colour-copy-dark);
  }
  .aside-btn,
  .aside-close,
  .aside-overlay {
    display: none;
  }
}
.footer {
  position: relative;
  display: block;
  overflow: hidden;
  background-color: #0a0a0a;
}
.footer * {
  color: #fff;
}
.footer-main {
  position: relative;
  padding: 6rem 0;
  background-color: #0a0a0a;
}
.footer-main-menu {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: none;
  grid-row-gap: 1.2rem;
  align-items: flex-end;
  margin-bottom: 0;
}
.footer-main-menu-link {
  text-decoration: none;
}
.footer-main-menu-link * {
  margin-bottom: 0;
}
.footer-sub {
  position: relative;
}
.footer-sub-wrapper {
  display: flex;
  flex-flow: column nowrap;
  border-top: 2px solid rgba(255, 255, 255, 0.15);
  padding-top: 1.4rem;
  padding-bottom: 1.4rem;
}
.footer-sub-text {
  color: #9a9a9a;
}
.footer-sub-menu {
  display: flex;
  flex-direction: row;
  margin-bottom: 0.8rem;
}
.footer-sub-menu-link {
  text-decoration: none;
  white-space: nowrap;
  color: var(--colour-copy-dark);
  font-weight: 400;
}
.footer-sub-menu-link::after {
  content: "|";
  color: var(--colour-copy-dark);
  margin: 0 8px;
}
.footer-sub-menu-item:last-child .footer-sub-menu-link::after {
  display: none;
}
.footer-contact {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin: 3rem 0;
}
.footer-contact-sub {
  color: var(--colour-copy-dark);
}
.footer-symbol {
  position: absolute;
  display: flex;
  bottom: 0;
  right: 15px;
  width: clamp(220px, 80vw, 350px);
  max-width: 350px;
}
.footer-symbol img {
  height: 100%;
  width: 100%;
}
.footer-logo {
  display: none;
  width: 30%;
  max-width: 240px;
  margin-bottom: 1rem;
}
.footer-logo img {
  width: 100%;
}
.footer-heading {
  margin-bottom: 0;
}
@media (max-width: 350px) {
  .footer-sub-menu {
    flex-direction: column;
  }
  .footer-sub-menu-link::after {
    display: none;
  }
}
@media (min-width: 568px) {
  .footer-contact {
    flex-direction: row;
    align-items: center;
  }
  .footer-contact-email {
    margin-bottom: 0;
    margin-right: 3rem;
  }
}
@media (min-width: 768px) {
  .footer-main {
    padding-bottom: 5rem;
  }
  .footer-main-menu {
    display: grid;
    grid-template-rows: repeat(3, 1fr);
    grid-template-columns: none;
    grid-auto-flow: column;
  }
}
@media (min-width: 1024px) {
  .footer-main-col {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  .footer-sub-wrapper {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 1.6rem 0;
  }
  .footer-sub-menu {
    margin-left: 4rem;
    margin-bottom: 0;
    order: 99;
  }
  .footer-heading {
    margin-bottom: 1rem;
    line-height: 1.3;
    letter-spacing: -1px;
    margin-bottom: 5rem;
  }
  .footer-heading {
    font-size: 23px;
  }
}
@media screen and (min-width: 1024px) and (min-width: 400px) {
  .footer-heading {
    font-size: calc(23px + 14 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (min-width: 1600px) {
  .footer-heading {
    font-size: 37px;
  }
}
@media (min-width: 1024px) {
  .footer-contact {
    margin: 0;
  }
  .footer-logo {
    display: block;
  }
}
@media (min-width: 1024px) and (max-width: 1300px) {
  .footer-heading {
    margin-bottom: 3rem;
  }
  .footer-contact {
    flex-direction: column;
    align-items: flex-start;
  }
  .footer-contact-email {
    margin-right: 0;
    margin-bottom: 1.6rem;
  }
}
.form {
  position: relative;
  display: block;
}
.form-wrapper {
  padding: 2rem;
  background-color: #f2f2f2;
  border-radius: 8px;
  margin-bottom: 3rem;
}
.form-group {
  margin-bottom: 2rem;
}
.form-group-bee {
  opacity: 0;
  display: none;
}
.form-input {
  position: relative;
  width: 100%;
  margin-bottom: 1.3rem;
  line-height: 1.2;
  letter-spacing: -1px;
  margin: 0;
  padding: 0;
  border: none;
  color: #0a0a0a;
  background-color: transparent;
  line-height: 1.2;
  font-weight: 700;
  font-family: plus jakarta sans, -apple-system, BlinkMacSystemFont, segoe ui,
    Roboto, Helvetica, Arial, sans-serif, apple color emoji, segoe ui emoji,
    segoe ui symbol;
  outline: none;
  resize: vertical;
  -webkit-appearance: none;
  appearance: none;
}
.form-input {
  font-size: 34px;
}
@media screen and (min-width: 400px) {
  .form-input {
    font-size: calc(34px + 16 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  .form-input {
    font-size: 50px;
  }
}
.form-label {
  display: flex;
  width: 100%;
}
.form-submit {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  background-color: transparent;
}
.form-error .form-number {
  color: #ff5043;
}
.form-error .form-input {
  border-bottom-color: #ff5043;
}
.form-success .form-input {
  border-bottom-color: #70cbce;
}
.form input:-webkit-autofill,
.form input:-webkit-autofill:hover,
.form input:-webkit-autofill:focus,
.form input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset !important;
}
.form ::placeholder {
  color: #0a0a0a;
  opacity: 1;
}
.form :-ms-input-placeholder {
  color: #0a0a0a;
}
.form ::-ms-input-placeholder {
  color: #0a0a0a;
}
@media (min-width: 1024px) {
  .form-wrapper {
    padding: 3rem;
  }
}
.header {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: space-between;
  top: 0;
  left: 0;
  height: 80px;
  width: 100%;
  padding: 0 7vw;
  backdrop-filter: blur(1px);
  z-index: 99999;
  transition: background-color 600ms ease;
}
.header-logo {
  display: flex;
  align-items: center;
  z-index: 999999;
  height: 100%;
  width: 115px;
}
.header-logo svg {
  width: 100%;
  height: 100%;
}
.header-colour-black {
  background-color: rgba(10, 10, 10, 0.6);
  border-bottom: none;
}
.header-colour-white {
  background-color: rgba(255, 255, 255, 0.6);
  border-bottom: 1px solid rgba(10, 10, 10, 0.2);
}
.header-colour-white .nav-btn-arrow path,
.header-colour-white .header-logo path {
  fill: #0a0a0a;
}
.header-colour-white .nav-btn-text {
  color: #0a0a0a;
}
.header-nav {
  position: absolute;
}
.header-nav * {
  color: #fff;
}
@media (min-width: 1024px) {
  .header {
    padding: 0 30px;
    background-color: transparent;
    backdrop-filter: blur(2px);
  }
  .header-colour-black {
    backdrop-filter: none;
  }
}
.hero {
  position: relative;
}
.hero .container {
  z-index: 9;
}
.hero-background {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: 100vw;
  z-index: -2;
}
.hero-background img,
.hero-background source {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-full-height,
.hero-half-height {
  display: flex;
  align-items: center;
  width: 100%;
}
.hero-simple {
  padding-top: 120px;
}
.hero-simple-padding-bottom {
  padding-bottom: clamp(80px, 20vw, 200px);
}
.hero-full-height {
  height: 100vh;
  height: 100svh;
}
.hero-half-height {
  padding-top: 80px;
  height: 70vh;
  min-height: 500px;
}
.hero-space-around {
  display: flex;
  padding-top: 120px;
}
.hero-space-around .hero-row {
  margin-bottom: 3rem;
}
.hero-text,
.hero-text-large {
  margin-bottom: 8vh;
}
.hero-lead {
  margin-bottom: 0;
  color: #fff;
}
.hero-align-bottom {
  align-items: flex-end;
  padding-bottom: 7vh;
}
.hero-a-symbol {
  position: absolute;
  bottom: 0;
  right: 0;
  min-height: 360px;
  height: 50vw;
  aspect-ratio: 1.1/1;
  transform: translateY(-60%);
}
.hero-a-symbol-left {
  left: 0;
  right: auto;
}
.hero-a-symbol-right {
  right: 0;
  left: auto;
}
.hero-a-symbol svg {
  width: auto;
  height: 100%;
  opacity: 0.99;
}
.hero-logos {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 2rem;
  margin-bottom: -1.2rem;
}
.hero-logos a {
  display: flex;
  align-items: center;
}
.hero-logos figure {
  display: inline-grid;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  max-height: 50px;
  margin-bottom: 1.2rem;
}
.hero-logos figure img {
  width: 100%;
  max-width: 160px;
}
.hero-min-height {
  min-height: 720px;
}
.hero-animate {
  position: relative;
}
.hero-animate u,
.hero-animate h1 {
  position: relative;
}
.hero-animate span {
  display: inline !important;
}
@media (min-width: 568px) {
  .hero-align-bottom {
    padding-bottom: 10vh;
  }
  .hero-a-symbol {
    transform: none;
  }
  .hero-logos {
    display: flex;
    flex-wrap: wrap;
    grid-column-gap: 0;
    grid-row-gap: 0;
    max-width: 720px;
  }
  .hero-logos figure {
    width: auto;
    margin-right: 1.8rem;
  }
  .hero-logos figure img {
    max-width: 260px;
  }
}
@media (min-width: 768px) {
  .hero-simple {
    padding-top: clamp(100px, 20vw, 170px);
  }
  .hero-text-large {
    margin-bottom: 20vh;
  }
}
@media (min-height: 800px) {
  .hero-space-around {
    height: 100vh;
    height: 100svh;
    padding-top: 0;
  }
  .hero-space-around .hero-container {
    display: flex;
    flex-direction: column;
    height: 90%;
    justify-content: space-around;
    align-self: flex-end;
  }
  .hero-space-around .hero-row {
    margin-bottom: 0;
  }
}
@media (max-width: 567px) {
  .hero-space-around {
    height: auto;
    padding-top: 0;
  }
  .hero-space-around .hero-row {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 120px;
    min-height: 100svh;
  }
}
@media (min-width: 1024px) {
  .hero-arrow {
    transition: all 100ms;
    transform-style: preserve-3d;
    transform-origin: 50% 50%;
  }
  .hero-a-symbol-container {
    opacity: 1 !important;
    mix-blend-mode: normal !important;
  }
  .hero-logos {
    transform: scale(1.1);
    transform-origin: left;
  }
}
.nav {
  position: fixed;
  display: none;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  overflow-y: scroll;
  overflow-x: clip;
  background-color: #0a0a0a;
  z-index: 100009;
}
.nav-js {
  display: none;
}
.nav-container {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
}
.nav-row {
  width: 100%;
}
.nav-list-white .nav-link * {
  color: #0a0a0a;
}
.nav-list .nav-item:last-child {
  margin-bottom: 0;
}
.nav-item {
  margin-bottom: 1.8rem;
}
.nav-link {
  position: relative;
  display: inline-block;
  text-decoration: none;
}
.nav-link-text {
  position: relative;
  display: inline-block;
  margin-bottom: 0;
}
.nav-link-text {
  font-size: 34px;
}
@media screen and (min-width: 400px) {
  .nav-link-text {
    font-size: calc(34px + 46 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1600px) {
  .nav-link-text {
    font-size: 80px;
  }
}
.nav-contact {
  display: none;
  flex-direction: column;
}
.nav-contact-section:not(:last-child) {
  margin-bottom: 3rem;
}
.nav-btn {
  display: flex;
  align-items: flex-end;
  cursor: pointer;
  z-index: 10;
  padding: 10px;
  margin-right: -10px;
  margin-top: -10px;
}
.nav-btn-text {
  display: block;
  color: var(--colour-paragraph);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 0.9rem;
  color: var(--colour-foreground);
  margin-right: 8px;
  margin-bottom: 0;
  font-size: 0.9rem;
  user-select: none;
}
.nav-btn-wrapper {
  position: relative;
}
.nav-btn-arrow {
  display: flex;
  width: 18px;
  height: 18px;
}
.nav-btn-arrow svg {
  width: 100%;
  height: 100%;
}
.nav-checkbox {
  position: absolute;
  display: none;
  top: -9999999px;
  left: -9999999px;
}
@media screen and (max-height: 1000px) and (min-width: 768px) {
  .nav-link-text {
    font-size: 8vh;
  }
}
@media (max-width: 350px) {
  .nav-link-text {
    font-size: 30px;
  }
}
@media (min-width: 568px) {
  .nav-btn-text {
    margin-right: 12px;
  }
}
@media (min-width: 1024px) {
  .nav-row {
    align-items: flex-end;
  }
  .nav-list {
    display: inline-block;
  }
  .nav-item {
    margin-bottom: 2.6rem;
  }
  .nav-list:hover .nav-link:not(:hover) {
    opacity: 0.4;
  }
  .nav-link {
    transition: opacity 500ms ease;
    will-change: opacity;
  }
  .nav-link-text {
    margin-bottom: 0;
    transition: transform 500ms ease-in-out;
    will-change: transform;
  }
  .nav-link::after {
    content: url(/images/icons/nav-arrow.svg);
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(-100%, -50%);
    opacity: 0;
    transition: transform 500ms ease-in-out, opacity 500ms ease-in-out;
    will-change: transform, opacity;
  }
  .nav-link:hover .nav-link-text {
    transform: translateX(100px);
  }
  .nav-link:hover::after {
    opacity: 1;
    transform: translate(0, -50%);
  }
  .nav-images {
    display: block;
  }
  .nav-contact {
    display: flex;
  }
}
@media screen and (orientation: landscape) and (max-height: 600px) {
  .nav-row {
    align-items: flex-start;
  }
  .nav-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 1fr);
    grid-column-gap: 1rem;
    grid-row-gap: 1.8rem;
  }
  .nav-link {
    margin-bottom: 0;
  }
}
.richtext p + h1,
.richtext p + h2,
.richtext p + h3,
.richtext p + h4,
.richtext p + h5,
.richtext ul + h1,
.richtext ul + h2,
.richtext ul + h3,
.richtext ul + h4,
.richtext ul + h5,
.richtext blockquote + h1,
.richtext blockquote + h2,
.richtext blockquote + h3,
.richtext blockquote + h4,
.richtext blockquote + h5,
.richtext .highlight + h1,
.richtext .highlight + h2,
.richtext .highlight + h3,
.richtext .highlight + h4,
.richtext .highlight + h5,
.richtext .codepen + h1,
.richtext .codepen + h2,
.richtext .codepen + h3,
.richtext .codepen + h4,
.richtext .codepen + h5 {
  margin-top: 3rem;
}
.richtext .lead {
  margin-bottom: 0;
}
.richtext > :last-child {
  margin-bottom: 0 !important;
}
.richtext ul:empty,
.richtext p:empty {
  display: none;
  margin: 0;
}
.richtext ul + .image,
.richtext ul + .highlight,
.richtext ul + .codepen,
.richtext p + .image,
.richtext p + .highlight,
.richtext p + .codepen {
  margin-top: 3rem;
}
.richtext a {
  word-break: break-word;
  color: #0a0a0a;
  text-decoration: underline;
}
.richtext .image + h1,
.richtext .image + h2,
.richtext .image + h3,
.richtext .image + h4,
.richtext .image + h5,
.richtext .image + p,
.richtext .codepen + h1,
.richtext .codepen + h2,
.richtext .codepen + h3,
.richtext .codepen + h4,
.richtext .codepen + h5,
.richtext .codepen + p,
.richtext .video-container + h1,
.richtext .video-container + h2,
.richtext .video-container + h3,
.richtext .video-container + h4,
.richtext .video-container + h5,
.richtext .video-container + p {
  margin-top: 3rem;
}
.richtext p + .video-container {
  margin-top: 1.8rem;
}
.richtext .video,
.richtext .image {
  margin-text-outline: 1.8rem;
}
.richtext .video + .image,
.richtext .image + .image {
  margin-bottom: 1.8rem;
}
.section {
  position: relative;
}
.section-padding {
  padding-top: clamp(80px, 20vw, 200px);
  padding-bottom: clamp(80px, 20vw, 200px);
}
.section-padding-small {
  padding-top: clamp(40px, 5vw, 140px);
  padding-bottom: clamp(40px, 5vw, 140px);
}
.section-padding-large {
  padding-top: clamp(120px, 30vw, 240px);
  padding-bottom: clamp(120px, 30vw, 240px);
}
.section-padding-bottom {
  padding-top: 0 !important;
}
.section-padding-top {
  padding-bottom: 0 !important;
}
.section-margin {
  margin-top: clamp(80px, 20vw, 200px);
  margin-bottom: clamp(80px, 20vw, 200px);
}
.section-margin-small {
  margin-top: clamp(40px, 5vw, 140px);
  margin-bottom: clamp(40px, 5vw, 140px);
}
.section-margin-large {
  margin-top: clamp(120px, 30vw, 240px);
  margin-bottom: clamp(120px, 30vw, 240px);
}
.section-margin-bottom {
  margin-top: 0 !important;
}
.section-margin-top {
  margin-bottom: 0 !important;
}
.section-hide-overflow {
  overflow-x: hidden;
}
.banner {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: clamp(80px, 20vw, 200px) 0;
  overflow: hidden;
}
.banner-image {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  width: 100%;
  height: 100%;
  user-select: none;
}
.banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 60%;
}
.banner-sub {
  color: #fff;
}
.map {
  position: relative;
  width: 100%;
  height: 60vh;
  min-height: 300px;
  z-index: 1;
}
.map-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  overflow: hidden;
}
.map-container {
  background-color: #0f0f0f;
}
.map-info {
  position: relative;
  width: 100%;
  margin: 0;
  background-color: transparent;
  color: #fff;
  user-select: none;
  z-index: 2;
}
.map-info-link {
  margin: 0;
  color: #fff;
}
.map-info address {
  font-style: normal;
}
.map-info address * {
  color: #fff;
}
@media (min-width: 768px) {
  .map {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  .map-wrapper {
    flex-direction: row;
    align-items: flex-start;
    width: 100%;
    height: 80vh;
  }
  .map-container {
    background-color: transparent;
  }
  .map-info {
    width: 340px;
    padding: 3rem 2rem;
    margin-top: 7vw;
    background-color: #0f0f0f;
    border-radius: 8px;
  }
}
@media (min-width: 1024px) {
  .map-wrapper {
    height: 600px;
    align-items: center;
  }
  .map-info {
    margin-top: 0;
  }
}
.quote {
  display: block;
  position: relative;
  margin: 0;
  font-size: inherit;
  font-style: normal;
}
.quote::before {
  display: none;
}
.quote-section {
  position: relative;
  z-index: 99;
}
.quote-title {
  margin: 0;
  line-height: 1.4;
}
.quote-cite {
  display: block;
  color: #9a9a9a;
  font-style: normal;
  font-weight: 300;
  margin-top: 1.8rem;
  margin-bottom: 0;
  line-height: 1.2;
}
.quote-mark {
  position: absolute;
  top: 0;
  left: 0;
  width: clamp(160px, 34vw, 360px);
  opacity: 0.1;
  transform: translateY(-70%);
}
.quote-mark svg {
  width: 100%;
}
@media (min-width: 1024px) {
  .quote-text {
    margin-bottom: 1.3rem;
    line-height: 1.2;
    letter-spacing: -1px;
    margin-bottom: 0;
  }
  .quote-text {
    font-size: 34px;
  }
}
@media screen and (min-width: 1024px) and (min-width: 400px) {
  .quote-text {
    font-size: calc(34px + 16 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (min-width: 1600px) {
  .quote-text {
    font-size: 50px;
  }
}
@media (min-width: 1024px) {
  .quote-mark {
    transform: translate(-30%, -70%);
  }
}
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
}
.brand-list {
  color: var(--colour-foreground);
}
.brand-list-description * {
  color: var(--colour-copy-dark);
}
@media (max-width: 767px) {
  .brand-list-description p {
    margin-bottom: 10px;
  }
}
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
}
.contact-aside {
  position: relative;
}
.contact-aside-item *:not(h6) {
  margin-bottom: 0;
}
@media (max-width: 1023px) {
  .contact {
    padding-bottom: 0;
  }
  .contact-aside-item:not(:last-child) {
    margin-bottom: 1.8rem;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .contact-aside {
    display: flex;
    justify-content: space-between;
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .contact-aside-item {
    margin-bottom: 0 !important;
  }
}
@media (min-width: 1024px) {
  .contact {
    overflow: visible;
  }
  .contact-aside {
    position: sticky;
    flex-direction: column;
    top: 100px;
    padding: 0;
    margin: 0;
    background-color: transparent;
  }
  .contact-aside::after {
    display: none;
  }
}
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
}
.home-hero {
  overflow-x: hidden;
  pointer-events: none;
}
.home-hero-wrapper {
  height: 250vh;
}
.home-hero-text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
  height: 100svh;
}
.home-hero-heading {
  padding-top: 12.5vh;
}
.home-hero-lead {
  padding-bottom: 5vh;
}
.home-hero-heading {
  margin-bottom: 0;
}
.home-hero-heading h1 {
  margin-bottom: 0;
}
.home-first-section {
  position: relative;
  padding-top: 0;
  margin-top: 50vh;
}
.home-show-reel {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 300vh;
}
.home-show-reel-wrapper {
  position: sticky;
  display: flex;
  align-items: center;
  top: 0;
  width: 100%;
  height: 100vh;
  perspective: 100vw;
  overflow: hidden;
  transform-style: preserve-3d;
}
.home-show-reel-content {
  width: 100%;
}
.home-video {
  position: relative;
  display: block;
  width: 100%;
  max-height: 80vh;
  aspect-ratio: 16/9;
}
.home-video video {
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-video-btn {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 999;
}
.home-three-d {
  position: fixed;
  height: 90%;
  width: 90%;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  perspective: 2000px;
  filter: grayscale(100%);
  opacity: 0.4;
  will-change: transform, opacity, filter;
}
.home-three-d img,
.home-three-d svg {
  width: 100%;
  height: 100%;
}
.home-marquee {
  position: absolute;
  display: block;
  width: 100vw;
  height: auto;
  left: 0;
  z-index: 10;
  pointer-events: none;
}
.home #awwwards svg {
  position: fixed;
  top: 50%;
  right: 0;
  z-index: 999;
  transform: scale(0.9) translate(6px, -50%);
}
@media (min-width: 768px) {
  .home #awwwards svg {
    top: auto;
    bottom: 10%;
    transform: none;
  }
  .home-hero {
    height: 100vh;
    height: 100svh;
    display: flex;
    align-items: center;
  }
  .home-hero-text {
    display: block;
    height: auto;
  }
  .home-hero-heading {
    margin-bottom: 3rem;
  }
}
@media (min-width: 1024px) {
  .home-first-section {
    padding-top: clamp(80px, 20vw, 200px);
  }
  .home-three-d {
    width: 100%;
  }
  .home-marquee h2 {
    margin-bottom: 1.8rem;
    line-height: 1.03;
    letter-spacing: -1px;
    margin-bottom: 0;
  }
  .home-marquee h2 {
    font-size: 36px;
  }
}
@media screen and (min-width: 1024px) and (min-width: 400px) {
  .home-marquee h2 {
    font-size: calc(36px + 32 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (min-width: 1600px) {
  .home-marquee h2 {
    font-size: 68px;
  }
}
@media (min-width: 1024px) {
  .home-marquee h2 .type-serif {
    font-size: 44px;
  }
}
@media screen and (min-width: 1024px) and (min-width: 400px) {
  .home-marquee h2 .type-serif {
    font-size: calc(44px + 36 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (min-width: 1600px) {
  .home-marquee h2 .type-serif {
    font-size: 80px;
  }
}
@media (min-width: 1024px) and (max-width: 767px) {
  .home-marquee h2 .type-serif.small-mob {
    font-size: 47px;
  }
}
@media screen and (min-width: 1024px) and (max-width: 767px) and (min-width: 400px) {
  .home-marquee h2 .type-serif.small-mob {
    font-size: calc(47px + 33 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (max-width: 767px) and (min-width: 1600px) {
  .home-marquee h2 .type-serif.small-mob {
    font-size: 80px;
  }
}
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
}
.insight-intro {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
}
.insight-intro-crumbs {
  margin-bottom: 8px;
  display: none;
}
.insight-intro-tags {
  display: flex;
  align-items: center;
  flex-grow: 2;
  transform: translateX(-2px);
}
.insight-author {
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-top: 1.8rem;
}
.insight-author-photo {
  width: 60px;
  height: 60px;
  min-width: 60px;
  max-width: 60px;
  margin-right: 1rem;
  border-radius: 100%;
  overflow: hidden;
  background: #70cbce;
}
.insight-author-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.insight-author-text {
  display: flex;
  flex-direction: column;
}
.insight-author-text * {
  line-height: 1;
  color: var(--colour-paragraph);
}
.insight-author-title {
  color: #0a0a0a;
  margin-bottom: 4px;
}
.insight-author-title:not(h5) {
  font-weight: 500;
}
.insight-author-bio {
  margin-bottom: 1rem !important;
}
.insight-author-bio .insight-author-title {
  margin-bottom: 10px;
}
.insight-author-bio p {
  margin-bottom: 0;
}
.insight-bio {
  margin-top: 3rem;
  padding-top: 3rem;
  border-top: var(--card-border);
}
.insight-bio-wrapper {
  display: flex;
}
.insight-bio-photo {
  margin-right: 3rem;
}
.insight-bio-follow {
  margin-bottom: 6px;
}
.insight-meta {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-bottom: 1.8rem;
  width: 100%;
}
.insight-social {
  display: flex;
  align-items: center;
}
.insight-social-item {
  display: flex;
  margin-bottom: 0;
  cursor: pointer;
}
.insight-social-item svg {
  min-height: 30px;
}
.insight-social-item:not(:first-child) {
  margin-left: 1.4rem;
}
.insight-social-small .insight-social-item:not(:first-child) {
  margin-left: 1rem;
}
.insight-year {
  padding-bottom: 3rem;
  border-bottom: var(--card-border);
}
.insight-year:not(:first-child) {
  padding-top: 3rem;
}
@media (min-width: 768px) {
  .insight-author {
    margin-top: 0;
    margin-bottom: 0;
  }
  .insight-meta {
    flex-direction: row-reverse;
    align-items: center;
  }
  .insight-author-title-large {
    margin-bottom: 8px;
  }
}
@media (min-width: 1024px) {
  .insight-intro {
    flex-direction: row;
    align-items: center;
    order: -1;
    margin-top: 0;
    margin-bottom: 1.8rem;
  }
  .insight-intro-crumbs {
    display: flex;
    margin-bottom: 0;
  }
  .insight-intro-tags {
    justify-content: flex-end;
    margin-left: 1rem;
    transform: none;
  }
  .insight-meta {
    margin-bottom: 3rem;
  }
}
@use "sass:math";
@use "sass:color";
:root {
  --colour-background: #0a0a0a;
  --colour-foreground: #ffffff;
  --colour-black: #0a0a0a;
  --colour-white: #ffffff;
  --colour-orange: #ff5043;
  --colour-blue: #70cbce;
  --colour-copy: #0a0a0a;
  --colour-copy-dark: #9a9a9a;
  --colour-copy-light: #595959;
  --colour-off-white: #f2f2f2;
  --colour-paragraph: #9a9a9a;
  --colour-list: #ffffff;
  --a-symbol-clip-left: -22%;
  --a-symbol-clip-right: 22%;
  --card-border: 2px solid rgba(255, 255, 255, 0.15);
  --alpha-standard: 0.15;
  --alpha-light: 0.1;
  --margin: 1.8rem;
  --margin-small: 1rem;
  --margin-large: 3rem;
  --link-hover-colour: #70cbce;
  --table-border-colour: #2b2b2b;
  --table-cell-colour: #9a9a9a;
  --table-stripe-colour: #0f0f0f;
}
:root .theme-white {
  background-color: #fff;
  --colour-background: #ffffff;
  --colour-foreground: #0a0a0a;
  --colour-paragraph: #595959;
  --colour-list: #595959;
  --card-border: 2px solid rgba(10, 10, 10, 0.15);
  --table-border-colour: #dddddd;
  --table-cell-colour: #595959;
  --table-stripe-colour: #f2f2f2;
}
:root .theme-white strong,
:root .theme-white b {
  color: #0a0a0a;
}
.portfolio {
  overflow-x: clip;
}
.portfolio-aside {
  position: relative;
  margin-bottom: clamp(80px, 20vw, 200px);
}
.portfolio-featured {
  display: block;
  height: auto;
}
.portfolio-featured img,
.portfolio-featured source {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.portfolio-arrow {
  display: none;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 10;
  transform: translateY(50%);
}
.portfolio-results {
  left: -7vw;
  padding: clamp(80px, 20vw, 200px) 7vw;
  width: 100vw;
}
.portfolio-next {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  background-color: #171717;
}
.portfolio-next-image {
  display: block;
  width: 100vw;
  height: 40vh;
  flex-grow: 2;
}
.portfolio-next-image img,
.portfolio-next-image source {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.portfolio-next-container {
  display: flex;
  align-items: center;
  padding-top: clamp(80px, 20vw, 200px);
  padding-bottom: clamp(80px, 20vw, 200px);
  height: auto;
}
@media (min-width: 568px) {
  .portfolio-content .video-container,
  .portfolio-content .image:not(.portfolio-featured) {
    width: 75%;
    margin-left: 25%;
  }
}
@media (min-width: 768px) {
  .portfolio-arrow {
    display: block;
  }
  .portfolio-next {
    height: 100vh;
    height: 100svh;
  }
  .portfolio-next-image {
    height: 50%;
  }
}
@media (min-width: 1024px) {
  .portfolio {
    padding-top: 0;
  }
  .portfolio-aside {
    position: sticky;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100vh;
    height: 100svh;
    top: 0;
    padding: 0;
    margin: 0;
  }
  .portfolio-title {
    margin-bottom: 1.3rem;
    line-height: 1.2;
    letter-spacing: -1px;
  }
  .portfolio-title {
    font-size: 34px;
  }
}
@media screen and (min-width: 1024px) and (min-width: 400px) {
  .portfolio-title {
    font-size: calc(34px + 16 * ((100vw - 400px) / 1200));
  }
}
@media screen and (min-width: 1024px) and (min-width: 1600px) {
  .portfolio-title {
    font-size: 50px;
  }
}
@media (min-width: 1024px) {
  .portfolio-featured {
    width: 50vw;
    height: 100vh;
    height: 100svh;
  }
  .portfolio-arrow {
    bottom: 10vh;
    transform: none;
  }
  .portfolio-next {
    height: 60vh;
    max-height: 800px;
  }
  .portfolio-next-image {
    display: block;
    width: 50vw;
    height: 100%;
  }
  .portfolio-next-container {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    padding-top: 0;
    padding-bottom: 0;
  }
  .portfolio-content .video-container,
  .portfolio-content .image {
    width: 50vw !important;
    margin-left: 0 !important;
    right: 15px;
  }
  .portfolio-content .image {
    padding: 0;
  }
  .portfolio-results {
    width: 50vw;
    padding-left: 0;
    padding-right: 0;
    left: auto;
  }
}
@media (min-width: 2100px) {
  .portfolio-aside {
    transform: translateX(-5vw);
  }
}
