:root {
  --fz-html: 62.5%;
  --fz-base: 1.6rem;
  --fw-base: 400;
  --lh-base: 1.3;
  --ff-base: "T-Star Pro", Helvetica, Arial, sans-serif;
  --c-base: #000;
  --c-black: #000;
  --c-white: #fff;
  --t-duration: 0.3s;
}
@media (max-width: 767px) {
  :root {
    --fz-base: 1.8rem;
  }
}
* {
  padding: 0;
  margin: 0;
  outline: 0;
  box-sizing: border-box;
}
*:before,
*:after {
  box-sizing: inherit;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
main {
  display: block;
}
template {
  display: none;
}
html {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  tap-highlight-color: rgba(0, 0, 0, 0);
}
body {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-size-adjust: none;
}
img,
iframe,
video,
audio,
object {
  max-width: 100%;
}
img,
iframe {
  border: 0 none;
}
img {
  height: auto;
  display: inline-block;
  vertical-align: middle;
}
img,
[style*=background-image] {
  image-rendering: -webkit-optimize-contrast;
}
b,
strong {
  font-weight: bold;
}
address {
  font-style: normal;
}
svg:not(:root) {
  overflow: hidden;
}
a,
button,
input[type=submit],
input[type=button],
input[type=reset],
input[type=file],
input[type=image],
label[for] {
  cursor: pointer;
}
a[href^=tel],
button[disabled],
input[disabled],
textarea[disabled],
select[disabled] {
  cursor: default;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
input[type=button],
input[type=text],
input[type=password],
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=month],
input[type=week],
input[type=email],
input[type=number],
input[type=search],
input[type=tel],
input[type=time],
input[type=url],
input[type=color],
textarea,
a[href^=tel] {
  appearance: none;
}
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  appearance: none;
}
textarea {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
}
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
}
button,
select {
  text-transform: none;
}
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}
nav ul,
nav ol {
  list-style: none outside none;
}
input::placeholder {
  color: inherit;
  opacity: 1;
}
textarea::placeholder {
  color: inherit;
  opacity: 1;
}
input:-webkit-autofill {
  -webkit-text-fill-color: inherit;
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
}
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
    animation: none !important;
  }
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-Bold.woff2") format("woff2"), url("../assets/fonts/T-StarPro-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-BoldItalic.woff2") format("woff2"), url("../assets/fonts/T-StarPro-BoldItalic.woff") format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-HeavyItalic.woff2") format("woff2"), url("../assets/fonts/T-StarPro-HeavyItalic.woff") format("woff");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-Medium.woff2") format("woff2"), url("../assets/fonts/T-StarPro-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-RegularItalic.woff2") format("woff2"), url("../assets/fonts/T-StarPro-RegularItalic.woff") format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-LightItalic.woff2") format("woff2"), url("../assets/fonts/T-StarPro-LightItalic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-MediumItalic.woff2") format("woff2"), url("../assets/fonts/T-StarPro-MediumItalic.woff") format("woff");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-Regular.woff2") format("woff2"), url("../assets/fonts/T-StarPro-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-Light.woff2") format("woff2"), url("../assets/fonts/T-StarPro-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "T-Star Pro";
  src: url("../assets/fonts/T-StarPro-Heavy.woff2") format("woff2"), url("../assets/fonts/T-StarPro-Heavy.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
html {
  font-size: var(--fz-html);
}
body {
  min-width: 320px;
  font-family: var(--ff-base);
  font-weight: var(--fw-base);
  font-size: var(--fz-base);
  line-height: var(--lh-base);
  color: var(--c-base);
}
@media (max-width: 1079px) {
  body {
    background-color: #f7f7f7;
  }
}
a {
  color: inherit;
  text-decoration: underline;
}
@media (hover: hover) {
  a:where(:hover, :focus-visible) {
    text-decoration: none;
  }
}
a[href^=tel] {
  text-decoration: none;
}
.level-1,
h1,
.level-2,
h2,
.level-3,
h3,
.level-4,
h4,
.level-5,
h5,
.level-6,
h6 {
  margin-bottom: calc(var(--lh-base) * 0.5em);
  text-transform: uppercase;
}
.level-1,
h1 {
  font-size: clamp(13.6rem, 13.3333vw, 19.2rem);
  line-height: 0.85;
  letter-spacing: -0.0078em;
}
@media (max-width: 1079px) {
  .level-1,
  h1 {
    font-size: 9.6rem;
  }
}
@media (max-width: 767px) {
  .level-1,
  h1 {
    font-size: 9.6rem;
  }
}
.level-3,
h3 {
  font-size: 4.8rem;
  line-height: 0.9;
  letter-spacing: -0.03em;
  margin-bottom: 2rem;
}
@media (max-width: 767px) {
  .level-3,
  h3 {
    font-size: 6.4rem;
    letter-spacing: -0.01em;
    margin-bottom: 3.2rem;
  }
}
.level-4,
h4 {
  font-size: 3.2rem;
  line-height: 0.9;
  letter-spacing: -0.013em;
  margin-bottom: 1.8rem;
}
@media (max-width: 767px) {
  .level-4,
  h4 {
    font-size: 4.8rem;
    letter-spacing: -0.0035em;
    margin-bottom: 2.1rem;
  }
}
.level-6,
h6 {
  font-size: 1.6rem;
  line-height: 1.1;
  letter-spacing: 0.01em;
}
@media (max-width: 767px) {
  .level-6,
  h6 {
    letter-spacing: 0.001em;
    font-size: 1.5rem;
    line-height: 1.1;
  }
}
p,
ul,
ol,
dl,
hr,
table,
blockquote {
  margin-bottom: 2.4rem;
  letter-spacing: -0.01em;
}
h1[class],
h2[class],
h3[class],
h4[class],
h5[class],
h6[class],
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
p:last-child,
ul:last-child,
ol:last-child,
dl:last-child,
table:last-child,
blockquote:last-child {
  margin-bottom: 0;
}
small {
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 400;
}
small p {
  letter-spacing: 0.005em;
}
@media (max-width: 767px) {
  small {
    font-size: 1.2rem;
  }
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
[hidden],
.hidden {
  display: none !important;
}
[disabled],
.disabled {
  cursor: default;
}
.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
  display: none !important;
}
@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
  .visible-xs-block {
    display: block !important;
  }
  .visible-xs-inline {
    display: inline !important;
  }
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 767.02px) and (max-width: 1079px) {
  .hidden-sm {
    display: none !important;
  }
  .visible-sm-block {
    display: block !important;
  }
  .visible-sm-inline {
    display: inline !important;
  }
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1079.02px) and (max-width: 1199px) {
  .hidden-md {
    display: none !important;
  }
  .visible-md-block {
    display: block !important;
  }
  .visible-md-inline {
    display: inline !important;
  }
  .visible-md-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1199.02px) {
  .hidden-lg {
    display: none !important;
  }
  .visible-lg-block {
    display: block !important;
  }
  .visible-lg-inline {
    display: inline !important;
  }
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}
/*  Background options  */
.bg--black {
  background-color: var(--c-black);
  color: var(--c-white);
}
/* ------------------------------------------------------------ *\
	..article
\* ------------------------------------------------------------ */
.article .media {
  padding-top: 125%;
}
@media (hover: hover) and (pointer: fine) {
  .article .media[data-hover=popup]:hover .plyr__video-wrapper:before {
    opacity: 0.25;
  }
}
.article h3 {
  margin-bottom: 1.5rem;
}
@media (max-width: 767px) {
  .article h3 {
    padding-right: 0.2rem;
    margin-bottom: 3.2rem;
  }
}
.article h3:last-child {
  margin-bottom: 0;
}
.article h3 strong {
  position: relative;
  display: inline-block;
  color: var(--c-white);
}
.article h3 strong:before {
  position: absolute;
  top: 0.11em;
  left: -0.04em;
  right: -0.15em;
  bottom: -0.08em;
  background-color: var(--c-black);
  z-index: -1;
  transition: opacity var(--t-duration);
  content: "";
}
@media (max-width: 767px) {
  .article h3 strong:before {
    right: -0.1em;
  }
}
.article h3 strong:has(.word.is-active):before {
  opacity: 1;
}
.article h3 .word:empty:not(strong .word),
.article h3 .whitespace:empty:not(strong .whitespace) {
  display: none;
}
.article h3 .word {
  opacity: 0.05;
  transition: opacity 0.15s cubic-bezier(0.42, 0, 1, 1), clip-path 0.15s cubic-bezier(0.42, 0, 1, 1);
}
.article h3 .word.is-active {
  opacity: 1;
}
.article h3 strong .word {
  opacity: 1;
  clip-path: inset(0 var(--clip, 100%) 0 0);
}
.article h3 strong .word.is-active {
  clip-path: inset(0 var(--clip, 0%) 0 0);
}
.article .article__media {
  margin-bottom: 1.1rem;
}
@media (max-width: 767px) {
  .article .article__media {
    margin-bottom: 2.9rem;
  }
}
.article .article__media:last-child {
  margin-bottom: 0;
}
.article .article__content {
  padding-right: 6.5rem;
  position: relative;
  min-height: 22px;
}
.article .article__content > .article__link {
  position: absolute;
  top: 0;
  height: 22px;
  left: 0;
  width: 100%;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  transition: color var(--t-duration) 0.2s, opacity var(--t-duration);
  z-index: 2;
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 400;
}
.article .article__content > .article__link p {
  letter-spacing: 0.005em;
}
@media (max-width: 767px) {
  .article .article__content > .article__link {
    font-size: 1.2rem;
  }
}
@media (max-width: 1079px) {
  .article .article__content > .article__link {
    width: calc(100% - 1rem);
  }
}
.article .article__content > .article__link:after {
  position: absolute;
  top: 50%;
  right: 0.4rem;
  width: 10px;
  height: 8px;
  background-color: var(--c-black);
  mask: url("../assets/images/svg/ico-chevron-down.svg") center center no-repeat;
  mask-size: contain;
  transition: transform var(--t-duration), top var(--t-duration);
  transform: translateY(-50%) rotate(-90deg);
  content: "";
}
@media (max-width: 767px) {
  .article .article__content > .article__link:after {
    width: 17px;
    right: -2px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .article .article__content > .article__link:hover {
    opacity: 0.5;
  }
}
.article .article__content > .article__link span {
  display: inline-block;
  line-height: inherit;
  position: relative;
  top: -0.2rem;
}
.article .article__content .article__entry {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-right: 6.5rem;
  height: auto;
  opacity: 0;
  background-color: inherit;
  transition: opacity var(--t-duration), box-shadow var(--t-duration);
  z-index: 1;
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 400;
}
.article .article__content .article__entry p {
  letter-spacing: 0.005em;
}
@media (max-width: 767px) {
  .article .article__content .article__entry {
    font-size: 1.2rem;
  }
}
@media (min-width: 767.02px) {
  .article .article__content .article__entry {
    display: block !important;
  }
}
@media (max-width: 1079px) {
  .article .article__content .article__entry {
    padding: 2rem 6.5rem 2rem 2rem;
    background-color: rgb(243, 243, 243);
  }
}
@media (max-width: 767px) {
  .article .article__content .article__entry {
    position: relative;
    opacity: 1;
    padding: 0 5rem 0.3rem 0;
    background-color: transparent;
    display: none;
  }
}
.article .article__content.is-expanded .article__link {
  color: transparent;
  pointer-events: none;
  transition: color 0s, opacity var(--t-duration);
}
.article .article__content.is-expanded .article__link:after {
  pointer-events: auto;
  top: calc(var(--captions-height, 0px) - 12px);
  transform: translateY(-50%) rotate(-180deg);
}
@media (max-width: 1079px) {
  .article .article__content.is-expanded .article__link:after {
    top: calc(var(--captions-height, 0px) - 32px);
  }
}
@media (max-width: 767px) {
  .article .article__content.is-expanded .article__link:after {
    top: 2rem;
  }
}
.article .article__content.is-expanded .article__entry {
  opacity: 1;
  pointer-events: auto;
}
@media (max-width: 767px) {
  .article .article__content.is-expanded .article__entry {
    box-shadow: unset;
  }
}
/*  Alternative  */
.article.article--alt {
  display: flex;
  flex-flow: row wrap;
  margin: calc(var(--gap-y, 0px) / 2 * -1) calc(var(--gap-x, 0px) / 2 * -1);
  --gap-y: 1.6rem;
  --total-width: clamp(101rem, calc(100vw - var(--shell-gutter) * 2), calc(var(--shell-max-width) + var(--gap-x)));
}
.article.article--alt > * {
  padding: calc(var(--gap-y, 0px) / 2) calc(var(--gap-x, 0px) / 2);
}
.article.article--alt .article__media,
.article.article--alt .article__content {
  flex: 0 0 calc((var(--total-width) - var(--gap-x) / 2) / 4 + 2px);
  max-width: calc((var(--total-width) - var(--gap-x) / 2) / 4 + 2px);
}
@media (max-width: 767px) {
  .article.article--alt .article__media,
  .article.article--alt .article__content {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
.article.article--alt .article__content {
  padding-right: calc(var(--gap-x) / 2 + 6.5rem);
}
@media (max-width: 767px) {
  .article.article--alt .article__content {
    padding-right: 0;
    padding-left: 0;
  }
}
.article.article--alt .article__content:after {
  right: calc(var(--gap-x) / 2 + 0.5rem);
  content: "";
}
.article.article--alt .article__content > .article__link {
  left: calc(var(--gap-x) / 2);
}
.article.article--alt .article__content > .article__link:after {
  right: calc(0.4rem + var(--gap-x));
}
.article.article--alt .article__entry {
  left: calc(var(--gap-x) / 2);
  width: calc(100% - var(--gap-x));
}
.article.article--alt h3 {
  flex: 0 0 calc((var(--total-width) - var(--gap-x) / 2) / 4 * 2 - 2px);
  max-width: calc((var(--total-width) - var(--gap-x) / 2) / 4 * 2 - 2px);
  align-self: flex-end;
  margin-bottom: 1.3rem;
}
@media (max-width: 767px) {
  .article.article--alt h3 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 646px) {
  .article.article--alt h3 strong:nth-last-child(2) .whitespace {
    display: none;
  }
}
/*  Article reverse-mobile  */
@media (max-width: 767px) {
  .article--reverse-mobile {
    display: flex;
    flex-direction: column;
  }
  .article--reverse-mobile h3 {
    order: -1;
  }
}
/* ------------------------------------------------------------ *\
	.articles
\* ------------------------------------------------------------ */
@media (max-width: 767px) {
  .articles .grid {
    --gap-y: 6.4rem;
  }
}
.articles .grid .grid__col:nth-child(3n) {
  margin-left: auto;
  margin-top: -3.7rem;
}
@media (max-width: 767px) {
  .articles .grid .grid__col:nth-child(3n) {
    margin-top: 1.2rem;
  }
}
@media (max-width: 767px) {
  .articles .grid .grid__col:nth-child(3n) .article .article__media {
    margin-bottom: 2.2rem;
  }
}
.articles .grid .grid__col:nth-child(3n) .article .article__media .media {
  padding-top: 56.3%;
}
.articles .grid .grid__col:nth-child(3n) .article h3 {
  margin-bottom: 1.3rem;
}
@media (max-width: 767px) {
  .articles .grid .grid__col:nth-child(3n) .article h3 {
    margin-bottom: 3rem;
  }
}
.articles .grid .grid__col:nth-child(3n) .article .article__content .article__entry {
  padding-right: 9.7rem;
}
@media (max-width: 767px) {
  .articles .grid .grid__col:nth-child(3n) .article .article__content .article__entry {
    padding-right: 0rem;
  }
}
.articles .grid .grid__col:nth-child(3n+2) {
  align-self: flex-end;
}
@media (max-width: 1079px) {
  .articles .grid .grid__col:nth-child(3n+2) {
    align-self: unset;
  }
}
.articles .grid .grid__col:nth-child(3n+2) .article {
  padding-bottom: 8.5rem;
}
@media (max-width: 1079px) {
  .articles .grid .grid__col:nth-child(3n+2) .article {
    padding-bottom: 0;
  }
}
@media (max-width: 1079px) {
  .articles .grid .grid__col--1of4 {
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }
}
@media (max-width: 767px) {
  .articles .grid .grid__col--1of4 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 1079px) {
  .articles .grid .grid__col--3of4 {
    flex: 0 0 66.66%;
    max-width: 66.66%;
  }
}
@media (max-width: 767px) {
  .articles .grid .grid__col--3of4 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  .articles .grid .grid__col--1of2 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/* ------------------------------------------------------------ *\
	.box-video
\* ------------------------------------------------------------ */
.box-video {
  width: 314px;
  height: 558px;
}
.box-video .media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.btn {
  display: inline-flex;
  vertical-align: middle;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  appearance: none;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.3;
  border-radius: 3.2rem;
  padding: 1.6rem 2.7rem;
  text-transform: uppercase;
  background-color: transparent;
  color: var(--c-black);
  border: 1px solid var(--c-black);
  transition: background-color var(--t-duration), opacity var(--t-duration), border-color var(--t-duration), color var(--t-duration);
}
@media (max-width: 1079px) {
  .btn {
    letter-spacing: 0.05em;
  }
}
@media (hover: hover) and (pointer: fine) {
  .btn:hover {
    background-color: var(--c-black);
    color: var(--c-white);
  }
}
.btn * + * {
  margin-left: 1.3rem;
}
.btn span {
  display: inline-block;
  line-height: inherit;
}
.btn svg {
  position: relative;
  top: 1px;
}
/*  Btn block  */
.btn--block {
  display: block;
  padding-inline: 0;
}
/*  Btn clear  */
.btn--clear {
  padding: 0;
  border: none;
  letter-spacing: 0.005em;
}
@media (max-width: 767px) {
  .btn--clear {
    letter-spacing: 0.007em;
    font-size: 1.8rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .btn--clear:hover {
    background-color: transparent;
    color: var(--c-black);
    opacity: 0.4;
  }
}
/* ------------------------------------------------------------ *\
	.footer
\* ------------------------------------------------------------ */
.footer {
  padding: 6rem 0 calc(var(--header-height, 0px) + 2.4rem);
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 400;
}
.footer p {
  letter-spacing: 0.005em;
}
@media (max-width: 767px) {
  .footer {
    font-size: 1.2rem;
  }
}
@media (max-width: 1079px) {
  .footer {
    padding-bottom: 18rem;
  }
}
.footer .footer__entry {
  max-width: 42.2rem;
  margin-bottom: 2.9rem;
}
@media (max-width: 767px) {
  .footer .footer__entry {
    margin-bottom: 2.5rem;
  }
}
.footer .footer__entry:last-child {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .footer .footer__logo {
    width: 12rem;
    display: inline-block;
    margin-bottom: 2.1rem;
  }
}
@media (max-width: 767px) {
  .footer .footer__logo picture {
    display: block;
  }
}
@media (max-width: 767px) {
  .footer .footer__logo img {
    width: 100%;
  }
}
.footer .footer__outro {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .footer .footer__outro {
    display: block;
  }
}
.footer .footer__outro p {
  position: relative;
  bottom: -3px;
}
.footer p {
  margin-bottom: 0;
}
/* ------------------------------------------------------------ *\
	.form
\* ------------------------------------------------------------ */
.form {
  max-width: 42.4rem;
}
.form input {
  width: 100%;
  border-radius: 0.8rem;
  outline: none !important;
  border: unset;
  font-size: 1.6rem;
  font-weight: 400;
  padding: 1rem 1.6rem;
  background-color: rgba(84, 84, 84, 0.1);
  position: relative;
  transition: background-color var(--t-duration);
  z-index: 1;
}
@media (max-width: 767px) {
  .form input {
    padding: 1.8rem 1.6rem;
    font-size: 1.8rem;
    line-height: 1.3;
  }
}
.form input::placeholder {
  color: rgba(84, 84, 84, 0.5);
}
.form .form__controls {
  position: relative;
}
.form .form__controls:before {
  position: absolute;
  top: 0.5px;
  left: 0.5px;
  width: calc(100% - 1px);
  height: calc(100% - 1px);
  background-color: var(--c-white);
  content: "";
  z-index: 1;
  border-radius: 0.8rem;
}
.form .form__controls:after {
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  bottom: -1px;
  background: linear-gradient(271.77deg, #7f7f7f 25.47%, #bbbbbb 83.38%);
  border-radius: 0.8rem;
  opacity: 0;
  content: "";
  transition: opacity var(--t-duration);
}
.form .form__controls:focus-within:after {
  opacity: 1;
}
.form .form__controls:focus-within input {
  background-color: var(--c-white);
}
.form .form__controls.form--error input {
  color: red !important;
  -webkit-text-fill-color: red !important;
}
.form .form__controls.form--error input::placeholder {
  color: red !important;
}
.form .form__row {
  margin-bottom: 1.6rem;
}
@media (max-width: 767px) {
  .form .form__row {
    margin-bottom: 1.7rem;
  }
}
.form .form__row + p {
  margin-top: 1.9rem;
}
@media (max-width: 767px) {
  .form .form__row + p {
    margin-top: -0.4rem;
  }
}
.form .form__row + p small {
  letter-spacing: 0.01em;
  line-height: 1.5;
  display: inline-block;
}
.form p:has(small) {
  line-height: 1.5;
}
.form .form__body {
  margin-bottom: 1.9rem;
}
@media (max-width: 767px) {
  .form .form__body {
    margin-bottom: 2.5rem;
  }
}
.form .form__body:last-child {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .form .form__body p {
    margin-bottom: 2rem;
  }
}
.form .btn {
  padding: 1.6rem 1.7rem;
}
@media (max-width: 767px) {
  .form .btn {
    padding: 1.7rem 2.2rem;
  }
}
@media (max-width: 1079px) {
  .form .btn {
    background: black;
    color: white;
  }
}
.form .form__success a {
  text-decoration: none;
  font-size: 1.6rem;
  line-height: 1.1;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  font-weight: 700;
  transition: opacity var(--t-duration);
}
@media (min-width: 1079.02px) {
  .form .form__success a:hover {
    opacity: 0.4;
  }
}
.grid {
  display: flex;
  flex-flow: row wrap;
  --gap-x: 2rem;
  --gap-y: 1.3rem;
  margin: calc(var(--gap-y, 0px) / 2 * -1) calc(var(--gap-x, 0px) / 2 * -1);
}
.grid .grid__col {
  padding: calc(var(--gap-y, 0px) / 2) calc(var(--gap-x, 0px) / 2);
  flex: 1;
}
.grid .grid__col--1of2 {
  flex: 0 0 50%;
  max-width: 50%;
}
.grid .grid__col--1of3 {
  flex: 0 0 33.3333333333%;
  max-width: 33.3333333333%;
}
.grid .grid__col--1of4 {
  flex: 0 0 25%;
  max-width: 25%;
}
.grid .grid__col--1of5 {
  flex: 0 0 20%;
  max-width: 20%;
}
.grid .grid__col--1of6 {
  flex: 0 0 16.6666666667%;
  max-width: 16.6666666667%;
}
.grid .grid__col--3of4 {
  flex: 0 0 75%;
  max-width: 75%;
}
/* ------------------------------------------------------------ *\
	.header
\* ------------------------------------------------------------ */
.header {
  position: fixed;
  bottom: 0;
  padding-bottom: clamp(3.2rem, 7.6vh, 3rem);
  left: 0;
  width: 100%;
  height: auto;
  z-index: 99;
  transform: translate3d(0, 100%, 0);
  transition: transform var(--t-duration);
  pointer-events: none;
}
@media (max-width: 1079px) {
  .header {
    transform: translate3d(0, 0%, 0);
    top: 0;
    padding-bottom: 3.2rem;
  }
}
.header.is-visible {
  transform: translate3d(0, 0%, 0);
}
@media (max-width: 1079px) {
  .header.is-visible .header__logo,
  .header.is-visible .header__aside {
    transform: translate3d(0, 0%, 0);
  }
}
@media (max-width: 1079px) {
  .header.is-visible .header__aside .btn {
    background: black;
    color: white;
  }
}
@media (max-width: 1079px) {
  .header.is-visible .header__nav {
    transform: translate3d(-50%, 0%, 0);
  }
}
.header.over-callout .header__aside .btn {
  opacity: 0;
  pointer-events: none;
}
.header.over-callout .header__aside .header__slogan {
  opacity: 1;
  pointer-events: auto;
}
.header.is-white .header__aside {
  color: var(--c-white);
}
.header.is-white .header__aside .btn {
  color: var(--c-white);
  border-color: var(--c-white);
}
@media (hover: hover) and (pointer: fine) {
  .header.is-white .header__aside .btn:hover {
    background-color: var(--c-white);
    border-color: var(--c-white);
    color: var(--c-black);
  }
}
.header.is-white .header__nav {
  border-color: gray;
}
.header .header__inner {
  display: flex;
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  pointer-events: auto;
}
@media (max-width: 1079px) {
  .header .header__inner {
    padding-top: 2.8rem;
  }
}
.header .header__logo {
  transition: opacity var(--t-duration);
}
.header .header__aside {
  max-width: 14.1rem;
  position: relative;
}
.header .header__aside .btn {
  position: absolute;
  top: 50%;
  right: 0;
  width: auto;
  height: auto;
  transform: translateY(-50%);
  mix-blend-mode: difference;
}
.header .header__aside .header__slogan {
  display: inline-block;
  transition: opacity var(--t-duration);
  opacity: 0;
  pointer-events: none;
}
@media (max-width: 1079px) {
  .header .header__logo,
  .header .header__aside {
    transition: transform var(--t-duration);
    transform: translate3d(0, calc(-100% - 4rem), 0);
  }
}
.header nav {
  display: none;
}
.header .header__nav {
  position: absolute;
  --bottom: clamp(3.2rem, 7.6vh, 3rem);
  bottom: var(--bottom);
  left: 50%;
  transform: translateX(-50%);
  padding: 0rem 2.2rem 0.3rem;
  border-radius: 1.6rem;
  min-height: 5.8rem;
  width: 42.3rem;
  backdrop-filter: blur(40px);
  background: linear-gradient(109.65deg, rgba(240, 236, 236, 0.5) 9.3%, rgba(240, 236, 236, 0.25) 97.39%), linear-gradient(290.95deg, rgba(0, 0, 0, 0.05) 6.98%, rgba(0, 0, 0, 0.01) 74.01%);
  border: 1px solid #e8e8e8;
  overflow-x: hidden;
  max-height: calc(100vh - var(--bottom) - 3rem);
  transition: border-color var(--t-duration), transform var(--t-duration);
}
@media (max-width: 1079px) {
  .header .header__nav {
    transform: translate3d(-50%, calc(100% + var(--bottom, 0px)), 0);
  }
}
@media (max-width: 767px) {
  .header .header__nav {
    width: 100%;
    max-width: calc(100% - var(--shell-gutter, 32px) * 2);
    --bottom: 3rem;
    max-height: calc(100vh - var(--bottom) - 15.4rem);
    padding: 0.1rem 2.2rem 0.1rem;
    background: linear-gradient(109.65deg, #f5f3f3 9.3%, #efeeee 97.39%);
  }
  .header .header__nav:before {
    position: absolute;
    top: 0.9rem;
    left: 50%;
    width: 4.8rem;
    height: 0.6rem;
    background-color: #d9d9d9;
    border-radius: 3.2rem;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity var(--t-duration);
    content: "";
  }
}
@media (max-width: 1079px) {
  .header .header__nav.is-expanded:before {
    opacity: 1;
  }
}
.header .header__nav.is-expanded .header__toggle:after {
  opacity: 0;
}
.header .header__nav.is-expanded .header__toggle:before {
  opacity: 1;
}
.header .header__nav.is-expanded .header__toggle h6 {
  width: 100%;
  color: rgba(84, 84, 84, 0.25);
}
.header .header__nav > * {
  position: relative;
  z-index: 1;
}
.header .header__nav .header__toggle {
  height: auto;
  padding: 1.8rem 0 1.8rem;
  text-decoration: none;
  display: block;
  transition: opacity var(--t-duration);
  text-transform: uppercase;
}
@media (max-width: 1079px) {
  .header .header__nav .header__toggle {
    position: relative;
    min-height: 5.4rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .header .header__nav .header__toggle:hover {
    opacity: 0.6;
  }
}
.header .header__nav .header__toggle h6 {
  transition: color var(--t-duration);
}
@media (max-width: 1079px) {
  .header .header__nav .header__toggle h6 {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
  }
}
@media (max-width: 1079px) {
  .header .header__nav .header__toggle h6 {
    transition: color 0.4s, left 0.4s, transform 0.4s;
  }
}
.header .header__nav .header__toggle:after {
  position: absolute;
  top: 50%;
  right: 0.6rem;
  width: 1.6rem;
  height: 1.3rem;
  background-color: currentcolor;
  mask: url("../assets/images/svg/ico-menu.svg") center center no-repeat;
  mask-size: contain;
  transform: translateY(-50%);
  transition: opacity var(--t-duration);
  content: "";
}
.header .header__nav .header__toggle:before {
  position: absolute;
  top: 50%;
  right: 0.8rem;
  width: 1.2rem;
  height: 1rem;
  background-color: currentcolor;
  mask: url("../assets/images/svg/ico-chevron-down.svg") center center no-repeat;
  mask-size: contain;
  transform: translateY(-50%);
  opacity: 0;
  transition: opacity var(--t-duration);
  content: "";
}
/* ------------------------------------------------------------ *\
	.main
\* ------------------------------------------------------------ */
.main {
  padding-top: 800vh;
}
@media (max-width: 767px) {
  .main {
    padding-top: 0;
  }
}
/* ------------------------------------------------------------ *\
	Media
\* ------------------------------------------------------------ */
.media {
  padding-top: 56.25%;
  position: relative;
  overflow: hidden;
}
.media .media-image--desktop,
.media [id*=video-desktop-],
.media .plyr--desktop {
  display: block;
}
@media screen and (max-width: 767px) {
  .media .media-image--desktop,
  .media [id*=video-desktop-],
  .media .plyr--desktop {
    display: none;
  }
}
.media .media-image--mobile,
.media [id*=video-mobile-],
.media .plyr--mobile {
  display: none;
}
@media screen and (max-width: 767px) {
  .media .media-image--mobile,
  .media [id*=video-mobile-],
  .media .plyr--mobile {
    display: block;
  }
}
.media .plyr__poster {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.media .embed-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.media .embed-container iframe {
  width: 100%;
  height: 100%;
}
.media[data-autoplay=false] .plyr--video:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  transition: opacity var(--t-duration);
  pointer-events: none;
  opacity: 0.5;
}
.media[data-autoplay=false] .plyr--video.plyr--playing:after {
  opacity: 0;
}
.media .plyr--playing ~ picture img {
  opacity: 0;
}
.media video {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.media iframe {
  /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
  min-height: 101%;
  /* Given a 16:9 aspect ratio, 16/9*100 = 177.77 */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: unset;
  min-height: 100% !important;
}
@media (max-width: 767px) {
  .media iframe {
    min-height: 100%;
  }
}
.media .plyr--video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  transition: transform var(--t-duration);
  pointer-events: none;
}
.media .plyr--video .plyr__video-wrapper {
  height: 100%;
  width: 100%;
}
.media .plyr--video .plyr--video .plyr__controls {
  display: none !important;
}
.media .plyr--video .plyr__control.plyr__control--overlaid {
  opacity: 0 !important;
  visibility: hidden !important;
}
.media .plyr--video .player-hover {
  width: 100%;
  height: 100% !important;
}
.media .plyr--video .plyr--vimeo iframe {
  transform: translate(-50%, -50%);
  height: 102% !important;
  min-height: 102% !important;
  min-width: 177.77vh;
}
.media .plyr--video .plyr--vimeo .plyr__video-embed__container {
  display: contents;
}
.media .plyr--vimeo {
  height: 100%;
}
.media .plyr--full-ui .plyr__video-embed > .plyr__video-embed__container {
  height: 101%;
  padding-bottom: 0;
  transform: translateY(0);
  display: contents;
}
.media picture {
  width: 100%;
  height: 100%;
}
.media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  transition: transform var(--t-duration), opacity var(--t-duration);
  z-index: 2;
}
.media .media__video--mobile {
  display: none;
}
@media (max-width: 767px) {
  .media .media__video--mobile {
    display: block;
  }
}
@media (max-width: 767px) {
  .media .media__video--mobile + .media__video {
    display: none;
  }
}
.media .js-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  text-decoration: none;
  will-change: transform;
  width: 4rem;
  height: 4rem;
  background-color: var(--c-base);
  border-radius: 50%;
  transition: opacity var(--t-duration), visibility var(--t-duration);
}
.media .js-play-btn img,
.media .js-play-btn svg {
  position: absolute;
  top: 50%;
  left: 53%;
  transform: translate(-50%, -50%);
}
.media .js-play-btn:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 40%;
  transform: translate(-50%, -50%);
  width: 2px;
  height: 1.4rem;
  background-color: #fff;
  transition: opacity var(--t-duration);
  pointer-events: none;
  z-index: 3;
  opacity: 0;
}
.media .js-play-btn:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 60%;
  width: 2px;
  height: 1.4rem;
  transform: translate(-50%, -50%);
  background-color: #fff;
  transition: opacity var(--t-duration);
  pointer-events: none;
  z-index: 3;
  opacity: 0;
}
.media .js-play-btn.is-played svg,
.media .js-play-btn.is-played img {
  opacity: 0;
  visibility: hidden;
}
.media .js-play-btn.is-played:before, .media .js-play-btn.is-played:after {
  opacity: 1;
  visibility: visible;
}
.media .js-play-btn.is-not-visible {
  opacity: 0;
  visibility: hidden;
}
.media .plyr--video .plyr__controls {
  pointer-events: none;
}
.media .plyr--video .plyr__controls > * {
  pointer-events: all;
}
.media[data-hover=popup]:after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5.6rem;
  height: 5.6rem;
  background: white;
  border-radius: 4.8rem;
  content: "";
  transform: translate3d(-50%, -50%, 0);
  will-change: transform;
  opacity: 0;
  transition: opacity var(--t-duration);
  z-index: 1;
}
@media (max-width: 1079px) {
  .media[data-hover=popup]:after {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    top: 50%;
    left: 50%;
    margin: -29px 0 0 -29px;
  }
}
.media[data-hover=popup]:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--c-black);
  mask: url("../assets/images/svg/ico-expand.svg") center center no-repeat;
  mask-size: contain;
  transform: translate3d(-50%, -50%, 0);
  will-change: transform;
  opacity: 0;
  transition: opacity var(--t-duration);
  z-index: 3;
  content: "";
}
@media (max-width: 1079px) {
  .media[data-hover=popup]:before {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    top: 50%;
    left: 50%;
    margin: -8px 0 0 -8px;
  }
}
.media[data-hover=popup] .plyr__video-wrapper:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  background-color: var(--c-black);
  opacity: 0;
  transition: opacity var(--t-duration);
  z-index: 1;
  transform: translate3d(0, 0, 0);
  will-change: transform;
}
.media[data-hover=popup]:hover {
  cursor: pointer;
}
@media (hover: hover) and (pointer: fine) {
  .media[data-hover=popup]:hover .plyr__video-wrapper:before {
    opacity: 0.6;
  }
  .media[data-hover=popup]:hover:after {
    opacity: 1;
  }
  .media[data-hover=popup]:hover:before {
    opacity: 1;
  }
}
.popup .slick-slider .slick-slide .media.pause {
  position: relative;
  left: 99999px;
}
.popup .slick-slider .slick-current .media.play {
  left: 0;
}
.media--poster .plyr {
  opacity: 0;
  transition: opacity var(--t-duration);
}
.media--poster.is-played .plyr {
  opacity: 1;
}
.media--poster.is-played img {
  opacity: 0;
}
/* specific overrides for the carousel */
.section-carousel iframe {
  width: 100vw;
  /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
}
/* ------------------------------------------------------------ *\
	.nav
\* ------------------------------------------------------------ */
.nav {
  padding-bottom: 1.9rem;
  pointer-events: none;
  overflow: hidden;
}
.nav ul {
  pointer-events: auto;
}
.nav a {
  display: block;
  background: linear-gradient(109.65deg, rgba(240, 236, 236, 0.5) 9.3%, rgba(240, 236, 236, 0.25) 97.39%), linear-gradient(290.95deg, rgba(0, 0, 0, 0.05) 6.98%, rgba(0, 0, 0, 0.01) 74.01%);
  text-decoration: none;
  text-transform: uppercase;
  padding: 1.8rem 4rem 1.8rem 2.2rem;
  font-weight: 700;
  line-height: 1.1;
  font-size: 1.6rem;
  position: relative;
  border-radius: 1.2rem;
  transition: opacity var(--t-duration);
}
@media (max-width: 767px) {
  .nav a {
    font-size: 1.8rem;
    letter-spacing: 0.001em;
    padding: 1.5rem 4rem 1.5rem 2.5rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .nav a:hover {
    opacity: 0.6;
  }
}
.nav a:after {
  position: absolute;
  top: 50%;
  right: 2.3rem;
  width: 1rem;
  height: 1rem;
  background-color: currentcolor;
  mask: url("../assets/images/svg/ico-chevron-right.svg") center center no-repeat;
  mask-size: contain;
  transform: translateY(-50%);
  content: "";
}
@media (max-width: 767px) {
  .nav a:after {
    right: 3.2rem;
    width: 1.2rem;
    height: 1.2rem;
  }
}
.nav li + li {
  margin-top: 0.6rem;
}
@media (max-width: 767px) {
  .nav li + li {
    margin-top: 1.2rem;
  }
}
/* ------------------------------------------------------------ *\
	.popup
\* ------------------------------------------------------------ */
.mfp-content:has(.media--video) {
  max-width: 115rem;
  padding: 0 3rem;
  margin: 0 auto;
}
@media (max-width: 123rem) {
  .mfp-content:has(.media--video) {
    max-width: calc(100vw - 10rem);
  }
}
@media (max-width: 1079px) {
  .mfp-content:has(.media--video) {
    max-width: 100vw;
    padding: 0 1.5rem;
  }
}
.mfp-close {
  opacity: 1;
  top: 0;
  right: 0px;
  width: 4.5rem;
  height: 4.5rem;
}
.mfp-close svg {
  transition: fill var(--t-duration);
}
.mfp-close path {
  transition: stroke var(--t-duration);
}
@media (hover: hover) and (pointer: fine) {
  .mfp-close:hover svg {
    fill: var(--c-white);
  }
  .mfp-close:hover path {
    stroke: var(--c-black);
  }
}
.mfp-bg {
  opacity: 0.9;
}
.mfp-content:has(.media--box) {
  max-width: 37.4rem;
  padding: 0 3rem 3.7rem;
  margin: 0 auto;
}
.mfp-content:has(.media--box) .media {
  padding-bottom: 121.69%;
}
.mfp-content:has(.media--box) .media .plyr--video {
  pointer-events: auto;
}
.mfp-content:has(.media--box) .media .plyr--video .plyr--video .plyr__controls {
  display: block !important;
}
.mfp-content:has(.media--box) .media .plyr--video .plyr__control.plyr__control--overlaid {
  opacity: 0 !important;
  visibility: hidden !important;
}
.mfp-content:has(.media--box) .media .plyr--video .plyr__controls {
  pointer-events: auto;
}
/* ------------------------------------------------------------ *\
	.section-articles
\* ------------------------------------------------------------ */
.section-articles {
  padding: 13.8rem 0 17.1rem;
  position: relative;
  overflow: hidden;
}
@media (max-width: 1079px) {
  .section-articles {
    padding-bottom: 5rem;
  }
}
@media (max-width: 767px) {
  .section-articles {
    padding: 7rem 0 2rem;
  }
}
/* ------------------------------------------------------------ *\
	.section-callout
\* ------------------------------------------------------------ */
.section-callout {
  position: relative;
  padding: 16rem 0 22.8rem;
  overflow: hidden;
}
@media (max-width: 767px) {
  .section-callout {
    padding: 2.9rem 0 8rem;
  }
}
.section-callout p {
  margin-bottom: 2rem;
}
@media (max-width: 767px) {
  .section-callout p {
    margin-bottom: 2.8rem;
  }
}
.section-callout p:last-child {
  margin-bottom: 0;
}
.section-callout .btn {
  margin-bottom: 3rem;
}
@media (max-width: 767px) {
  .section-callout .btn {
    margin-bottom: 5.5rem;
  }
}
.section-callout .btn:last-child {
  margin-bottom: 0;
}
@media (max-width: 1079px) {
  .section-callout .btn_donate {
    background: black;
    color: white;
  }
}
.section-callout ul {
  list-style-type: none;
  padding-left: 0;
}
.section-callout ul li + li {
  margin-top: 0.4rem;
}
@media (max-width: 767px) {
  .section-callout ul li + li {
    margin-top: 1.1rem;
  }
}
@media (max-width: 767px) {
  .section-callout h4 {
    margin-bottom: 2.4rem;
  }
}
.section-callout h4 + ul {
  margin-top: -0.2rem;
}
@media (max-width: 767px) {
  .section-callout h4 + ul {
    margin-top: 0rem;
  }
}
@media (max-width: 767px) {
  .section-callout h4 + .form {
    margin-top: -0.6rem;
  }
}
@media (max-width: 767px) {
  .section-callout .grid {
    --gap-y: 1.8rem;
  }
}
@media (max-width: 767px) {
  .section-callout .grid .grid__col--1of2 {
    max-width: 100%;
    flex: 0 0 100%;
  }
}
/* ------------------------------------------------------------ *\
	.section-carousel
\* ------------------------------------------------------------ */
.section-carousel {
  padding: 8rem 0;
  overflow: hidden;
  position: relative;
}
@media (max-width: 767px) {
  .section-carousel {
    padding: 4.3rem 0;
  }
}
.section-carousel .section__head {
  max-width: 31.3rem;
  margin-bottom: 10.2rem;
}
@media (max-width: 767px) {
  .section-carousel .section__head {
    max-width: 50rem;
    margin-bottom: 7.8rem;
  }
}
.section-carousel .section__head:last-child {
  margin-bottom: 0;
}
/* ------------------------------------------------------------ *\
	.section-headline
\* ------------------------------------------------------------ */
.section-headline {
  min-height: 100vh;
  padding-bottom: clamp(11.6rem, 15vw, 21.6rem);
  display: flex;
  overflow: hidden;
  position: relative;
  margin-top: -70vh;
}
@media (max-width: 1079px) {
  .section-headline {
    padding-bottom: 4rem;
    min-height: unset;
  }
}
@media (max-width: 767px) {
  .section-headline {
    margin-top: 0;
    padding: 5.9rem 0 3.8rem;
  }
}
.section-headline .shell {
  --shell-gutter: 0px;
}
.section-headline .section__inner {
  display: flex;
  height: 100%;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .section-headline .section__inner {
    flex-direction: column;
  }
}
.section-headline .section__inner h2 {
  transition: opacity var(--t-duration);
  opacity: 0;
}
@media (max-width: 1079px) {
  .section-headline .section__inner h2 {
    opacity: 1;
    margin-bottom: 7.1rem;
  }
  .section-headline .section__inner h2:last-child {
    margin-bottom: 0;
  }
}
.section-headline .section__inner h2.is-visible {
  opacity: 1;
}
.section-headline .section__inner h2:nth-of-type(1) {
  position: relative;
  left: -0.069em;
  top: -0.145em;
}
.section-headline .section__inner h2:nth-of-type(2) {
  text-align: right;
  align-self: flex-end;
}
/* ------------------------------------------------------------ *\
	.section-intro
\* ------------------------------------------------------------ */
.section-intro {
  position: fixed;
  top: 0;
  left: 0;
  min-height: 100vh;
  min-height: 100lvh;
  width: 100%;
  z-index: -1;
  transition: opacity var(--t-duration);
  will-change: transform;
  transform: translate3d(0, 0, 0);
  overflow: hidden;
}
@media (max-width: 767px) {
  .section-intro {
    position: relative;
  }
}
@media (max-width: 1079px) {
  .section-intro .shell {
    padding: 0;
  }
}
.section-intro.is-faded {
  opacity: 0.2;
}
@media (max-width: 767px) {
  .section-intro.is-faded {
    opacity: 1;
  }
}
.section-intro.entry-visible .section__entry {
  opacity: 1;
}
.section-intro video {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: bottom;
  transform: translateX(-50%);
  transition: opacity var(--t-duration);
}
@media (max-width: 1079px) {
  .section-intro video {
    position: relative;
    height: auto;
    width: 100vw;
    left: auto;
    transform: unset;
  }
}
.section-intro .section__entry {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%);
  max-width: 30.9rem;
  opacity: 0;
  transition: opacity var(--t-duration);
}
@media (max-width: 767px) {
  .section-intro .section__entry {
    position: relative;
    height: auto;
    width: auto;
    top: auto;
    left: auto;
    opacity: 1;
    max-width: 100vw;
    padding: 6.7rem var(--shell-gutter) 0;
    transform: unset;
  }
}
@media (max-width: 767px) {
  .section-intro .section__entry h4 {
    margin-right: -0.5rem;
    margin-bottom: 1.7rem;
  }
}
@media (max-width: 767px) {
  .section-intro .section__entry p {
    padding-right: 1.2rem;
    line-height: 1.28;
    margin-bottom: 1.5rem;
  }
}
@media (max-width: 767px) {
  .section-intro .section__entry p:has(strong) {
    max-width: 18rem;
  }
}
.shell {
  --shell-max-width: 131.2rem;
  --shell-gutter: 3.25rem;
  max-width: calc(var(--shell-max-width) + var(--shell-gutter) * 2);
  padding-inline: var(--shell-gutter);
  margin-inline: auto;
  width: 100%;
}
.shell--fluid {
  max-width: none;
}
/* ------------------------------------------------------------ *\
	.slider-videos
\* ------------------------------------------------------------ */
.slider-videos .splide__track {
  overflow: visible !important;
}
.slider-videos video,
.slider-videos iframe {
  will-change: transform;
}
.slider-videos iframe {
  transform: translate3d(-50%, -50%, 0);
}
.slider-videos video {
  transform: translate3d(0, 0, 0);
}
.slider-videos .box-video, .slider-videos .box-image {
  will-change: transform;
  transform: translate3d(0, 0, 0);
}
.slider-videos .splide__list {
  margin: 0 !important;
  padding: 0 !important;
  height: 100%;
  display: flex;
  width: -webkit-max-content;
  width: max-content;
  will-change: transform;
}
.slider-videos .splide__track > .splide__list > .splide__slide {
  transform: translate3d(0px, 0, 0);
  -webkit-transform: translate3d(0px, 0, 0);
  -moz-transform: translate3d(0px, 0, 0);
  -ms-transform: translate3d(0px, 0, 0);
  -o-transform: translate3d(0px, 0, 0);
  will-change: inherit;
}
.slider-videos .splide__list > .splide__slide:first-child {
  z-index: 2;
}
.slider-videos .splide__slide:first-of-type,
.slider-videos .is-prev {
  opacity: 1 !important;
}
.wrapper {
  position: relative;
  min-height: 100svh;
}