:root {
  --black: rgb(0, 0, 0);
  --black-60: rgba(0, 0, 0, .6);
  --white: rgb(255, 255, 255);
  --gray: #d2d2d2;
  --margin: 10px;
}

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

.nav-sub swiper-slide {
  width: auto;
}

.locations,
.contacts {
  margin: 70px 0 0;
}

html {
  box-sizing: border-box;
}

/**
 * Make all elements from the DOM inherit from the parent box-sizing
 * Since `*` has a specificity of 0, it does not override the `html` value
 * making all elements inheriting from the root box-sizing value
 * See: https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/
 */
*,
*::before,
*::after {
  box-sizing: inherit;
}

h1,
h2,
h3,
h4,
h5 {
  font-weight: 400;
  margin: 0;
}

p {
  margin: 0 0 1.4em;
}

p:last-child {
  margin-bottom: 0;
}

.site-footer h4 {
  margin: 0 0 2em;
  text-transform: uppercase;
}

.subtitle {
  font-weight: 700;
}

/**
 * Clear inner floats
 */
.clearfix::after {
  clear: both;
  content: "";
  display: table;
}

/**
 * Hide text while making it readable for screen readers
 * 1. Needed in WebKit-based browsers because of an implementation bug;
 *    See: https://code.google.com/p/chromium/issues/detail?id=457146
 */
.hide-text {
  overflow: hidden;
  padding: 0; /* 1 */
  text-indent: 101%;
  white-space: nowrap;
}

/**
 * Hide element while making it readable for screen readers
 * Shamelessly borrowed from HTML5Boilerplate:
 * https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css#L119-L133
 */
.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.site-header {
  display: flex;
  position: fixed;
  inset: 0 0 auto;
  z-index: 400;
  padding: 12px 10px;
}

.site-header .site-branding {
  margin: 0 auto;
}

.admin-bar .site-header {
  top: 32px;
}

.menu-main-container {
  position: absolute;
  inset: 50% auto auto var(--margin);
  transform: translateY(-50%);
  color: var(--white);
  text-transform: uppercase;
}

.menu-main-container .menu {
  margin: 0;
  padding: 0;
  list-style: none;
}

.menu-main-container .menu a {
  text-decoration: none;
}

.menu-main-container .menu a::before {
  content: "[ ";
}

.menu-main-container .menu a::after {
  content: " ]";
}

.site-logo {
  position: fixed;
  inset: 50% auto auto 50%;
  z-index: 10;
  transform: translate(-50%, -50%);
  pointer-events: none;
  transition: opacity 0.4s;
}

.site-logo.hidden, body:has(#overlay) .site-logo {
  opacity: 0;
}

