@font-face {
  font-family: Nitti Grotesk;
  font-style: normal;
  font-weight: 400;
  font-display: fallback;
  src: local(Nitti Grotesk), url("/assets/v/nittigrotesk-normal-v20-5arqyEjT.eot?") format("eot"), url("/assets/v/nittigrotesk-normal-v20-B2LzrVD1.woff") format("woff");
}

@font-face {
  font-family: Nitti Grotesk;
  font-style: normal;
  font-weight: 200;
  font-display: fallback;
  src: local(Nitti Grotesk), url("/assets/v/nittigrotesk-light-v20-qIYsaGlu.eot?") format("eot"), url("/assets/v/nittigrotesk-light-v20-Bt1btABZ.woff") format("woff");
}

:root {
  --backgroundGray: #f5f5f5;
  --gray100: #fefaf8;
  --gray300: #bbbcbf;
  --gray500: #646464;
  --purple: #cd7fdf;
  --yellow: #ffc91f;
  --green: #00cc57;
  --green-darker: #154345;
  --green-lighter: #6ccccb;
  --red: #fb5f34;
  --red-lighter: #fb9d77;
  --blue900: #053d44;
  --blue500: #3d6bbb;
  --blue400: #006cbf;
  --blue300: #0090ff;
  --blue200: #5996fe;
  --blue-lighter: #9fe6fd;
  --blue: var(--blue400);
  --text: #4a4a4a;
  --black: #000;
  --gray-darker: #979797;
  --white: #fff;
}

.panel.careers {
  position: relative;
}

.panel.careers:after {
  content: "";
  background: url("/assets/v/vliegtuig-BNadrLWc.png") 50% / contain no-repeat;
  width: 12rem;
  height: 13rem;
  display: block;
  position: absolute;
  top: 0;
  right: 15%;
  transform: translate(50%, -50%);
}

@media (width >= 768px) {
  .panel.careers {
    padding: 8rem 3rem;
  }

  .panel.careers:after {
    background-image: url("/assets/v/vliegtuig-flip-B0Q05X37.png");
    left: 25%;
    right: auto;
    transform: translate(-50%, -50%);
  }

  .panel.careers article {
    max-width: 78rem;
  }

  .panel.careers article section {
    column-count: 2;
    column-gap: 6rem;
    padding: 2rem 0 0;
  }

  .panel.careers article p:first-child {
    margin-top: 0;
  }
}

:is(main.home, main.about-us) .cases {
  position: relative;
}

:is(main.home, main.about-us) .cases:after {
  content: "";
  background: url("/assets/v/vliegtuig-flip-B0Q05X37.png") 50% / contain no-repeat;
  width: 12rem;
  height: 13rem;
  display: block;
  position: absolute;
  top: 0;
  right: 45%;
  transform: translate(50%, -50%);
}

:is(main.home, main.about-us) .cases header {
  text-align: center;
  padding: 3rem 0 2rem;
}

:is(main.home, main.about-us) .cases header h2 {
  margin: 0;
  font-size: 3.4rem;
  font-weight: 500;
}

:is(main.home, main.about-us) .cases header p {
  margin: .25em 0 0;
  font-size: 1.8rem;
  font-weight: 200;
  line-height: 1.4;
}

:is(main.home, main.about-us) .cases .items {
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
  width: 100vw;
  margin-left: 50%;
  overflow-x: auto;
  transform: translateX(-50%);
}

:is(main.home, main.about-us) .cases .items > ul {
  scroll-snap-type: x mandatory;
  box-sizing: border-box;
  scrollbar-width: none;
  flex-wrap: nowrap;
  margin: 0;
  padding: 2rem 8rem 2rem 0;
  scroll-padding: 0 0 0 10vw;
  list-style: none;
  display: flex;
  overflow-x: auto;
}

:is(main.home, main.about-us) .cases .items > ul::-webkit-scrollbar {
  display: none;
}

:is(main.home, main.about-us) .cases .items > ul:after {
  content: "";
  flex: 0 0 8rem;
  display: block;
}

:is(main.home, main.about-us) .cases .items li {
  box-sizing: border-box;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  background: var(--white);
  box-shadow: 0 2px 4px var(--gray300);
  flex: 0 0 36rem;
  margin-left: 1.25rem;
  margin-right: 1.25rem;
}

:is(main.home, main.about-us) .cases .items li:first-child {
  margin-left: 10vw;
}

:is(main.home, main.about-us) .cases .items li:last-child {
  margin-right: 11rem;
}

:is(main.home, main.about-us) .cases .items li a {
  text-decoration: none;
}

:is(main.home, main.about-us) .cases .items li a:focus {
  outline: none;
}

:is(main.home, main.about-us) .cases .items .top {
  color: var(--text);
  padding: 2rem;
}

