/*! 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;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* 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;
}

/*********************
COLORS
*********************/
@font-face {
  font-display: swap;
  font-family: "Metropolis";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/Metropolis-Regular.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Metropolis";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/Metropolis-RegularItalic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Metropolis";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/Metropolis-Medium.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Metropolis";
  font-style: italic;
  font-weight: 500;
  src: url("../fonts/Metropolis-MediumItalic.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Metropolis";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/Metropolis-Bold.woff2") format("woff2");
}
/* Default*/
.wrapper {
  margin-right: auto;
  margin-left: auto;
  max-width: 1520px;
  padding-left: 20px;
  padding-right: 20px;
}

.flex {
  display: flex;
}

.flex--wrap {
  flex-wrap: wrap;
}

:where(ul.base) {
  list-style: none;
  padding: 0;
  margin: 0;
}

@media only screen and (min-width: 768px) {
  .flex-m {
    display: flex;
  }
}
@media only screen and (min-width: 1024px) {
  .flex-l {
    display: flex;
  }
}
/*********************
INPUTS
*********************/
form {
  max-width: 400px;
}

label {
  font-weight: 700;
  display: block;
  margin-bottom: 5px;
}

input:where([type=text], [type=email], [type=url], [type=password], [type=search], [type=tel], [type=range], [type=date], [type=month], [type=week], [type=time], [type=datetime], [type=datetime-local], [type=color], [type=number]), textarea {
  width: 100%;
  max-width: 430px;
  margin-bottom: 1em;
  background-color: #B9BAA6;
  color: #fff;
  border: none;
  padding: 0 12px;
}

input:where([type=text], [type=email], [type=url], [type=password], [type=search], [type=tel], [type=range], [type=date], [type=month], [type=week], [type=time], [type=datetime], [type=datetime-local], [type=color], [type=number]) {
  height: 34px;
}

textarea {
  min-height: 120px;
  padding: 12px;
}

button.btn {
  display: inline-block;
  background-color: #fff;
  color: #747F5B;
  height: 37px;
  min-width: 200px;
  text-align: center;
  padding: 0 1em;
  text-transform: uppercase;
  font-size: 0.875rem;
  border: none;
}

.main-header {
  position: sticky;
  top: 0;
  background: #747F5B url(../images/header-bg-olive.png);
  z-index: 10;
}
.main-header .wrapper {
  max-width: unset;
  padding: 13px 20px 17px;
  position: relative;
  z-index: 11;
}
.main-header .wrapper::before, .main-header .wrapper::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: -1;
  transition: all 0.3s ease-in-out;
}
.main-header .wrapper::before {
  background: linear-gradient(90deg, #747F5B 9.62%, rgba(116, 127, 91, 0.75) 44.71%, #747F5B 95%);
}
.main-header .wrapper::after {
  background: linear-gradient(90deg, #FFF 9.62%, rgba(255, 255, 255, 0.75) 44.71%, #FFF 95%);
  opacity: 0;
}
@media (min-width: 1024px) {
  .main-header .wrapper {
    padding: 33px clamp(1.25rem, 0.45rem + 4vw, 5.25rem) 25px;
    align-items: center;
    justify-content: space-between;
  }
}
.main-header .bg {
  position: absolute;
  inset: 0;
  background: url(../images/header-bg-white.png);
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}
@media (max-width: 1023px) {
  .main-header, .main-header .bg {
    background-size: 15% auto;
  }
}

@media (hover: hover) {
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .wrapper::before {
    opacity: 0;
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .wrapper::after {
    opacity: 1;
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .bg {
    opacity: 1;
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .logo svg path.net {
    fill: #000;
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .nav-open svg.hamburger-icon path {
    stroke: #747F5B;
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .main-nav.d a {
    color: rgba(116, 127, 91, 0.5);
  }
  .main-header:has(.wrapper:hover):not(body.nav-is-open .main-header) .main-nav.d a.current {
    color: #747F5B;
  }
}
.logo {
  width: 150px;
}
.logo svg path.net {
  fill: #fff;
  transition: fill 0.3s ease-in-out;
}
@media (max-width: 1023px) {
  .logo {
    display: block;
  }
}
@media (min-width: 1024px) {
  .logo {
    width: 237px;
  }
}

.nav-open {
  cursor: pointer;
  width: 50px;
  aspect-ratio: 1;
  display: flex;
  border: none;
  position: absolute;
  right: 20px;
  top: 15px;
  background-color: transparent;
}
.nav-open svg {
  transition: opacity 0.3s ease-in-out;
  position: absolute;
  inset: 0;
  margin: auto;
}
.nav-open svg.hamburger-icon {
  opacity: 1;
}
.nav-open svg.close-icon {
  opacity: 0;
}
@media (min-width: 1024px) {
  .nav-open {
    display: none;
  }
}

body.nav-is-open .nav-open svg.hamburger-icon {
  opacity: 0;
}
body.nav-is-open .nav-open svg.close-icon {
  opacity: 1;
}
body.nav-is-open .main-header .wrapper {
  z-index: 200;
}

@media (max-width: 1023px) {
  .main-nav.d {
    display: none;
  }
  .main-nav {
    position: fixed;
    inset: 0;
    z-index: 100;
    background: #747F5B;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.4s ease-in-out, visibility 0.4s ease-in-out;
  }
  .main-nav.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .main-nav::before {
    content: "";
    display: block;
    position: absolute;
    inset: 0;
    background: url(../images/header-bg-olive.png);
    background-size: 15% auto;
    opacity: 0.3;
  }
}
@media (min-width: 1024px) {
  .main-nav.m {
    display: none;
  }
}
.main-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (max-width: 1023px) {
  .main-nav ul {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0;
    background: none;
    position: relative;
    z-index: 1;
  }
}
@media (min-width: 1024px) {
  .main-nav ul {
    gap: 20px;
  }
}
@media (min-width: 1280px) {
  .main-nav ul {
    gap: 60px;
  }
}
.main-nav ul a {
  text-transform: uppercase;
  text-decoration: none;
  transition: color 0.3s ease-in-out, opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
}
@media (max-width: 1023px) {
  .main-nav ul a {
    color: #fff;
    font-size: 1.5rem;
    line-height: 1.5;
    display: block;
    padding: 6px 0;
    opacity: 0;
    transform: translateY(16px);
  }
}
@media (min-width: 1024px) {
  .main-nav ul a {
    line-height: 1;
    font-size: 1.125rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.5);
  }
  .main-nav ul a.current {
    color: #fff;
  }
}
@media (max-width: 1023px) {
  .main-nav.active li:nth-child(1) a {
    opacity: 1;
    transform: none;
    transition-delay: 0.15s;
  }
  .main-nav.active li:nth-child(2) a {
    opacity: 1;
    transform: none;
    transition-delay: 0.25s;
  }
  .main-nav.active li:nth-child(3) a {
    opacity: 1;
    transform: none;
    transition-delay: 0.35s;
  }
  .main-nav.active li:nth-child(4) a {
    opacity: 1;
    transform: none;
    transition-delay: 0.45s;
  }
  .main-nav.active li:nth-child(5) a {
    opacity: 1;
    transform: none;
    transition-delay: 0.55s;
  }
}

.sub-nav {
  padding: 1em;
  justify-content: center;
  background-color: #989f7e;
  z-index: 11;
  position: relative;
}
@media (min-width: 1024px) {
  .sub-nav li + li {
    border-left: 1px solid #fff;
  }
}
.sub-nav a, .sub-nav button {
  text-transform: uppercase;
  display: block;
  padding: 3px 1em;
  text-decoration: none;
  border: none;
  background-color: transparent;
  line-height: 1;
}
@media (max-width: 1023px) {
  .sub-nav a, .sub-nav button {
    color: #383d2c;
    font-weight: 400;
    font-size: 0.8125rem;
  }
  .sub-nav a:hover, .sub-nav button:hover {
    color: rgba(56, 61, 44, 0.6);
  }
}
.sub-nav a.active, .sub-nav button.active {
  pointer-events: none;
}
@media (min-width: 1024px) {
  .sub-nav a, .sub-nav button {
    color: rgba(255, 255, 255, 0.5);
    font-weight: 700;
    font-size: 1.125rem;
  }
  .sub-nav a:hover, .sub-nav button:hover {
    color: rgba(255, 255, 255, 0.2);
  }
}

.main-footer {
  background: linear-gradient(180deg, rgba(185, 186, 166, 0) 0, rgba(185, 186, 166, 0.7) 18.51%, #B9BAA6 35%);
  padding: 1em 0;
  letter-spacing: 1px;
  position: relative;
  z-index: 3;
  margin-top: -30px;
}
@media (min-width: 1024px) {
  .main-footer {
    padding: 40px 0;
    margin-top: -40px;
  }
}
.main-footer .wrapper {
  max-width: unset;
  padding: 0 clamp(1.25rem, 0.45rem + 4vw, 5.25rem);
  color: #fff;
  gap: 1em;
  position: relative;
  z-index: 3;
}
@media (max-width: 767px) {
  .main-footer .wrapper {
    flex-direction: column-reverse;
  }
}
@media (max-width: 1023px) {
  .main-footer .wrapper {
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .main-footer .wrapper {
    justify-content: space-between;
  }
}
.main-footer .wrapper a {
  color: #fff;
  text-decoration: none;
}
.main-footer .contacts {
  gap: 1em;
}
@media (max-width: 767px) {
  .main-footer .contacts {
    flex-direction: column;
  }
  .main-footer .contacts .newsletter {
    display: none;
  }
}
@media (min-width: 1024px) {
  .main-footer .contacts {
    gap: 40px;
  }
}
.main-footer .contacts svg {
  margin-right: 10px;
}
@media (min-width: 1024px) {
  .main-footer .contacts svg {
    margin-right: 20px;
  }
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

figure {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

textarea {
  resize: vertical;
}

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

address {
  font-style: normal;
}

button {
  cursor: pointer;
}

html, body {
  scroll-behavior: smooth;
}

body {
  font-family: "Metropolis", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #060D0A;
  background-color: #fff;
  flex-direction: column;
  min-height: 100vh;
  gap: 60px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.35;
  /*overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;*/
}
@media (min-width: 1280px) {
  body {
    font-size: 1.125em;
  }
}

main {
  letter-spacing: 10%;
}
main .wrapper > :first-child, main .content > :first-child {
  margin-top: 0;
}
main .wrapper > :last-child, main .content > :last-child {
  margin-bottom: 0;
}
main a.back {
  display: block;
  background-color: #747F5B;
  color: #fff;
  font-size: clamp(1.5rem, 1.1667rem + 1.6667vw, 2.5rem);
  z-index: 3;
  position: absolute;
  top: 5px;
  right: 10px;
  line-height: 1;
}
@media (min-width: 1280px) {
  main a.back {
    background-color: transparent;
    top: 40px;
    padding: 0;
  }
}
@media (min-width: 1600px) {
  main a.back {
    right: 90px;
  }
}

/*********************
LINK STYLES
*********************/
a {
  transition: color 0.3s ease-in-out;
  text-decoration: none;
  /* on hover */
}
a:link {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.3);
}
p:has(a.more) {
  margin: 0;
}

a.more, span.more {
  display: inline-block;
  color: #fff;
  text-transform: uppercase;
  font-size: 0.875rem;
  padding: 3px 6px;
  text-decoration: none;
  border-radius: 0 15px 15px 0;
}
a.more svg, span.more svg {
  margin-left: 1rem;
  width: 7px;
}

/******************************************************************
H1, H2, H3, H4, H5 STYLES
******************************************************************/
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5 {
  text-rendering: optimizelegibility;
  font-weight: 700;
  letter-spacing: 5%;
}

h1,
.h1 {
  font-size: clamp(32px, 5vw, 40px);
}

h2,
.h2 {
  font-size: clamp(20px, 4.4vw, 28px);
}

h3,
.h3 {
  font-size: 18px;
}

h4,
.h4 {
  font-size: 16px;
}

h5,
.h5 {
  font-size: 15px;
}

.home {
  min-height: 100vh;
}
.home, .home .slick-slide {
  position: relative;
}
.home .main-header {
  position: absolute;
  width: 100%;
  top: 0;
  z-index: 7;
}
.home .slick-slide {
  height: 100vh;
  overflow: hidden;
}
.home .slick-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home blockquote {
  margin: 0 20px;
  color: #fff;
  z-index: 6;
  font-weight: 700;
  font-size: clamp(1.75rem, 1.1071rem + 3.2143vw, 4rem);
  position: absolute;
  bottom: 60px;
  line-height: 1.15;
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .home blockquote {
    margin: 0 50px;
  }
}
.home blockquote footer {
  margin-top: 1em;
  font-weight: 500;
  font-style: italic;
  font-size: clamp(0.875rem, 0.6964rem + 0.8929vw, 1.5rem);
  text-transform: none;
}
.home .main-footer {
  display: none;
}

.home.intro .main-header {
  opacity: 0;
  background: none;
  animation: fadeIn 0.5s ease 3s 1 normal forwards;
}
.home.intro .main-header .wrapper::before {
  opacity: 0;
}
@media (max-width: 1023px) {
  .home.intro.nav-is-open .main-header {
    background: #747F5B url(../images/header-bg-olive.png);
    background-size: 15% auto;
  }
  .home.intro.nav-is-open .main-header .wrapper::before {
    opacity: 1;
  }
}
.home.intro .intro-section {
  position: absolute;
  inset: 0;
  z-index: 9;
  overflow: hidden;
  display: grid;
  place-content: center;
  background-color: #747F5B;
  animation: bgColor 0.5s ease 2s 1 alternate forwards, zoomOut 0.5s ease 3s 1 alternate forwards;
}
@media (max-width: 1023px) {
  .home.intro .intro-section {
    padding: 0 10%;
  }
}
.home.intro .intro-section::after, .home.intro .intro-section::before {
  content: "";
  display: block;
  position: absolute;
  position: absolute;
  opacity: 0;
}
.home.intro .intro-section::after {
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.9) 74.04%, #fff 100%);
  z-index: 9;
  width: 100%;
  height: 70%;
  left: 0;
  top: 0;
  animation: fadeIn 0.5s ease 0.5s 1 normal forwards, fadeOut 0.5s ease 2.5s 1 normal forwards;
}
.home.intro .intro-section::before {
  background: url(../svg/intro-grid.svg);
  background-size: cover;
  inset: 0;
  z-index: 8;
  animation: fadeIn06 0.5s ease 1s 1 normal forwards, fadeOut 0.5s ease 2.5s 1 normal forwards;
}
.home.intro .intro-section #top, .home.intro .intro-section #bottom {
  z-index: 10;
  position: relative; /*transition: all 0.5s ease-in-out;*/
  opacity: 0;
}
.home.intro .intro-section #top {
  margin-bottom: -50%;
  animation: slideTop 1s ease 1s 1 alternate forwards, zoomOut 1s ease 2s 1 alternate forwards;
}
.home.intro .intro-section #bottom {
  animation: slideBottom 1s ease 1s 1 alternate forwards, zoomOut 1s ease 2s 1 alternate forwards;
}
@keyframes bgColor {
  0% {
    background-color: #747F5B;
  }
  100% {
    background-color: rgba(116, 127, 91, 0);
  }
}
@keyframes fadeIn06 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 0.4;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeOut {
  100% {
    opacity: 0;
  }
}
@keyframes slideTop {
  0% {
    opacity: 0;
    transform: translateY(-250px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideBottom {
  0% {
    opacity: 0;
    transform: translateY(250px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes zoomOut {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(0);
  }
}

body.bureau main .intro {
  background: url(../images/bureau-hero.webp) 50% 0;
  background-size: cover;
  padding-top: clamp(3.125rem, -13.8963rem + 26.5957vw, 9.375rem);
  padding-bottom: clamp(8rem, -57.9787rem + 98.4043vw, 28.125rem);
  position: relative;
}
body.bureau main .intro::after {
  height: 150px;
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(0deg, #747F5B 0%, rgba(116, 127, 91, 0) 100%);
}
body.bureau main .intro .container {
  padding: 0 20px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  color: #fff;
}
body.bureau main .intro h1 {
  font-size: clamp(3.125rem, 0.6806rem + 12.2222vw, 7.8125rem);
  margin: 0 0 0.3em;
  line-height: 1;
  text-transform: uppercase;
}
body.bureau main .intro h2 {
  font-size: clamp(1.5rem, 1.2037rem + 1.4815vw, 2.5rem);
  margin-top: 0;
}
body.bureau main .intro blockquote {
  margin: 0;
  font-weight: 700;
}
body.bureau main section:not(.intro) {
  padding: clamp(2.5rem, -0.8333rem + 16.6667vw, 13.75rem) 0;
  position: relative;
}
body.bureau main section:not(.intro)::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
}
@media (min-width: 1024px) {
  body.bureau main section:not(.intro) {
    scroll-margin-top: 50px;
  }
}
@media (min-width: 1280px) {
  body.bureau main section:not(.intro) {
    scroll-margin-top: 20px;
  }
}
body.bureau main section:not(.intro) .wrapper {
  position: relative;
  z-index: 3;
}
@media (min-width: 1024px) {
  body.bureau main section:not(.intro) .wrapper {
    display: flex;
    gap: 40px;
    align-items: center;
    font-size: 1.125rem;
  }
  body.bureau main section:not(.intro) .wrapper > * {
    flex: 1 1 50%;
  }
}
@media (min-width: 1280px) {
  body.bureau main section:not(.intro) .wrapper {
    justify-content: space-between;
  }
  body.bureau main section:not(.intro) .wrapper > * {
    max-width: 637px;
  }
}
body.bureau main section:not(.intro) .wrapper .copy > :last-child {
  margin-bottom: 0;
}
body.bureau main section:not(.intro) h2 {
  text-transform: uppercase;
  font-size: clamp(1.5rem, 1.1667rem + 1.6667vw, 2.5rem);
  line-height: 1;
  margin-bottom: 0.7em;
}
@media (min-width: 1024px) {
  body.bureau main section:not(.intro) h2 {
    margin-top: 0;
  }
}
body.bureau main section:not(.intro) h3 {
  font-size: clamp(1rem, 0.8333rem + 0.8333vw, 1.5rem);
}
body.bureau main section:not(.intro):nth-child(even) {
  background: url(../images/bg-olive-dark-lines.webp);
  background-attachment: fixed;
  color: #fff;
}
@media (max-width: 1023px) {
  body.bureau main section:not(.intro):nth-child(even) {
    background-size: 15% auto;
  }
}
body.bureau main section:not(.intro):nth-child(even)::after {
  background: linear-gradient(180deg, #747F5B 69.23%, rgba(116, 127, 91, 0.5) 100%);
}
body.bureau main section:not(.intro):nth-child(odd) {
  background: url(../images/header-bg-white.png);
  background-attachment: fixed;
}
@media (max-width: 1023px) {
  body.bureau main section:not(.intro):nth-child(odd) {
    background-size: 15% auto;
  }
}
body.bureau main section:not(.intro):nth-child(odd)::after {
  background: linear-gradient(0deg, rgba(255, 255, 255, 0.5) 0%, #fff 27.4%);
}

body.nieuws main a.sign-up, body.publicaties main a.sign-up {
  padding: 7px;
  width: 154px;
  text-align: center;
  text-transform: uppercase;
  color: #fff;
  background-color: #fff;
  background-color: #B9BAA6;
  margin: 40px auto 70px;
  display: block;
  border: none;
  font-size: 0.625rem;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  font-weight: 700;
  letter-spacing: 10%;
  text-decoration: none;
}
body.nieuws main a.sign-up:hover, body.publicaties main a.sign-up:hover {
  background-color: #989f7e;
}
body.nieuws main a.sign-up:focus, body.publicaties main a.sign-up:focus {
  background-color: #747F5B;
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.25) inset;
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.25);
}
@media (min-width: 1024px) {
  body.nieuws main a.sign-up, body.publicaties main a.sign-up {
    position: fixed;
    right: 30px;
    bottom: 120px;
    z-index: 7;
    margin: 0;
    width: 174px;
    height: 78px;
    display: grid;
    place-items: center;
    font-size: 0.75rem;
    padding: 10px;
  }
}
body.nieuws article, body.publicaties article {
  padding: clamp(2.5rem, 1.7593rem + 3.7037vw, 5rem) 0;
  position: relative;
}
body.nieuws article::after, body.publicaties article::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
}
@media (max-width: 1023px) {
  body.nieuws article:nth-child(odd), body.publicaties article:nth-child(odd) {
    background: url(../images/bg-olive-dark-lines.webp);
    background-attachment: fixed;
    color: #fff;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  body.nieuws article:nth-child(odd), body.publicaties article:nth-child(odd) {
    background-size: 15% auto;
  }
}
@media (max-width: 1023px) {
  body.nieuws article:nth-child(odd)::after, body.publicaties article:nth-child(odd)::after {
    background: linear-gradient(180deg, #747F5B 69.23%, rgba(116, 127, 91, 0.5) 100%);
  }
  body.nieuws article:nth-child(odd) .more a, body.publicaties article:nth-child(odd) .more a {
    color: #fff;
  }
  body.nieuws article:nth-child(even), body.publicaties article:nth-child(even) {
    background: url(../images/header-bg-white.png);
    background-attachment: fixed;
    color: #747F5B;
  }
}
@media (max-width: 1023px) and (max-width: 1023px) {
  body.nieuws article:nth-child(even), body.publicaties article:nth-child(even) {
    background-size: 15% auto;
  }
}
@media (max-width: 1023px) {
  body.nieuws article:nth-child(even)::after, body.publicaties article:nth-child(even)::after {
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.5) 0%, #fff 27.4%);
  }
  body.nieuws article:nth-child(even) .more a, body.publicaties article:nth-child(even) .more a {
    color: #747F5B;
  }
  body.nieuws article .date, body.publicaties article .date {
    color: #B9BAA6;
  }
}
@media (min-width: 1024px) {
  body.nieuws article:nth-child(even), body.publicaties article:nth-child(even) {
    background: url(../images/bg-olive-dark-lines.webp);
    background-attachment: fixed;
    color: #fff;
  }
  body.nieuws article:nth-child(even)::after, body.publicaties article:nth-child(even)::after {
    background: linear-gradient(180deg, #747F5B 69.23%, rgba(116, 127, 91, 0.5) 100%);
  }
  body.nieuws article:nth-child(even) .more a, body.publicaties article:nth-child(even) .more a {
    color: #fff;
  }
  body.nieuws article:nth-child(odd), body.publicaties article:nth-child(odd) {
    background: url(../images/header-bg-white.png);
    background-attachment: fixed;
    color: #747F5B;
  }
  body.nieuws article:nth-child(odd)::after, body.publicaties article:nth-child(odd)::after {
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.5) 0%, #fff 27.4%);
  }
  body.nieuws article:nth-child(odd) .more a, body.publicaties article:nth-child(odd) .more a {
    color: #747F5B;
  }
}
body.nieuws article .wrapper, body.publicaties article .wrapper {
  position: relative;
  z-index: 3;
}
@media (min-width: 1024px) {
  body.nieuws article .wrapper, body.publicaties article .wrapper {
    display: flex;
    gap: 20px;
    justify-content: space-between;
  }
  body.nieuws article .wrapper > *, body.publicaties article .wrapper > * {
    flex: 1 1 50%;
  }
  body.nieuws article .wrapper figure, body.publicaties article .wrapper figure {
    max-width: 653px;
  }
}
body.nieuws article a, body.publicaties article a {
  text-decoration: underline;
}
body.nieuws article a:hover, body.publicaties article a:hover {
  text-decoration: none;
}
body.nieuws article .more, body.publicaties article .more {
  font-weight: 700;
  margin-bottom: 0;
}
body.nieuws article .more a.download, body.publicaties article .more a.download {
  color: #B9BAA6;
  margin-left: 1rem;
}
@media (max-width: 1023px) {
  body.nieuws article .more a.download, body.publicaties article .more a.download {
    display: none;
  }
}
@media (min-width: 1024px) {
  body.nieuws .copy, body.publicaties .copy {
    max-width: 644px;
    font-size: 1.125rem;
  }
}
body.nieuws .copy h2, body.publicaties .copy h2 {
  text-transform: uppercase;
  margin: 1.25em 0 0.5em;
  font-size: clamp(0.875rem, 0.4676rem + 2.037vw, 2.25rem);
}
@media (min-width: 1024px) {
  body.nieuws .copy h2, body.publicaties .copy h2 {
    margin: 0 0 0.3em;
  }
}

body.nieuwsbrief {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 0;
}
body.nieuwsbrief main {
  flex-grow: 1;
  background-position: center;
  background-size: cover;
  padding: 2em 0;
  color: #fff;
  text-align: center;
  display: grid;
  place-items: center;
}
@media (max-width: 1023px) {
  body.nieuwsbrief main {
    background-image: url(../images/nieuwsbrief-mob-bg.webp);
  }
}
@media (min-width: 1024px) {
  body.nieuwsbrief main {
    background-image: url(../images/nieuwsbrief-bg.webp);
  }
}
body.nieuwsbrief main .wrapper {
  max-width: 1120px;
}
body.nieuwsbrief main h1 {
  text-transform: uppercase;
  font-size: clamp(2.5rem, 1.463rem + 5.1852vw, 6rem);
}
body.nieuwsbrief main h1 + p {
  font-weight: 500;
  font-size: clamp(1.125rem, 1rem + 0.625vw, 1.5rem);
}
body.nieuwsbrief main form {
  max-width: 430px;
  margin: 0 auto;
  font-weight: 500;
}
body.nieuwsbrief main input::placeholder {
  text-transform: uppercase;
  color: #fff;
}
body.nieuwsbrief main button.submit {
  display: block;
  margin-left: auto;
}
body.nieuwsbrief .main-footer {
  margin: 0;
  background-color: #B9BAA6;
}

body.article {
  background: #747F5B url(../images/header-bg-olive.png);
  background-attachment: fixed;
}
@media (max-width: 1023px) {
  body.article {
    background-size: 15% auto;
  }
}
body.article main {
  position: relative;
}
body.article .hero {
  background: linear-gradient(180deg, rgba(116, 127, 91, 0.75) 0%, #747F5B 100%);
  padding: 40px 0 0;
}
body.article .hero img {
  display: block;
  margin: auto;
}
body.article article {
  background-color: #747F5B;
  color: #fff;
  padding-bottom: 50px;
}
body.article article .wrapper {
  max-width: 1264px;
}
body.article article header {
  position: sticky;
  top: 70px;
  background: linear-gradient(180deg, #747F5B 75%, rgba(116, 127, 91, 0) 100%);
  padding: 30px 0;
}
@media (min-width: 768px) {
  body.article article header {
    top: 112px;
  }
}
@media (min-width: 1024px) {
  body.article article header {
    top: 140px;
  }
}
body.article article header h2 {
  margin-top: 0;
  max-width: 600px;
  letter-spacing: 10%;
  text-transform: uppercase;
  font-size: clamp(0.875rem, 0.4167rem + 2.2917vw, 2.25rem);
}
body.article article header p {
  margin-bottom: 0;
}
@media (max-width: 1023px) {
  body.article article header p {
    color: #B9BAA6;
  }
}
body.article article header a.download {
  color: #fff;
  text-decoration: underline;
  position: absolute;
  right: 0;
  top: 20px;
}
body.article article header a.download:hover {
  text-decoration: none;
}
@media (max-width: 1023px) {
  body.article article header a.download {
    display: none;
  }
}
@media (min-width: 1024px) {
  body.article article section {
    overflow: hidden;
  }
  body.article article section img.right {
    float: right;
    margin: 0 0 40px 80px;
  }
  body.article article section img.right:first-child {
    margin-top: 80px;
  }
  body.article article section img.left {
    float: left;
    margin: 0 80px 40px 0;
  }
}

body.contact {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 0;
}
body.contact main {
  flex-grow: 1;
  padding: 2em 0;
  color: #fff;
  background-color: #747F5B;
}
body.contact main iframe {
  width: 100%;
  aspect-ratio: 1;
}
@media (min-width: 768px) {
  body.contact main iframe {
    aspect-ratio: 16/9;
  }
}
body.contact main h2 {
  font-weight: 500;
  font-size: clamp(1rem, 0.8333rem + 0.8333vw, 1.5rem);
}
@media (max-width: 1023px) {
  body.contact main .contact-info {
    display: none;
  }
}
@media (min-width: 1024px) {
  body.contact main .wrapper {
    gap: 30px;
    align-items: center;
  }
  body.contact main iframe {
    width: calc(100% - 510px);
  }
  body.contact main .content {
    flex: 0 0 480px;
    font-size: 1rem;
  }
  body.contact main .contact-info {
    display: grid;
    gap: 10px;
    font-size: 1.5rem;
  }
  body.contact main .contact-info a {
    color: #fff;
  }
}
@media (min-width: 1280px) {
  body.contact main .wrapper {
    gap: 45px;
  }
  body.contact main iframe {
    width: calc(100% - 525px);
    aspect-ratio: 1084/693;
  }
}
body.contact .main-footer {
  margin-top: 0;
  background-color: #B9BAA6;
}

body.projecten .sub-nav {
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 767px) {
  body.projecten .sub-nav.s-is-open .search-container {
    flex: 0 1 120px;
  }
  body.projecten .sub-nav.s-is-open ul {
    flex: 0 1 70%;
    justify-content: unset;
  }
  body.projecten .sub-nav.s-is-open #search-query {
    max-width: 120px;
  }
  body.projecten .sub-nav.s-is-open .search svg {
    color: #747F5B;
  }
  body.projecten .sub-nav ul {
    flex-wrap: wrap;
    justify-content: left;
    transition: all 0.3s ease-in-out;
    flex: 0 1 85%;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  body.projecten .sub-nav {
    justify-content: space-between;
    align-items: center;
    gap: 10px;
  }
  body.projecten .sub-nav ul {
    gap: 5px;
  }
}
@media (max-width: 1023px) {
  body.projecten .sub-nav {
    justify-content: flex-start;
  }
  body.projecten .sub-nav li {
    border: none;
  }
  body.projecten .sub-nav button {
    font-size: 0.8rem;
    line-height: 1.6;
    padding: 3px 7px;
  }
  body.projecten .sub-nav button.is-checked {
    opacity: 0.6;
  }
}
@media (min-width: 1024px) {
  body.projecten .sub-nav li {
    place-content: center;
  }
}
@media (min-width: 1600px) {
  body.projecten .sub-nav {
    padding-right: calc((100vw - 1580px) / 2);
  }
}
body.projecten .search-container {
  position: relative;
  transition: all 0.3s ease-in-out;
}
@media (max-width: 767px) {
  body.projecten .search-container {
    flex: 0 1 1px;
    margin-left: auto;
  }
}
body.projecten .search-container #search-query {
  margin: 0;
  transition: all 0.3s ease-in-out;
}
@media (max-width: 767px) {
  body.projecten .search-container #search-query {
    padding: 0;
    max-width: 0;
    overflow: hidden;
    height: 18px;
  }
}
@media (min-width: 768px) {
  body.projecten .search-container #search-query:focus-visible + button {
    display: none;
  }
}
body.projecten .search-container .search {
  position: absolute;
  right: 5px;
  top: 2px;
  z-index: 3;
}
@media (max-width: 767px) {
  body.projecten .search-container .search {
    width: 2rem;
    aspect-ratio: 1;
    padding: 2px;
  }
  body.projecten .search-container .search svg {
    width: 24px;
    color: #383d2c;
    padding-top: 12px;
  }
}
@media (min-width: 1024px) {
  body.projecten .search-container .search {
    padding: 0;
    top: 3px;
    right: 10px;
  }
}
body.projecten main {
  background-image: url(../images/header-bg-white.png);
  background-attachment: fixed;
  position: relative;
  overflow: hidden;
  padding-top: 1rem;
}
@media (max-width: 1023px) {
  body.projecten main {
    background-size: 15% auto;
  }
}
body.projecten main::after {
  content: "";
  display: block;
  position: absolute;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  height: 110vh;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.5) 0%, #fff 100%);
}
body.projecten article {
  padding: 1rem;
  position: relative;
  z-index: 3;
  margin-bottom: 1rem;
}
body.projecten article::before {
  content: "";
  display: block;
  position: absolute;
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, #747F5B 50%, rgba(116, 127, 91, 0.35) 100%);
}
body.projecten article::after {
  content: "";
  display: block;
  position: absolute;
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: rgba(116, 127, 91, 0.5);
}
body.projecten article figure, body.projecten article .copy {
  position: relative;
  z-index: 2;
}
body.projecten article .copy {
  color: #fff;
  padding-top: 1em;
}
body.projecten article h2, body.projecten article .cats, body.projecten article .city {
  text-transform: uppercase;
}
body.projecten article .cats {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
body.projecten article h2 {
  font-size: 0.9375rem;
}
body.projecten article p, body.projecten article .cats {
  font-size: 0.75rem;
}
body.projecten article .city, body.projecten article .year {
  font-size: 0.625rem;
}
body.projecten article .cats, body.projecten article .city, body.projecten article .year {
  color: #B9BAA6;
}
body.projecten article .year {
  margin: 0;
}
@media (max-width: 767px) {
  body.projecten article .year {
    text-align: right;
    margin-top: -1em;
  }
}
@media (min-width: 768px) {
  body.projecten article a {
    display: flex;
    gap: 20px;
  }
  body.projecten article figure {
    flex: 0 0 325px;
  }
  body.projecten article .copy {
    padding-top: 0;
    display: flex;
    gap: 10px;
    align-items: flex-start;
  }
  body.projecten article h2 {
    font-size: 1.25rem;
    margin-bottom: 14px;
  }
  body.projecten article .cats {
    font-size: 0.75rem;
    margin-bottom: 1rem;
    line-height: 1;
  }
  body.projecten article .cats + p {
    margin-top: 0;
  }
  body.projecten article .year {
    font-size: 0.875rem;
    color: #fff;
  }
  body.projecten article p {
    font-size: 1rem;
  }
  body.projecten article .city {
    font-size: 0.6875rem;
    color: #fff;
  }
}
@media (min-width: 1024px) {
  body.projecten main {
    padding: 100px 0 240px;
  }
  body.projecten main .wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: space-between;
    max-width: 1600px;
  }
  body.projecten article {
    margin: 0;
  }
}
@media (min-width: 1280px) {
  body.projecten article {
    flex: 0 1 49%;
    max-width: 750px;
    padding: 35px;
  }
  body.projecten h2 {
    word-break: break-word;
  }
}
body.projecten .main-footer {
  background-color: #B9BAA6;
}

body.project {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 0;
}
body.project main {
  flex-grow: 1;
  padding: 2em 0;
  color: #fff;
  background-color: #747F5B;
  position: relative;
}
body.project article {
  position: relative;
}
@media (max-width: 1023px) {
  body.project article {
    padding-bottom: 2em;
  }
}
@media (min-width: 1024px) {
  body.project article header, body.project article section {
    max-width: 686px;
  }
}
@media (min-width: 1280px) {
  body.project article header {
    margin-top: -140px;
    position: relative;
  }
}
body.project article header h2 {
  text-transform: uppercase;
  font-size: clamp(1rem, 0.7037rem + 1.4815vw, 2rem);
  margin-bottom: 10px;
  letter-spacing: 10%;
}
body.project article p.city {
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
}
@media (max-width: 1023px) {
  body.project article p.city {
    margin: 0;
    position: absolute;
    bottom: 0;
    width: 100%;
    display: flex;
    justify-content: space-between;
    color: #B9BAA6;
  }
}
body.project article p.cats {
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  color: #B9BAA6;
}
@media (min-width: 1600px) {
  body.project article p.cats {
    position: absolute;
    left: calc(100% + 25px);
    top: 16px;
    margin: 0;
    width: 230px;
  }
}
body.project .main-footer {
  margin-top: 0;
  background-color: #B9BAA6;
}

@media print {
  /******************************************************************
  Site Name:
  Author:

  Stylesheet: Print Stylesheet

  This is the print stylesheet. There's probably not a lot
  of reasons to edit this stylesheet. If you want to
  though, go for it.

  ******************************************************************/
  * {
    background: transparent !important;
    color: black !important;
    text-shadow: none !important;
    filter: none !important;
    -ms-filter: none !important;
  }
  a, a:visited {
    color: #444 !important;
    text-decoration: underline;
  }
  a:after, a:visited:after {
    content: " (" attr(href) ")";
  }
  a abbr[title]:after, a:visited abbr[title]:after {
    content: " (" attr(title) ")";
  }
  .ir a:after,
  a[href^="javascript:"]:after,
  a[href^="#"]:after {
    content: "";
  }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group;
  }
  tr, img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  @page {
    margin: 0.5cm;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
  h3 {
    page-break-after: avoid;
  }
  .sidebar,
  .page-navigation,
  .wp-prev-next,
  .respond-form,
  nav {
    display: none;
  }
}

/*# sourceMappingURL=style.css.map */