.site-footer {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-gap: var(--margin);
  padding: 20vw var(--margin);
  background: var(--wp--preset--color--gray) url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjE3OCIgdmlld0JveD0iMCAwIDUwMCAxNzgiIHdpZHRoPSI1MDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0ibTAgMTc0LjRoMy41di0yNi4yaC0zLjV2LTMuMWgxMy43djMuMWgtMy41djEwaDE3LjF2LTEwaC0zLjV2LTMuMWgxMy43djMuMWgtMy41djI2LjJoMy41djMuMWgtMTMuNnYtMy4xaDMuNXYtMTIuOWgtMTcuMXYxMi45aDMuNXYzLjFoLTEzLjh6bTQxLjMtMTNjMC0xMC43IDcuNi0xNi43IDE3LjQtMTYuN3MxNy4zIDYgMTcuMyAxNi43LTcuNyAxNi42LTE3LjMgMTYuNi0xNy40LTYtMTcuNC0xNi42em0xNy40IDEzLjVjNS40IDAgOS45LTMuNyA5LjktMTMuNnMtNC41LTEzLjYtOS45LTEzLjYtOS45IDMuNy05LjkgMTMuNiA0LjQgMTMuNiA5LjkgMTMuNnptMzAuMi0uNWgzLjd2LTI2LjNoLTIuN2MtNC4xIDAtNi44IDIuOC03LjEgNy4zaC0zdi0xMC4zaDMyLjR2MTAuM2gtM2MtLjMtNC41LTMtNy4zLTcuMS03LjNoLTIuN3YyNi4zaDMuN3YzLjFoLTE0LjJ6bTI3LjMgMGgzLjV2LTI2LjJoLTMuNXYtMy4xaDMyLjh2OS42aC0zLjFjLS4zLTQuMS0yLjYtNi42LTguMi02LjZoLTExLjN2OS45aDE0LjJ2My45aC0xNC4ydjEyLjZoMTAuMWM1LjUgMCA4LjUtMS40IDkuNC03LjRoMy4xdjEwLjVoLTMyLjh6bTM3LjggMGgzLjV2LTI2LjJoLTMuNXYtMy4xaDEzLjd2My4xaC0zLjV2MjYuMmg5LjRjNC43IDAgOC0xLjQgOC44LTguMWgzdjExLjJoLTMxLjR6bTQzLjctMTIuNWMwLTEwLjcgOC42LTE2LjcgMTkuNC0xNi43aDExLjR2MTAuNmgtMy4zYy0uNy01LjUtNC03LjUtOC41LTcuNS02LjEgMC0xMS41IDMuMi0xMS41IDEyLjhzNiAxMi42IDExLjMgMTIuNmM0LjEgMCA4LTEuNiAxMC4xLTYuNGgzLjZjLTEuNyA1LjktNi44IDEwLjctMTUuMyAxMC43LTkuMiAwLTE3LjItNS4xLTE3LjItMTYuMXptMzYuMS0uNWMwLTEwLjcgNy42LTE2LjcgMTcuNC0xNi43czE3LjMgNiAxNy4zIDE2LjctNy43IDE2LjYtMTcuMyAxNi42LTE3LjQtNi0xNy40LTE2LjZ6bTE3LjQgMTMuNWM1LjQgMCA5LjktMy43IDkuOS0xMy42cy00LjUtMTMuNi05LjktMTMuNi05LjkgMy43LTkuOSAxMy42IDQuNSAxMy42IDkuOSAxMy42em0yMS0uNWgzLjV2LTI2LjJoLTMuNXYtMy4xaDExLjFsMTkuNSAyMS40aC4xdi0xOC4zaC0zLjV2LTMuMWgxMS4xdjMuMWgtMy41djI5LjNoLTRsLTIzLjItMjUuNnYyMi41aDMuNXYzLjFoLTExLjF6bTQxLjMtMTIuNWMwLTEwLjcgOC42LTE2LjcgMTkuNC0xNi43aDExLjR2MTAuNmgtMy4zYy0uNy01LjUtNC03LjUtOC41LTcuNS02LjEgMC0xMS41IDMuMi0xMS41IDEyLjhzNiAxMi42IDExLjMgMTIuNmM0LjEgMCA4LTEuNiAxMC4xLTYuNGgzLjZjLTEuNyA1LjktNi44IDEwLjctMTUuMyAxMC43LTkuMiAwLTE3LjItNS4xLTE3LjItMTYuMXptMzYuMi0uNWMwLTEwLjcgNy42LTE2LjcgMTcuNC0xNi43czE3LjMgNiAxNy4zIDE2LjctNy43IDE2LjYtMTcuMyAxNi42LTE3LjQtNi0xNy40LTE2LjZ6bTE3LjQgMTMuNWM1LjQgMCA5LjktMy43IDkuOS0xMy42cy00LjUtMTMuNi05LjktMTMuNi05LjkgMy43LTkuOSAxMy42IDQuNCAxMy42IDkuOSAxMy42em0yMC45LS41aDMuNXYtMjYuMmgtMy41di0zLjFoMTguMmM4LjMgMCAxNC43IDMuNCAxNC43IDguOCAwIDQuNy0zLjkgNy40LTExLjQgNy43bDEwLjkgMTIuOGgzLjV2My4xaC05LjdsLTE0LTE2LjNoLTJ2MTMuMmgzLjV2My4xaC0xMy43em0xNy42LTE1LjNjNS4zIDAgNy45LTEuOCA3LjktNS4zIDAtMy4zLTIuNi01LjctNy45LTUuN2gtNy41djExem0yMiAxNS4zaDMuNXYtMjYuMmgtMy41di0zLjFoMTUuOGMxMi41IDAgMjAuMyA2LjEgMjAuMyAxNi4ycy03LjggMTYuMi0yMC4xIDE2LjJoLTE2em0xNi4xIDBjOC4zIDAgMTIuNS00LjggMTIuNS0xMy4xcy00LjUtMTMuMS0xMi44LTEzLjFoLTUuNnYyNi4yem0yMy41IDBoMy41di0yNi4yaC0zLjV2LTMuMWgzMi44djkuNmgtMy4xYy0uMy00LjEtMi42LTYuNi04LjItNi42aC0xMS4zdjkuOWgxNC4ydjMuOWgtMTQuMnYxMi42aDEwLjFjNS41IDAgOC41LTEuNCA5LjQtNy40aDMuMXYxMC41aC0zMi44em0tMjIzLjgtMTE0Ljd2My4zaC0xNC4ydi0zLjJoMy43di0yMy41aC0zLjd2LTMuMWgxNC4ydjMuMWgtMy42djguOWgyMC41di04LjloLTMuNnYtMy4xaDE0LjJ2My4xaC0zLjZ2MjMuNWgzLjZ2My4yaC0xNC4ydi0zLjJoMy42di0xMS4zaC0yMC41djExLjNoMy42em02Mi45LTguNmgtMTguN2MtLjkgMjQuNi0xNi45IDQzLjEtMzYuMSA0NSAyOC43LS4xIDUzLTE5LjkgNTQuOC00NXptLTE4LjctNS4yaDE4LjhjLTEuMy0yNS41LTI1LjgtNDUuOS01NC45LTQ1LjkgMTkuNiAxLjkgMzUuNiAyMC44IDM2LjEgNDUuOXptLTc1LjMgMi4xYzAtMjUuNyAxNi4xLTQ2LjEgMzYuMS00OC0yOS45IDAtNTQuOSAyMS40LTU0LjkgNDhzMjUgNDggNTQuOSA0OGMtMTkuOS0xLjktMzYuMS0yMi4zLTM2LjEtNDh6IiBmaWxsPSJyZ2JhKDI1NSwgMjU1LCAyNTUsIDAuNikiLz48L3N2Zz4=) no-repeat center center;
  background-size: 50%;
}