:is(main.home, main.about-us) .cases .items .top h4 {
  color: var(--blue400);
  text-overflow: ellipsis;
  text-transform: uppercase;
  letter-spacing: 1px;
  height: 2.8rem;
  margin: 0;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1;
  overflow-y: hidden;
}

:is(main.home, main.about-us) .cases .items .top h3 {
  margin: .25em 0;
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1.2;
}

:is(main.home, main.about-us) .cases .items figure {
  background-position: 50%;
  background-size: cover;
  height: 24rem;
  margin: 0;
  display: block;
}

:is(main.home, main.about-us) .cases .items .more {
  padding: 1.6rem 2rem;
}

:is(main.home, main.about-us) .cases .items .more span {
  color: var(--blue400);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1;
}

:is(main.home, main.about-us) .clients ul {
  flex-wrap: wrap;
  justify-content: space-between;
  height: 5rem;
  margin: 10rem 0 3rem;
  padding: 0;
  list-style: none;
  display: flex;
  overflow: hidden;
}

:is(main.home, main.about-us) .clients ul li {
  filter: grayscale();
  opacity: .8;
  flex: 1 0 12%;
  height: 100%;
  margin: 0 2.5rem;
  padding: 0;
  transition: all .3s;
  display: block;
  position: relative;
}

:is(main.home, main.about-us) .clients ul li:hover, :is(main.home, main.about-us) .clients ul li:focus {
  filter: grayscale(0%);
  opacity: 1;
}

