html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

* {
  box-sizing: border-box;
}

*:before,
*:after {
  box-sizing: border-box;
}

.visually-hidden {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

.hidden {
  display: none !important;
}

textarea,
input,
button,
select {
  font-family: inherit;
  font-size: inherit;
  text-align: inherit;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
}

input,
textarea {
  background: inherit;
  color: inherit;
  border: none;
  padding: 0;
  outline: inherit;
  opacity: 1;
}

textarea {
  resize: none;
}

input:not([type=submit]),
textarea {
  display: block;
  width: 100%;
  border-radius: 0;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

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

input[type=number] {
  -moz-appearance: textfield;
}

select {
  background: none;
  width: 100%;
  cursor: pointer;
  border: none;
  outline: none;
  border-radius: 0;
  color: var(--fg);
  margin: 0;
  padding: 0;
}

select option {
  color: var(--fg);
  margin: 0;
  padding: 0;
  background: var(--bg);
}

select:focus {
  outline: none;
}

ul,
li {
  text-decoration: none;
  list-style: none;
}

/* Input Elements */
button,
input[type=submit],
input[type=reset],
div[role=button] {
  background: none;
  color: inherit;
  border: none;
  padding: 0;
  font: inherit;
  cursor: pointer;
  outline: inherit;
  -webkit-appearance: none;
  border-radius: 0;
}

input[type=button],
input[type=button]:focus {
  outline: none;
}

a:link,
a:visited,
a:link span,
a:visited span {
  color: inherit;
  cursor: pointer;
  text-decoration: none;
}

@font-face {
  font-family: "Archivo";
  src: url("../fonts/Archivo-Bold.eot");
  src: url("../fonts/Archivo-Bold.eot?#iefix") format("embedded-opentype"), url("../fonts/Archivo-Bold.woff2") format("woff2"), url("../fonts/Archivo-Bold.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Archivo";
  src: url("../fonts/Archivo-Black.eot");
  src: url("../fonts/Archivo-Black.eot?#iefix") format("embedded-opentype"), url("../fonts/Archivo-Black.woff2") format("woff2"), url("../fonts/Archivo-Black.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
:root {
  --white: #fff;
  --white-40: #ffffff66;
  --white-20: #ffffff36;
  --grey-100: #eaeaea;
  --grey-300: #b2b2b2;
  --grey-700: #333333;
  --black: #000;
  --black-10: #0000001a;
  --dark-grey: #333333;
  --green: #48c75f;
  --blue: #3872e4;
  --yellow: #f5c20f;
  --fg: var(--black);
  --fg-2: var(--black-10);
  --bg: var(--grey-100);
  --bg-2: var(--grey-300);
  --fg-rev: var(--white);
  --fg-2-rev: var(--white-40);
  /* Font sizes */
  --font-size-s: 13px;
  --font-size-p: 18px;
  --font-size-h6: 21px;
  --font-size-h5: 34px;
  --font-size-h4: 48px;
  --font-size-h3: 70px;
  --font-size-h2: 82px;
  --font-size-h1: 100px;
  /* Line heights */
  --line-height-s: 16px;
  --line-height-p: 20px;
  --line-height-h6: 24px;
  --line-height-h5: 36px;
  --line-height-h4: 48px;
  --line-height-h3: 68px;
  --line-height-h2: 80px;
  --line-height-h1: 88px;
  /* Letter spacing */
  --letter-spacing-s: 0.2px;
  --letter-spacing-p: 0.1px;
  --letter-spacing-h6: 0.3px;
  --letter-spacing-h5: 0.5px;
  --letter-spacing-h4: 1px;
  --letter-spacing-h3: 1px;
  --letter-spacing-h2: 1px;
  --letter-spacing-h1: 0px;
  --Pm: 20px;
  --Pd: calc(var(--Pm) * 2);
  --Pg: 24px;
  --Ps: 16px;
  --Pl: 36px;
  --Pxl: 56px;
  --Ph: calc(var(--Pm) / 2);
  --pad-xs: 24px;
  --pad-s: 36px;
  --pad-sm: 72px;
  --pad-m: 108px;
  --pad-l: 144px;
  --pad-xl: 180px;
  --pad-xxl: 216px;
  --border-radius: 24px;
  --border-radius-l: 72px;
  --header-height: 97px;
  --footer-height: 380px;
}
:root.dark-mode {
  --fg: var(--white);
  --fg-2: var(--white-40);
  --bg: var(--black);
  --bg-2: var(--grey-700);
  --fg-rev: var(--black);
  --fg-2-rev: var(--black-10);
}
@media screen and (max-width: 786px) {
  :root {
    /* Font sizes */
    --font-size-s: 12px;
    --font-size-p: 16px;
    --font-size-h6: 19px;
    --font-size-h5: 28px;
    --font-size-h4: 32px;
    --font-size-h3: 44px;
    --font-size-h2: 46px;
    --font-size-h1: 58px;
    /* Line heights */
    --line-height-s: 16px;
    --line-height-p: 18px;
    --line-height-h6: 20px;
    --line-height-h5: 28px;
    --line-height-h4: 32px;
    --line-height-h3: 40px;
    --line-height-h2: 44px;
    --line-height-h1: 56px;
    /* Letter spacing */
    --letter-spacing-s: 0.2px;
    --letter-spacing-p: 0.2px;
    --letter-spacing-h6: 0.3px;
    --letter-spacing-h5: 0.5px;
    --letter-spacing-h4: 0.5px;
    --letter-spacing-h3: 1px;
    --letter-spacing-h2: 1px;
    --letter-spacing-h1: 0px;
    --Pm: 12px;
    --Pg: 12px;
    --Ps: 12px;
    --Pl: 24px;
    --Pxl: 36px;
    --pad: 56px;
    --pad-xs: 12px;
    --pad-s: 24px;
    --pad-m: 72px;
    --pad-l: 108px;
    --pad-xl: 108px;
    --pad-xxl: 216px;
    --border-radius: 16px;
    --border-radius-l: 48px;
  }
}

html {
  font-size: var(--font-size-p);
  line-height: var(--line-height-p);
  letter-spacing: var(--letter-spacing-p);
  font-family: "Archivo", Arial, Helvetica, sans-serif;
  font-style: normal;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  height: auto;
  background-color: var(--bg);
}

body.no-scroll {
  height: 100vh;
  overflow: hidden;
}

main,
body {
  color: var(--fg);
}

[data-barba-namespace=project],
[data-barba-namespace=product] {
  height: 100dvh;
  min-height: 100dvh;
  overflow: hidden;
}
[data-barba-namespace=project] footer,
[data-barba-namespace=product] footer {
  display: none;
}

.visaully-hidden {
  visibility: hidden;
  position: absolute;
  z-index: -10;
  display: none;
}

.split {
  opacity: 0;
  transform: translateY(1vh);
  transition: opacity 1s ease 0.1s, transform 1s ease 0.1s;
}

.split.entered {
  transform: translateY(0);
  opacity: 1;
}

.enter {
  opacity: 0;
  transform: translateY(1vh);
  transition: opacity 1s ease 0.2s, transform 1s ease 0.2s;
}

.enter.entered {
  transform: translateY(0);
  opacity: 1;
}

/* Details Elements */
summary,
summary:focus {
  outline: none;
  list-style-type: none;
  position: relative;
  cursor: pointer;
  transition: all 0.3s;
}

details summary::marker,
details summary::-webkit-details-marker {
  content: "";
  visibility: hidden;
  position: absolute;
  z-index: -10;
  list-style-type: none;
  display: none;
}

summary > * {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

summary > *::after {
  content: "+";
  margin-left: var(--Pm);
}

@media (hover: hover) and (pointer: fine) {
  details summary:hover {
    opacity: 0.5;
  }
}
details[open] summary > *::after {
  content: "-";
}

details[open] summary ~ * {
  animation: appear 0.4s ease-in;
  -webkit-animation: appear 0.4s ease-in;
}

details.closing summary ~ * {
  animation: close 0.4s ease-out;
}

@keyframes appear {
  0% {
    opacity: 0;
    max-height: 0;
  }
  100% {
    opacity: 1;
    max-height: calc(var(--vh, 1vh) * 100);
  }
}
@keyframes close {
  0% {
    opacity: 1;
    max-height: calc(var(--vh, 1vh) * 100);
  }
  100% {
    opacity: 0;
    max-height: 0;
  }
}
/* Image/Video Elements */
.aspectholder > * {
  display: block;
}

.vsc-controller {
  height: 0 !important;
  width: 0 !important;
  object-fit: unset !important;
}

.grid-8 {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-auto-rows: minmax(min-content, max-content);
  column-gap: var(--Pm);
  row-gap: var(--Pm);
  width: 100%;
}

.grid-24, .feature-pages-block.padding {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  grid-auto-rows: minmax(min-content, max-content);
  column-gap: var(--Pm);
  row-gap: var(--Pm);
  width: 100%;
}

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: minmax(min-content, max-content);
  column-gap: var(--Pm);
  row-gap: var(--Pm);
  width: 100%;
}

.p-gutter {
  padding-left: var(--Pg);
  padding-right: var(--Pg);
}

.p-gutter-y {
  padding-top: var(--Pg);
  padding-bottom: var(--Pg);
}

/* Font sizes, line heights, and letter spacings */
/* Classes for typography */
.fs, .text_items-text-item h6, .pill, .text_items-text-item p a {
  font-size: var(--font-size-s);
  line-height: var(--line-height-s);
  letter-spacing: var(--letter-spacing-s);
}

.fp, .text_items-text-item p,
.text_items-text-item h5,
.text_items-text-item h4,
.text_items-text-item h3,
.text_items-text-item h2,
.text_items-text-item h1 {
  font-size: var(--font-size-p);
  line-height: var(--line-height-p);
  letter-spacing: var(--letter-spacing-p);
}

.fh6 {
  font-size: var(--font-size-h6);
  line-height: var(--line-height-h6);
  letter-spacing: var(--letter-spacing-h6);
}

.fh5, .wpcf7-list-item-label, form input,
textarea {
  font-size: var(--font-size-h5);
  line-height: var(--line-height-h5);
  letter-spacing: var(--letter-spacing-h5);
}

.fh4, form h3 {
  font-size: var(--font-size-h4);
  line-height: var(--line-height-h4);
  letter-spacing: var(--letter-spacing-h4);
}

.fh3 {
  font-size: var(--font-size-h3);
  line-height: var(--line-height-h3);
  letter-spacing: var(--letter-spacing-h3);
}

.fh2 {
  font-size: var(--font-size-h2);
  line-height: var(--line-height-h2);
  letter-spacing: var(--letter-spacing-h2);
}

.fh1 {
  font-size: var(--font-size-h1);
  line-height: var(--line-height-h1);
  letter-spacing: var(--letter-spacing-h1);
}

.upcase, form h3 {
  text-transform: uppercase;
}

.no_top {
  padding-top: 0 !important;
}

body.admin-bar .site_header {
  margin-top: 32px; /* Adjust to the toolbar height */
}

body.admin-bar .site-main {
  margin-top: -32px; /* Adjust to the toolbar height */
  --header-height: calc(97px + 32px);
}

/* For smaller screens where the toolbar is taller */
@media (max-width: 782px) {
  body.admin-bar .site_header {
    margin-top: 46px;
  }
}
.site {
  opacity: 0;
  transition: opacity 0.2s ease;
}
.site.loaded {
  opacity: 1;
}

.enter {
  opacity: 0;
  transition: opacity 0.8s ease, transform 0.8s ease;
  transform: translateY(5vh);
}
.enter.entered {
  opacity: 1;
  transform: translateY(0vh);
}

.split {
  font-kerning: none;
}
.split .line {
  overflow: hidden;
}

.aspectholder {
  filter: blur(10px);
  transition: filter 0.8s ease, background-color 0.8s ease;
  background-color: #333;
  overflow: hidden;
}
.aspectholder * {
  mix-blend-mode: hard-light;
  transform: scale(1.02);
  transition: transform 0.8s ease;
}
.aspectholder.entered {
  filter: blur(0);
  background-color: transparent;
}
.aspectholder.entered * {
  transform: scale(1);
}

.hide {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease-in-out;
}

/* The .image-container class needs to be applied to a div wrapped around the image you want to apply this filter to */
.pill, .text_items-text-item p a {
  display: block;
  padding: var(--Pg);
  position: relative;
  color: var(--bg);
  width: fit-content;
  text-transform: uppercase;
  z-index: 0;
}
.pill:before, .text_items-text-item p a:before {
  content: "";
  position: absolute;
  z-index: -1;
  background-color: var(--accent);
  width: 100%;
  height: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: var(--border-radius);
  transition: width 0.3s ease, height 0.3s ease, box-shadow 0.5s ease 0s;
}
.pill:hover:before, .text_items-text-item p a:hover:before {
  width: calc(100% + 10px);
  height: calc(100% + 10px);
  box-shadow: rgba(255, 255, 255, 0.17) 0px -23px 25px 0px inset, rgba(255, 255, 255, 0.15) 0px -36px 30px 0px inset, rgba(255, 255, 255, 0.1) 0px -79px 40px 0px inset;
}

.site_header {
  width: 100vw;
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  padding: var(--Ph);
  color: var(--white);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  mix-blend-mode: difference;
  transition: opacity 0.3s ease-in-out, background-color 0.3s ease, color 0.3s ease;
}
.site_header.shade {
  background-color: var(--bg);
  mix-blend-mode: unset;
  color: var(--fg);
}
.site_header.hide {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease-in-out;
}
.site_header .site_logo {
  width: 118px;
  height: 100%;
}
.site_header .site_logo a {
  transition: opacity 0.2s ease;
}
.site_header .site_logo a:hover {
  opacity: 0.4;
}
.site_header .site_logo svg {
  width: 100%;
  height: 100%;
}
.site_header .site_logo svg path {
  fill: var(--white);
}
.site_header .main-navigation {
  width: 100%;
  overflow: hidden;
  position: relative;
}
.site_header .main-navigation .current-page {
  position: absolute;
  right: 0;
  color: var(--fg);
}
.site_header .menu-container {
  display: flex;
  column-gap: var(--Pm);
  transform: translateX(120%);
  opacity: 0;
}
.site_header .menu-container a {
  opacity: 0.4;
  transition: opacity 0.2s ease;
}
.site_header .menu-container a:hover {
  opacity: 1;
}
.site_header .menu-container .active {
  color: var(--active);
  opacity: 1;
}
.site_header-data {
  display: flex;
  column-gap: var(--Ph);
  align-items: center;
}
.site_header-data-controls {
  background-color: var(--white-40);
  display: flex;
  padding: 8px var(--Ph);
  justify-content: center;
  align-items: center;
  border-radius: var(--border-radius);
  gap: 8px;
}
.site_header-data-controls svg path {
  fill: var(--fg);
}
.site_header-data-controls button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 100%;
}
.site_header-data-controls button svg {
  width: 16px;
  height: auto;
}
.site_header-data-controls .sound-toggle {
  display: none;
  opacity: 0.4;
  transition: opacity 0.2s ease;
}
.site_header-data-controls .sound-toggle .sound {
  display: none;
}
.site_header-data-controls .sound-toggle span {
  display: block;
  height: 20px;
}
.site_header-data-controls .sound-toggle:hover, .site_header-data-controls .sound-toggle.on {
  opacity: 1;
}
.site_header-data-controls .sound-toggle.on .mute {
  display: none;
}
.site_header-data-controls .sound-toggle.on .sound {
  display: block;
}
.site_header-data-controls .theme-toggle span {
  display: block;
  width: 14px;
  height: 14px;
  border: 1px solid var(--fg);
  border-radius: 100px;
  transition: opacity 0.2s ease;
  background-color: var(--fg);
  opacity: 1;
}
.site_header-data-controls .theme-toggle:hover span {
  opacity: 1;
}

.dark-mode .theme-toggle span {
  opacity: 0.4;
  background-color: transparent;
}

.sound-on .sound-toggle {
  opacity: 0.4;
  transition: opacity 0.2s ease;
  opacity: 1;
}
.sound-on .sound-toggle .sound {
  display: block;
}
.sound-on .sound-toggle .mute {
  display: none;
}

.site-main {
  min-height: 100vh;
  margin-bottom: var(--footer-height);
  position: relative;
  z-index: 1;
  background-color: var(--bg);
  box-shadow: 0px 6px 20px 5px rgba(0, 0, 0, 0.25);
  overflow: hidden;
}

.site_footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: calc(var(--footer-height) + 100px);
  background-color: var(--bg-2);
  z-index: 0;
  padding: var(--Pg);
  padding-top: calc(var(--Pg) + 100px);
}
.site_footer_col-one {
  grid-column: 1/7;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: calc(var(--footer-height) - var(--Pg) * 2);
}
.site_footer_col-one .footer_menus {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pm);
}
.site_footer_col-one .footer_menus .footer_menu {
  display: flex;
  flex-direction: column;
}
.site_footer_col-one .copyright {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pm);
}
.site_footer_col-one a {
  transition: opacity 0.2s ease;
  width: fit-content;
}
.site_footer_col-one a:hover {
  opacity: 0.4;
}
.site_footer_col-one a.opacity {
  opacity: 0.4;
}
.site_footer_col-one a.opacity:hover {
  opacity: 1;
}
.site_footer .footer_logo {
  grid-column: 13/-1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  row-gap: var(--Pm);
}
.site_footer .footer_logo a {
  width: 118px;
  height: fit-content;
  transition: opacity 0.2s ease;
}
.site_footer .footer_logo a:hover {
  opacity: 0.4;
}
.site_footer .footer_logo a.opacity {
  opacity: 0.4;
  width: fit-content;
}
.site_footer .footer_logo a.opacity:hover {
  opacity: 1;
}
.site_footer .footer_logo svg {
  width: 118px;
  height: 100%;
  width: 100%;
  height: auto;
}

main {
  width: 100%;
}

.form_button_holder {
  bottom: -200%;
  right: 12px;
  position: fixed;
  z-index: 100;
  border-radius: 24px;
  mix-blend-mode: difference;
  box-shadow: 0px 0px 10px 0px rgba(127, 127, 127, 0.15);
  backdrop-filter: blur(10px);
  display: flex;
}
.form_button_holder.fixed {
  position: absolute;
}
.form_button_holder .form_button {
  display: flex;
  width: 214px;
  height: 76px;
  justify-content: flex-start;
  align-items: center;
  column-gap: 5px;
  border-radius: 24px;
  background: var(--Colours-System-White-Opacity-2, rgba(255, 255, 255, 0.2));
  white-space: nowrap;
  overflow: hidden;
  transition: width 0.2s ease, height 0.2s ease, margin 0.2s ease, background-color 0.2s ease;
}
.form_button_holder .form_button span {
  display: flex;
  align-items: center;
  column-gap: 3px;
}
.form_button_holder .form_button svg {
  width: 20px;
  height: 20px;
}
.form_button_holder .form_button:hover {
  width: 218px;
  height: 80px;
  margin-right: -4px;
  margin-top: -4px;
  background-color: var(--accent);
}
.form_button_holder:hover {
  mix-blend-mode: unset;
}

.form-holder {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  padding: 24px;
  z-index: 10000000000;
  display: none;
  opacity: 0;
}
.form-holder.active {
  display: block;
}
.form-holder-bottom {
  width: 100%;
  position: fixed;
  bottom: 24px;
  left: 24px;
  right: 24px;
  padding: 16px 24px 16px 32px;
  z-index: 100;
  height: 76px;
  width: calc(100vw - 48px);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 4%, rgba(51, 51, 51, 0.7707676821) 51%, rgb(51, 51, 51) 88%);
  border-radius: 0 0 24px 24px;
}
.form-holder-inner {
  width: 0;
  height: 0;
  border-radius: 40px;
  background: var(--Primary-bg-2, #333);
  position: relative;
  overflow: scroll;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -ms-overflow-style: none; /* Internet Explorer 10+ */
  scrollbar-width: none; /* Firefox */
}
.form-holder-inner::-webkit-scrollbar {
  display: none; /* Safari and Chrome */
}
.form-holder-inner .button-holder {
  padding: 24px;
  display: flex;
  justify-content: space-between;
  position: sticky;
  top: 0;
  background: linear-gradient(180deg, var(--Primary-bg-2, #333) 25%, rgba(51, 51, 51, 0) 100%);
  z-index: 10;
}
.form-holder-inner .button-holder .form-selector {
  display: flex;
  column-gap: 8px;
}
.form-holder-inner .button-holder .form-selector-btn {
  display: flex;
  padding: 4px 16px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: var(--Border-border-default, 24px);
  background: var(--Primary-text-2, rgba(255, 255, 255, 0.4));
  transition: background-color 0.2s ease, color 0.2s ease;
}
.form-holder-inner .button-holder .form-selector-btn:hover {
  background-color: var(--white);
  color: var(--black);
}
.form-holder-inner .button-holder .form-selector-btn.active {
  background-color: var(--hover);
  color: var(--black);
  pointer-events: none;
}
.form-holder-inner .button-holder .form-selector-btn.active:hover {
  background-color: var(--hover);
}
.form-holder-inner .form_form {
  padding: 24px;
  display: flex;
  flex-direction: column;
  padding-top: 120px;
  position: relative;
  display: none;
  row-gap: var(--pad-m);
  padding-bottom: 100px;
}
.form-holder-inner .form_form.active {
  display: flex;
}
.form-holder-inner .form_form-text {
  display: flex;
  flex-direction: column;
  row-gap: var(--Ps);
  max-width: 625px;
  width: 100%;
}
.form-holder-inner .form_form-text-body {
  max-width: 330px;
}

form {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pd);
  max-width: 900px;
}

.yes-container,
.no-container {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pd);
  display: none;
}
.yes-container.active,
.no-container.active {
  display: flex;
}

label,
.label {
  padding-bottom: 8px;
  display: block;
}
label span,
label i,
.label span,
.label i {
  color: var(--white-40);
}

form fieldset,
form p {
  display: flex;
  flex-direction: column;
}
form fieldset input,
form p input {
  margin-bottom: 4px;
}

form input,
textarea {
  text-transform: uppercase;
}

input.other-input {
  display: none;
  padding-top: var(--Ph);
}
input.other-input.active {
  display: block;
}

.wpcf7-form-control-wrap {
  padding-top: 4px;
  display: block;
}

.radio-group {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  column-gap: 12px;
}
.radio-group.col {
  flex-direction: column;
}

form h3 {
  padding-top: var(--Pg);
}

select {
  padding: 20px;
  border: 1px solid var(--white-40);
  border-radius: 10px;
}

.radio-group label {
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: all 0.3s ease;
  color: var(--white-40);
  margin: 0;
  padding: 0;
}
.radio-group label.full {
  width: 100%;
}
.radio-group label:hover {
  color: var(--white);
}

.label .message {
  padding-top: var(--Pd);
}

.label .radio-group,
.label label.fs,
.label label.pill {
  padding-bottom: var(--Pd);
}

/* Default state: semi-transparent text */
.wpcf7-list-item-label {
  transition: opacity 0.2s ease;
  cursor: pointer;
  text-transform: uppercase;
}

.wpcf7-list-item {
  margin: 0;
  margin-right: 10px;
}

.wpcf7-list-item-label:hover {
  opacity: 0.5;
}

/* When checkbox is checked: fully opaque */
input[type=checkbox]:checked + .wpcf7-list-item-label {
  opacity: 1;
  color: var(--white);
}

.radio-group input {
  display: none; /* Hide default radio buttons */
}

fieldset button {
  color: var(--white-40);
  transition: color 0.2s ease;
}
fieldset button:hover {
  color: var(--white);
}

/* Style when radio is selected */
.radio-group input:checked + label {
  color: var(--accent);
}

.wpcf7 form .wpcf7-response-output {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

input[type=submit],
button[type=submit] {
  display: flex;
  top: 0;
  left: 0;
  position: relative;
  padding: 31px 30px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: fit-content;
  overflow: hidden;
  color: var(--Primary-bg-1, #000);
  font-feature-settings: "case" on;
  text-overflow: ellipsis;
  font-size: 13.6px;
  font-style: normal;
  font-weight: 500;
  line-height: 16px; /* 117.647% */
  letter-spacing: 0.2px;
  text-transform: uppercase;
  border-radius: 24px;
  background: var(--accent, #fff);
  /* Shadow + Layer Fade */
  box-shadow: 0px 0px 10px 0px rgba(127, 127, 127, 0.15);
  backdrop-filter: blur(10px);
  transition: padding 0.2s ease, top 0.2s ease, left 0.2s ease;
}
input[type=submit]:hover,
button[type=submit]:hover {
  padding: 37px 36px;
  left: -6px;
  top: -6px;
}
input[type=submit].disabled,
button[type=submit].disabled {
  opacity: 0.3;
  pointer-events: none;
}

input::placeholder,
textarea::placeholder {
  color: var(--white-40);
  transition: color 0.2s ease;
}

input:hover::placeholder,
textarea:hover::placeholder {
  color: var(--white);
}

.feature-pages-block {
  width: 100vw;
  height: 80vh;
  overflow: hidden;
  /* Carousel container styles */
}
.feature-pages-block.padding {
  height: auto;
  padding-top: var(--header-height);
}
.feature-pages-block.padding .single_media,
.feature-pages-block.padding .carousel_hero {
  grid-column: 2/24;
}
.feature-pages-block.tall {
  height: 100dvh;
}
.feature-pages-block.tall .carousel_hero-frame {
  height: 100dvh;
}
.feature-pages-block .carousel_hero {
  display: flex;
  position: relative;
  white-space: nowrap;
}
.feature-pages-block .carousel_hero-frame {
  flex-shrink: 0;
  display: inline-block;
  width: auto;
  height: 80vh;
  margin-left: -56px;
  mix-blend-mode: difference;
}
.feature-pages-block .carousel_hero-frame .aspectholder {
  width: 100%;
  height: 100%;
}
.feature-pages-block .carousel_hero-frame .aspectholder * {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.feature-pages-block .carousel_hero-frame .aspectholder video {
  aspect-ratio: 1;
}
.feature-pages-block .single_media {
  width: 100%;
  height: 100%;
}
.feature-pages-block .single_media .aspectholder {
  width: 100%;
  height: 100%;
}
.feature-pages-block .single_media .aspectholder * {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.feature-pages-block .hero_pages {
  position: absolute;
  z-index: 10;
  bottom: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  mix-blend-mode: difference;
  padding: var(--Pd) var(--Pg);
  display: flex;
  flex-direction: column;
  height: 100vh;
  justify-content: flex-end;
}
.feature-pages-block .hero_pages .page_link {
  --fg: var(--white);
  color: transparent; /* Text color */
  -webkit-text-stroke: 2px var(--fg); /* Stroke width and color */
  width: fit-content;
  transition: all 0.2s ease;
  font-weight: 900;
}
.feature-pages-block .hero_pages .page_link:hover {
  color: var(--hover); /* Text color */
  -webkit-text-stroke: 1px var(--hover); /* Stroke width and color */
}

.text-block {
  padding: var(--Pg);
}
.text-block .body {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.text-block .Full {
  grid-column: 1/-1;
}
.text-block .Three-Quarters {
  grid-column: 1/21;
}
.text-block .Two-Thirds {
  grid-column: 1/15;
}
.text-block .One-Third {
  grid-column: 1/10;
}
.text-block .body {
  color: var(--fg);
}

.double-media-block.Portrait .aspectholder {
  aspect-ratio: 0.8;
}
.double-media-block.Landscape .aspectholder {
  aspect-ratio: 1.69;
}
.double-media-block .aspectholder {
  grid-column: span 1;
  width: 100%;
}
.double-media-block .aspectholder * {
  width: 100%;
  object-fit: cover;
  height: 100%;
}

.artist_list-items-item-btns .audio-btn:hover ~ .artist_list-items-item-toggle .shift,
.artist_list-items-item-btns .link-btn:hover ~ .artist_list-items-item-toggle .shift {
  /* Add your styles here */
  transform: translateY(-5px); /* Example effect */
  background-color: #f0f0f0; /* Example background change */
  transition: all 0.3s ease; /* Smooth transition */
}

.contact-info-block {
  padding-top: var(--pad-xxl);
  padding-bottom: var(--pad-xxl);
}

.contact-info-data {
  grid-column: 1/-13;
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.contact-info-data a {
  max-width: 300px;
  display: block;
  transition: opacity 0.2s ease;
}
.contact-info-data a:hover {
  opacity: 0.4;
}
.contact-info-data .title {
  padding-bottom: 4px;
}

.contact-info-buttons {
  grid-column: 13/-1;
  display: flex;
  flex-direction: column;
  row-gap: 8px;
}
.button-with-ticker {
  width: 100%;
  min-width: 370px;
  position: relative;
  display: flex;
  overflow: hidden;
  column-gap: 8px;
  transition: color 0.2s ease;
}
.button-with-ticker button {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.button-with-ticker span {
  display: flex;
  column-gap: 8px;
  align-items: flex-start;
  white-space: nowrap;
  opacity: 0;
}
.button-with-ticker span svg {
  width: 35px;
  height: 44px;
}
.button-with-ticker span.main {
  opacity: 1;
}
.button-with-ticker:hover span {
  opacity: 1;
}
.button-with-ticker:hover {
  color: var(--hover);
}

.contact-block.grid-24, .contact-block.feature-pages-block.padding {
  row-gap: 0;
}
.contact-block-text,
.contact-block .form_button_holder {
  grid-column: 1/-1;
}
.contact-block .form_button_holder {
  position: relative;
  top: unset;
  bottom: unset;
  right: unset;
  z-index: unset;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: blur(0px);
}
.contact-block .form_button_holder .form_button {
  display: flex;
  width: 364px;
  height: auto;
  justify-content: flex-start;
  align-items: center;
  column-gap: 5px;
  border-radius: 0;
  background: transparent;
  white-space: nowrap;
  overflow: hidden;
  transition: opacity 0.2s ease, height 0.2s ease, margin 0.2s ease, background-color 0.2s ease;
}
.contact-block .form_button_holder .form_button svg {
  width: 40px;
  height: 40px;
}
.contact-block .form_button_holder .form_button:hover {
  width: 364px;
  height: auto;
  background: transparent;
  margin: 0 !important;
  opacity: 0.5;
}

.label-block .heading {
  grid-column: 1/-1;
}
.label-block .label_list-items {
  color: var(--fg);
  grid-column: 1/-1;
  display: flex;
  flex-wrap: wrap;
  column-gap: var(--Pg);
}
.label-block .label_list-items-item {
  position: relative;
  width: fit-content;
  cursor: ne-resize !important;
  height: fit-content;
}
.label-block .label_list-items-item .artist-title {
  display: block;
  color: transparent; /* Text color */
  -webkit-text-stroke: 1px var(--fg-2);
  transition: all 0.2s ease;
}
.label-block .label_list-items-item .artist_list-items-item-toggle {
  width: 32px;
  height: 32px;
  background-color: var(--fg);
  position: absolute;
  z-index: 10;
  pointer-events: none;
  opacity: 0;
  top: -20px;
  right: -10px;
  border-radius: 40px;
  display: flex;
  transition: all 0.2s ease;
}
.label-block .label_list-items-item .artist_list-items-item-toggle .play,
.label-block .label_list-items-item .artist_list-items-item-toggle .link {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2px 2px 2px 4px;
  z-index: 2;
  position: relative;
  transition: all 0.2s ease;
}
.label-block .label_list-items-item .artist_list-items-item-toggle .play svg path,
.label-block .label_list-items-item .artist_list-items-item-toggle .link svg path {
  transition: all 0.2s ease;
}
.label-block .label_list-items-item .artist_list-items-item-toggle .link {
  right: 1px;
  color: var(--fg);
}
.label-block .label_list-items-item .artist_list-items-item-toggle .link svg path {
  stroke: var(--bg);
}
.label-block .label_list-items .label_list-items-item:hover {
  cursor: ne-resize !important;
}
.label-block .label_list-items .label_list-items-item:hover .artist_list-items-item-toggle {
  top: -35px;
  opacity: 1;
}
.label-block .label_list-items .label_list-items-item:hover span {
  -webkit-text-stroke: 1px var(--fg);
  color: var(--fg);
}

.artists-block {
  padding: var(--Pg);
}
.artists-block .artist_list-items {
  color: var(--fg);
  grid-column: 1/15;
  display: flex;
  flex-wrap: wrap;
  column-gap: var(--Pm);
  height: fit-content;
}
.artists-block .artist_list-items-item {
  position: relative;
  width: fit-content;
  height: fit-content;
}
.artists-block .artist_list-items-item .artist-title {
  display: block;
  color: transparent; /* Text color */
  -webkit-text-stroke: 1px var(--fg-2);
  transition: all 0.2s ease;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle {
  width: 60px;
  height: 32px;
  background-color: var(--fg);
  position: absolute;
  z-index: 10;
  pointer-events: none;
  opacity: 0;
  top: -20px;
  right: -10px;
  border-radius: 40px;
  display: flex;
  transition: all 0.2s ease;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .shift {
  position: absolute;
  background-color: var(--bg);
  width: 28px;
  height: 28px;
  border-radius: 20px;
  left: 2px;
  top: 2px;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .play,
.artists-block .artist_list-items-item .artist_list-items-item-toggle .link {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2px;
  z-index: 2;
  position: relative;
  transition: all 0.2s ease;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .play svg path,
.artists-block .artist_list-items-item .artist_list-items-item-toggle .link svg path {
  transition: all 0.2s ease;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .play {
  color: var(--fg);
  left: 1px;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .link {
  right: 1px;
  color: var(--fg);
  opacity: 0.4;
}
.artists-block .artist_list-items-item .artist_list-items-item-toggle .link svg path {
  stroke: var(--bg-2);
}
.artists-block .artist_list-items-item .artist_list-items-item-btns {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  z-index: 3;
  display: flex;
}
.artists-block .artist_list-items-item .artist_list-items-item-btns .btn {
  flex: 1;
  height: 100%;
  display: block;
}
.artists-block .artist_list-items-item .artist_list-items-item-btns .btn.link-btn {
  cursor: ne-resize;
}
.artists-block .artist_list-items-item:hover .artist_list-items-item-toggle {
  top: -35px;
  opacity: 1;
}
.artists-block .artist_list-items-item:hover span {
  -webkit-text-stroke: 1px var(--fg);
  color: var(--fg);
}
.artists-block .artist_list-items-item.active span {
  -webkit-text-stroke: 1px var(--fg);
  color: var(--fg);
}
.artists-block .artist_list-items-item.shifted .play,
.artists-block .artist_list-items-item.shifted .link {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2px;
}
.artists-block .artist_list-items-item.shifted .play {
  opacity: 0.4;
}
.artists-block .artist_list-items-item.shifted .play svg path {
  fill: var(--bg-2);
}
.artists-block .artist_list-items-item.shifted .link {
  opacity: 1;
}
.artists-block .artist_list-items-item.shifted .link svg path {
  stroke: var(--fg);
}
.artists-block .artist_list-media {
  grid-column: 16/-1;
  position: relative;
  aspect-ratio: 3/4;
  width: 100%;
  margin: 0;
  pointer-events: none !important;
}
.artists-block .artist_list-media .swiper-wrapper {
  position: absolute;
}
.artists-block .artist_list-media .artist_list-media-item {
  position: absolute;
  opacity: 0 !important;
  transition: opacity 0.3s ease;
  pointer-events: none !important;
}
.artists-block .artist_list-media .artist_list-media-item.active {
  opacity: 1;
}
.artists-block .artist_list-media .artist_list-media-item .aspectholder {
  width: 100%;
  aspect-ratio: 3/4;
  overflow: hidden;
  border-radius: var(--border-radius);
}
.artists-block .artist_list-media .artist_list-media-item .aspectholder * {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.artists-block .artist_list-media .swiper-slide {
  opacity: 0 !important;
}
.artists-block .artist_list-media .swiper-slide .aspectholder {
  filter: blur(10px);
  transition: filter 0.8s ease, background-color 0.8s ease;
  background-color: #333;
  overflow: hidden;
}
.artists-block .artist_list-media .swiper-slide .aspectholder * {
  mix-blend-mode: hard-light;
  transform: scale(1.02);
  transition: transform 0.8s ease;
}
.artists-block .artist_list-media .swiper-slide-active {
  opacity: 1 !important;
}
.artists-block .artist_list-media .swiper-slide-active .aspectholder {
  filter: blur(0);
  background-color: transparent;
}
.artists-block .artist_list-media .swiper-slide-active .aspectholder * {
  transform: scale(1);
}
.artists-block.in-view .artist_list-media {
  opacity: 1;
  scale: 1;
}

.mini-audio-player {
  position: fixed;
  bottom: 8px;
  left: 8px;
  display: flex;
  padding: 8px;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  z-index: 90;
  transform: translateY(120%);
}
.mini-audio-player .close-mini-audio {
  position: absolute;
  top: -6px;
  right: -6px;
  width: 24px;
  height: 24px;
  border-radius: 80px;
  backdrop-filter: blur(10px);
  box-shadow: 0px 0px 10px 0px rgba(127, 127, 127, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--Colours-System-White-Opacity-2, rgba(255, 255, 255, 0.2));
  transition: background-color 0.2s ease;
}
.mini-audio-player .close-mini-audio:hover {
  background-color: var(--Colours-System-White-Opacity-2, rgba(255, 255, 255, 0.4));
}
.mini-audio-player-inner {
  display: flex;
  column-gap: 20px;
  min-width: 314px;
  width: 100%;
  height: 76px;
  justify-content: flex-start;
  align-items: center;
  column-gap: 12px;
  border-radius: 80px;
  background: var(--Colours-System-White-Opacity-2, rgba(255, 255, 255, 0.2));
  white-space: nowrap;
  overflow: hidden;
  backdrop-filter: blur(10px);
  box-shadow: 0px 0px 10px 0px rgba(127, 127, 127, 0.15);
  padding: 8px;
}
.mini-audio-player-inner .mini-play-pause {
  display: flex;
  width: 60px;
  height: 60px;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  border-radius: 100px;
  border: 1px solid var(--white);
  overflow: hidden;
}
.mini-audio-player-inner .mini-play-pause .playpause-audio {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: difference;
}
.mini-audio-player-inner .mini-play-pause .playpause-audio .hide {
  display: none;
}
.mini-audio-player-inner .mini-play-pause img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mini-audio-player-inner .mini-play-pause img.spin {
  animation-name: spin;
  animation-duration: 7000ms;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}
.mini-audio-player-inner .song-title {
  padding-right: 12px;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.media-block .aspectholder {
  width: 100%;
  height: 100%;
}
.media-block .aspectholder * {
  width: 100%;
  height: 100%;
}

.text_items-heading {
  grid-column: 1/15;
}

.text_items-headings {
  grid-column: 1/15;
}
@media screen and (min-width: 786px) {
  .text_items-headings-item .text_items-text-item {
    display: none !important;
  }
}
.text_items-headings-item button {
  -webkit-text-stroke: 1px var(--fg); /* Stroke width and color */
  color: transparent;
  transition: all 0.2s ease;
}
.text_items-headings-item button:hover {
  color: var(--fg);
}
.text_items-headings-item button.active {
  color: var(--active);
  -webkit-text-stroke: 1px var(--active); /* Stroke width and color */
}

.text_items-text {
  grid-column: 16/-2;
  height: 100%;
  position: relative;
}
.text_items-text-item {
  position: relative;
  display: none;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}
.text_items-text-item.active {
  display: block;
  opacity: 1;
  pointer-events: all;
}
.text_items-text-item ol {
  list-style-type: decimal;
}
.text_items-text-item ol li {
  display: flex;
}

.text-ticker-block,
.icon-ticker-block {
  position: relative;
  width: 100%;
  overflow: hidden;
  row-gap: 0;
}
.text-ticker-block .heading,
.icon-ticker-block .heading {
  grid-column: 1/-1;
}

.ticker_wrapper {
  overflow-x: hidden;
  width: 100vw;
  height: 270px;
}
.ticker_wrapper.icons {
  pointer-events: none !important;
}
.ticker_wrapper .ticker_middle,
.ticker_wrapper .ticker_bottom {
  display: flex;
  row-gap: 2rem;
}
.ticker_wrapper span {
  margin-right: 2rem;
  white-space: nowrap;
  transition: color 0.2s ease;
  display: flex;
  align-items: center;
  column-gap: var(--Ph);
}
.ticker_wrapper span svg {
  height: 100%;
}
.ticker_wrapper:hover span {
  color: var(--hover);
}
.ticker_wrapper.icons {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.ticker_wrapper.icons span object {
  padding: var(--Ph) var(--pad-m);
  height: 80px;
}
.ticker_wrapper.icons span object path {
  fill: black;
}

.partnerships-archive.top,
.licensing-archive.top {
  padding-top: var(--pad-l);
}
.partnerships-archive-heading,
.licensing-archive-heading {
  grid-column: 1/-1;
}
.partnerships-archive .partnership-card,
.licensing-archive .partnership-card {
  grid-column: span 6;
  display: flex;
  flex-direction: column;
  row-gap: var(--Pm);
  padding-bottom: var(--Pm);
}
.partnerships-archive .partnership-card.no_pad,
.licensing-archive .partnership-card.no_pad {
  padding-bottom: 0;
}
.partnerships-archive .partnership-card .partnership-image,
.licensing-archive .partnership-card .partnership-image {
  width: 100%;
  aspect-ratio: 1.5;
  overflow: hidden;
}
.partnerships-archive .partnership-card .partnership-image *,
.licensing-archive .partnership-card .partnership-image * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1);
  transition: filter 0.3s ease;
}
.partnerships-archive .partnership-card .aspectholder,
.licensing-archive .partnership-card .aspectholder {
  width: 100%;
  aspect-ratio: 1.5;
  overflow: hidden;
}
.partnerships-archive .partnership-card .aspectholder *,
.licensing-archive .partnership-card .aspectholder * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1);
  transition: filter 0.3s ease;
}
.partnerships-archive .partnership-card .title,
.licensing-archive .partnership-card .title {
  transition: color 0.3s ease;
}
.partnerships-archive .partnership-card:hover .aspectholder *,
.partnerships-archive .partnership-card:hover .partnership-image *,
.licensing-archive .partnership-card:hover .aspectholder *,
.licensing-archive .partnership-card:hover .partnership-image * {
  filter: grayscale(0);
}
.partnerships-archive .partnership-card:hover .title,
.licensing-archive .partnership-card:hover .title {
  color: var(--hover);
}
.partnerships-archive .button-holder,
.licensing-archive .button-holder {
  grid-column: 1/-1;
  display: flex;
  justify-content: flex-end;
}

.licensing-archive .partnership-card {
  grid-column: span 6;
}

.sub_hero {
  position: relative;
  height: auto;
  padding-top: var(--header-height);
  padding-bottom: var(--pad-m);
}
.sub_hero-media {
  grid-column: 2/24;
  aspect-ratio: 1.82;
}
.sub_hero-media .close-button {
  position: absolute;
  z-index: 10000000;
  top: var(--pad-s);
  right: var(--pad-s);
  color: white;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.sub_hero-media.active .close-button {
  opacity: 1;
  visibility: visible;
}
.sub_hero-media.active .close-button:hover {
  opacity: 0.5;
}
.sub_hero-media .aspectholder {
  width: 100%;
  aspect-ratio: 1.82; /* Maintain aspect ratio */
  position: relative;
  overflow: hidden; /* Prevent any overflow */
  display: flex; /* Helps with centering children */
  align-items: center;
  justify-content: center;
  transition: border-radius 0.2s ease;
}
.sub_hero-media .aspectholder .play-pause {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 4;
  top: 0;
  left: 0;
  mix-blend-mode: difference;
  color: white;
}
.sub_hero-media .aspectholder .play-pause.playing {
  pointer-events: none;
}
.sub_hero-media .aspectholder .play-pause.playing svg {
  opacity: 0;
}
.sub_hero-media .aspectholder .play-pause svg {
  width: 60px;
  height: auto;
  transition: opacity 0.2s ease, width 0.2s ease;
}
.sub_hero-media .aspectholder > * {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Ensures media fills container */
  position: absolute; /* Keeps it aligned properly */
  top: 0;
  left: 0;
}
.sub_hero-media:hover .aspectholder {
  border-radius: var(--border-radius-l);
}
.sub_hero-media:hover .play-pause svg {
  width: 80px;
}
.sub_hero-media.active:hover .aspectholder {
  border-radius: 0;
}
.sub_hero-title {
  position: absolute;
  bottom: 0;
  left: var(--Pg);
  mix-blend-mode: difference;
  color: var(--white);
  transition: opacity 0.3s ease-in-out;
  pointer-events: none;
}
.sub_hero-title.hide {
  opacity: 0;
  pointer-events: none;
}

#single-wrapper .text-ticker-block {
  padding: var(--pad-l) 0;
}

.license-data-left {
  grid-column: 1/15;
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.license-data-right {
  grid-column: 16/-2;
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.license-data .data-list {
  display: flex;
  flex-direction: column;
}
.license-data .data-list-item {
  border-top: 1px solid var(--fg);
  display: flex;
}
.license-data .data-list-item:last-child {
  border-bottom: 1px solid var(--fg);
}
.license-data .data-list-item span {
  flex: 1;
  display: block;
  padding: 9px 0 6px 0;
}

.audio-player {
  display: flex;
  align-items: center;
  background: var(--fg);
  color: var(--bg);
  border-radius: 50px;
  padding: 24px 32px;
  width: 100%;
  justify-content: space-between;
}
.audio-player .play-button {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 18px;
  margin-right: var(--Pg);
  margin-top: 2px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15px;
  height: 15px;
}
.audio-player .play-button svg {
  width: 15px;
  height: 15px;
}
.audio-player .play-button .play {
  display: block;
}
.audio-player .play-button .pause {
  display: none;
}
.audio-player .play-button.playing .play {
  display: none;
}
.audio-player .play-button.playing .pause {
  display: block;
}
.audio-player .track-title {
  flex-grow: 1;
  margin: 0 10px;
}

.privacy-main {
  padding-top: var(--pad-m);
  padding-bottom: var(--pad-m);
}
.privacy-main-left {
  grid-column: 1/13;
  height: 100%;
}
.privacy-main-left-sticky {
  display: flex;
  row-gap: var(--Pd);
  flex-direction: column;
  padding-bottom: var(--Ph);
}
.privacy-main-left-top {
  display: flex;
  row-gap: var(--Pg);
  flex-direction: column;
}
.privacy-main-left-top-data {
  display: flex !important;
  flex-direction: column;
}
.privacy-main-left-btns {
  display: flex;
  flex-direction: column;
}
.privacy-main-left-btns button {
  opacity: 0.4;
  transition: opacity 0.2s ease;
  width: 336px;
  display: flex !important;
  flex-direction: row;
}
.privacy-main-left-btns button .index {
  display: block;
  width: 36px;
}
.privacy-main-left-btns button .label {
  width: 300px;
}
.privacy-main-left-btns button.active, .privacy-main-left-btns button:hover {
  opacity: 1;
}
.privacy-main-right {
  grid-column: 16/23;
  display: flex;
  row-gap: var(--Pxl);
  flex-direction: column;
  padding-top: calc(var(--Pxl) * 2);
}
.privacy-main-right ul {
  list-style-type: disc;
  list-style-position: inside;
  padding-left: var(--Pm);
}
.privacy-main-right ol {
  list-style-type: decimal;
  list-style-position: inside;
  padding-left: var(--Pm);
}
.privacy-main-right ul ul,
.privacy-main-right ol ul {
  list-style-type: circle;
  list-style-position: inside;
  padding-left: var(--Pm);
}
.privacy-main-right ol ol,
.privacy-main-right ul ol {
  list-style-type: lower-latin;
  list-style-position: inside;
  padding-left: var(--Pm);
}
.privacy-main-right li {
  text-decoration: unset;
  list-style: unset;
  padding-bottom: 8px;
}
.privacy-main-right li ::marker {
  position: relative;
}
.privacy-main-right-blurb {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.privacy-main-right-blocks {
  display: flex;
  row-gap: var(--Pxl);
  flex-direction: column;
}
.privacy-main-right-blocks .block-item {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.privacy-main-right-blocks .block-item .content {
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.privacy-main-right-blocks .block-item .content ol,
.privacy-main-right-blocks .block-item .content ol ol,
.privacy-main-right-blocks .block-item .content ul ol {
  list-style-type: lower-roman;
}

.sib-nav {
  row-gap: 0;
  padding-top: var(--pad-xl);
  padding-bottom: var(--pad-l);
}
.sib-nav-nav {
  grid-column: 16/23;
}
.sib-nav-nav:hover .sib-nav-item {
  opacity: 0.5 !important;
}
.sib-nav-nav .sib-nav-item {
  opacity: 0.5;
  transition: opacity 0.2s ease;
}
.sib-nav-nav .sib-nav-item.is-current {
  opacity: 1;
}
.sib-nav-nav .sib-nav-item:hover {
  opacity: 1 !important;
}

.form-block {
  padding-top: var(--pad-xxl);
  padding-bottom: var(--pad-xxl);
}
.form-block .form-text {
  grid-column: 1/-1;
  display: flex;
  flex-direction: column;
  row-gap: var(--Pg);
}
.form-block .form-text .form-sub-text {
  max-width: 500px;
}
.form-block .form-content {
  grid-column: 1/23;
  padding-top: var(--Pl);
}
