/* ==========================================================================
 * Settings
   ========================================================================== */
:root {
  --color-primary: #000000;
  --color-black: #000000;
  --color-gray-100: #f2f2f2;
  --color-gray-200: #cccccc;
  --color-gray-300: #999999;
  --color-gray-400: #666666;
  --color-gray-500: #333333;
  --color-border: var(--color-gray-200);
  --color-text-light: var(--color-gray-500);
  --z-modal: 50;
  --z-navigation: 25;
  --font-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
* {
  margin: 0;
}
html:focus-within {
  scroll-behavior: smooth;
}
input,
button,
textarea,
select {
  font: inherit;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* ==========================================================================
 * Content Basic
   ========================================================================== */
* {
  box-sizing: border-box;
}
*::selection {
  background: #000;
  color: #FFF;
  text-shadow: none;
}
body {
  background-color: var(--color-bg);
  color: var(--color-text);
  text-rendering: optimizeLegibility;
  font-size: 100%;
  font-family: var(--font-regular);
  line-height: 1.5;
}
[data-mode="maintenance"] {
  overflow: hidden;
}
.main {
  min-height: 80dvh;
  margin-bottom: 4.5rem;
}
@media only screen and (min-width: 50.625em) {
  .main {
    min-height: 90dvh;
    margin-bottom: 7.5rem;
  }
}
/* ==========================================================================
 * Content Typography
   ========================================================================== */
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  display: block;
  font-family: var(--font-semibold);
  letter-spacing: -0.005em;
}
blockquote {
  position: relative;
  margin: 2.25rem 0 4.5rem;
  text-align: center;
  font-family: var(--font-italic);
}
@media only screen and (min-width: 36em) {
  blockquote {
    margin: 3rem 0 6rem;
  }
}
blockquote::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -1.5rem;
  transform: translateX(-50%);
  width: 80px;
  height: 4px;
  background-color: var(--color-link);
}
blockquote cite {
  display: block;
  margin-top: 0.5rem;
}
.label {
  display: block;
}
.badge {
  display: inline-block;
  padding: 1px 10px;
  border-radius: 6px;
  background-color: var(--color-text);
  color: var(--color-bg);
  font-family: var(--font-sans-serif);
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.75em;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}
.badge--large {
  font-size: 1.125rem;
  font-size: clamp(1rem, 0.975rem + 0.125vw, 1.125rem);
}
strong,
b {
  font-family: var(--font-bold);
}
em {
  font-family: var(--font-italic);
}
.fontregular {
  font-family: var(--font-regular);
}
.fontmedium {
  font-family: var(--font-medium);
}
.fontsemibold {
  font-family: var(--font-semibold);
}
.fontbold {
  font-family: var(--font-bold);
}
.fontitalic {
  font-family: var(--font-italic);
}
/* ==========================================================================
 * Content Links
   ========================================================================== */
a {
  color: var(--color-link);
  text-decoration: underline;
}
a:hover,
a:focus {
  text-decoration: none;
}
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--color-link);
  outline-offset: 2px;
  transition: none;
}
@supports not selector(:focus-visible) {
  a:focus,
  button:focus {
    outline: 2px solid var(--color-link);
    outline-offset: 2px;
    transition: none;
  }
}
h2 > a {
  text-decoration: none;
}
h2 > a:hover,
h2 > a:focus {
  text-decoration: underline;
}
.link-site {
  color: var(--nav-color);
  font-size: 1.6875rem;
  font-size: clamp(1.3125rem, 1.2375rem + 0.375vw, 1.6875rem);
  font-family: var(--font-medium);
  text-decoration: none;
}
.link-site span {
  display: block;
  width: 24px;
  height: 24px;
  border: 2px solid var(--nav-color);
}
.link-site .link-site__circle {
  border-radius: 50%;
}
.link-site .link-site__diamond {
  transform: rotate(45deg);
}
.link-site:focus {
  outline-color: var(--color-text);
}
.link {
  display: inline-block;
  color: var(--color-text);
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
.link--arrow {
  position: relative;
  padding-left: 10px;
}
.link--arrow::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 0px;
  height: 0px;
  transform: translateY(-50%);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 6px solid var(--color-text);
}
/* ==========================================================================
 * Content List
   ========================================================================== */