:is(main.home, main.about-us) .clients ul span {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

@media (width >= 768px) {
  :is(main.home, main.about-us) .cases:after {
    right: 15%;
  }
}

@media (width <= 1024px) {
  :is(main.home, main.about-us) .cases {
    padding: 4rem;
  }

  :is(main.home, main.about-us) .cases .items > ul {
    padding: 2rem 3rem 2rem 0;
    scroll-padding: 0 0 0 3rem;
  }

  :is(main.home, main.about-us) .cases .items > ul:after {
    flex-basis: 3rem;
  }

  :is(main.home, main.about-us) .cases .items li {
    flex-basis: 32rem;
  }

  :is(main.home, main.about-us) .cases .items li:first-child {
    margin-left: 3rem;
  }

  :is(main.home, main.about-us) .cases .items li:last-child {
    margin-right: 0;
  }

  :is(main.home, main.about-us) .cases .items .top {
    padding: 1.6rem;
  }

  :is(main.home, main.about-us) .cases .items .top h4 {
    letter-spacing: 0;
    height: 1.32rem;
    font-size: 1.2rem;
    line-height: 1.2;
  }

  :is(main.home, main.about-us) .cases .items .top h3 {
    font-size: 2rem;
  }
}

.client-fade-enter-active, .client-fade-leave-active {
  transition: opacity .4s;
}

.client-fade-enter, .client-fade-leave-to {
  opacity: 0;
}

.client-fade-enter-active {
  transition-delay: .8s;
}

header.top {
  background: var(--blue500);
  position: relative;
}

header.top h1 {
  background-image: url("/assets/v/tcc-logo-CT0poj7y.svg");
  background-position: 0;
  background-repeat: no-repeat;
  background-size: contain;
  height: 11rem;
  margin: 0 2rem 4rem 0;
}

header.top h1 a {
  height: 100%;
  font: ~ "0/0" a;
  color: #0000;
  text-shadow: none;
  background-color: #0000;
  border: 0;
  display: block;
}

header.top h1 a:focus {
  outline: 1px dotted var(--white);
}

header.top a {
  text-decoration: none;
}

header.top nav {
  display: none;
}

header.top nav a:focus {
  outline: 1px dotted var(--white);
}

header.top section {
  flex-direction: row;
  justify-content: space-between;
  padding: 20px 20px 0;
  display: flex;
}

header.top section h1 {
  flex-grow: 1;
}

header.top .headline {
  color: var(--white);
  padding: 0 2rem 4rem;
}

header.top .headline h2 {
  margin: 0 0 .25em;
  font-size: 2.4rem;
  font-weight: normal;
  line-height: 1.15em;
}

header.top .headline p {
  margin: 1em 0 0;
  line-height: 1.2;
}

header.top .cta {
  margin: 3rem 0 0;
}

header.top .cta a {
  color: var(--white);
  text-transform: uppercase;
  border: 1px solid;
  padding: .75em 1.25em;
  font-size: 1.4rem;
  text-decoration: none;
  transition: all .3s;
  display: inline-block;
}

header.top .cta a:hover, header.top .cta a:focus {
  color: var(--green);
  background: none;
  border-color: currentColor;
}

.nav-toggle {
  flex: 0 0 2rem;
  margin-right: -1em;
  padding: 1em;
  display: inline-block;
}

.nav-toggle span {
  width: 2rem;
  display: block;
  position: relative;
}

.nav-toggle span:before, .nav-toggle span:after {
  content: "";
  width: 100%;
  position: absolute;
}

.nav-toggle span:before {
  top: -6px;
}

.nav-toggle span:after {
  bottom: -6px;
}

.nav-toggle span, .nav-toggle span:before, .nav-toggle span:after {
  background: var(--white);
  height: 2px;
  left: 0;
}

@media (width <= 1024px) {
  header.top nav {
    box-sizing: border-box;
    width: 100vw;
    height: 100vh;
    height: calc(var(--vh) * 100);
    background: var(--blue500);
    z-index: 1000;
    flex-direction: column;
    justify-content: flex-end;
    transition: transform .6s cubic-bezier(.65, 0, .35, 1);
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    transform: translate(-100%);
  }

  header.top nav.active {
    transform: translate(0);
  }

  header.top nav a.close {
    color: var(--white);
    text-align: center;
    width: 1em;
    height: 1em;
    padding: .5em;
    font-size: 4rem;
    line-height: 1em;
    text-decoration: none;
    position: absolute;
    top: 0;
    right: 0;
  }

  header.top nav ul {
    flex-direction: column;
    height: 70vh;
    margin: 0 0 30px;
    padding: 0;
    list-style: none;
    display: flex;
  }

  header.top nav ul li {
    flex: 1;
    display: block;
  }

  header.top nav ul a {
    height: 100%;
    color: var(--white);
    align-items: center;
    padding: 0 .75em;
    font-size: 3rem;
    transition: color .2s;
    display: flex;
  }

  header.top nav ul a:hover, header.top nav ul a:focus {
    color: var(--green);
  }

  header.top nav ul li.active {
    background: var(--white);
  }

  header.top nav ul li.active a {
    color: var(--blue);
  }
}

@media (width >= 768px) {
  header.top h1 {
    height: 170px;
  }

  header.top nav {
    flex: 1;
    margin-left: -1em;
    display: block;
  }

  header.top .headline {
    flex-direction: row;
    justify-content: flex-end;
    padding: 0 2rem 6rem;
    display: flex;
  }

  header.top .headline > div {
    flex: 0 0 50%;
  }

  header.top .headline h2 {
    margin: 0 0 .25em;
    font-size: 4rem;
  }

  header.top .headline p {
    margin: 0 7rem 0 0;
    font-size: 1.8rem;
    line-height: 1.25em;
  }
}

@media (width >= 1024px) {
  header.top section {
    align-items: flex-start;
    padding: 40px 40px 0;
  }

  header.top h1 {
    flex: 0 0 50%;
    height: 125px;
  }

  header.top .nav-toggle {
    display: none;
  }

  header.top nav {
    flex: 0 0 50%;
  }

  header.top nav .close {
    display: none;
  }

  header.top nav ul {
    margin: 0 30px 0 0;
    padding: 0;
    list-style: none;
    display: block;
  }

  header.top nav li {
    font-size: 1.8rem;
    display: inline-block;
  }

  header.top nav ul li:first-child {
    margin-left: -1em;
  }

  header.top nav a {
    color: var(--white);
    padding: .35em 1em;
    display: block;
  }

  header.top nav a span {
    display: inline-block;
    position: relative;
  }

  header.top nav a span:after {
    content: "";
    background: var(--white);
    opacity: 0;
    width: 100%;
    height: 2px;
    transition: all .3s cubic-bezier(.33, 1, .68, 1);
    display: block;
    position: absolute;
    top: 110%;
    left: 0;
    transform: translate(0, 20px);
  }

  header.top nav a:hover span:after, header.top nav a:focus span:after {
    opacity: 1;
    transform: translate(0);
  }

  header.top nav li.active a {
    color: var(--green);
  }

  header.top nav li.active a span:after {
    background: var(--green);
  }
}

.bottom footer {
  background: var(--white);
  margin: 6rem 0 0;
  padding: 2rem;
}

.bottom footer a {
  text-decoration: none;
}

.bottom footer h1 {
  background-image: url("/assets/v/tcc-logo-small-yz533mxi.svg");
  background-position: 0;
  background-repeat: no-repeat;
  background-size: contain;
  height: 24px;
  margin: 0;
}

.bottom footer h1 a {
  text-indent: -999em;
  height: 100%;
  display: block;
}

.bottom footer h2 {
  font-variant: small-caps;
  text-transform: uppercase;
  color: var(--black);
  margin: 2em 0 .5em;
  font-size: 1.8rem;
  font-weight: 600;
}

.bottom footer section {
  color: var(--gray500);
  font-weight: 200;
}

.bottom footer section p {
  line-height: 1.25em;
}

.bottom footer section a {
  color: var(--gray500);
}

.bottom footer section a:hover, .bottom footer section a:focus {
  color: var(--blue);
}

.bottom footer section.tcc {
  flex-direction: column;
  justify-content: space-between;
  display: flex;
}

.bottom footer section.tcc .bcorp {
  background: url("/assets/v/bcorp-DBWUm_YY.svg") 0 100% / contain no-repeat;
  flex: 0 0 10rem;
}

.bottom footer address {
  font-style: normal;
}

.bottom footer div[itemprop="localBusiness"] {
  margin: 1em 0 0;
  line-height: 1.25em;
}

.bottom footer [itemprop="streetAddress"] {
  display: block;
}

.bottom footer [itemprop="addressCountry"] {
  display: none;
}

.bottom footer a[itemprop="telephone"], .bottom footer a[itemprop="email"] {
  display: block;
}

.bottom footer a[itemprop="telephone"] {
  margin: 1em 0 0;
}

.bottom .legal {
  flex-direction: row;
  justify-content: space-between;
  padding: 2rem;
  font-size: 1.4rem;
  display: flex;
}

.bottom .legal a {
  color: var(--black);
}

.bottom .legal .terms a:hover {
  text-decoration: underline;
}

@media (width >= 768px) {
  .bottom footer {
    flex-direction: row;
    justify-content: space-between;
    gap: 3rem;
    margin: 8rem 0 0;
    padding: 4rem;
    display: flex;
  }

  .bottom footer > section {
    flex: 1;
  }

  .bottom footer > section.complaints a {
    color: var(--blue500);
  }

  .bottom footer h2 {
    margin-top: 0;
  }
}

.panel {
  background: var(--white);
  margin: 0 0 2rem;
  padding: 2rem;
}

@media (width >= 768px) {
  .panel {
    margin: 0 0 3rem;
    padding: 4rem 8rem;
  }
}

.tagline {
  background: var(--blue);
  margin: 3em 0 8rem;
  padding: 2rem 2rem 6rem;
  position: relative;
}

.tagline blockquote {
  color: var(--white);
  text-align: center;
  margin: 4rem 0;
  padding: 0;
  font-size: 2.6rem;
  line-height: 1.25em;
}

.tagline strong {
  background: var(--green);
  padding: .1em .25em;
}

.tagline:before {
  content: "";
  pointer-events: none;
  background: url("/assets/v/windmolentje-B4na0F63.png") 100% 0 / contain no-repeat;
  width: 14rem;
  height: 36rem;
  display: block;
  position: absolute;
  bottom: 0;
  right: 3rem;
  transform: translate(0, 80%);
}

@media (width >= 768px) {
  .tagline {
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
    margin-bottom: 0;
    padding: 2rem;
    display: flex;
    position: relative;
  }

  .tagline blockquote {
    text-align: left;
    width: 50%;
  }

  .tagline:before {
    background-position: 50% 0;
    width: 50%;
    height: 110%;
    inset: 0 auto auto 0;
    transform: translate(0, 10%);
  }
}

:is(main.legal, main.careers, main.errors) section {
  background: var(--white);
  min-height: 40vh;
  padding: 3rem;
}

:is(main.legal, main.careers, main.errors) article {
  max-width: 45em;
  margin: 0 auto;
  font-size: 1.6rem;
  line-height: 1.5;
}

:is(main.legal, main.careers, main.errors) h3 {
  text-transform: uppercase;
  color: var(--gray500);
  margin: 1.5em 0 .35em;
  font-size: 1.6rem;
}

@media (width >= 768px) {
  :is(main.legal, main.careers, main.errors) section {
    padding: 8rem 3rem;
  }
}

header.about-us {
  padding-bottom: 7rem;
}

header.about-us:after {
  content: "";
  background: url("/assets/v/vliegtuig-flip-B0Q05X37.png") 50% / contain no-repeat;
  width: 15rem;
  height: 15rem;
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 40%);
}