.site-footer .column.span-2 {
  grid-column: span 2;
}

.site-footer .items {
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-footer .items li {
  display: flex;
}

.site-footer .abbreviation {
  position: relative;
  display: inline-block;
  width: 2.5em;
  padding-left: 0.5em;
  margin-right: 2em;
}

.site-footer .abbreviation::before {
  content: "[";
  position: absolute;
  left: 0;
}

.site-footer .abbreviation::after {
  content: "]";
  position: absolute;
  right: 0;
}

@media screen and (max-width: 781px) {

  .site-footer {
    grid-template-columns: 1fr;
    grid-gap: 2em;
    background-position: center 75%;
    background-size: 90%;
    padding-bottom: 500px;
  }

  .site-footer .column.span-2 {
    grid-column: span 1;
  }
}

.wp-block-blank-slideshow {
  position: relative;
  height: 100%;
}

.wp-block-blank-slideshow--info {
  position: absolute;
  inset: auto auto var(--margin) var(--margin);
  z-index: 100;
  color: var(--white);
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 2px;
}

.wp-block-blank-slideshow--info .swiper {
  margin-left: 0;
}

.wp-block-blank-slideshow--info summary {
  text-transform: uppercase;
}

.wp-block-blank-slideshow--info .content {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: all 0.4s ease;
}

.wp-block-blank-slideshow--info details[open] .content {
  max-height: 500px;
  opacity: 1;
}

.wp-block-blank-slideshow .swiper-main {
  height: 100%;
}

.wp-block-blank-slideshow .swiper-main img,
.wp-block-blank-slideshow .swiper-main video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wp-block-blank-slideshow .swiper-thumbs .swiper-slide {
  width: 30px;
  height: 30px;
  cursor: pointer;
  background: var(--black);
}

.wp-block-blank-slideshow details summary {
  cursor: pointer;
  list-style: none;
}

.wp-block-blank-slideshow details summary::-webkit-details-marker {
  display: none;
}

.wp-block-blank-slideshow details summary::after {
  content: "[ CREDITS ]";
  margin-left: 0.5em;
  color: var(--wp--preset--color--gray);
}

.wp-block-blank-slideshow details[open] summary::after {
  content: "[ CLOSE ]";
}

.wp-block-blank-slideshow .date {
  display: inline-block;
  width: 4em;
}

.wp-block-blank-slideshow .content {
  padding-left: 4.3em;
}

.wp-block-project-list .project-list--text {
  columns: 2;
  margin: 1em 0 3em;
}

@media screen and (max-width: 781px) {

  .wp-block-project-list .project-list--text {
    columns: 1;
  }
}

.wp-block-project-list .project-list--text .project-meta {
  display: flex;
  gap: var(--margin);
}

.wp-block-project-list .project-list--text .project-date {
  flex: 0 1 30%;
}

.wp-block-project-list .project-list--text .project-title {
  flex: 0 1 70%;
}

.wp-block-project-list .swiper-slide {
  width: auto;
  max-width: 100%;
}

.wp-block-project-list .swiper-slide .project-image {
  aspect-ratio: 36/42;
  margin-bottom: 2px;
}

.wp-block-project-list .swiper-slide img {
  display: block;
}

.wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
  flex-basis: 50%;
}