ul,
ol {
  margin-bottom: 0.75rem;
  padding-left: 1.25rem;
}
@media only screen and (min-width: 36em) {
  ul,
  ol {
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  ul,
  ol {
    margin-bottom: 1.5rem;
  }
}
ul li,
ol li {
  margin-bottom: 0;
}
ul.list-unstyled,
ol.list-unstyled {
  margin: 0;
  padding: 0;
  list-style: none;
}
ul.list-inline,
ol.list-inline {
  margin: 0;
  padding: 0;
  list-style: none;
}
ul.list-inline li,
ol.list-inline li {
  display: inline-block;
  margin: 0 0.5rem 0 0;
}
.list h2 {
  margin-bottom: 1rem;
}
.list--lined ul,
.list--lined ol,
.list--lined dl {
  margin: 0;
  padding: 0;
  list-style: none;
}
.list--lined ul li,
.list--lined ol li,
.list--lined dl li,
.list--lined ul dd,
.list--lined ol dd,
.list--lined dl dd {
  margin-bottom: 7px;
  padding-bottom: 7px;
  border-bottom: 1px solid var(--color-text);
  line-height: 1.25em;
}
.list--lined ul li:last-child,
.list--lined ol li:last-child,
.list--lined dl li:last-child,
.list--lined ul dd:last-child,
.list--lined ol dd:last-child,
.list--lined dl dd:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
.list--colored ul,
.list--colored ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
.list--colored ul li,
.list--colored ol li {
  margin-bottom: 2px;
  padding: 0.25rem 0.5rem;
  background-color: var(--list-bg);
  color: var(--list-color);
}
.list--dates ul,
.list--dates ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
.list--dates ul li.date,
.list--dates ol li.date {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-text);
}
.list--dates ul li.date:last-child,
.list--dates ol li.date:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
.list--dates ul li.date--canceled .date__data,
.list--dates ol li.date--canceled .date__data,
.list--dates ul li.date--canceled p,
.list--dates ol li.date--canceled p {
  text-decoration: line-through;
}
.list--dates ul li.date .date__date,
.list--dates ol li.date .date__date {
  flex: 0 0 100%;
  max-width: 100%;
}
@media only screen and (min-width: 36em) {
  .list--dates ul li.date .date__date,
  .list--dates ol li.date .date__date {
    padding-right: 0.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .list--dates ul li.date .date__date,
  .list--dates ol li.date .date__date {
    flex: 0 0 20%;
    max-width: 20%;
  }
}
.list--dates ul li.date .date__date p,
.list--dates ol li.date .date__date p {
  margin: 0;
}
.list--dates ul li.date .date__data,
.list--dates ol li.date .date__data {
  flex: 0 0 100%;
  max-width: 100%;
}
@media only screen and (min-width: 50.625em) {
  .list--dates ul li.date .date__data,
  .list--dates ol li.date .date__data {
    flex: 0 0 80%;
    max-width: 80%;
  }
}
.list--dates ul li.date p,
.list--dates ol li.date p {
  width: 100%;
  max-width: 760px;
  margin: 0.25rem 0 0;
  line-height: 1.25em;
}
.list--dates ul li.date a,
.list--dates ol li.date a {
  color: var(--color-text);
}
.list--dates ul li.date .badge,
.list--dates ol li.date .badge {
  margin-bottom: 0.25rem;
}
.list--dates ul li.date time,
.list--dates ol li.date time {
  margin-bottom: 0.5rem;
  font-family: var(--font-medium);
}
@media only screen and (min-width: 50.625em) {
  .list--dates ul li.date time,
  .list--dates ol li.date time {
    margin-bottom: 0;
  }
}
.list--dates-disabled ul li.date {
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  opacity: 0.35;
}
.list--dates-disabled ul li.date time {
  margin: 0;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
ul.tags {
  margin: 3rem 0 0;
  padding: 0;
  list-style: none;
}
ul.tags li {
  display: inline-block;
  margin: 0 0.25rem 0.5rem 0;
}
ul.tags a {
  display: inline-block;
  padding: 2px 8px;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  text-decoration: none;
}
ul.tags a:hover {
  background-color: var(--color-text);
  color: white;
}
ul.tags a:focus-visible {
  outline-color: var(--color-text);
  background-color: var(--color-text);
  color: white;
}
/* ==========================================================================
 * Content Image
   ========================================================================== */
img {
  display: block;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
figcaption {
  padding-top: 0.25rem;
  color: var(--color-text-light);
  font-size: 16px;
  font-size: 1rem;
  text-align: center;
}
.bgimage {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.icon {
  display: inline-block;
  width: 16px;
  height: 16px;
  vertical-align: middle;
}
.icon--reverse {
  transform: rotate(180deg);
}
.icon--12 {
  width: 12px;
  height: 12px;
  margin-bottom: 4px;
}
.icon--24 {
  width: 24px;
  height: 24px;
}
.icon--32 {
  width: 32px;
  height: 32px;
}
.icon--48 {
  width: 48px;
  height: 48px;
}
.icon--64 {
  width: 64px;
  height: 64px;
}
/* ==========================================================================
 * Content Colors
   ========================================================================== */
.color-primary {
  color: var(--color-primary);
}
.color-copy {
  color: var(--color-text);
}
.color-copy-light {
  color: var(--color-text-light);
}
.color-black {
  color: var(--color-black);
}
.color-white {
  color: white;
}
.color-gray-100 {
  color: var(--color-gray-100);
}
.color-gray-200 {
  color: var(--color-gray-200);
}
.color-gray-300 {
  color: var(--color-gray-300);
}
.color-gray-400 {
  color: var(--color-gray-400);
}
.color-gray-500 {
  color: var(--color-gray-500);
}
.bg-color-primary {
  background-color: var(--color-primary);
}
.bg-color-copy {
  background-color: var(--color-text);
}
.bg-color-black {
  background-color: var(--color-black);
}
.bg-color-gray-100 {
  color: var(--color-gray-100);
}
.bg-color-gray-200 {
  color: var(--color-gray-200);
}
.bg-color-gray-300 {
  color: var(--color-gray-300);
}
.bg-color-gray-400 {
  color: var(--color-gray-400);
}
.bg-color-gray-500 {
  color: var(--color-gray-500);
}
/* ==========================================================================
 * Content Elements
   ========================================================================== */
.content {
  width: 100%;
}
.content .content__text,
.content .content__image,
.content .content__textimage,
.content .content__heading,
.content .content__list,
.content .content__articles,
.content .content__quote,
.content .content__video,
.content .content__audio,
.content .content__embed {
  max-width: 1080px;
  margin-bottom: 2.25rem;
  margin-inline: auto;
}
@media only screen and (min-width: 36em) {
  .content .content__text,
  .content .content__image,
  .content .content__textimage,
  .content .content__heading,
  .content .content__list,
  .content .content__articles,
  .content .content__quote,
  .content .content__video,
  .content .content__audio,
  .content .content__embed {
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .content .content__text,
  .content .content__image,
  .content .content__textimage,
  .content .content__heading,
  .content .content__list,
  .content .content__articles,
  .content .content__quote,
  .content .content__video,
  .content .content__audio,
  .content .content__embed {
    margin-bottom: 4.5rem;
  }
}
.content .content__heading,
.content .content__text,
.content .content__list,
.content .content__quote,
.content .content__articles,
.content .content__audio {
  max-width: 760px;
}
.content .content__heading {
  margin-bottom: 0;
}
.content .content__image figure {
  margin-inline: auto;
}
.content .content__image .image-default {
  max-width: 1080px;
}
.content .content__image .image-small {
  max-width: 600px;
}
@media only screen and (min-width: 50.625em) {
  .content .content__textimage .row--textimage .col:first-of-type {
    padding-right: 3rem;
  }
}
@media only screen and (min-width: 50.625em) and only screen and (min-width: 36em) {
  .content .content__textimage .row--textimage .col:first-of-type {
    padding-right: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) and only screen and (min-width: 50.625em) {
  .content .content__textimage .row--textimage .col:first-of-type {
    padding-right: 6rem;
  }
}
.content .content__textimage .row--imagetext .col:first-of-type {
  padding-top: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .content .content__textimage .row--imagetext .col:first-of-type {
    padding-top: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .content .content__textimage .row--imagetext .col:first-of-type {
    padding-top: 1.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .content .content__textimage .row--imagetext .col:first-of-type {
    padding-top: 0;
    padding-left: 3rem;
  }
}
@media only screen and (min-width: 50.625em) and only screen and (min-width: 36em) {
  .content .content__textimage .row--imagetext .col:first-of-type {
    padding-left: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) and only screen and (min-width: 50.625em) {
  .content .content__textimage .row--imagetext .col:first-of-type {
    padding-left: 6rem;
  }
}
.content--limiter {
  max-width: 1080px;
  margin-inline: auto;
}
.work .work__info,
.work .work__press,
.work .work__downloads {
  margin-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .work .work__info,
  .work .work__press,
  .work .work__downloads {
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .work .work__info,
  .work .work__press,
  .work .work__downloads {
    margin-bottom: 4.5rem;
  }
}
.work .work__info {
  width: 100%;
  max-width: 1080px;
  margin-inline: auto;
}
.work .work__info figure {
  margin-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .work .work__info figure {
    margin-bottom: 0;
  }
}
.work .work__press a {
  color: var(--color-text);
}
.work-item {
  width: 100%;
  max-width: 1280px;
  margin-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .work-item {
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .work-item {
    margin-bottom: 4.5rem;
  }
}
@media only screen and (min-width: 120em) {
  .work-item {
    max-width: 1720px;
  }
}
.work-item:last-of-type {
  margin-bottom: 0;
}
.work-item h2 {
  margin-bottom: 0.25rem;
}
.work-item p {
  margin-bottom: 0.75rem;
}
.work-item a {
  color: var(--color-text);
  text-decoration: none;
}
.work-item a:hover {
  text-decoration: underline;
}
.work-item a:focus-visible {
  text-decoration: underline;
  outline-color: var(--color-text);
}
.work-item a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}
.work-item .work-item__content {
  width: 100%;
  max-width: 1080px;
}
.work-item .work-item__image {
  margin-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .work-item .work-item__image {
    margin-bottom: 0;
  }
}
.work-item .work-item__image a {
  display: block;
}
.work-item .work-item__data {
  display: block;
  margin-bottom: 0.75rem;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
@media only screen and (min-width: 36em) {
  .work-item .work-item__data {
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .work-item .work-item__data {
    margin-bottom: 1.5rem;
  }
}
.work__downloads a {
  color: var(--color-text);
}
time {
  display: inline-block;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
.download {
  margin-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .download {
    margin-bottom: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .download {
    margin-bottom: 3rem;
  }
}
.download p {
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
}
.download a {
  color: var(--color-text);
}
.articles ul {
  margin-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .articles ul {
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .articles ul {
    margin-bottom: 1.5rem;
  }
}
.articles ul li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  line-height: 1.25em;
}
.articles .articles__headline {
  margin-bottom: 0.5rem;
  font-family: var(--font-bold);
}
.articles .articles__content {
  width: 100%;
}
@media only screen and (min-width: 36em) {
  .articles .articles__content {
    width: 66%;
    padding-right: 0.75rem;
  }
}
.articles .articles__link {
  width: 100%;
}
@media only screen and (min-width: 36em) {
  .articles .articles__link {
    width: 33%;
    text-align: right;
  }
}
/* ==========================================================================
 * Content Media
   ========================================================================== */
iframe {
  width: 100%;
  border: 0;
}
audio {
  width: 100%;
}
.video {
  position: relative;
}
.video .video__inner {
  position: relative;
  aspect-ratio: 1.7777778;
  background-color: var(--color-black);
  border: 1px solid white;
}
@supports not (aspect-ratio: 1.7777778) {
  .video .video__inner::before {
    float: left;
    padding-bottom: calc(100% / 1.7777778);
    content: "";
  }
  .video .video__inner::after {
    display: block;
    content: "";
    clear: both;
  }
}
.video .video__preview {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.video .video__desc {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 100%;
  transform: translateX(-50%);
  padding: 0.25rem;
  background-color: rgba(255, 255, 255, 0.75);
  z-index: 5;
}
@media only screen and (min-width: 36em) {
  .video .video__desc {
    bottom: 1.5rem;
    width: 95%;
    padding: 0.75rem;
  }
}
.video .video__desc p {
  margin: 0;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1em;
}
@media only screen and (min-width: 36em) {
  .video .video__desc p {
    font-size: 16px;
    font-size: 1rem;
  }
}
.video .btn-play {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.video img,
.video iframe,
.video video {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: black;
}
.embed {
  position: relative;
  background-color: var(--color-gray-100);
  height: 12em;
  border: 1px solid white;
}
.embed .embed__privacy {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 75%;
  text-align: center;
  z-index: 5;
}
.embed iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
}
.embed .btn {
  margin: 0 0 1rem;
}
.embed p {
  margin: 0;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.25em;
}
.embed.is-loaded {
  height: auto;
  background-color: transparent;
}
.embed.is-loaded iframe {
  position: relative!important;
  min-height: 160px;
}
/* ==========================================================================
 * Layout Flex-Grid
   ========================================================================== */
.row {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.row--gap {
  margin: 0 -1.5rem;
}
.row--gap > * {
  padding: 1.5rem;
}
.row--gap-s {
  margin: 0 -0.75rem;
}
.row--gap-s > * {
  padding: 0.75rem;
}
.row--imagetext {
  flex-direction: column-reverse;
}
@media only screen and (min-width: 50.625em) {
  .row--imagetext {
    flex-direction: row-reverse;
  }
}
.align-left {
  justify-content: flex-start;
}
.align-right {
  justify-content: flex-end;
}
.align-center {
  justify-content: center;
}
.align-justify {
  justify-content: space-between;
}
.align-spaced {
  justify-content: space-around;
}
.align-items-center {
  align-items: center;
}
.items-end {
  align-items: flex-end;
}
.col {
  flex: 1 0 0%;
}
.col--1 {
  flex: 0 0 8.33333333%;
  max-width: 8.33333333%;
}
.col--2 {
  flex: 0 0 16.66666667%;
  max-width: 16.66666667%;
}
.col--3 {
  flex: 0 0 25%;
  max-width: 25%;
}
.col--4 {
  flex: 0 0 33.33333333%;
  max-width: 33.33333333%;
}
.col--5 {
  flex: 0 0 41.66666667%;
  max-width: 41.66666667%;
}
.col--6 {
  flex: 0 0 50%;
  max-width: 50%;
}
.col--7 {
  flex: 0 0 58.33333333%;
  max-width: 58.33333333%;
}
.col--8 {
  flex: 0 0 66.66666667%;
  max-width: 66.66666667%;
}
.col--9 {
  flex: 0 0 75%;
  max-width: 75%;
}
.col--10 {
  flex: 0 0 83.33333333%;
  max-width: 83.33333333%;
}
.col--11 {
  flex: 0 0 91.66666667%;
  max-width: 91.66666667%;
}
.col--12 {
  flex: 0 0 100%;
  max-width: 100%;
}
@media only screen and (min-width: 36em) {
  .col--sm-1 {
    flex: 0 0 8.33333333%;
    max-width: 8.33333333%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-2 {
    flex: 0 0 16.66666667%;
    max-width: 16.66666667%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-5 {
    flex: 0 0 41.66666667%;
    max-width: 41.66666667%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-7 {
    flex: 0 0 58.33333333%;
    max-width: 58.33333333%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-8 {
    flex: 0 0 66.66666667%;
    max-width: 66.66666667%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-10 {
    flex: 0 0 83.33333333%;
    max-width: 83.33333333%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-11 {
    flex: 0 0 91.66666667%;
    max-width: 91.66666667%;
  }
}
@media only screen and (min-width: 36em) {
  .col--sm-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-1 {
    flex: 0 0 8.33333333%;
    max-width: 8.33333333%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-2 {
    flex: 0 0 16.66666667%;
    max-width: 16.66666667%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-5 {
    flex: 0 0 41.66666667%;
    max-width: 41.66666667%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-7 {
    flex: 0 0 58.33333333%;
    max-width: 58.33333333%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-8 {
    flex: 0 0 66.66666667%;
    max-width: 66.66666667%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-10 {
    flex: 0 0 83.33333333%;
    max-width: 83.33333333%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-11 {
    flex: 0 0 91.66666667%;
    max-width: 91.66666667%;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-1 {
    flex: 0 0 8.33333333%;
    max-width: 8.33333333%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-2 {
    flex: 0 0 16.66666667%;
    max-width: 16.66666667%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-5 {
    flex: 0 0 41.66666667%;
    max-width: 41.66666667%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-7 {
    flex: 0 0 58.33333333%;
    max-width: 58.33333333%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-8 {
    flex: 0 0 66.66666667%;
    max-width: 66.66666667%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-10 {
    flex: 0 0 83.33333333%;
    max-width: 83.33333333%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-11 {
    flex: 0 0 91.66666667%;
    max-width: 91.66666667%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media only screen and (min-width: 67.5em) {
  .col--lg-hide {
    display: none;
  }
}
@media only screen and (min-width: 50.625em) {
  .col--md-hide {
    display: none;
  }
}
.grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
}
@media only screen and (min-width: 36em) {
  .grid {
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .grid {
    grid-gap: 3rem;
  }
}
@media only screen and (min-width: 67.5em) {
  .grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
/* ==========================================================================
 * Layout Header
 * ========================================================================== */
.header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: var(--z-navigation);
  border: 0;
  background-color: var(--nav-bgcolor);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);
}
@media only screen and (min-width: 67.5em) {
  .header {
    position: absolute;
    box-shadow: none;
  }
}
@media only screen and (min-width: 67.5em) {
  .header--lined {
    border-bottom: 1px solid var(--color-text);
  }
}
.header--colored {
  box-shadow: none;
}
.header--home {
  background-color: var(--color-bg);
  border-color: var(--color-black);
}
@media only screen and (min-width: 67.5em) {
  .header--home {
    background-color: transparent;
    border-color: var(--color-home);
  }
}
.header--home .nav--primary > ul > li.nav__item::after {
  border-top: 6px solid var(--color-home);
}
.header--home .nav--primary > ul > li.nav__item > a {
  color: white;
}
@media only screen and (min-width: 50.625em) {
  .header--home .nav--primary > ul > li.nav__item > a {
    color: var(--color-home);
  }
}
.header--home .nav--primary > ul > li.nav__item > a:hover {
  border-color: var(--color-home);
}
.header--home .nav--primary > ul > li.nav__item > a:focus-visible {
  outline-color: var(--color-home);
}
.header--home .link-site {
  border-color: var(--color-text);
  color: var(--color-text);
}
@media only screen and (min-width: 67.5em) {
  .header--home .link-site {
    color: var(--color-home);
  }
}
.header--home .link-site:focus-visible {
  outline-color: var(--color-home);
}
.header--home .link-site span {
  border-color: var(--color-text);
}
@media only screen and (min-width: 50.625em) {
  .header--home .link-site span {
    border-color: var(--color-home);
  }
}
.header.is-sticky {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  background-color: var(--color-bg);
  box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.25);
  z-index: var(--z-navigation);
  transform: translateY(-100%);
  animation: headerSlideIn 250ms ease-in-out 150ms 1 forwards;
}
.header.is-sticky .nav--primary > ul > li.nav__item::after {
  border-top: 6px solid var(--color-text);
}
.header.is-sticky .nav--primary > ul > li.nav__item > a {
  color: var(--color-text);
}
.header.is-sticky .nav--primary > ul > li.nav__item > a:hover {
  border-color: var(--color-text);
}
.header.is-sticky .link-site {
  color: var(--color-text);
}
.header.is-sticky .link-site span {
  border-color: var(--color-black);
}
@keyframes headerSlideIn {
  from {
    transform: translateY(-100%);
  }
  to {
    transform: translateY(0%);
  }
}
/* ==========================================================================
 * Layout Hero
 * ========================================================================== */
.hero {
  position: relative;
  margin-top: 56px;
  padding: 2.25rem 0 4.5rem;
}
@media only screen and (min-width: 67.5em) {
  .hero {
    margin-top: 0;
    padding: 9rem 0 6rem;
  }
}
.hero .hero__text {
  width: 100%;
  max-width: 1080px;
  margin-inline: auto;
  text-align: center;
}
.hero .hero__text p {
  margin: 0;
  font-size: 1.96875rem;
  font-size: clamp(1.5rem, 1.40625rem + 0.46875vw, 1.96875rem);
}
.hero .hero__title {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}
@media only screen and (min-width: 50.625em) {
  .hero .hero__title {
    top: 45%;
  }
}
.hero .hero__headline {
  margin: 0;
  color: var(--color-home);
}
.hero .hero__subline {
  margin: 0;
  color: var(--color-home);
}
.hero--home {
  height: calc(var(--height-home) - 56px);
}
@media only screen and (min-width: 67.5em) {
  .hero--home {
    height: var(--height-home);
  }
}
.hero--home .bgimage--desktop {
  display: none;
}
@media only screen and (min-width: 50.625em) {
  .hero--home .bgimage--desktop {
    display: block;
  }
}
@media only screen and (min-width: 50.625em) {
  .hero--home .bgimage--mobile {
    display: none;
  }
}
.hero--small {
  padding-bottom: 0;
}
.hero--work h1 {
  margin-bottom: 0.75rem;
}
/* ==========================================================================
 * Layout Article
 * ========================================================================== */
.article {
  position: relative;
  margin-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .article {
    margin-bottom: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .article {
    margin-bottom: 3rem;
  }
}
.article .article__image {
  max-width: 760px;
}
.article .article__end {
  display: block;
  width: 50px;
  height: 4px;
  margin: 1.5rem auto;
  background-color: var(--color-text);
}
.article .article__time {
  position: relative;
  margin: 0 auto 2.25rem;
  text-align: center;
}
.article .tags {
  width: 100%;
  max-width: 760px;
  margin-inline: auto;
  text-align: center;
}
.article-teaser {
  position: relative;
  width: 100%;
  max-width: 760px;
  margin-inline: auto;
  margin-bottom: 3rem;
}
.article-teaser:last-of-type {
  margin-bottom: 0;
}
.article-teaser h2 {
  margin-bottom: 0.5rem;
  line-height: 1em;
}
.article-teaser p {
  margin-bottom: 0.5rem;
}
.article-teaser a {
  color: var(--color-text);
  text-decoration: none;
}
.article-teaser a:hover {
  text-decoration: underline;
}
.article-teaser a:focus-visible {
  text-decoration: underline;
  outline-color: var(--color-text);
}
.article-teaser a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}
.article-teaser .badge {
  margin-bottom: 0.5rem;
}
/* ==========================================================================
 * Layout Section
 * ========================================================================== */
.section {
  position: relative;
  margin-bottom: 3rem;
}
@media only screen and (min-width: 36em) {
  .section {
    margin-bottom: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .section {
    margin-bottom: 6rem;
  }
}
/* ==========================================================================
 * Layout Footer
 * ========================================================================== */
.footer {
  position: relative;
  margin: 2.25rem 0;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
  text-align: center;
}
@media only screen and (min-width: 36em) {
  .footer {
    text-align: left;
  }
}
/* ==========================================================================
 * Component Button
   ========================================================================== */
button {
  padding: 0;
  border: 0;
  background-color: transparent;
  cursor: pointer;
}
.btn {
  position: relative;
  display: inline-block;
  margin: 0.25em 0;
  padding: 0.75rem 1.5rem;
  background-color: var(--color-link);
  border: 2px solid transparent;
  color: #FFF;
  font-family: var(--font-sans-serif);
  font-size: 14px;
  font-size: 0.875rem;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  vertical-align: middle;
  letter-spacing: 1px;
  cursor: pointer;
  appearance: none;
}
.btn:hover {
  background-color: transparent;
  border-color: var(--color-link);
  color: var(--color-text);
}
.btn--outline {
  background-color: transparent;
  border-color: var(--color-link);
  color: var(--color-text);
}
.btn--outline:hover {
  background-color: oklch(from var(--color-link) 75% c h);
}
.btn--rounded {
  border-radius: 32px;
}
.btn--large {
  padding: 1rem 2.5rem;
  font-size: 16px;
  font-size: 1rem;
}
.btn--small {
  padding: 0.5rem 1.25rem;
  font-size: 12px;
  font-size: 0.75rem;
}
.btn-menu {
  display: block;
  position: relative;
  width: 32px;
  height: 32px;
  color: var(--nav-color);
}
@media only screen and (min-width: 67.5em) {
  .btn-menu {
    display: none;
  }
}
.btn-menu--close {
  color: white;
}
.btn-play {
  position: relative;
  width: 96px;
  height: 96px;
  background-color: white;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  color: var(--color-link);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.35);
}
.btn-play svg.icon--play {
  left: 55%;
}
/* ==========================================================================
 * Component Navigation
 * ========================================================================== */
.nav-container {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
@media only screen and (min-width: 67.5em) {
  .nav-container {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}
.nav {
  position: relative;
}
.nav > ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.nav--primary > ul {
  display: none;
  text-align: right;
}
@media only screen and (min-width: 67.5em) {
  .nav--primary > ul {
    display: block;
  }
}
.nav--primary > ul > li.nav__item {
  display: inline-block;
  margin: 0 0 0 1.875rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.nav--primary > ul > li.nav__item.is-active > a {
  font-family: var(--font-bold);
}
.nav--primary > ul > li.nav__item > a {
  display: inline-block;
  color: var(--nav-color);
  font-size: 1.6875rem;
  font-size: clamp(1.3125rem, 1.2375rem + 0.375vw, 1.6875rem);
  line-height: 1em;
  text-decoration: none;
  border-bottom: 2px solid transparent;
}
.nav--primary > ul > li.nav__item > a:hover {
  border-color: var(--nav-color);
}
.nav--primary > ul > li.nav__item > a:focus-visible {
  border-color: transparent;
  outline-color: var(--color-text);
}
.nav--pills {
  margin-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .nav--pills {
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .nav--pills {
    margin-bottom: 4.5rem;
  }
}
.nav--pills ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.nav--pills ul li {
  display: inline-block;
  margin: 0 0.25rem 0.5rem 0;
}
@media only screen and (min-width: 36em) {
  .nav--pills ul li {
    margin: 0 0.5rem 0.5rem 0;
  }
}
.nav--pills ul li.is-active a {
  background-color: var(--color-text);
  color: white;
}
.nav--pills ul a {
  padding: 2px 12px 3px;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  text-decoration: none;
}
.nav--pills ul a:hover {
  background-color: var(--color-text);
  color: white;
}
.nav--pills ul a:focus-visible {
  outline-color: var(--color-text);
  background-color: var(--color-text);
  color: white;
}
.nav--pagination {
  margin-bottom: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .nav--pagination {
    margin-bottom: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .nav--pagination {
    margin-bottom: 7.5rem;
  }
}
.nav--pagination a {
  padding: 2px 12px;
  border: 1px solid var(--color-black);
  text-decoration: none;
  color: var(--color-text);
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
}
.nav--pagination a:hover,
.nav--pagination a:focus {
  background-color: var(--color-black);
  color: white;
}
.nav--pagination .prev-page {
  text-align: right;
}
.nav--footer {
  text-align: center;
}
@media only screen and (min-width: 36em) {
  .nav--footer {
    text-align: right;
  }
}
.nav--footer a {
  color: var(--color-text);
  text-decoration: none;
}
.nav--footer a:focus-visible {
  outline-color: var(--color-text);
}
.menu {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  z-index: var(--z-modal);
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}
.menu .menu__title {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  padding: 0.75rem 1.5rem;
}
.menu .menu__nav {
  padding: 60px 1.5rem 0;
}
.menu .menu__nav > ul > li.nav__item {
  display: block;
  margin: 0;
}
.menu .menu__nav > ul > li.nav__item.is-active > a {
  text-decoration: underline;
}
.menu .menu__nav > ul > li.nav__item > a {
  color: white;
  text-decoration: none;
}
.menu .menu__nav > ul > li.nav__item--child {
  margin-left: 1rem;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
.menu .menu__meta {
  position: absolute;
  left: 1.5rem;
  bottom: 1.5rem;
}
.menu .menu__meta > ul > li {
  display: block;
  margin: 0;
}
.menu .menu__meta > ul > li > a {
  color: white;
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
  text-decoration: none;
}
.menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.menu .link-site {
  color: white;
}
.menu .link-site span {
  position: relative;
  top: 4px;
  border-color: var(--color-white);
}
.breadcrumb {
  margin-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .breadcrumb {
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .breadcrumb {
    margin-bottom: 1.5rem;
  }
}
.breadcrumb ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.breadcrumb ul li {
  position: relative;
  display: inline-block;
  margin-right: 6px;
  padding-left: 12px;
}
.breadcrumb ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 55%;
  width: 0px;
  height: 0px;
  transform: translateY(-50%);
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 5px solid var(--color-text);
}
.breadcrumb ul li a {
  color: var(--color-text);
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
  text-decoration: none;
}
/* ==========================================================================
 * Component Dropdown
 * ========================================================================== */
.dropdown {
  position: relative;
  padding-right: 0.5rem;
}
.dropdown:hover .dropdown__menu,
.dropdown:focus-within .dropdown__menu {
  opacity: 1;
  visibility: visible;
}
.dropdown::after {
  content: "";
  position: absolute;
  right: -10px;
  top: 55%;
  width: 0px;
  height: 0px;
  transform: translateY(-50%);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid var(--nav-color);
}
.dropdown .dropdown__menu {
  position: absolute;
  left: 50%;
  top: 100%;
  min-width: 240px;
  transform: translateX(-50%);
  margin: 0;
  padding: 1.25rem 0.5rem;
  list-style: none;
  background-color: var(--color-bg);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.25);
  opacity: 0;
  visibility: hidden;
  text-align: center;
  z-index: var(--z-dropdown);
}
.dropdown .dropdown__menu::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -8px;
  width: 0px;
  height: 0px;
  transform: translateX(-50%);
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid var(--color-bg);
}
.dropdown .dropdown__menu.is-open {
  opacity: 1;
  visibility: visible;
}
.dropdown .dropdown__menu > li {
  margin-bottom: 0.5rem;
  line-height: 1.75rem;
}
.dropdown .dropdown__menu > li:last-child {
  margin-bottom: 0;
}
.dropdown .dropdown__menu > li.is-active > a {
  font-style: italic;
}
.dropdown .dropdown__menu > li > a {
  color: var(--color-text);
  text-decoration: none;
  line-height: 1.25rem;
}
.dropdown .dropdown__menu > li > a:hover,
.dropdown .dropdown__menu > li > a:focus {
  font-style: italic;
}
.dropdown .dropdown__menu > li > a:focus-visible {
  outline-color: var(--color-text);
}
/* ==========================================================================
 * Component Gallery
 * ========================================================================== */
.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  grid-gap: 3rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.gallery .gallery__item {
  margin: 0;
}
.gallery .gallery__item a {
  display: block;
  outline-offset: 2px;
  text-decoration: none;
  transition: 300ms ease-in-out;
}
.gallery .gallery__item img {
  object-fit: cover;
}
/* ==========================================================================
 * Helpers Spacing
   ========================================================================== */
.mt-1 {
  margin-top: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .mt-1 {
    margin-top: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-1 {
    margin-top: 1.5rem;
  }
}
.mt-2 {
  margin-top: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .mt-2 {
    margin-top: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-2 {
    margin-top: 3rem;
  }
}
.mt-3 {
  margin-top: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .mt-3 {
    margin-top: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-3 {
    margin-top: 4.5rem;
  }
}
.mt-4 {
  margin-top: 3rem;
}
@media only screen and (min-width: 36em) {
  .mt-4 {
    margin-top: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-4 {
    margin-top: 6rem;
  }
}
.mt-5 {
  margin-top: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .mt-5 {
    margin-top: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-5 {
    margin-top: 7.5rem;
  }
}
.mt-6 {
  margin-top: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .mt-6 {
    margin-top: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-6 {
    margin-top: 9rem;
  }
}
.mt-7 {
  margin-top: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .mt-7 {
    margin-top: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-7 {
    margin-top: 10.5rem;
  }
}
.mt-8 {
  margin-top: 6rem;
}
@media only screen and (min-width: 36em) {
  .mt-8 {
    margin-top: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-8 {
    margin-top: 12rem;
  }
}
.mt-9 {
  margin-top: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .mt-9 {
    margin-top: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-9 {
    margin-top: 13.5rem;
  }
}
.mt-10 {
  margin-top: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .mt-10 {
    margin-top: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mt-10 {
    margin-top: 15rem;
  }
}
.mb-1 {
  margin-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .mb-1 {
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-1 {
    margin-bottom: 1.5rem;
  }
}
.mb-2 {
  margin-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .mb-2 {
    margin-bottom: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-2 {
    margin-bottom: 3rem;
  }
}
.mb-3 {
  margin-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .mb-3 {
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-3 {
    margin-bottom: 4.5rem;
  }
}
.mb-4 {
  margin-bottom: 3rem;
}
@media only screen and (min-width: 36em) {
  .mb-4 {
    margin-bottom: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-4 {
    margin-bottom: 6rem;
  }
}
.mb-5 {
  margin-bottom: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .mb-5 {
    margin-bottom: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-5 {
    margin-bottom: 7.5rem;
  }
}
.mb-6 {
  margin-bottom: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .mb-6 {
    margin-bottom: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-6 {
    margin-bottom: 9rem;
  }
}
.mb-7 {
  margin-bottom: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .mb-7 {
    margin-bottom: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-7 {
    margin-bottom: 10.5rem;
  }
}
.mb-8 {
  margin-bottom: 6rem;
}
@media only screen and (min-width: 36em) {
  .mb-8 {
    margin-bottom: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-8 {
    margin-bottom: 12rem;
  }
}
.mb-9 {
  margin-bottom: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .mb-9 {
    margin-bottom: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-9 {
    margin-bottom: 13.5rem;
  }
}
.mb-10 {
  margin-bottom: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .mb-10 {
    margin-bottom: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .mb-10 {
    margin-bottom: 15rem;
  }
}
.pt-1 {
  padding-top: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .pt-1 {
    padding-top: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-1 {
    padding-top: 1.5rem;
  }
}
.pt-2 {
  padding-top: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .pt-2 {
    padding-top: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-2 {
    padding-top: 3rem;
  }
}
.pt-3 {
  padding-top: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .pt-3 {
    padding-top: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-3 {
    padding-top: 4.5rem;
  }
}
.pt-4 {
  padding-top: 3rem;
}
@media only screen and (min-width: 36em) {
  .pt-4 {
    padding-top: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-4 {
    padding-top: 6rem;
  }
}
.pt-5 {
  padding-top: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .pt-5 {
    padding-top: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-5 {
    padding-top: 7.5rem;
  }
}
.pt-6 {
  padding-top: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .pt-6 {
    padding-top: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-6 {
    padding-top: 9rem;
  }
}
.pt-7 {
  padding-top: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .pt-7 {
    padding-top: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-7 {
    padding-top: 10.5rem;
  }
}
.pt-8 {
  padding-top: 6rem;
}
@media only screen and (min-width: 36em) {
  .pt-8 {
    padding-top: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-8 {
    padding-top: 12rem;
  }
}
.pt-9 {
  padding-top: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .pt-9 {
    padding-top: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-9 {
    padding-top: 13.5rem;
  }
}
.pt-10 {
  padding-top: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .pt-10 {
    padding-top: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pt-10 {
    padding-top: 15rem;
  }
}
.pb-1 {
  padding-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .pb-1 {
    padding-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-1 {
    padding-bottom: 1.5rem;
  }
}
.pb-2 {
  padding-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .pb-2 {
    padding-bottom: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-2 {
    padding-bottom: 3rem;
  }
}
.pb-3 {
  padding-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .pb-3 {
    padding-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-3 {
    padding-bottom: 4.5rem;
  }
}
.pb-4 {
  padding-bottom: 3rem;
}
@media only screen and (min-width: 36em) {
  .pb-4 {
    padding-bottom: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-4 {
    padding-bottom: 6rem;
  }
}
.pb-5 {
  padding-bottom: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .pb-5 {
    padding-bottom: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-5 {
    padding-bottom: 7.5rem;
  }
}
.pb-6 {
  padding-bottom: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .pb-6 {
    padding-bottom: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-6 {
    padding-bottom: 9rem;
  }
}
.pb-7 {
  padding-bottom: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .pb-7 {
    padding-bottom: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-7 {
    padding-bottom: 10.5rem;
  }
}
.pb-8 {
  padding-bottom: 6rem;
}
@media only screen and (min-width: 36em) {
  .pb-8 {
    padding-bottom: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-8 {
    padding-bottom: 12rem;
  }
}
.pb-9 {
  padding-bottom: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .pb-9 {
    padding-bottom: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-9 {
    padding-bottom: 13.5rem;
  }
}
.pb-10 {
  padding-bottom: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .pb-10 {
    padding-bottom: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pb-10 {
    padding-bottom: 15rem;
  }
}
.pr-1 {
  padding-right: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .pr-1 {
    padding-right: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-1 {
    padding-right: 1.5rem;
  }
}
.pr-2 {
  padding-right: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .pr-2 {
    padding-right: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-2 {
    padding-right: 3rem;
  }
}
.pr-3 {
  padding-right: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .pr-3 {
    padding-right: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-3 {
    padding-right: 4.5rem;
  }
}
.pr-4 {
  padding-right: 3rem;
}
@media only screen and (min-width: 36em) {
  .pr-4 {
    padding-right: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-4 {
    padding-right: 6rem;
  }
}
.pr-5 {
  padding-right: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .pr-5 {
    padding-right: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-5 {
    padding-right: 7.5rem;
  }
}
.pr-6 {
  padding-right: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .pr-6 {
    padding-right: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-6 {
    padding-right: 9rem;
  }
}
.pr-7 {
  padding-right: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .pr-7 {
    padding-right: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-7 {
    padding-right: 10.5rem;
  }
}
.pr-8 {
  padding-right: 6rem;
}
@media only screen and (min-width: 36em) {
  .pr-8 {
    padding-right: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-8 {
    padding-right: 12rem;
  }
}
.pr-9 {
  padding-right: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .pr-9 {
    padding-right: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-9 {
    padding-right: 13.5rem;
  }
}
.pr-10 {
  padding-right: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .pr-10 {
    padding-right: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pr-10 {
    padding-right: 15rem;
  }
}
.pl-1 {
  padding-left: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .pl-1 {
    padding-left: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-1 {
    padding-left: 1.5rem;
  }
}
.pl-2 {
  padding-left: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .pl-2 {
    padding-left: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-2 {
    padding-left: 3rem;
  }
}
.pl-3 {
  padding-left: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .pl-3 {
    padding-left: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-3 {
    padding-left: 4.5rem;
  }
}
.pl-4 {
  padding-left: 3rem;
}
@media only screen and (min-width: 36em) {
  .pl-4 {
    padding-left: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-4 {
    padding-left: 6rem;
  }
}
.pl-5 {
  padding-left: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .pl-5 {
    padding-left: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-5 {
    padding-left: 7.5rem;
  }
}
.pl-6 {
  padding-left: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .pl-6 {
    padding-left: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-6 {
    padding-left: 9rem;
  }
}
.pl-7 {
  padding-left: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .pl-7 {
    padding-left: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-7 {
    padding-left: 10.5rem;
  }
}
.pl-8 {
  padding-left: 6rem;
}
@media only screen and (min-width: 36em) {
  .pl-8 {
    padding-left: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-8 {
    padding-left: 12rem;
  }
}
.pl-9 {
  padding-left: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .pl-9 {
    padding-left: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-9 {
    padding-left: 13.5rem;
  }
}
.pl-10 {
  padding-left: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .pl-10 {
    padding-left: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .pl-10 {
    padding-left: 15rem;
  }
}
.my-1 {
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
}
@media only screen and (min-width: 36em) {
  .my-1 {
    margin-top: 1.125rem;
    margin-bottom: 1.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-1 {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
  }
}
.my-2 {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .my-2 {
    margin-top: 2.25rem;
    margin-bottom: 2.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-2 {
    margin-top: 3rem;
    margin-bottom: 3rem;
  }
}
.my-3 {
  margin-top: 2.25rem;
  margin-bottom: 2.25rem;
}
@media only screen and (min-width: 36em) {
  .my-3 {
    margin-top: 3.375rem;
    margin-bottom: 3.375rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-3 {
    margin-top: 4.5rem;
    margin-bottom: 4.5rem;
  }
}
.my-4 {
  margin-top: 3rem;
  margin-bottom: 3rem;
}
@media only screen and (min-width: 36em) {
  .my-4 {
    margin-top: 4.5rem;
    margin-bottom: 4.5rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-4 {
    margin-top: 6rem;
    margin-bottom: 6rem;
  }
}
.my-5 {
  margin-top: 3.75rem;
  margin-bottom: 3.75rem;
}
@media only screen and (min-width: 36em) {
  .my-5 {
    margin-top: 5.625rem;
    margin-bottom: 5.625rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-5 {
    margin-top: 7.5rem;
    margin-bottom: 7.5rem;
  }
}
.my-6 {
  margin-top: 4.5rem;
  margin-bottom: 4.5rem;
}
@media only screen and (min-width: 36em) {
  .my-6 {
    margin-top: 6.75rem;
    margin-bottom: 6.75rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-6 {
    margin-top: 9rem;
    margin-bottom: 9rem;
  }
}
.my-7 {
  margin-top: 5.25rem;
  margin-bottom: 5.25rem;
}
@media only screen and (min-width: 36em) {
  .my-7 {
    margin-top: 7.875rem;
    margin-bottom: 7.875rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-7 {
    margin-top: 10.5rem;
    margin-bottom: 10.5rem;
  }
}
.my-8 {
  margin-top: 6rem;
  margin-bottom: 6rem;
}
@media only screen and (min-width: 36em) {
  .my-8 {
    margin-top: 9rem;
    margin-bottom: 9rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-8 {
    margin-top: 12rem;
    margin-bottom: 12rem;
  }
}
.my-9 {
  margin-top: 6.75rem;
  margin-bottom: 6.75rem;
}
@media only screen and (min-width: 36em) {
  .my-9 {
    margin-top: 10.125rem;
    margin-bottom: 10.125rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-9 {
    margin-top: 13.5rem;
    margin-bottom: 13.5rem;
  }
}
.my-10 {
  margin-top: 7.5rem;
  margin-bottom: 7.5rem;
}
@media only screen and (min-width: 36em) {
  .my-10 {
    margin-top: 11.25rem;
    margin-bottom: 11.25rem;
  }
}
@media only screen and (min-width: 50.625em) {
  .my-10 {
    margin-top: 15rem;
    margin-bottom: 15rem;
  }
}
.no-padding {
  padding: 0!important;
}
.no-margin {
  margin: 0!important;
}
/* ==========================================================================
 * Helpers Helpers
   ========================================================================== */
.container {
  position: relative;
  width: 100%;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
@media only screen and (min-width: 36em) {
  .container {
    padding-left: 5%;
    padding-right: 5%;
  }
}
.maintenance {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: white;
  z-index: var(--z-modal);
}
.maintenance .is-centered {
  width: 90%;
  max-width: 760px;
}
.maintenance p {
  margin: 0 auto;
  font-size: 1.96875rem;
  font-size: clamp(1.5rem, 1.40625rem + 0.46875vw, 1.96875rem);
}
.maintenance-badge {
  position: fixed;
  right: 0;
  bottom: 0;
  padding: 1px 10px;
  background-color: red;
  color: white;
  font-size: 16px;
  font-size: 1rem;
  z-index: var(--z-modal);
}
.visually-hidden:not(:focus):not(:active) {
  position: absolute;
  height: 1px;
  width: 1px;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  overflow: hidden;
  white-space: nowrap;
}
hr {
  margin: 3rem 0;
  height: 1px;
  background-color: var(--color-black);
  border: 0;
}
.is-endless {
  max-width: 100%!important;
}
.is-centered {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.is-fullscreen {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.is-hidden {
  display: none;
}
.is-invisible {
  opacity: 0;
}
.is-disabled {
  opacity: 0.35;
}
.is-clickable {
  cursor: pointer;
}
.is-canceled {
  text-decoration: line-through;
}
.has-shadow {
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.35);
}
.has-border {
  border: 1px solid var(--color-black);
}
.text-align-left {
  text-align: left;
}
.text-align-center {
  text-align: center;
}
.text-align-right {
  text-align: right;
}
.no-overflow {
  overflow: hidden;
}
@media only screen and (min-width: 36em) {
  .hide-sm {
    display: none;
  }
}
@media only screen and (min-width: 50.625em) {
  .hide-md {
    display: none;
  }
}
@media only screen and (min-width: 67.5em) {
  .hide-lg {
    display: none;
  }
}
.show-sm {
  display: none;
}
@media only screen and (min-width: 36em) {
  .show-sm {
    display: inline-block;
  }
}
.show-md {
  display: none;
}
@media only screen and (min-width: 50.625em) {
  .show-md {
    display: inline-block;
  }
}
/* ==========================================================================
 * Helpers Fallbacks
   ========================================================================== */
/* ==========================================================================
 * Template Yates
   ========================================================================== */
@font-face {
  font-family: 'EB Garamond Regular';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local(''), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-regular.woff2') format('woff2'), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-regular.woff') format('woff');
}
@font-face {
  font-family: 'EB Garamond Medium';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local(''), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-500.woff2') format('woff2'), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-500.woff') format('woff');
}
@font-face {
  font-family: 'EB Garamond Semibold';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local(''), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-600.woff2') format('woff2'), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-600.woff') format('woff');
}
@font-face {
  font-family: 'EB Garamond Bold';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: local(''), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-700.woff2') format('woff2'), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-700.woff') format('woff');
}
@font-face {
  font-family: 'EB Garamond Italic';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: local(''), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-italic.woff2') format('woff2'), url('../fonts/eb-garamond/eb-garamond-v24-latin-ext-italic.woff') format('woff');
}
:root {
  --font-regular: 'EB Garamond Regular', Georgia, serif;
  --font-medium: 'EB Garamond Medium', Georgia, serif;
  --font-semibold: 'EB Garamond Semibold', Georgia, serif;
  --font-bold: 'EB Garamond Bold', Georgia, serif;
  --font-italic: 'EB Garamond Italic', Georgia, serif;
}
h1,
.h1 {
  margin-bottom: 0;
  font-size: 6.625rem;
  font-size: clamp(2.53125rem, 1.7125rem + 4.09375vw, 6.625rem);
  line-height: 1em;
}
h2,
.h2 {
  margin-bottom: 1.25rem;
  font-size: 3.375rem;
  font-size: clamp(1.96875rem, 1.6875rem + 1.40625vw, 3.375rem);
  line-height: calc(2px + 2ex + 2px);
}
h3,
.h3 {
  margin-bottom: 1rem;
  font-size: 2.9375rem;
  font-size: clamp(1.6875rem, 1.4375rem + 1.25vw, 2.9375rem);
  line-height: calc(2px + 2ex + 2px);
}
h4,
.h4 {
  margin-bottom: 0.75rem;
  font-size: 2.25rem;
  font-size: clamp(1.5rem, 1.35rem + 0.75vw, 2.25rem);
  line-height: calc(2px + 2ex + 2px);
}
.fontsize-small {
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
}
.fontsize-default {
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
.fontsize-nav {
  font-size: 1.6875rem;
  font-size: clamp(1.3125rem, 1.2375rem + 0.375vw, 1.6875rem);
}
.fontsize-large {
  font-size: 1.96875rem;
  font-size: clamp(1.5rem, 1.40625rem + 0.46875vw, 1.96875rem);
}
.hero__headline {
  font-size: 6.625rem;
  font-size: clamp(2.9375rem, 2.2rem + 3.6875vw, 6.625rem);
  font-family: var(--font-semibold);
}
.hero__subline {
  font-size: 5.6875rem;
  font-size: clamp(2.9375rem, 2.3875rem + 2.75vw, 5.6875rem);
  line-height: 0.9em;
}
p {
  margin-bottom: 1.25rem;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
  line-height: 1.4em;
}
blockquote p {
  margin: 0;
  line-height: 1.15em;
  font-size: 1.96875rem;
  font-size: clamp(1.5rem, 1.40625rem + 0.46875vw, 1.96875rem);
  font-family: var(--font-medium);
}
ul li,
ol li {
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
dl dd {
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}
ul.tags a {
  font-size: 1.25rem;
  font-size: clamp(1.125rem, 1.1rem + 0.125vw, 1.25rem);
}
.list--dates time {
  font-size: 5.0625rem;
  font-size: clamp(2.25rem, 1.6875rem + 2.8125vw, 5.0625rem);
  line-height: 0.9em;
}
@media only screen and (min-width: 50.625em) {
  .list--dates time {
    letter-spacing: -0.05em;
  }
}
.label {
  font-size: 1.9375rem;
  font-size: clamp(1.3125rem, 1.1875rem + 0.625vw, 1.9375rem);
  line-height: calc(1ex / 0.38);
}
.articles__download-size {
  font-size: 14px;
  font-size: 0.875rem;
}
.menu .menu__nav > ul > li.nav__item > a {
  font-size: 5.0625rem;
  font-size: clamp(2.25rem, 1.6875rem + 2.8125vw, 5.0625rem);
}
.menu .menu__nav > ul > li.nav__item--child > a {
  font-size: 3.375rem;
  font-size: clamp(1.9375rem, 1.65rem + 1.4375vw, 3.375rem);
}