main.about-us .spirited {
  padding: 12rem 2rem 2rem;
}

main.about-us .spirited article {
  margin-bottom: 4rem;
}

main.about-us .spirited .visuals {
  min-height: 26rem;
  position: relative;
}

main.about-us .spirited figure {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
  margin: 0;
  display: block;
  position: absolute;
}

main.about-us .trailblazers {
  padding: 10rem 2rem 2rem;
}

main.about-us .trailblazers .visuals figure {
  aspect-ratio: 1;
  background-position: center;
  background-size: cover;
  margin: 0;
  display: block;
}

main.about-us .collab {
  padding: 4rem 2rem;
}

main.about-us .collab ol {
  counter-reset: tcc-counter;
  padding: 2rem 0 0;
  list-style: none;
}

main.about-us .collab ol li {
  box-sizing: border-box;
  counter-increment: tcc-counter;
  background: var(--white);
  margin: 0 0 2rem;
  padding: 2rem 2rem 2rem 6rem;
  position: relative;
}

main.about-us .collab ol li:before {
  content: "0" counter(tcc-counter);
  color: var(--green);
  font-size: 2rem;
  font-weight: 600;
  line-height: ;
  position: absolute;
  top: 2rem;
  left: 2.4rem;
}

main.about-us .collab ol h3 {
  margin: 0 0 1rem;
  font-size: 2rem;
}