.wp-block-column .wp-block-image {
  height: 100%;
}

.wp-block-column .wp-block-image img,
.wp-block-column .wp-block-image video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wp-block-column.has-background {
  display: flex;
  flex-wrap: wrap;
  padding: var(--margin);
  align-content: flex-start;
  flex-direction: column;
  aspect-ratio: 1/1;
}

.wp-block-column.has-background > p {
  margin: auto 0;
}

@media screen and (max-width: 781px) {

  .wp-block-column.has-background > p {
    margin: auto 0 0;
  }
}

.nav-main {
  position: absolute;
  inset: 12px 20px;
  display: flex;
  flex-direction: column;
}

.nav-main .icon {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: 16px;
  height: 16px;
  justify-content: space-between;
  margin: 0 0 0 auto;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px 1px;
}

.nav-main .icon span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--black);
  transform-origin: center center;
  transition: all 0.3s ease-in-out;
}

.light .nav-main .icon span {
  background: var(--white);
}

.nav-main .icon.active {
  justify-content: normal;
}

.light .nav-main .icon.active span {
  background: var(--black);
}

.nav-main .icon.active span:nth-child(1) {
  transform: rotate(45deg) translate(4px, 4px);
}

.nav-main .icon.active span:nth-child(2) {
  transform: rotate(-45deg) translate(-3px, 2px);
}

.nav-main--list {
  position: absolute;
  inset: -12px -20px auto;
  height: 100vh;
  margin: 0;
  padding: 70px 20px 20px;
  list-style: none;
  overflow: auto;
  background: var(--white);
  font-weight: 700;
}

.nav-main--list li {
  margin: 0 0 14px;
}

.nav-main--list > li > a.active, .nav-main--list > li > a.router-link-active {
  border-bottom: 2px solid currentcolor;
}

.nav-main--list a {
  border-bottom: none;
  text-decoration: none;
}

.nav-main--list a.active, .nav-main--list a.router-link-active {
  color: var(--black);
}

.nav-main--list ul {
  position: absolute;
  inset: 70px 50% auto;
  width: 50vw;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--mid-grey);
}

.nav-main--list ul a {
  border-bottom-width: 1px;
}

.nav-sub {
  margin-left: calc(var(--base-margin) * -1);
  margin-right: calc(var(--base-margin) * -1);
}

.nav-sub div {
  color: var(--mid-grey);
  border: none;
  background: transparent;
  font-weight: bolder;
  cursor: pointer;
}

.nav-sub .swiper-slide-thumb-active div, .nav-sub.small-screen .swiper-slide-active div {
  color: var(--black);
}

#overlay {
  position: fixed;
  inset: 0;
  z-index: 2;
  color: var(--white);
  background: var(--black-60) url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjEzNCIgdmlld0JveD0iMCAwIDE1OCAxMzQiIHdpZHRoPSIxNTgiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0ibTY5LjcgODMuNHY0LjVoLTE5Ljl2LTQuNWg1LjJ2LTMyLjhoLTUuMnYtNC40aDE5Ljl2NC40aC01djEyLjRoMjguN3YtMTIuNGgtNXYtNC40aDE5Ljl2NC40aC01djMyLjhoNXY0LjVoLTIwdi00LjVoNXYtMTUuOGgtMjguNnYxNS43aDV6bTg4LjItMTIuMmgtMjYuMmMtMS4yIDM0LjMtMjMuNiA2MC4xLTUwLjYgNjIuOCA0MC4xIDAgNzQuMi0yNy43IDc2LjgtNjIuOHptLTI2LjItNy4xaDI2LjNjLTEuOS0zNS43LTM2LjEtNjQuMS03Ni45LTY0LjEgMjcuNCAyLjYgNDkuOCAyOS4xIDUwLjYgNjQuMXptLTEwNS40IDIuOWMwLTM1LjggMjIuNi02NC4zIDUwLjYtNjctNDEuOSAwLTc2LjkgMjkuOS03Ni45IDY3czM1IDY3IDc2LjkgNjdjLTI4LTIuNy01MC42LTMxLjItNTAuNi02N3oiIGZpbGw9IiNmZmYiLz48L3N2Zz4=) center center no-repeat;
  animation: fadeIn 0.4s ease-out;
}

@keyframes fadeIn {

  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.site-home {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 32px - 2 * var(--base-margin));
  margin: 0 40px;
  color: var(--white);
  text-shadow: 0 0 30px rgba(0, 0, 0, 0.25);
}

.site-home .title {
  margin: auto 0 0;
}

.site-home .subtitle {
  margin: 10px 0 60px;
  text-decoration: none;
}

.site-home .subtitle::after {
  content: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAxNiAxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTExLjU4NTggNy4wMDAwMUw3LjI5Mjg5IDIuNzA3MTJMOC43MDcxMSAxLjI5MjkxTDE1LjQxNDIgOC4wMDAwMUw4LjcwNzExIDE0LjcwNzFMNy4yOTI4OSAxMy4yOTI5TDExLjU4NTggOS4wMDAwMUwxIDkuMDAwMDFWNy4wMDAwMUwxMS41ODU4IDcuMDAwMDFaIiBmaWxsPSJ3aGl0ZSIvPgo8L3N2Zz4K);
  margin: 0 0 0 0.5em;
}

.site-home .opener {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media screen and (max-width: 781px) {

  .site-home {
    margin: 0;
  }
}

body {
  margin: 0;
}

a {
  color: currentcolor;
  text-decoration: underline;
  text-underline-offset: 2px;
}

a:hover, a:active, a:focus {
  text-decoration: none;
}

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