main.about-us .change figure {
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  margin: 0;
  display: block;
}

main.about-us .change .visuals {
  margin: 6rem 0 0;
}

main.about-us .change .visuals .sustainable {
  background-image: url("/assets/v/sustainable-DPvaYXop.png");
  margin: 0 0 2rem;
  padding-top: 62.5%;
}

main.about-us .change .visuals .bcorp {
  background-image: url("/assets/v/b-corp-i5hY8nnW.png");
}

main.about-us .change .visuals .co2 {
  background-image: url("/assets/v/co2-neutral-D3yBeX7A.png");
}

main.about-us .change .visuals div {
  justify-content: space-between;
  display: flex;
}

main.about-us .change .visuals div figure {
  flex: 0 20rem;
  max-width: 20rem;
  height: 20rem;
}

@media (width >= 768px) {
  main.about-us .spirited {
    justify-content: space-between;
    padding: 8rem;
    display: flex;
  }

  main.about-us .spirited article {
    flex: 2;
  }

  main.about-us .spirited .visuals {
    flex: 3;
  }

  main.about-us .trailblazers {
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center;
    gap: 4rem;
    padding: 8rem;
    display: flex;
  }

  main.about-us .trailblazers article {
    flex: 2;
  }

  main.about-us .trailblazers .visuals {
    flex: 1 0 20rem;
    max-width: 400px;
  }

  main.about-us .collab {
    padding: 4rem;
  }

  main.about-us .collab ol {
    flex-wrap: wrap;
    justify-content: space-between;
    display: flex;
  }

  main.about-us .collab ol li {
    flex: 0 0 calc(50% - 2rem);
    margin: 0 2rem 4rem 0;
  }

  main.about-us .collab ol li:nth-child(2n) {
    margin: 0 0 4rem 2rem;
  }

  main.about-us .change {
    flex-direction: row-reverse;
    justify-content: space-between;
    padding: 8rem;
    display: flex;
  }

  main.about-us .change article, main.about-us .change .visuals {
    flex: 1;
  }

  main.about-us .change .visuals {
    margin: 0 2rem 0 0;
    padding-right: 6rem;
  }

  main.about-us .change .visuals .sustainable {
    margin-bottom: 3rem;
  }
}

main.careers article img {
  max-width: 100%;
  display: block;
}

main.careers hr {
  border: none;
  border-bottom: 1px solid var(--gray300);
  height: 0;
  margin: 6rem 0;
}

main.cases .cases {
  padding-top: 6rem;
}

main.cases .cases .item {
  margin: 0 0 8rem;
}

main.cases .cases .item .card {
  box-sizing: border-box;
  background: var(--white);
  width: 100%;
  max-width: 36rem;
  box-shadow: 0 2px 4px var(--gray300);
  margin: 0 auto 2rem;
}

main.cases .cases .item .card a {
  text-decoration: none;
}

main.cases .cases .item .card a:focus {
  outline: none;
}

main.cases .cases .item .top {
  color: var(--text);
  padding: 2rem;
}

main.cases .cases .item .top h4 {
  color: var(--blue400);
  text-overflow: ellipsis;
  text-transform: uppercase;
  letter-spacing: 1px;
  height: 2.8rem;
  margin: 0;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1;
  overflow-y: hidden;
}

main.cases .cases .item .top h3 {
  margin: .25em 0;
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1.2;
}

main.cases .cases .item figure {
  background-position: 50%;
  background-size: cover;
  height: 24rem;
  margin: 0;
  display: block;
}

main.cases .cases .item .more {
  padding: 1.6rem 2rem;
}

main.cases .cases .item .more span {
  color: var(--blue400);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1;
}

@media (width >= 768px) {
  main.cases .cases {
    padding-top: 10rem;
  }

  main.cases .cases .item {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    max-width: 90rem;
    margin: 0 auto 10rem;
    display: flex;
  }

  main.cases .cases .item .card {
    box-sizing: border-box;
    background: var(--white);
    box-shadow: 0 2px 4px var(--gray300);
    flex: 0 0 36rem;
    margin: 0 4rem 0 0;
  }

  main.cases .cases .item .card a {
    text-decoration: none;
  }

  main.cases .cases .item .card a:focus {
    outline: none;
  }

  main.cases .cases .item:nth-child(2n) {
    flex-direction: row-reverse;
  }

  main.cases .cases .item:nth-child(2n) .card {
    margin: 0 0 0 4rem;
  }

  main.cases .cases .item article p:last-child {
    margin-bottom: 0;
  }

  main.cases .cases .item .top {
    color: var(--text);
    padding: 2rem;
  }

  main.cases .cases .item .top h4 {
    color: var(--blue400);
    text-overflow: ellipsis;
    text-transform: uppercase;
    letter-spacing: 1px;
    height: 2.8rem;
    margin: 0;
    font-size: 1.4rem;
    font-weight: normal;
    line-height: 1;
    overflow-y: hidden;
  }

  main.cases .cases .item .top h3 {
    margin: .25em 0;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.2;
  }

  main.cases .cases .item figure {
    background-position: 50%;
    background-size: cover;
    height: 24rem;
    margin: 0;
    display: block;
  }

  main.cases .cases .item .more {
    padding: 1.6rem 2rem;
  }

  main.cases .cases .item .more span {
    color: var(--blue400);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 1.4rem;
    font-weight: normal;
    line-height: 1;
  }
}

header.cases.view {
  background-color: var(--red);
}

main.cases.view {
  padding: 4rem 2rem 0;
}

main.cases.view section {
  margin: 0 0 6rem;
}

main.cases.view section:last-child {
  margin-bottom: 0;
}

main.cases.view article {
  margin: 0;
}

main.cases.view figure {
  background-position: 50%;
  background-size: cover;
  height: 22rem;
  margin: 0;
}

main.cases.view h3 {
  margin: 0 0 .67em;
  font-size: 2.6rem;
  position: relative;
}

main.cases.view h3:after {
  content: "";
  background: var(--black);
  width: 1ch;
  height: 2px;
  position: absolute;
  bottom: -4px;
  left: 0;
}

main.cases.view .cta {
  text-align: center;
}

main.cases.view .cta a {
  color: var(--text);
  text-transform: uppercase;
  border: 1px solid;
  padding: .75em 1.25em;
  font-size: 1.4rem;
  text-decoration: none;
  transition: border .3s;
  display: inline-block;
}

main.cases.view .cta a:hover, main.cases.view .cta a:focus {
  color: var(--blue);
  background: none;
  border-color: currentColor;
}

@media (width >= 768px) {
  main.cases.view {
    padding: 12rem 10rem;
  }

  main.cases.view section {
    flex-direction: row;
    justify-content: space-between;
    margin: 0 0 10rem;
    display: flex;
  }

  main.cases.view section:nth-child(2n) {
    flex-direction: row-reverse;
  }

  main.cases.view section:nth-child(2n) article {
    margin: 0 0 0 4rem;
  }

  main.cases.view section:nth-child(2n) figure {
    margin: 0 4rem 0 0;
  }

  main.cases.view article {
    flex: 1;
    margin: 0 4rem 0 0;
  }

  main.cases.view figure {
    flex: 1;
    height: auto;
    margin: 0 0 0 4rem;
  }

  main.cases.view h3 {
    font-size: 2.6rem;
  }
}

main.contact .location {
  padding: 3rem;
}

main.contact .location figure.map {
  background: var(--gray300) url("/assets/v/map-BO3qS1gl.png") 50% 50% no-repeat;
  border: 1px solid var(--gray300);
  background-size: cover;
  border-radius: 3px;
  width: 100%;
  height: 40vh;
  margin: 3rem auto 0;
}

main.contact figure.office {
  margin: 0 0 2rem;
}

main.contact figure.office img {
  width: 100%;
  max-width: 100%;
  display: block;
}

@media (width >= 768px) {
  main.contact .location {
    justify-content: space-between;
    padding: 6rem 0 6rem 11rem;
    display: flex;
  }

  main.contact .location article {
    flex-direction: column;
    flex: 4;
    justify-content: space-between;
    margin-right: 3rem;
    font-weight: 200;
    line-height: 1.35em;
    display: flex;
  }

  main.contact .location figure.map {
    flex: 5;
    height: 70vh;
    margin: 0 5rem 0 3rem;
  }
}

header.home {
  padding-bottom: 11rem;
}

header.home:after {
  content: "";
  background: url("/assets/v/globe-BhTb91IR.png") 50% / contain no-repeat;
  width: 15rem;
  height: 22rem;
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 40%);
}

main.home .team {
  flex-direction: column;
  align-items: center;
  padding: 14rem 3rem 8rem;
  display: flex;
}

main.home .team .visuals {
  width: 80vw;
  height: 26rem;
  position: relative;
}

main.home .team .visuals > div {
  background-color: var(--green-darker);
  position: absolute;
}

main.home .team .visuals > div figure {
  -ms-interpolation-mode: bicubic;
  image-rendering: smooth;
  image-rendering: high-quality;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin: 0;
  display: block;
  position: absolute;
  inset: 0;
}

main.home .team .visuals > div:first-child {
  width: 42vw;
  height: 26rem;
  top: 0;
  left: 0;
}

main.home .team .visuals > div:nth-child(2) {
  width: 44vw;
  height: 22rem;
  top: -4rem;
  right: 0;
}

main.home .team .visuals > div:nth-child(3) {
  width: 20rem;
  height: 20rem;
  top: 12rem;
  left: 22vw;
}

main.home .team .visuals > div:nth-child(4), main.home .team .visuals > div:nth-child(5) {
  display: none;
}

main.home .team article {
  margin-top: 12rem;
}

main.home .team article h2 {
  margin: 0 0 .5em;
  font-size: 3.4rem;
  font-weight: 500;
  line-height: 1;
}

main.home .team article p {
  margin: .25em 0 0;
  font-size: 1.6rem;
  font-weight: 200;
  line-height: 1.4;
}

main.home .team .cta {
  margin: 3rem 0 0;
}

main.home .team .cta a {
  color: var(--text);
  text-transform: uppercase;
  border: 1px solid;
  padding: .75em 1.25em;
  font-size: 1.4rem;
  text-decoration: none;
  transition: border .3s;
  display: inline-block;
}

main.home .team .cta a:hover, main.home .team .cta a:focus {
  color: var(--blue);
  background: none;
  border-color: currentColor;
}

@media (width >= 768px) {
  header.home {
    padding-bottom: 0;
  }

  header.home:after {
    width: 22rem;
    height: 32rem;
    left: 10%;
    transform: translate(0, 20%);
  }

  main.home .team {
    align-items: flex-end;
    padding: 10rem 10rem 6rem;
  }

  main.home .team .visuals {
    width: 70rem;
    height: 52rem;
    position: relative;
    transform: translate(6rem)scale(.8);
  }

  main.home .team .visuals > div:first-child {
    width: 40rem;
    height: 26rem;
    top: 0;
    left: 0;
  }

  main.home .team .visuals > div:nth-child(2) {
    width: 18rem;
    height: 18rem;
    top: 8rem;
    left: 42rem;
  }

  main.home .team .visuals > div:nth-child(3) {
    width: 14rem;
    height: 14rem;
    top: 28rem;
    left: 8rem;
  }

  main.home .team .visuals > div:nth-child(4) {
    width: 22rem;
    height: 30rem;
    display: block;
    top: 28rem;
    left: 24rem;
  }

  main.home .team .visuals > div:nth-child(5) {
    width: 22rem;
    height: 22rem;
    display: block;
    top: 28rem;
    left: 48rem;
  }

  main.home .team article {
    align-self: flex-start;
    width: auto;
  }

  main.home .team article h2 {
    font-size: 4.2rem;
  }

  main.home .team article p {
    font-size: 2rem;
  }
}

@media (width >= 1024px) {
  header.home:after {
    width: 25rem;
    height: 39rem;
    bottom: 0;
    left: 15%;
    transform: translate(0, 50%);
  }

  main.home .team {
    padding: 22rem 4rem 6rem;
  }

  main.home .team .visuals {
    transform: none;
  }

  main.home .team article {
    margin: 1.6rem 0 6rem;
  }

  main.home .team article h2 {
    max-width: 37rem;
  }
}

@media (width >= 1150px) {
  main.home .team {
    padding: 22rem 6rem 6rem;
  }

  main.home .team article {
    max-width: 47rem;
    margin: -12.6rem 0 6rem;
  }
}

@media (width >= 1250px) {
  main.home .team {
    padding: 22rem 11rem 6rem;
  }

  main.home .team article {
    max-width: 47rem;
    margin: -17.2rem 0 6rem;
  }
}

.member-fade-enter-active, .member-fade-leave-active {
  transition: opacity .7s;
}

.member-fade-enter, .member-fade-leave-to {
  opacity: 0;
}

main.legal {
  counter-reset: chapterCounter;
}

main.legal h4 {
  counter-increment: chapterCounter;
  margin: 2.5em 0 .25em;
}

main.legal h4:before {
  content: counter(chapterCounter) ". ";
  padding-right: .25em;
  display: inline-block;
}

main.legal h4 + ul {
  list-style: lower-latin;
}

main.legal h4 + p {
  margin-top: .25em;
}

header.vision {
  padding-bottom: 11rem;
}

header.vision:after {
  content: "";
  background: url("/assets/v/vuur-QECZAwv4.png") 50% / contain no-repeat;
  width: 15rem;
  height: 22rem;
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 40%);
}

main.vision .panel:first-child {
  padding-top: 14rem;
}

main.vision .panel.rethink figure {
  margin: 2rem -2rem -2rem;
}

main.vision .panel.rethink figure img {
  width: 100%;
  max-width: 100%;
  display: block;
}

main.vision .panel.reshape section {
  padding-top: 4rem;
}

main.vision .panel.reshape section:first-child {
  padding-top: 0;
}

main.vision .cta {
  margin: 3rem auto 0;
}

main.vision .cta a {
  color: var(--text);
  text-transform: uppercase;
  border: 1px solid;
  padding: .75em 1.25em;
  font-size: 1.4rem;
  text-decoration: none;
  transition: border .3s;
  display: inline-block;
}

main.vision .cta a:hover, main.vision .cta a:focus {
  color: var(--blue);
  background: none;
  border-color: currentColor;
}

main.vision ol {
  counter-reset: tcc-counter;
  padding-left: 1.5em;
  list-style: none;
}

main.vision ol li {
  counter-increment: tcc-counter;
  padding-bottom: .5em;
  position: relative;
}

main.vision ol li:before {
  content: counter(tcc-counter) ".";
  color: var(--green);
  font-weight: 600;
  position: absolute;
  top: 0;
  left: -1.2em;
}

@media (width >= 768px) {
  header.vision {
    padding-bottom: 0;
  }

  header.vision:after {
    width: 22rem;
    height: 32rem;
    left: 10%;
    transform: translate(0, 20%);
  }

  main.vision .panel article, main.vision .panel .cta {
    max-width: 80rem;
  }

  main.vision .panel article section {
    column-count: 2;
    column-gap: 4rem;
  }

  main.vision .panel.rethink figure {
    margin: 4rem -8rem -4rem;
  }

  main.vision .panel.reshape {
    padding: 8rem 2rem;
  }

  main.vision .panel.reshape > div {
    justify-content: space-between;
    max-width: 80rem;
    margin: 0 auto;
    display: flex;
  }

  main.vision .panel.reshape > div section {
    column-count: 1;
    flex-direction: column;
    flex: 1;
    padding: 0 4rem 0 0;
    display: flex;
  }

  main.vision .panel.reshape > div section:last-child {
    padding: 0 0 0 4rem;
  }

  main.vision .panel.reshape > div section h2 {
    flex-grow: 0;
  }

  main.vision .panel.reshape > div section article {
    flex-grow: 1;
  }

  main.vision .panel.reshape > div section .cta {
    flex-grow: 0;
    margin: 3rem 0;
  }
}

@media (width >= 1024px) {
  header.vision:after {
    width: 25rem;
    height: 39rem;
    bottom: 0;
    left: 15%;
    transform: translate(0, 22%);
  }
}

body.whitepaper {
  background: var(--white);
}

body.whitepaper article {
  background: url("/assets/v/tcc-C4Kv-7Dr.png") 50% 30px / 200px no-repeat;
  width: 100%;
  max-width: 47em;
  margin: 0 auto;
  padding: 22rem 3rem 3rem;
  font-size: 1.8rem;
  line-height: 1.7;
}

body.whitepaper img {
  max-width: 100%;
  margin: 0;
  display: block;
}

body.whitepaper h1 {
  letter-spacing: .03em;
  text-align: center;
  margin: 0 0 2em;
  font-size: 3.2rem;
  font-weight: 600;
}

body.whitepaper h2 {
  color: var(--green);
  border-bottom: 3px solid var(--green);
  margin: 3em 0 0;
  padding-bottom: .4em;
  font-size: 2.6rem;
}

body.whitepaper h2:first-of-type {
  margin-top: 0;
}

body.whitepaper h3 {
  margin-top: 2em;
}

body.whitepaper h3 img {
  vertical-align: bottom;
  height: 1.4em;
  margin-right: .5em;
  display: inline-block;
}

body.whitepaper blockquote {
  border-left: 2px solid var(--gray300);
  margin: 1em 0;
  padding: 0 0 0 1em;
  font-style: italic;
}

body.whitepaper a {
  color: var(--green);
  margin: -.15em;
  padding: .15em;
  text-decoration: none;
  transition: all .2s;
}

body.whitepaper a:hover, body.whitepaper a:focus {
  background: var(--green);
  color: var(--white);
}

::selection {
  background: var(--green);
  color: var(--white);
  text-shadow: none;
}

[v-cloak] {
  display: none;
}

html {
  font-family: Nitti Grotesk, system-ui;
  font-size: 62.5%;
}

body {
  background: var(--backgroundGray);
  color: var(--text);
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
  overflow-x: hidden;
}

.wrapper {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}

main {
  display: block;
}

a:focus {
  outline: none;
}

main article p, main article li {
  font-weight: 200;
  line-height: 1.35;
}

main article p:first-child {
  margin-top: 0;
}

main article h2 {
  margin: 0 0 .67em;
  font-size: 2.6rem;
  position: relative;
}

main article h2.f:after {
  content: "";
  background: var(--black);
  width: 1ch;
  height: 2px;
  position: absolute;
  bottom: -4px;
  left: 0;
}

main article a {
  color: var(--blue500);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  margin: -.15em;
  padding: .15em;
  text-decoration: none;
  transition: all .2s;
}

main article a:hover, main article a:focus {
  background: var(--green);
  color: var(--white);
}

@media (width >= 768px) and (width <= 1024px) {
  .wrapper {
    padding: 0;
  }
}

@media (width >= 1024px) {
  .wrapper {
    padding: 3rem 3rem 0;
  }
}

@media (width >= 768px) {
  main h2 {
    font-size: 3.2rem;
  }

  main article {
    max-width: 55em;
    margin: 0 auto;
    font-size: 1.8rem;
  }

  main article .text {
    columns: 10em 2;
    column-gap: 3.5em;
  }
}
