@charset "UTF-8";
@import 'https://fonts.googleapis.com/css2?family=Source+Sans+Pro:ital,wght@0,400;0,600;0,700;0,900;1,400&display=swap';
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: "Source Sans Pro";
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  overflow-x: hidden;
}
body.no-scroll {
  overflow-y: hidden;
}

img,
svg {
  vertical-align: top;
}

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

button,
input,
select,
textarea {
  font-family: inherit;
}

a {
  color: #1d79a8;
  text-decoration: none;
}
a:hover {
  cursor: pointer;
}

ul,
ol {
  padding: 0;
  margin: 0;
  list-style: none;
}

.is-invisible,
.header__search {
  z-index: -1;
  opacity: 0;
  transition: opacity, z-index, 0.25s ease-out;
}

.is-visible {
  z-index: 9;
  opacity: 1;
  transition: opacity, z-index, 0.25s ease-out;
}

.hidden,
.is-hidden,
.header__icon--close-search,
html.no-js .no-js-hidden,
html.js .js-hidden {
  display: none;
}

.is-unhidden {
  display: block;
}

.off-screen,
.form input[type=file] {
  position: absolute;
  left: -9999px;
}

.on-screen,
.no-js .form input[type=file] {
  position: relative;
  left: 0;
}

.overlay,
.header::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  width: 100%;
  background-image: linear-gradient(-180deg, rgba(0, 0, 0, 0.72) 0%, rgba(116, 116, 118, 0) 96%);
  content: "";
  opacity: 0.5;
}

.light-grey-bg {
  background-color: #f7f7f7;
}

.show-mobile {
  display: block;
}
@media (min-width: 768px) {
  .show-mobile {
    display: none;
  }
}

.show-tablet {
  display: none;
}
@media (min-width: 768px) {
  .show-tablet {
    display: block;
  }
}

html {
  font-size: 100%;
  line-height: 1.5;
  color: #404041;
}

/* ============================================
    Families – one mixin per typeface
    :: For each font mixin defined here, make sure each property is negated (set
    :: to its default value, usually `inherit`) in all other font mixins.
*/
h1,
h2,
h3,
h4,
h5,
h6,
.heading-text {
  margin: 0 0 1rem;
  font-family: "Source Sans Pro";
  font-style: inherit;
  font-weight: 700;
}

.body-text {
  font-size: 1.5079365079vw;
}
@media (max-width: 1061.0526315789px) {
  .body-text {
    font-size: 16px;
  }
}
@media (min-width: 1260px) {
  .body-text {
    font-size: 19px;
  }
}

h1,
.alpha {
  font-size: 5.7142857143vw;
  font-weight: 800;
  letter-spacing: -0.02rem;
}
@media (max-width: 700px) {
  h1,
  .alpha {
    font-size: 40px;
  }
}
@media (min-width: 1260px) {
  h1,
  .alpha {
    font-size: 72px;
  }
}

h2,
.beta {
  font-size: 3.3333333333vw;
  letter-spacing: -0.02rem;
}
@media (max-width: 900px) {
  h2,
  .beta {
    font-size: 30px;
  }
}
@media (min-width: 1260px) {
  h2,
  .beta {
    font-size: 42px;
  }
}

h3,
.blockquote,
.gamma {
  font-size: 2.8571428571vw;
  letter-spacing: -0.02rem;
}
@media (max-width: 700px) {
  h3,
  .blockquote,
  .gamma {
    font-size: 20px;
  }
}
@media (min-width: 1260px) {
  h3,
  .blockquote,
  .gamma {
    font-size: 36px;
  }
}

h4,
.delta {
  font-size: 1.9047619048vw;
  letter-spacing: -0.02rem;
}
@media (max-width: 945px) {
  h4,
  .delta {
    font-size: 18px;
  }
}
@media (min-width: 1260px) {
  h4,
  .delta {
    font-size: 24px;
  }
}

h5,
.epsilon {
  font-size: 1.3492063492vw;
}
@media (max-width: 1111.7647058824px) {
  h5,
  .epsilon {
    font-size: 15px;
  }
}
@media (min-width: 1260px) {
  h5,
  .epsilon {
    font-size: 17px;
  }
}

h6,
.pagination,
.nav__item--breadcrumb,
.listing__deadline,
.zeta {
  font-size: 0.9375rem;
}

small,
.milli {
  font-size: 0.8125rem;
}

@font-face {
  font-family: "montserrat";
  font-style: normal;
  font-weight: 200;
  src: url("../../fonts/montserrat/Montserrat-Light.9ff80120ab5d.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "montserrat";
  font-style: normal;
  font-weight: 400;
  src: url("../../fonts/montserrat/Montserrat-Regular.de4a911e831c.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "montserrat";
  font-style: normal;
  font-weight: 600;
  src: url("../../fonts/montserrat/Montserrat-SemiBold.3d2d13853665.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "montserrat";
  font-style: normal;
  font-weight: 700;
  src: url("../../fonts/montserrat/Montserrat-Bold.a79b68fcda60.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "montserrat";
  font-style: normal;
  font-weight: 800;
  src: url("../../fonts/montserrat/Montserrat-Black.c20b9740ecf9.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "noto-sans";
  font-style: normal;
  font-weight: 400;
  src: url("../../fonts/noto-sans/NotoSans.ea46f0e5ea83.woff") format("woff");
  text-rendering: optimizelegibility;
}
@font-face {
  font-family: "noto-sans";
  font-style: normal;
  font-weight: 700;
  src: url("../../fonts/noto-sans/NotoSans-Bold.88748ed4a056.woff") format("woff");
  text-rendering: optimizelegibility;
}
.apply-bar {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
}
@media (min-width: 480px) {
  .apply-bar {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
  }
}
.apply-bar__heading, .apply-bar__subheading {
  margin: 0;
}
.apply-bar__heading {
  display: flex;
  align-items: center;
  margin-bottom: 5px;
  font-size: 36px;
}
@media (min-width: 768px) {
  .apply-bar__heading {
    margin: inherit;
  }
}
.apply-bar__icon {
  margin-right: 10px;
}

a[href="https://apply.opentech.fund/sua-lab/"] {
  display: none;
}

.all-investments-table {
  font-size: 14px;
}
.all-investments-table thead th.desc, .all-investments-table thead th.asc {
  position: relative;
  color: #404041;
}
.all-investments-table thead th.desc::after, .all-investments-table thead th.asc::after {
  position: absolute;
  top: 50%;
  margin-left: 3px;
}
.all-investments-table thead th.desc a, .all-investments-table thead th.asc a {
  color: inherit;
}
.all-investments-table thead th.desc::after {
  width: 0;
  height: 0;
  content: "";
  border-bottom: 7.5px solid #404041;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
}
.all-investments-table thead th.asc::after {
  width: 0;
  height: 0;
  content: "";
  border-top: 7.5px solid #404041;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
}
.all-investments-table thead {
  display: none;
}
@media (min-width: 1024px) {
  .all-investments-table thead {
    display: table-header-group;
  }
}
.all-investments-table thead th.reviews_stats {
  color: rgba(0, 0, 0, 0.6);
}
.all-investments-table thead th.reviews_stats div {
  font-size: 13px;
}
@media (min-width: 1024px) {
  .all-investments-table thead th.title {
    width: 130px;
  }
}
@media (min-width: 1320px) {
  .all-investments-table thead th.title {
    width: 260px;
  }
}
@media (min-width: 1024px) {
  .all-investments-table thead th.phase {
    width: 150px;
  }
}
.all-investments-table thead th.selected input[type=checkbox] {
  margin: 0 auto;
  display: block;
  width: 20px;
  height: 20px;
  border: 1px solid #cfcfcf;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
}
.all-investments-table thead th.selected input[type=checkbox]:checked {
  background: url("./../../images/tick.03718d20977b.svg") #0c72a0 center no-repeat;
  background-size: 12px;
  border: 1px solid #0c72a0;
}
@media (min-width: 1024px) {
  .all-investments-table thead th.selected {
    width: 50px;
    padding-right: 0;
  }
}
@media (min-width: 1024px) {
  .all-investments-table thead th.comments {
    width: 110px;
  }
}
.all-investments-table thead tr:hover {
  box-shadow: none;
}
.all-investments-table tbody td.title {
  position: relative;
  padding-top: 15px;
  font-weight: 700;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.title {
    display: flex;
    align-items: center;
  }
}
@media (min-width: 1320px) {
  .all-investments-table tbody td.title {
    display: table-cell;
  }
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.title.has-tooltip::before {
    position: absolute;
    top: 75px;
    left: 45px;
    z-index: -1;
    width: 200px;
    padding: 5px;
    font-size: 12px;
    font-weight: 400;
    white-space: normal;
    background: #e7f2f6;
    border: 1px solid #14729a;
    content: attr(data-title-tooltip);
    opacity: 0;
    transition: opacity 0.25s ease-out;
  }
  .all-investments-table tbody td.title.has-tooltip:hover::before {
    z-index: 10;
    opacity: 1;
  }
}
.all-investments-table tbody td.title a {
  color: #1d79a8;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.title a {
    color: #404041;
  }
}
.all-investments-table tbody td.phase span {
  display: inline-block;
  padding: 5px;
  font-size: 13px;
  font-weight: 700;
  color: #14729a;
  text-align: center;
  background-color: #e7f2f6;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.phase span {
    width: 100%;
  }
}
.all-investments-table tbody td.comments {
  display: none;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.comments {
    display: table-cell;
    font-size: 13px;
    text-align: center;
    vertical-align: middle;
    background: url("./../../images/quote-outline.e5f1c530def6.svg") transparent no-repeat center center;
    background-size: 24px;
  }
}
.all-investments-table tbody td.reviews_stats {
  display: none;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.reviews_stats {
    display: table-cell;
  }
}
.all-investments-table tbody td.selected {
  display: none;
  padding-right: 0;
}
.all-investments-table tbody td.selected input[type=checkbox] {
  margin: 0 auto;
  display: block;
  width: 20px;
  height: 20px;
  border: 1px solid #cfcfcf;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
}
.all-investments-table tbody td.selected input[type=checkbox]:checked {
  background: url("./../../images/tick.03718d20977b.svg") #0c72a0 center no-repeat;
  background-size: 12px;
  border: 1px solid #0c72a0;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td.selected {
    display: table-cell;
  }
}
.all-investments-table tbody td.fund, .all-investments-table tbody td.round, .all-investments-table tbody td.screening_status {
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td .arrow {
    width: 0;
    height: 0;
    content: "";
    border-left: 9px solid #1d79a8;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    position: relative;
    display: inline-block;
    margin-right: 15px;
    transform: rotate(0);
    transition: transform 0.25s ease-out;
  }
  .all-investments-table tbody td .arrow:hover {
    cursor: pointer;
  }
}
.all-investments-table tbody td > span.mobile-label {
  display: inline-block;
  width: 90px;
}
.all-investments-table tbody td > span.mobile-label.phase, .all-investments-table tbody td > span.mobile-label.title {
  display: none;
}
@media (min-width: 1024px) {
  .all-investments-table tbody td > span.mobile-label {
    display: none;
  }
}
.all-investments-table__parent.is-expanded {
  background-color: #f3fafe;
  border-bottom: 1px solid #e8e8e8;
}
.all-investments-table__parent.is-expanded + .all-investments-table__child {
  border-bottom: 1px solid #e8e8e8;
}
.all-investments-table__parent.is-expanded + .all-investments-table__child,
.all-investments-table__parent.is-expanded + .all-investments-table__child + .all-investments-table__child {
  display: table-row;
}
.all-investments-table__parent.is-expanded .arrow {
  border-right-color: #085071;
  transform: rotate(90deg);
}
.all-investments-table__child {
  display: none;
  color: #919191;
  vertical-align: top;
  background-color: #f3fafe;
  border: 0;
  border-bottom: 2px solid #f7f7f7;
}
.all-investments-table__child:hover {
  box-shadow: none;
}
.all-investments-table__child td {
  padding: 10px;
}
.all-investments-table__child p {
  margin: 0;
  font-weight: 700;
  color: #404041;
}
.all-investments-table__child .title a {
  visibility: hidden;
}
.all-investments-table__empty td {
  padding: 20px;
}
.all-investments-table__toggle {
  padding: 5px 0 5px 5px;
}
.all-investments-table__more {
  display: flex;
  justify-content: center;
  background-color: #fff;
  padding: 20px 25px;
  min-height: auto;
}
.all-investments-table__more a {
  margin: 0;
  flex-basis: auto;
  font-weight: 600;
}

.button {
  padding: 0;
  background-color: transparent;
  background-image: none;
  border: 0;
  box-shadow: none;
}
.button:hover {
  cursor: pointer;
}
.button:disabled, .button.is-disabled {
  pointer-events: none;
  opacity: 0.5;
}
.button--primary {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #1d79a8;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  display: inline-block;
}
.button--primary:hover, .button--primary:active {
  cursor: pointer;
  background: #0c72a0;
}
.form--filters .button--primary {
  width: 100%;
  text-align: center;
  height: 45px;
}
.button--filters {
  display: flex;
  justify-content: space-between;
  max-width: 300px;
  padding: 15px 20px;
  font-weight: 400;
  color: #404041;
  background: url("./../../images/filters.af35bb547443.svg") #fff no-repeat 93% center;
  border: 1px solid #e8e8e8;
  transition: none;
  width: 100%;
}
@media (min-width: 1024px) {
  .button--filters {
    background: none;
    padding: 10px;
    border: 0;
    justify-content: flex-start;
    width: auto;
    opacity: 0.7;
  }
  .button--filters::before {
    content: "";
    background-image: url("./../../images/filters.af35bb547443.svg");
    transform: rotate(90deg);
    background-color: transparent;
    background-position: left center;
    background-size: 20px;
    width: 20px;
    height: 20px;
    display: inline-block;
    margin-right: 10px;
  }
}
.button--filters-header {
  display: flex;
}
.button--search {
  position: absolute;
  top: 0.65em;
  right: 10px;
}
.button--search svg {
  fill: #1d79a8;
}
.button--left-space {
  margin-left: 20px;
}
.button--contains-icons {
  display: flex;
  align-items: center;
}
.header .button--contains-icons {
  margin-right: 20px;
}
.button--transparent, .button--transparent--wide {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
}
.button--transparent:hover, .button--transparent:active, .button--transparent--wide:hover, .button--transparent--wide:active {
  cursor: pointer;
  background: #fff;
}
.header--light-bg .button--transparent, .header--light-bg .button--transparent--wide {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  padding: 5px;
  font-size: 15px;
  color: #141414;
  border: 1px solid #141414;
}
.header--light-bg .button--transparent:hover, .header--light-bg .button--transparent:active, .header--light-bg .button--transparent--wide:hover, .header--light-bg .button--transparent--wide:active {
  cursor: pointer;
  background: #141414;
}
@media (min-width: 1024px) {
  .header--light-bg .button--transparent, .header--light-bg .button--transparent--wide {
    padding: 5px 15px;
  }
}
.button--transparent:hover, .button--transparent--wide:hover {
  color: #0c72a0;
}
.header--light-bg .button--transparent:hover, .header--light-bg .button--transparent--wide:hover {
  color: #fff;
}
.button--transparent {
  padding: 5px;
  font-size: 15px;
}
@media (min-width: 1024px) {
  .button--transparent {
    padding: 5px 15px;
  }
}
.button--cookieconsent {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
}
.button--cookieconsent:hover, .button--cookieconsent:active {
  cursor: pointer;
  background: #fff;
}
.button--cookieconsent:focus, .button--cookieconsent:hover {
  color: #0c72a0;
}
.button--google-translate {
  width: 160px;
  margin-left: 10px;
}
@media (min-width: 1024px) {
  .button--google-translate {
    width: 180px;
  }
}
.button--google-translate .goog-te-gadget-simple {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  padding: 5px;
  font-size: 15px;
  padding: 5px;
  font-family: "Source Sans Pro";
  font-weight: 700;
  transition: background, color, 0.25s ease-out;
}
.button--google-translate .goog-te-gadget-simple:hover, .button--google-translate .goog-te-gadget-simple:active {
  cursor: pointer;
  background: #fff;
}
@media (min-width: 1024px) {
  .button--google-translate .goog-te-gadget-simple {
    padding: 5px 15px;
  }
}
.header--light-bg .button--google-translate .goog-te-gadget-simple {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  padding: 5px;
  font-size: 15px;
  border: 1px solid #141414;
}
.header--light-bg .button--google-translate .goog-te-gadget-simple:hover, .header--light-bg .button--google-translate .goog-te-gadget-simple:active {
  cursor: pointer;
  background: #141414;
}
@media (min-width: 1024px) {
  .header--light-bg .button--google-translate .goog-te-gadget-simple {
    padding: 5px 15px;
  }
}
.button--google-translate .goog-te-gadget-simple:hover .goog-te-menu-value span {
  color: #0c72a0 !important;
}
.header--light-bg .button--google-translate .goog-te-gadget-simple:hover .goog-te-menu-value span {
  color: #fff !important;
}
.button--google-translate .goog-te-gadget-simple .goog-te-menu-value {
  color: #fff;
}
.header--light-bg .button--google-translate .goog-te-gadget-simple .goog-te-menu-value {
  color: #141414;
}
.button--google-translate .goog-te-gadget-simple .goog-te-menu-value span {
  color: #fff !important;
  transition: color 0.25s ease-out;
}
.header--light-bg .button--google-translate .goog-te-gadget-simple .goog-te-menu-value span {
  color: #141414 !important;
}
.button--google-translate .goog-te-gadget-simple .goog-te-menu-value span:nth-of-type(2) {
  display: none;
}
.button--google-translate .goog-te-gadget-icon {
  display: none;
}

.actions-bar {
  margin: 20px 0;
  width: 100%;
}
@media (min-width: 1024px) {
  .actions-bar {
    display: flex;
    justify-content: space-between;
  }
}
.actions-bar__inner > * {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .actions-bar__inner {
    display: flex;
    align-items: center;
  }
  .actions-bar__inner > * {
    margin: 0 0 0 20px;
  }
  .actions-bar__inner > *:first-child {
    margin-left: 0;
  }
}
.actions-bar__inner--left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.actions-bar__inner--right {
  align-items: flex-end;
}
.actions-bar__inner--batch-actions {
  display: none;
}
@media (min-width: 1024px) {
  .actions-bar__inner--batch-actions {
    display: flex;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease;
    margin: 20px 0 0;
  }
  .batch-actions-enabled .actions-bar__inner--batch-actions {
    opacity: 1;
    pointer-events: all;
  }
}
.actions-bar__total {
  background-color: #1d79a8;
  color: #fff;
  padding: 6px 16px;
  border-radius: 30px;
  min-width: 120px;
  text-align: center;
  font-weight: 600;
}

.blockquote {
  position: relative;
  font-weight: 800;
  text-align: center;
}
.blockquote__cite, .blockquote__job-title {
  font-size: 1.3492063492vw;
  display: block;
  font-style: normal;
  color: #3d6bdb;
  text-transform: uppercase;
}
@media (max-width: 1111.7647058824px) {
  .blockquote__cite, .blockquote__job-title {
    font-size: 15px;
  }
}
@media (min-width: 1260px) {
  .blockquote__cite, .blockquote__job-title {
    font-size: 17px;
  }
}
.blockquote__cite h5 {
  margin: 0;
}
.blockquote__job-title {
  font-weight: 400;
}

.wmd-preview {
  background-color: #e7f2f6;
  padding: 0 10px;
  width: 100%;
  overflow: hidden; /* prevent collapsing margins */
}
.wmd-preview ul {
  padding-left: 20px;
  list-style: outside disc;
}
.wmd-preview ol {
  list-style: inside decimal;
}

.wmd-button-row {
  display: flex;
  background-color: #fff;
  padding: 4px;
}

.wmd-spacer {
  background-color: #cfcfcf;
  width: 1px;
  height: 20px;
  margin: 0 14px;
  list-style: none;
}

.wmd-button {
  width: 20px;
  height: 20px;
  margin: 0 2px;
  list-style: none;
  cursor: pointer;
}
.wmd-button > span {
  display: inline-block;
  background-image: url("./../../images/editor-buttons.235c6a346ad7.png");
  background-repeat: no-repeat;
  background-position: 0 0;
  width: 20px;
  height: 20px;
}

.wmd-prompt-background {
  background-color: #141414;
}

.wmd-prompt-dialog {
  background-color: #f7f7f7;
  padding: 0.5em;
  border: 4px solid #1d79a8;
}

.card {
  position: relative;
  padding: 30px 30px 100px;
  background-color: #fff;
  transition: background-color, color, 0.25s ease-out;
}
.card--lab {
  box-shadow: 0 8px 15px 0 rgba(0, 0, 0, 0.1);
}
.card:hover {
  color: #fff;
  background: #1d79a8;
}
.card__teaser {
  margin-top: 5px;
  font-size: 16px;
  color: #404041;
  transition: color 0.25s ease-out;
}
.card:hover .card__teaser {
  color: #fff;
}
.card__heading {
  margin-bottom: 0;
}
.card__subheading {
  margin: 0 0 5px;
  color: #d02a85;
  transition: color 0.25s ease-out;
}
.card:hover .card__subheading {
  color: #fff;
}
.card__icon {
  margin-bottom: 10px;
}

.card-with-image:only-child {
  max-width: 260px;
}

.card-slim {
  padding: 20px;
  color: #1d79a8;
  background-color: #fff;
  border-left: 5px solid #1d79a8;
  box-shadow: 0 2px 15px 0 rgba(0, 0, 0, 0.1);
  transition: background-color, color, 0.25s ease-out;
}
@media (min-width: 1024px) {
  .card-slim {
    padding: 25px 50px 30px 35px;
  }
}
.card-slim:hover {
  color: #fff;
  background-color: #1d79a8;
  border-left: 5px solid #0c72a0;
}
.card-slim__contents {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.card-slim__contents > div {
  flex: 1;
  max-width: 450px;
}
.card-slim__icon {
  width: 20px;
  height: 30px;
  margin-left: 20px;
  transition: fill 0.25s ease-out;
  fill: #1d79a8;
}
.card-slim:hover .card-slim__icon {
  fill: #fff;
}
.card-slim__summary {
  display: none;
  margin: 0;
  font-size: 16px;
  color: #404041;
  transition: color 0.25s ease-out;
}
.card-slim:hover .card-slim__summary {
  color: #fff;
}
@media (min-width: 480px) {
  .card-slim__summary {
    display: block;
  }
}

.call-to-action {
  padding: 1rem 0;
  margin: 1rem 0;
}

.cookieconsent {
  position: fixed;
  bottom: 0;
  color: #fff;
  background-color: #0c72a0;
  border-top: 4px solid #1d79a8;
  transform: translateY(100vh);
  transition: all 0.25s ease-out;
}
.cookieconsent a {
  color: inherit;
}

.js-cookieconsent-open {
  transform: translateY(0);
}

.form--header-search-desktop {
  max-width: 300px;
  border-bottom: 1px solid #fff;
}
.form--with-p-tags p {
  margin: 0 0 10px;
}
.form--with-p-tags p label {
  display: block;
  margin-bottom: 0.5em;
  font-weight: 700;
}
.form--with-p-tags button {
  margin-top: 10px;
}
.form--user-login {
  padding-bottom: 3em;
}
.form--user-login ul {
  margin-bottom: 20px;
}
.form--user-login ol {
  margin-bottom: 20px;
}
.form--search-desktop {
  position: relative;
  max-width: 300px;
  margin-top: 20px;
}
@media (min-width: 1024px) {
  .form--search-desktop {
    max-width: 280px;
    margin: 0 0 0 30px;
  }
}
.form__group {
  position: relative;
  margin: 1rem 0;
}
.form__group:nth-of-type(1) {
  margin-top: 0;
}
.locality .form__group:last-child {
  margin-bottom: 0;
}
.form__group--wrap {
  flex-wrap: wrap;
}
.form__group--checkbox .form__item {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.form__group input[type=date]:last-child {
  max-width: 385px;
}
.form .field-group-wrapper {
  padding: 0.5rem;
  margin-bottom: 1rem;
  border: 1px solid #cfcfcf;
}
.form .field-group-wrapper.highlighted {
  animation: background-fade-highlight 2.5s ease-out;
}
@keyframes background-fade-highlight {
  0% {
    background-color: #e7f2f6;
  }
  100% {
    background-color: transparent;
  }
}
.form__question {
  display: block;
  margin-bottom: 0.5em;
  font-weight: 700;
}
.form__question--image_field, .form__question--multi_file_field, .form__question--single_file_field, .form__question--file_field {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #1d79a8;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  max-width: 290px;
  text-align: center;
  background: url("./../../images/upload.c90eefa7441d.svg") #1d79a8 no-repeat 50px center;
  border: 0;
}
.form__question--image_field:hover, .form__question--image_field:active, .form__question--multi_file_field:hover, .form__question--multi_file_field:active, .form__question--single_file_field:hover, .form__question--single_file_field:active, .form__question--file_field:hover, .form__question--file_field:active {
  cursor: pointer;
  background: #3d6bdb;
}
.no-js .form__question--image_field, .no-js .form__question--multi_file_field, .no-js .form__question--single_file_field, .no-js .form__question--file_field {
  display: none;
}
.form__question--image_field:hover, .form__question--multi_file_field:hover, .form__question--single_file_field:hover, .form__question--file_field:hover {
  background: url("./../../images/upload.c90eefa7441d.svg") #3d6bdb no-repeat 50px center;
}
.no-js .form__question--image_field:hover, .no-js .form__question--multi_file_field:hover, .no-js .form__question--single_file_field:hover, .no-js .form__question--file_field:hover {
  background: none;
}
.form__question--boolean_field {
  display: inline;
  font-size: 17px;
  margin-bottom: 0;
}
.form__file-list ul {
  margin: 0.5rem 0;
}
.form__file-drop-zone {
  color: #cfcfcf;
  padding: 25px;
  font-size: 17px;
  font-weight: 700;
  text-align: center;
  border: 2px dashed #cfcfcf;
  border-radius: 5px;
}
.form__filters .select2 .select2-selection.select2-selection--single {
  border: 0;
  border-top: 1px solid #cfcfcf;
}
.form__filters .select2 .select2-selection.select2-selection--single.is-active {
  font-weight: 400;
  background-color: rgba(29, 121, 168, 0.1);
  border-color: #cfcfcf;
}
@media (min-width: 1024px) {
  .form__filters .select2 .select2-selection.select2-selection--single {
    border: 1px solid #cfcfcf;
  }
}
@media (min-width: 1024px) {
  .form__filters {
    display: flex;
    align-items: flex-start;
    padding: 10px 0 30px;
    opacity: 0;
    transition: opacity 0.25s ease-out;
  }
  .filters-open .form__filters {
    opacity: 1;
    transition-delay: 300ms;
  }
  .filters--dates .form__filters {
    align-items: flex-end;
    margin: 10px 0 30px;
    padding: 0;
  }
}
.form__filters label {
  display: none;
}
.filters--dates .form__filters label {
  display: block;
}
@media (min-width: 1024px) {
  .form__filters > * {
    flex-basis: 225px;
  }
  .form__filters > *:not(:last-child) {
    margin-right: 10px;
  }
}
.form__filters--mobile {
  flex-direction: column;
  padding: 0;
}
.form__filters--mobile > * {
  flex-basis: auto;
  margin: 0;
}
.form__filters > li {
  padding: 0 1rem;
}
@media (min-width: 1024px) {
  .form__filters > li {
    padding: 0;
  }
}
.filters--dates .form__filters > li {
  margin: 0 auto 1rem;
  max-width: 320px;
}
@media (min-width: 480px) {
  .filters--dates .form__filters > li {
    display: flex;
    max-width: 600px;
  }
  @supports (display: grid) {
    .filters--dates .form__filters > li {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-gap: 5px;
    }
  }
}
@media (min-width: 1024px) {
  .filters--dates .form__filters > li {
    margin: 0 1rem 0 0;
    max-width: initial;
  }
}
@supports (display: grid) {
  .filters--dates .form__filters > li label {
    grid-column: 1;
    grid-row: 1;
  }
}
@supports (display: grid) {
  .filters--dates .form__filters > li input:first-of-type {
    grid-column: 1;
  }
}
@supports (display: grid) {
  .filters--dates .form__filters > li span {
    grid-column: 2;
    grid-row: 1;
  }
}
.form__required {
  color: #8c0bbf;
}
.form__help-link a:hover {
  cursor: pointer;
  color: #3d6bdb;
}
.form__open-icon {
  width: 20px;
  height: 20px;
  fill: #404041;
}
.form__item {
  position: relative;
  padding-bottom: 10px;
}
.form__select {
  max-width: 385px;
  background: url("./../../images/dropdown.4c178fe0d732.svg") #fff no-repeat 95% center;
  background-size: 8px;
}
.form--scoreable .form__select {
  margin-top: 20px;
}
.form__select .form__filters .form__select .form {
  max-width: 100%;
}
.form__select .form__filters .form__select .form select {
  height: 45px;
}
.form__select select[multiple=multiple] {
  display: block;
}
.form__select select {
  background: transparent;
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.form__select select option {
  background-color: #fff;
}
.form__select--narrow {
  width: 100%;
  max-width: none;
}
@media (min-width: 480px) {
  .form__select--narrow {
    max-width: 280px;
  }
}
.form__select--inline {
  display: inline-block;
}
.form select,
.form input[type=url],
.form input[type=text]:not(.input--secondary),
.form input[type=date],
.form input[type=time],
.form input[type=email]:not(.input--secondary),
.form input[type=number],
.form input[type=password],
.form input[type=datetime-local] {
  width: 100%;
  max-width: 385px;
  padding: 0.4em;
  border: 1px solid #cfcfcf;
}
.form select:disabled,
.form input[type=url]:disabled,
.form input[type=text]:not(.input--secondary):disabled,
.form input[type=date]:disabled,
.form input[type=time]:disabled,
.form input[type=email]:not(.input--secondary):disabled,
.form input[type=number]:disabled,
.form input[type=password]:disabled,
.form input[type=datetime-local]:disabled {
  color: rgba(0, 0, 0, 0.5);
  cursor: not-allowed;
}
.form select.invalid,
.form input[type=url].invalid,
.form input[type=text]:not(.input--secondary).invalid,
.form input[type=date].invalid,
.form input[type=time].invalid,
.form input[type=email]:not(.input--secondary).invalid,
.form input[type=number].invalid,
.form input[type=password].invalid,
.form input[type=datetime-local].invalid {
  border: 2px solid #f05e54;
  outline: none;
}
.form__error select,
.form__error textarea,
.form__error input[type=url],
.form__error input[type=text],
.form__error input[type=date],
.form__error input[type=time],
.form__error input[type=email],
.form__error input[type=number],
.form__error input[type=password],
.form__error input[type=datetime-local] {
  border: 2px solid #f05e54;
}
.form__error-text {
  max-width: 200px;
  padding: 5px;
  margin: 20px 0 0;
  color: #fff;
  background: #f05e54;
  z-index: 1;
}
@media (min-width: 1024px) {
  .form__error-text {
    position: absolute;
    top: 0;
    right: 0;
    max-width: auto;
    margin: 0;
  }
  .form__error-text::before {
    position: absolute;
    top: 12px;
    left: -10px;
    border-color: transparent #f05e54 transparent transparent;
    border-style: solid;
    border-width: 5px 10px 5px 0;
    content: "";
  }
}
.form input[type=date] {
  max-width: 285px;
}
.form input[type=date] + input[type=time] {
  width: 100px;
}
.form textarea {
  width: 100%;
  padding: 0.4em;
  border: 1px solid #cfcfcf;
  line-height: 1.5;
}
.form [type=radio],
.form [type=checkbox] {
  appearance: none;
  accent-color: #0c72a0;
  height: 0.7em;
  width: 0.7em;
  outline: 2px solid #0c72a0;
}
.form [type=radio] + label,
.form [type=checkbox] + label {
  padding-inline-start: 0.5em;
}
.form [type=radio] + label:hover,
.form [type=checkbox] + label:hover {
  font-weight: bold;
}
.form [type=radio]:checked,
.form [type=checkbox]:checked {
  background-color: #0c72a0;
}
.form [type=radio] {
  border-radius: 50%;
  outline-offset: 2px;
}
.form input[type=checkbox] {
  height: 1em;
  width: 1em;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 0.8em;
}
.form input[type=checkbox]:checked {
  background-image: url("./../../images/tick.03718d20977b.svg");
}
.form .errorlist {
  padding: 5px;
  margin-bottom: 0.2em;
  background: #ffe1df;
  border: 1px solid #f05e54;
}
.form .address {
  padding: 0.4em;
  border: 1px solid #cfcfcf;
  max-width: 410px;
}
.form .multi-input-field-hidden {
  display: none;
}
.form .password-reset {
  margin-top: -1em;
}

.flash-item {
  animation: flash 1s ease 1;
}

@keyframes flash {
  50% {
    background-color: #e6ab32;
  }
}
.heading--introduction {
  padding: 0 0 2rem;
  margin: 2rem 0;
  font-weight: 200;
  border-bottom: 1px solid #cfcfcf;
}
.heading--author {
  margin: 2rem 0 0;
}
.heading--no-margin {
  margin: 0;
  line-height: 1;
}
.heading--small-margin {
  margin: 0;
  line-height: 1.2;
}
.heading--regular {
  font-weight: 400;
}
.heading--person-introduction {
  margin: 1rem 0;
  font-weight: 200;
}
.heading--top-space {
  margin-top: 1rem;
}
.heading--total-funding span {
  color: #8c0bbf;
}
.heading--center {
  text-align: center;
}
.heading--listings-introduction {
  margin: 1rem 0;
  font-weight: 400;
}
.heading--contains-link {
  display: inline-block;
}
.heading--focus-areas {
  font-size: 3.3333333333vw;
}
@media (max-width: 720px) {
  .heading--focus-areas {
    font-size: 24px;
  }
}
@media (min-width: 1260px) {
  .heading--focus-areas {
    font-size: 42px;
  }
}

.focus-area {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 30px;
  border: 1px solid #cfcfcf;
}
.focus-area__icon {
  margin-bottom: 30px;
  stroke: #40c2ad;
}
.focus-area__teaser {
  width: 100%;
}
.focus-area__teaser span {
  font-weight: 700;
}

.fund-box {
  padding: 10px 15px;
  border: 1px solid #cfcfcf;
}
@media (min-width: 480px) {
  .fund-box {
    padding: 20px 30px;
  }
}
.fund-box__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 50px;
  padding: 0 10px;
  margin-bottom: 5px;
  background-color: #f7f7f7;
}
@media (min-width: 480px) {
  .fund-box__row {
    padding: 0 20px;
  }
}
.fund-box__link {
  display: inline-block;
  margin-bottom: 20px;
}
.fund-box__link:last-of-type {
  margin-bottom: 0;
}

.grid {
  display: flex;
  flex-wrap: wrap;
}
.grid > * {
  flex-basis: calc(100% - 20px);
  margin: 10px;
}
@media all and (min-width: 480px) {
  .grid > * {
    flex-basis: calc(50% - 20px);
  }
}
@media all and (min-width: 1024px) {
  .grid > * {
    flex-basis: calc(30% - 20px);
  }
}
.grid--narrow {
  text-align: center;
}
@media (min-width: 768px) {
  .grid--narrow {
    text-align: left;
  }
}
@media (min-width: 480px) {
  .grid--focus-areas {
    justify-content: center;
  }
}
.grid--focus-areas > * {
  flex-basis: 100%;
}
@media (min-width: 480px) {
  .grid--focus-areas > * {
    flex-basis: calc(35% - 20px);
  }
}
@media (min-width: 1320px) {
  .grid--focus-areas > * {
    flex-basis: calc(20% - 20px);
  }
}
.grid--max-three > * {
  flex-basis: 100%;
}
@media (min-width: 600px) {
  .grid--max-three > * {
    flex-basis: calc(30% - 20px);
  }
}
@media (min-width: 1320px) {
  .grid--max-three > * {
    flex-basis: 260px;
  }
}

@supports (display: grid) {
  .grid {
    display: grid;
    margin: 30px 0;
    grid-gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }
  .grid > * {
    flex-basis: initial;
    width: auto;
    margin: 0;
  }
  .grid--narrow {
    justify-content: center;
    text-align: center;
    grid-template-columns: repeat(auto-fit, minmax(200px, 200px));
  }
  @media (min-width: 768px) {
    .grid--narrow {
      justify-content: flex-start;
      text-align: left;
    }
  }
  .grid--one {
    grid-template-columns: 1fr;
    grid-gap: 30px;
  }
  .grid--two {
    grid-template-columns: 100%;
    grid-gap: 0;
  }
  @media (min-width: 768px) {
    .grid--two {
      grid-template-columns: 1fr 1fr;
    }
  }
  .grid--max-three {
    grid-template-columns: 1fr;
    grid-gap: 30px;
  }
  @media (min-width: 600px) {
    .grid--max-three {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (min-width: 768px) {
    .grid--max-three {
      grid-template-columns: repeat(3, 1fr);
    }
  }
  .grid--medium-gap {
    grid-gap: 35px;
  }
  .grid--small-gap {
    grid-gap: 20px;
  }
  .grid--no-margin {
    margin: 0;
  }
  .grid--proposal-info {
    padding-bottom: 30px;
    margin: 0 0 30px;
    border-bottom: 1px solid #cfcfcf;
    grid-template-columns: 100%;
    grid-gap: 10px;
  }
  @media (min-width: 480px) {
    .grid--proposal-info {
      margin: 0 0 30px;
      grid-template-columns: 1fr 1fr;
    }
  }
  .grid--proposal-info * {
    margin: 0;
  }
  .grid--focus-areas {
    margin: 20px 0;
    grid-gap: 20px;
    grid-template-columns: 1fr;
  }
  @media (min-width: 600px) {
    .grid--focus-areas {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (min-width: 1024px) {
    .grid--focus-areas {
      justify-content: space-between;
      margin: 3rem 0;
      text-align: center;
      grid-template-columns: repeat(4, 1fr);
      grid-gap: 35px;
    }
  }
}
.icon {
  width: 20px;
  height: 20px;
  transition: fill 0.25s ease-out;
  fill: #fff;
}
.header--light-bg .icon {
  fill: #404041;
}
.header__menus--mobile.is-visible .icon {
  fill: #fff;
}
@media (min-width: 768px) {
  .icon--footer-social {
    margin-right: 10px;
  }
}
.icon--mobile-menu {
  width: 32px;
  height: 28px;
}
.icon--footer-credit {
  width: 70px;
  height: 45px;
  margin-right: 3rem;
}
.icon--person {
  width: 15px;
  height: 15px;
  margin-right: 5px;
  transition: fill 0.25s ease-out;
  fill: #fff;
}
.button:hover .icon--person {
  fill: #0c72a0;
}
.header--light-bg .button:hover .icon--person {
  fill: #fff;
}
.header--has-bg-image .icon--person {
  fill: #0c72a0;
}
.search-open .icon--person, .header--homepage .icon--person {
  fill: #fff;
}
.header--light-bg.search-open .icon--person {
  fill: #404041;
}
.icon--social-share {
  width: 40px;
  height: 40px;
  padding: 10px;
  margin-right: 5px;
  margin-bottom: 10px;
}
.icon--twitter-share {
  background: #1da6f6;
}
.icon--linkedin-share {
  background: #137ab8;
}
.icon--facebook-share {
  background: #396ab5;
}
.icon--website-share {
  padding: 12px;
  background: #8c0bbf;
}
.icon--github-share {
  background: #141414;
}
.icon--card-pixels {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 35px;
  height: 52px;
}
.icon--calendar {
  transition: fill 0.25s ease-out;
  fill: #d02a85;
}
.card:hover .icon--calendar {
  fill: #fff;
}
.icon--error {
  width: 25px;
  height: 25px;
  margin-right: 10px;
}
.header--light-bg.search-open .icon--search {
  fill: #fff;
}
.icon--status {
  width: 65px;
  height: 160px;
  stroke: #cfcfcf;
  fill: transparent;
}
.is-active .icon--status {
  stroke: #40c2ad;
}
.icon--small {
  width: 14px;
  height: 14px;
}
.icon--body-pixels-right {
  position: absolute;
  right: 0;
  z-index: -1;
  display: none;
  width: 218px;
  height: 457px;
  fill: #0c72a0;
}
@media (min-width: 1320px) {
  .icon--body-pixels-right {
    display: block;
  }
}
.icon--body-pixels-left {
  position: absolute;
  top: -355px;
  left: 0;
  display: none;
  width: 109px;
  height: 275px;
  fill: #0c72a0;
}
@media (min-width: 1320px) {
  .icon--body-pixels-left {
    display: block;
  }
}
.icon--anchor-link {
  background-size: contain;
  margin-left: 7px;
  margin-top: 15px;
  fill: #f05e54;
}

.image--headshot-mobile {
  display: block;
}
@media (min-width: 768px) {
  .image--headshot-mobile {
    display: none;
  }
}
.image--headshot-desktop {
  display: none;
}
@media (min-width: 768px) {
  .image--headshot-desktop {
    display: block;
    margin-bottom: 20px;
  }
}
.image--float-small {
  display: block;
  margin: 0 auto 10px;
}
@media (min-width: 600px) {
  .image--float-small {
    float: right;
    margin: 10px 0 10px 10px;
  }
}

.investment-meta {
  background-color: transparent;
}
.investment-meta tbody td.phase span {
  display: inline-block;
  padding: 10px;
  font-size: 13px;
  font-weight: 700;
  color: #919191;
  text-align: center;
  background-color: transparent;
  border: 1px solid #919191;
}
.investment-meta__row {
  border: 0;
}
.investment-meta__row:hover {
  box-shadow: none;
}
.investment-meta__row--black {
  color: #404041;
}
.investment-meta__row th,
.investment-meta__row td {
  padding: 5px 10px;
}
.investment-meta__row td.lead span {
  background: #f3fafe;
}

.input--transparent {
  color: #fff;
  background: transparent;
  border: 0;
}
.input--bottom-space {
  margin-bottom: 10px;
}
.input--search {
  width: 100%;
  padding: 10px;
  color: #404041;
  background: transparent;
  border: 1px solid #919191;
}

.link:disabled, .link.is-disabled {
  pointer-events: none;
  opacity: 0.5;
}
.link--button {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #1d79a8;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  display: inline-block;
  line-height: 1;
}
.link--button:hover, .link--button:active {
  cursor: pointer;
  background: #3d6bdb;
}
.link--button--narrow {
  padding: 5px;
  font-size: 15px;
}
@media (min-width: 1024px) {
  .link--button--narrow {
    padding: 5px 15px;
  }
}
.link--button__stretch {
  width: 100%;
}
@media (min-width: 480px) {
  .link--button__stretch {
    width: inherit;
  }
}
.link--button__center {
  display: block;
  width: fit-content;
  margin: 0 auto;
}
.link--button-secondary {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #8c0bbf;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
}
.link--button-secondary:hover, .link--button-secondary:active {
  cursor: pointer;
  background: #45055f;
}
.link--button-tertiary {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  color: #8c0bbf;
  border-color: #8c0bbf;
}
.link--button-tertiary:hover, .link--button-tertiary:active {
  cursor: pointer;
  background: #45055f;
}
.link--button-tertiary:focus, .link--button-tertiary:hover {
  color: #fff;
}
.link--button-transparent {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  color: #fff;
}
.link--button-transparent:hover, .link--button-transparent:active {
  cursor: pointer;
  background: #3d6bdb;
}
.link--button-transparent:focus, .link--button-transparent:hover {
  border: 1px solid transparent;
}
.link--button-white {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  color: #141414;
  border-color: #141414;
}
.link--button-white:hover, .link--button-white:active {
  cursor: pointer;
  background: #141414;
}
.link--button-white:focus, .link--button-white:hover {
  color: #fff;
}
.link--button-white--narrow {
  padding: 5px;
  font-size: 15px;
}
@media (min-width: 1024px) {
  .link--button-white--narrow {
    padding: 5px 15px;
  }
}
.link--button-long-text {
  padding: 10px;
}
@media (min-width: 768px) {
  .link--button-long-text {
    padding: 10px 60px;
  }
}
.link--button-narrow {
  padding: 5px;
  font-size: 15px;
}
@media (min-width: 1024px) {
  .link--button-narrow {
    padding: 5px 15px;
  }
}
@media (min-width: 1024px) {
  .link--button-wide {
    padding: 0.5em 80px;
  }
}
.link--underlined {
  text-decoration: underline;
}
.link--footer-signup {
  margin-top: 1rem;
}
.link--mobile-standout {
  display: block;
  width: 100%;
  max-width: 250px;
  margin: 1rem auto 0;
  font-weight: 700;
  text-align: center;
}
@media (min-width: 768px) {
  .link--mobile-standout {
    display: none;
  }
}
.link--fixed-apply {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: #8c0bbf;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  position: fixed;
  bottom: 0;
  z-index: 100;
  display: none;
  color: #fff;
  border: 0;
}
.link--fixed-apply:hover, .link--fixed-apply:active {
  cursor: pointer;
  background: #45055f;
}
@media (min-width: 768px) {
  .link--fixed-apply {
    right: 5%;
    display: block;
  }
}
@media (min-width: 1024px) {
  .link--fixed-apply {
    right: 10%;
  }
}
.link--small {
  font-size: 15px;
}
.link--arrow-pixels-blue {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: #0c72a0;
}
.link--arrow-pixels-blue::after {
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #0c72a0;
  content: "";
}
.link--arrow-pixels-blue svg {
  width: 10px;
  height: 14px;
  margin-left: 10px;
  fill: #0c72a0;
}
.link--arrow-pixels-white {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  color: #fff;
}
.link--arrow-pixels-white::after {
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #fff;
  content: "";
}
.link--arrow-pixels-white svg {
  width: 10px;
  height: 14px;
  margin-left: 10px;
  fill: #fff;
}

.list--flex {
  display: flex;
}
.list--contact {
  margin: 0;
}
.list--contact > span {
  font-weight: 700;
}
.list--status {
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 0 20px;
  color: #cfcfcf;
  text-align: center;
}
.list--status.is-active {
  color: #404041;
}
.list--disc {
  padding-left: 20px;
  list-style: outside disc;
}
.list--disc li {
  margin-bottom: 1rem;
}
.list__label {
  padding: 10px;
  margin-right: 20px;
  color: #fff;
  background: #1d79a8;
}

.section--list-straight-left ul, .form--user-login ul {
  display: table;
  list-style: none;
  padding: 0;
}
.section--list-straight-left ul > li, .form--user-login ul > li {
  display: table-row;
}
.section--list-straight-left ul > li::before, .form--user-login ul > li::before {
  display: table-cell;
  content: "•";
  padding-right: 1rem;
}

.section--list-straight-left ol, .form--user-login ol {
  display: table;
  list-style: none;
  padding: 0;
}
.section--list-straight-left ol > li, .form--user-login ol > li {
  display: table-row;
  counter-increment: table-ol;
}
.section--list-straight-left ol > li::before, .form--user-login ol > li::before {
  display: table-cell;
  content: counter(table-ol) ".";
  padding-right: 1rem;
  text-align: right;
}

.listing {
  padding: 20px;
  margin-bottom: 20px;
  background: #fff;
  transition: box-shadow 0.25s ease-out;
}
@media (min-width: 768px) {
  .listing {
    position: relative;
    min-height: 180px;
    padding: 30px 210px 30px 30px;
  }
}
.listing:hover {
  box-shadow: 0 2px 15px 0 rgba(0, 0, 0, 0.1);
}
.listing--not-a-link {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0 0 20px;
  margin: 0 0 20px;
  border-bottom: 1px solid #e8e8e8;
}
@media (min-width: 480px) {
  .listing--not-a-link {
    align-items: center;
    flex-direction: row;
    height: 160px;
  }
}
.listing--not-a-link:hover {
  box-shadow: none;
}
.listing--not-a-link:first-child {
  padding-top: 20px;
  border-top: 1px solid #e8e8e8;
}
@media (min-width: 480px) {
  .listing--not-a-link:first-child {
    padding-top: 0;
    border-top: 0;
  }
}
.listing--not-a-link:last-child {
  border-bottom: 0;
}
.listing--not-a-link > div {
  flex-basis: 55%;
}
.listing--with-button .button {
  float: right;
}
@media (min-width: 768px) {
  .listing--with-button {
    position: relative;
    min-height: 180px;
    padding: 30px;
  }
}
.listing__title {
  margin-bottom: 5px;
  line-height: 1.2;
  transition: color 0.25s ease-out;
}
.listing:hover .listing__title {
  color: #0c72a0;
}
.listing__title--link {
  margin-bottom: 10px;
}
.listing:hover .listing__title--link {
  color: #404041;
}
.listing__title--link a {
  color: #404041;
  transition: color 0.25s ease-out;
}
.listing__title--link a:hover {
  color: #1d79a8;
}
.listing__teaser {
  font-weight: 400;
  color: #404041;
}
@media (min-width: 480px) {
  .listing--not-a-link .listing__teaser {
    margin: 0;
  }
}
.listing__meta {
  font-size: 15px;
  color: #9c9c9c;
}
.listing__image {
  width: 180px;
  height: 180px;
  margin-bottom: 10px;
}
.listing__image > img {
  min-height: 100%;
  width: auto;
}
@media (min-width: 768px) {
  .listing__image {
    position: absolute;
    top: 0;
    right: 0;
  }
}
.listing__image--default {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #1d79a8;
}
.listing__image--default > svg {
  width: 80px;
  height: 70px;
  fill: #fff;
}
.listing__path, .listing__category {
  margin-bottom: 5px;
  color: #404041;
}
.listing__deadline {
  display: flex;
  align-items: center;
  margin: 0 0 10px;
  font-weight: 600;
  color: #d02a85;
}
.listing__deadline span {
  margin-left: 5px;
}
.listing__button {
  padding: 0.5em 60px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background: transparent;
  border: 1px solid #fff;
  transition: color, background, border, 0.25s ease-out;
  color: #8c0bbf;
  text-align: center;
  border-color: #8c0bbf;
}
.listing__button:hover, .listing__button:active {
  cursor: pointer;
  background: #8c0bbf;
}
.listing__button:hover {
  color: #fff;
}
@media (min-width: 480px) {
  .listing__button {
    margin-right: 30px;
    text-align: left;
  }
}
.listing__path {
  display: flex;
}

.media-box {
  display: flex;
  flex-direction: column;
  border: 1px solid #cfcfcf;
}
@media (min-width: 480px) {
  .media-box {
    flex-direction: row;
  }
}
.media-box--reverse {
  border: 0;
}
@media (min-width: 480px) {
  .media-box--reverse {
    flex-direction: row-reverse;
  }
}
.media-box--bottom-space {
  margin-bottom: 1rem;
}
@media (min-width: 1024px) {
  .media-box--bottom-space {
    margin-bottom: 3rem;
  }
}
.media-box__image-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 170px;
}
@media (min-width: 480px) {
  .media-box__image-container {
    width: 210px;
    height: 210px;
  }
}
.media-box__image--large {
  width: 100%;
  height: 150px;
  object-fit: cover;
}
@media (min-width: 480px) {
  .media-box__image--large {
    width: auto;
    height: auto;
    object-fit: initial;
  }
}
.media-box__image--small {
  z-index: 10;
  max-width: 105px;
  border: 0 solid;
  box-sizing: content-box;
  transition: border 0.25s ease-out;
}
.media-box:hover .media-box__image--small {
  border: 10px solid #1d79a8;
  transition: border 0.25s ease-out;
}
.media-box--reverse:hover .media-box__image--small {
  border: 0;
}
.media-box__content {
  flex: 1;
  padding: 20px 30px;
  color: #1d79a8;
  background-color: #fff;
  transition: color, background-color, 0.25s ease-out;
}
.media-box:hover .media-box__content {
  color: #fff;
  background-color: #1d79a8;
}
.media-box--reverse .media-box__content {
  padding: 20px 0 0;
  color: #404041;
}
@media (min-width: 480px) {
  .media-box--reverse .media-box__content {
    padding: 0 20px 0 0;
  }
}
.media-box--reverse:hover .media-box__content {
  color: #404041;
  background-color: inherit;
}
@media (min-width: 480px) {
  .media-box__content {
    padding: 15px 20px;
  }
}
.media-box__teaser {
  display: none;
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  color: #404041;
  transition: color 0.25s ease-out;
}
.media-box:hover .media-box__teaser {
  color: #fff;
}
.media-box--reverse .media-box__teaser {
  font-size: 1.3492063492vw;
  display: block;
}
@media (max-width: 1111.7647058824px) {
  .media-box--reverse .media-box__teaser {
    font-size: 15px;
  }
}
@media (min-width: 1260px) {
  .media-box--reverse .media-box__teaser {
    font-size: 17px;
  }
}
.media-box--reverse .media-box__teaser--projectpage-introduction {
  font-size: 1.9047619048vw;
}
@media (max-width: 945px) {
  .media-box--reverse .media-box__teaser--projectpage-introduction {
    font-size: 18px;
  }
}
@media (min-width: 1260px) {
  .media-box--reverse .media-box__teaser--projectpage-introduction {
    font-size: 24px;
  }
}
.media-box--reverse:hover .media-box__teaser {
  color: #404041;
}
@media (min-width: 480px) {
  .media-box__teaser {
    display: block;
  }
}
@media (min-width: 768px) {
  .media-box__teaser {
    display: none;
  }
}
@media (min-width: 1024px) {
  .media-box__teaser {
    display: block;
  }
}
.media-box__default-image {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 210px;
  height: 210px;
  background-color: #1d79a8;
}
.media-box__default-image > svg {
  width: 80px;
  height: 70px;
  fill: #fff;
}
.media-box__default-image--small {
  width: 105px;
  height: 105px;
  background-color: #fff;
  border: 0 solid;
  box-sizing: content-box;
  transition: border 0.25s ease-out;
}
.media-box:hover .media-box__default-image--small {
  border: 10px solid #1d79a8;
  transition: border 0.25s ease-out;
}
.media-box__default-image--small > svg {
  width: 50px;
  height: 50px;
  fill: #1d79a8;
}
.media-box__category {
  margin-bottom: 5px;
  color: #404041;
}
.media-box__job-title {
  margin: 5px 0 0;
  color: #404041;
}
.media-box__category, .media-box__job-title {
  transition: color 0.25s ease-out;
}
.media-box:hover .media-box__category, .media-box:hover .media-box__job-title {
  color: #fff;
}

.messages {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 25;
  pointer-events: none;
}
.messages__text {
  position: relative;
  padding: 15px 20px;
  color: #fff;
  font-size: 14px;
  opacity: 1;
  transition: opacity, max-height, 0.25s ease-out;
  pointer-events: all;
  max-height: 1000px;
}
@media (min-width: 1320px) {
  .messages__text {
    padding: 15px 30px;
  }
}
.messages__text--info, .messages__text--success {
  background: #0c72a0;
}
.messages__text--error, .messages__text--warning {
  background: #cc1e12;
}
.messages__text--debug {
  background: #511034;
}
.messages__text--hide {
  opacity: 0;
  pointer-events: none;
  max-height: 0;
  padding: 0;
}
.messages__inner {
  display: flex;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
}
.messages__copy {
  padding-right: 20px;
  margin: 0;
  flex: 1;
  word-break: break-word;
}
.messages__button {
  margin-left: auto;
  color: #0c72a0;
  background-color: #fff;
  display: inline-block;
  font-weight: 700;
  padding: 2px 20px;
}
.messages__icon {
  width: 25px;
  height: 25px;
  fill: #fff;
  margin-right: 10px;
}

.nav {
  display: flex;
  align-items: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .nav {
    flex-direction: row;
    padding-top: 0;
  }
}
.nav--primary {
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .nav--primary {
    flex-direction: row;
    justify-content: flex-end;
    margin-top: 0;
  }
}
.nav--secondary {
  margin-right: 15px;
}
.nav--tertiary {
  height: auto;
}
.nav--tertiary li:first-child a {
  margin-left: 0;
}
.nav--breadcrumb {
  flex-direction: row;
}
.header--light-bg .nav--breadcrumb {
  display: none;
}
.nav__item {
  margin-bottom: 10px;
  font-weight: 700;
  text-align: center;
}
.nav--tertiary .nav__item {
  width: 100%;
  padding-bottom: 5px;
  margin-bottom: 0;
  border-bottom: 0;
}
@media (min-width: 768px) {
  .nav--tertiary .nav__item {
    width: auto;
  }
}
.nav__item:last-child {
  border-bottom: 0;
}
@media (min-width: 768px) {
  .nav__item {
    width: auto;
    padding: 0;
    margin: 0;
    text-align: left;
    border-bottom: 0;
  }
}
.nav__item--primary {
  margin: 0;
  letter-spacing: 1px;
}
@media (min-width: 1024px) {
  .nav__item--primary {
    margin: 0 18px;
  }
}
.nav__item--footer a {
  color: #fff;
}
.nav__item--footer-column::after {
  display: none;
}
.nav__item--footer-column a {
  color: #fff;
}
.nav__item--back {
  font-size: 0.8125rem;
  text-transform: uppercase;
}
.nav__item--breadcrumb {
  display: flex;
  align-items: center;
  width: auto;
  padding: 0;
  margin: 0 5px 0 0;
  font-weight: 400;
  border-bottom: 0;
}
.listing .nav__item--breadcrumb {
  margin-left: 10px;
}
.nav__item--breadcrumb::after {
  width: 0;
  height: 0;
  margin-left: 10px;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 5px solid #fff;
  content: "";
}
.listing .nav__item--breadcrumb::after {
  margin-left: 0;
  border-left: 5px solid #404041;
}
.listing .nav__item--breadcrumb:first-child {
  margin-left: 0;
}
.nav__item--breadcrumb:first-child a {
  margin-left: 0;
}
.nav__item--breadcrumb:last-child {
  margin-left: 10px;
}
.nav__link {
  display: inline-block;
  padding: 20px 10px;
  color: #fff;
  border-bottom: 1px solid transparent;
  transition: color, border 0.25s ease-out;
}
.header--light-bg .nav__link {
  color: #404041;
}
.header__menus--mobile .nav__link {
  color: #fff;
}
@media (min-width: 1024px) {
  .nav__link {
    display: initial;
    padding: 0;
  }
  .nav__link:hover {
    color: white;
    border-bottom: 1px solid #f7f7f7;
  }
  .header--light-bg .nav__link:hover {
    color: #404041;
    border-bottom: 1px solid #404041;
  }
}
.nav__link--breadcrumb {
  position: relative;
  z-index: 8;
  padding: 0;
}
.nav__link--breadcrumb:hover {
  border-bottom: 1px solid #fff;
}

.page-boxes {
  flex-flow: wrap;
  justify-content: space-between;
}

.page-box {
  padding: 1rem;
  margin-bottom: 1rem;
  background-color: #fff;
}
@media (min-width: 768px) {
  .page-box {
    padding: 2rem;
    margin-bottom: 2rem;
    width: 48%;
  }
}
.page-box > .wrapper {
  position: relative;
}
.page-box > .wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 40px;
  background-repeat: no-repeat;
}
.page-box .otf-icon-red::before {
  background-image: url("./../../images/learnings/otf-icon-red.67b22a2657d8.svg");
}
.page-box .bullhorn-icon-red::before {
  background-image: url("./../../images/learnings/bullhorn-icon-red.bbbed2165be3.svg");
}
.page-box .potion-icon-red::before {
  background-image: url("./../../images/learnings/potion-icon-red.cdd451f46f62.svg");
}
.page-box .user-friends-icon-red::before {
  background-image: url("./../../images/learnings/user-friends-icon-red.c632a29c4440.svg");
}
.page-box b:first-of-type {
  color: #d02a85;
}
.page-box h3,
.page-box h4,
.page-box h5 {
  color: #0c72a0;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
}
.pagination .cardinality {
  margin: 0 10px;
}
.pagination .previous a,
.pagination .next a {
  position: relative;
  display: block;
  width: 55px;
  height: 55px;
  font-size: 0;
  color: #fff;
  background: #fff;
  border: 1px solid #cfcfcf;
}
.pagination .previous a::after,
.pagination .next a::after {
  position: absolute;
  top: 18.5px;
  left: 22.5px;
}
.pagination .previous a::after {
  width: 0;
  height: 0;
  content: "";
  border-right: 10.5px solid #1d79a8;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
}
.pagination .next a::after {
  width: 0;
  height: 0;
  content: "";
  border-left: 10.5px solid #1d79a8;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
}

.responsive-object {
  position: relative;
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  .responsive-object {
    margin-bottom: 4rem;
  }
}
.responsive-object iframe,
.responsive-object object,
.responsive-object embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.rich-text {
  margin-bottom: 2rem;
  word-break: break-word;
}
.form .rich-text {
  margin-bottom: 0;
}
.rich-text--answers > section {
  margin: 0 0 1rem;
}
.rich-text--answers > section p:first-of-type {
  margin-top: 0;
}
.rich-text--answers > section p:empty {
  margin: 0;
}
.rich-text--answers h4 {
  margin: 0;
}
.rich-text a {
  font-weight: 700;
  border-bottom: 1px solid transparent;
  transition: border, color, 0.15s ease-in-out;
}
.rich-text a:hover {
  border-bottom: 1px solid #1d79a8;
}
.rich-text ul {
  padding-left: 20px;
  list-style: outside disc;
}
.rich-text ul li {
  margin-bottom: 1rem;
}
.rich-text ol {
  list-style: inside decimal;
}
.rich-text ol li {
  margin-bottom: 1rem;
}

.tox-statusbar__wordcount {
  padding-left: 10px;
  padding-right: 10px;
}
.tox-statusbar__wordcount::after {
  content: attr(data-after-word-count);
}
.tox-statusbar__wordcount.word-count-warning, .tox-statusbar__wordcount.word-count-warning-2 {
  background-color: #f1a9a9;
  font-weight: bold;
  text-shadow: none;
  color: #141414;
}
.tox-statusbar__wordcount.word-count-warning-2 {
  background-color: #f05e54;
}

.section--main {
  max-width: 790px;
}
.section--main:only-child {
  margin: 0 auto;
}
.section--share {
  padding: 2rem 0;
  margin: 3rem 0;
  border-top: 1px solid #cfcfcf;
}
.section--top-bottom-space {
  padding: 20px 0;
}
@media (min-width: 1024px) {
  .section--top-bottom-space {
    padding: 3rem 0;
  }
}
.section--introduction {
  display: flex;
  justify-content: space-between;
}
@media (min-width: 768px) {
  .section--introduction div:first-child {
    flex-basis: 65%;
  }
}

.section-head a {
  display: none;
  line-height: 30px;
  vertical-align: middle;
}
.section-head:hover a {
  display: inline;
}

.select2-container {
  z-index: 99995;
}
.select2 .select2-container--default, .select2.select2-container--default {
  width: 100% !important;
}
.select2 .select2-container--default .select2-selection--single, .select2.select2-container--default .select2-selection--single {
  height: 45px;
  border: 1px solid #cfcfcf;
  border-radius: 0;
}
.select2 .select2-container--default .select2-selection--single.is-active, .select2.select2-container--default .select2-selection--single.is-active {
  font-weight: 700;
  border-color: #1d79a8;
}
.select2 .select2-container--default .select2-selection--single .select2-selection__clear, .select2.select2-container--default .select2-selection--single .select2-selection__clear {
  display: none;
}
.select2 .select2-container--default .select2-selection--single .select2-selection__rendered, .select2.select2-container--default .select2-selection--single .select2-selection__rendered {
  padding-left: 15px;
  padding-right: 30px;
  line-height: 45px;
}
.select2 .select2-container--default .select2-selection--single .select2-selection__arrow, .select2.select2-container--default .select2-selection--single .select2-selection__arrow {
  right: 15px;
  height: 45px;
  pointer-events: none;
  background: url("./../../images/dropdown.4c178fe0d732.svg") transparent no-repeat 95% center;
  background-size: 8px;
  width: 8px;
}
.select2 .select2-container--default .select2-selection--single .select2-selection__arrow b[role=presentation], .select2.select2-container--default .select2-selection--single .select2-selection__arrow b[role=presentation] {
  display: none;
}
.select2 .select2-container--default .select2-selection--single .select2-selection__placeholder, .select2.select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: #404041;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  color: #404041 !important;
  background-color: rgba(29, 121, 168, 0.1) !important;
}
.select2-container .select2-dropdown {
  border: 0;
  border-bottom: 1px solid #cfcfcf;
  border-radius: 0;
}
@media (min-width: 600px) {
  .select2-container .select2-dropdown {
    border: 1px solid #cfcfcf;
  }
}
.select2-container .select2-results__option {
  display: flex;
  align-items: center;
  padding: 6px;
}
.select2-container .select2-results__option::before {
  min-width: 20px;
  height: 20px;
  margin-right: 10px;
  background: #fff;
  border: 1px solid #cfcfcf;
  content: "";
}
.select2-container .select2-results__option[aria-selected=true]::before {
  background: url("./../../images/tick.03718d20977b.svg") #0c72a0 center no-repeat;
  background-size: 12px;
  border: 1px solid #0c72a0;
  content: "";
}

.show-more--button {
  cursor: pointer;
  user-select: none;
}
@media (min-width: 768px) {
  .show-more--button {
    grid-column: 1/3;
  }
}
.show-more--target, .show-more--block {
  display: none;
}
.show-more--checkbox {
  display: none;
}
.show-more--checkbox:checked ~ .show-more--target {
  display: flex;
}
.show-more--checkbox:checked ~ .show-more--block {
  display: block;
}
.show-more--checkbox:checked ~ .show-more--button {
  display: none;
}

table {
  width: 100%;
  background-color: #fff;
  border-collapse: collapse;
  table-layout: fixed;
}
table th {
  padding: 20px 15px;
  font-size: 15px;
  font-weight: 600;
  text-align: left;
}
table th a {
  color: rgba(0, 0, 0, 0.6);
  transition: color 0.25s ease-out;
}
table tr {
  border: 1px solid #e8e8e8;
  transition: box-shadow 0.15s ease;
}
@media (min-width: 1024px) {
  table tr {
    border-top: 0;
    border-right: 0;
    border-bottom: 2px solid #f7f7f7;
    border-left: 0;
  }
  table tr.is-expanded {
    border-bottom: 1px solid #e8e8e8;
  }
  table tr.is-expanded .lead span {
    background-color: #f3fafe;
  }
  table tr:hover {
    box-shadow: 0 6px 35px -13px rgba(0, 0, 0, 0.5);
  }
  table tr.reviews-summary__tr {
    box-shadow: none;
  }
}
table tr > td {
  display: block;
  width: 100%;
}
@media (min-width: 1024px) {
  table tr > td {
    display: table-cell;
    width: initial;
  }
}
@media (min-width: 1024px) {
  table tr > td.lead span {
    position: relative;
    z-index: 1;
    display: block;
    padding-right: 5px;
    overflow: hidden;
    text-overflow: ellipsis;
    background: #fff;
  }
  table tr > td.lead span:hover {
    display: inline-block;
    overflow: visible;
  }
}
table tr > td.title a {
  font-weight: 700;
}
table td,
table th {
  padding: 5px 20px;
}
@media (min-width: 1024px) {
  table td,
  table th {
    padding: 15px 10px;
  }
}
table td.title,
table th.title {
  padding-left: 20px;
}

.filters {
  display: none;
}
.filters.filters-open {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 20;
  display: block;
  width: 100%;
  height: 100vh;
  background: #fff;
}
@media (min-width: 1024px) {
  .filters {
    display: block;
    max-height: 0;
    transition: max-height 0.5s ease;
    transition-delay: 30ms;
    pointer-events: none;
  }
  .filters.filters-open {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    height: auto;
    background: transparent;
    max-height: 85px;
    pointer-events: all;
  }
}
.filters__header {
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 20px 0;
}
@media (min-width: 1024px) {
  .filters__header {
    display: none;
  }
}
.filters__header > div[class^=js-] {
  color: #1d79a8;
}
.filters__header > div[class^=js-]:hover {
  cursor: pointer;
}
.filters__button {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  color: #1d79a8;
  background: transparent;
}

.wrapper {
  width: 100%;
}
.wrapper--small {
  max-width: 790px;
  margin: 0 auto;
}
.wrapper--medium {
  max-width: 1020px;
  margin: 0 auto;
}
.wrapper--large {
  max-width: 1280px;
  margin: 0 auto;
}
.wrapper--main {
  padding: 0 20px;
  min-height: calc(100vh - 410px - 160px);
}
.wrapper--admin {
  padding: 20px;
  color: #fff;
  background-color: #404041;
}
.wrapper--breakout {
  position: relative;
  right: 50%;
  left: 50%;
  width: 100vw;
  margin-right: -50vw;
  margin-left: -50vw;
}
.wrapper--blockquote {
  padding: 1rem 0;
  margin-top: 2rem;
  margin-bottom: 2rem;
  background: #f7f7f7;
}
@media (min-width: 768px) {
  .wrapper--blockquote {
    padding: 4rem 0;
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
}
.wrapper--blockquote svg {
  position: absolute;
  display: none;
  width: 110px;
  height: 110px;
  fill: #fff;
}
@media (min-width: 768px) {
  .wrapper--blockquote svg {
    display: block;
  }
}
.wrapper--blockquote svg:first-child {
  top: 0;
  left: 0;
  transform: rotate(90deg);
}
.wrapper--blockquote svg:last-child {
  right: 0;
  bottom: 0;
  transform: rotate(-90deg);
}
.wrapper--dark-bg {
  color: #fff;
  background-color: #404041;
}
.wrapper--streamfield {
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  .wrapper--streamfield {
    margin-bottom: 4rem;
  }
}
.wrapper--light-grey-bg {
  background-color: #f7f7f7;
}
.wrapper--media-boxes {
  max-width: 1220px;
  padding: 0 20px;
  margin: 0 auto;
}
.wrapper--apply-bar {
  padding: 30px 20px;
}
.wrapper--form {
  padding: 20px;
  margin: 20px auto;
}
@media (min-width: 768px) {
  .wrapper--form {
    padding: 2rem 10rem 2rem 5rem;
    margin: 1rem auto 3rem;
  }
}
.wrapper--error {
  display: flex;
  align-items: center;
  max-width: 830px;
  padding: 10px;
  margin: 0 auto 2rem;
  background: #ffe1df;
  border: 1px solid #f05e54;
}
.wrapper--bottom-space {
  padding-bottom: 20px;
  margin-bottom: 20px;
}
@media (min-width: 768px) {
  .wrapper--bottom-space {
    padding-bottom: 3rem;
    margin-bottom: 3rem;
  }
}
.wrapper--inner-space-small {
  padding: 20px 0;
}
.wrapper--inner-space-medium {
  padding: 20px 0;
}
@media (min-width: 480px) {
  .wrapper--inner-space-medium {
    padding: 2rem 0;
  }
}
.wrapper--inner-space-large {
  padding: 20px 0;
}
@media (min-width: 768px) {
  .wrapper--inner-space-large {
    padding: 3rem 0;
  }
}
.wrapper--inner-space-xl {
  padding: 2rem 20px;
}
@media (min-width: 768px) {
  .wrapper--inner-space-xl {
    padding: 4rem 20px;
  }
}
.wrapper--top-outer-space-small {
  margin: 20px 0 0;
}
.wrapper--outer-space-medium {
  margin: 20px 0;
}
@media (min-width: 480px) {
  .wrapper--outer-space-medium {
    margin: 2rem 0;
  }
}
.wrapper--outer-space-large {
  margin: 20px 0;
}
@media (min-width: 768px) {
  .wrapper--outer-space-large {
    margin: 3rem 0;
  }
}
.wrapper--sidebar {
  display: flex;
  flex-direction: column;
}
@media (min-width: 768px) {
  .wrapper--sidebar {
    flex-direction: row;
  }
  .wrapper--sidebar > div:last-child {
    flex-basis: 210px;
  }
}
.wrapper--sidebar > div:first-child {
  flex: 1;
  margin-bottom: 20px;
}
@media (min-width: 768px) {
  .wrapper--sidebar > div:first-child {
    padding-right: 20px;
    margin-bottom: 0;
  }
}
.wrapper--status {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
@media (min-width: 480px) {
  .wrapper--status {
    flex-direction: row;
  }
}
.wrapper--project {
  padding-top: 2rem;
}
.wrapper--listings {
  display: flex;
  flex-direction: column;
  margin-top: 20px;
}
@media (min-width: 768px) {
  .wrapper--listings {
    margin-top: 2rem;
  }
}
.wrapper--page-title {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: flex-end;
}
.header--homepage .wrapper--page-title {
  position: relative;
  z-index: 8;
  align-items: flex-start;
  justify-content: center;
  height: 100%;
}
.wrapper--center {
  text-align: center;
}
.wrapper--flex {
  display: flex;
}
.wrapper--page-box {
  background-color: #f7f7f7;
}
.wrapper--cookieconsent {
  padding: 40px 20px;
  z-index: 10;
}

.header--light-bg ~ .wrapper--main {
  min-height: calc(100vh - 260px - 160px);
}

.footer {
  color: #fff;
}
@media (min-width: 768px) {
  .footer {
    background: linear-gradient(to right, #0c72a0 50%, #1d79a8 50%);
  }
}
.footer a {
  color: inherit;
}
.footer__inner {
  padding: 20px;
}
@media (min-width: 768px) {
  .footer__inner {
    padding: 40px 80px;
  }
}
.footer__inner:first-child {
  background: #0c72a0;
}
.footer__inner:last-child {
  background: #1d79a8;
}
.footer__heading {
  display: none;
}
@media (min-width: 768px) {
  .footer__heading {
    display: block;
    margin: 0 20px 0 0;
  }
}
.footer__social-links a {
  display: flex;
  align-items: center;
}
.footer__social-links h4 {
  margin: 0;
}
.footer input[type=text], .footer input[type=email] {
  width: 100%;
  max-width: 390px;
  margin-bottom: 1rem;
  color: #fff;
  background: transparent;
  border-top: 0;
  border-right: 0;
  border-bottom: 4px solid #1d79a8;
  border-left: 0;
}
.footer label {
  display: block;
}
.footer__credits {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 3rem 0;
}

.header {
  position: relative;
  min-height: 300px;
  padding: 10px;
  background-color: #1d79a8;
}
.header::after {
  height: 300px;
}
@media (min-width: 768px) {
  .header {
    height: 410px;
    padding: 20px;
  }
}
.header--light-bg {
  height: auto;
  min-height: 250px;
  padding-bottom: 0;
  background: #fff;
}
.header--light-bg::after {
  display: none;
}
.header--standard {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.header--has-bg-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.header--narrow {
  height: auto;
  min-height: initial;
  padding: 20px;
}
.header--narrow::before {
  display: none;
}
.header--white-bg {
  background-color: #fff;
}
.header--homepage {
  height: 555px;
  padding: 20px;
}
@media (min-width: 768px) {
  .header--homepage {
    height: 660px;
  }
}
.header__title {
  z-index: 8;
  padding: 0 10px;
  margin: 0 0 20px;
  line-height: 1;
  color: #fff;
  text-shadow: 0 2px 15px rgba(0, 0, 0, 0.1);
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .header__title {
    padding: 0;
  }
}
.header--light-bg .header__title {
  color: #404041;
  text-shadow: none;
}
.template-lab-page .header__title, .template-fund-page .header__title, .template-news-page .header__title, .template-project-page .header__title {
  font-size: 3.8095238095vw;
}
@media (max-width: 1050px) {
  .template-lab-page .header__title, .template-fund-page .header__title, .template-news-page .header__title, .template-project-page .header__title {
    font-size: 40px;
  }
}
@media (min-width: 1260px) {
  .template-lab-page .header__title, .template-fund-page .header__title, .template-news-page .header__title, .template-project-page .header__title {
    font-size: 48px;
  }
}
.header__title--homepage {
  font-size: 5.7142857143vw;
  max-width: 750px;
  line-height: 1.1;
  text-shadow: 0 2px 15px rgba(0, 0, 0, 0.25);
}
@media (max-width: 630px) {
  .header__title--homepage {
    font-size: 36px;
  }
}
@media (min-width: 1260px) {
  .header__title--homepage {
    font-size: 72px;
  }
}
.header__title--homepage::after {
  display: inline-block;
  width: 15px;
  height: 15px;
  margin-left: 5px;
  background: #1d79a8;
  border-radius: 50%;
  content: "";
  transition: height, width, 10s ease;
}
.header__inner {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.header__inner--mobile-buttons {
  justify-content: flex-end;
}
@media (min-width: 768px) {
  .header__inner--mobile-buttons {
    display: none;
  }
}
.header__inner--menu-open {
  padding: 10px;
  background: transparent;
  transition: background 0.25s ease-out;
}
.header__menus--desktop {
  display: none;
}
@media (min-width: 768px) {
  .header__menus--desktop {
    display: flex;
    align-items: center;
  }
}
.header__menus--mobile {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: #404041;
  opacity: 0;
  transform: translate3d(0, -100%, 0);
  transition-duration: 0.25s;
  transition-property: transform, opacity;
  transition-timing-function: cubic-bezier(0.65, 0.05, 0.36, 1);
}
.header__menus--mobile.is-visible {
  opacity: 1;
  transform: translate3d(0, 0%, 0);
}
@media (min-width: 768px) {
  .header__menus--mobile.is-visible {
    display: none;
  }
}
.header__menus--mobile nav {
  width: 100%;
}
.header__logo {
  fill: #fff;
}
.header__logo--mobile {
  width: 60px;
  height: 60px;
}
@media (min-width: 1024px) {
  .header__logo--mobile {
    display: none;
  }
}
.header--light-bg .header__logo--mobile {
  fill: #404041;
}
.header__menus--mobile.is-visible .header__logo--mobile {
  fill: #fff;
}
.header__logo--desktop {
  display: none;
}
@media (min-width: 1024px) {
  .header__logo--desktop {
    display: block;
    width: 215px;
    height: 50px;
  }
}
@media (min-width: 1024px) {
  .header__logo--desktop-light {
    display: block;
  }
}
.header--light-bg .header__logo--desktop-light {
  display: none;
}
.header__logo--desktop-dark {
  display: none;
}
@media (min-width: 1024px) {
  .header--light-bg .header__logo--desktop-dark {
    display: block;
  }
}
@media (min-width: 768px) {
  .header__menu-toggle {
    display: none;
  }
}
.header__icon--pixels {
  position: absolute;
  bottom: 0;
  display: none;
}
@media (min-width: 1024px) {
  .header__icon--pixels {
    display: block;
  }
}
.header--light-bg .header__icon--pixels {
  display: none;
}
.header__icon--pixels-left {
  left: 0;
  width: 105px;
  height: 98px;
  fill: #fff;
}
.light-grey-bg .header__icon--pixels-left, .header--grey-pixels .header__icon--pixels-left {
  fill: #f7f7f7;
}
.header__icon--pixels-left-home {
  left: 0;
  width: 110px;
  height: 165px;
  fill: #fff;
}
.header__icon--pixels-right {
  right: 0;
  width: 295px;
  height: 300px;
  fill: #0c72a0;
}
.header__icon--pixels-right-home {
  right: 0;
  bottom: -55px;
  width: 328px;
  height: 567px;
  fill: #0c72a0;
}
.header__search {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 100%;
  height: 180px;
  padding-bottom: 50px;
  background: #0c72a0;
}
.header__button-container {
  display: none;
}
@media (min-width: 768px) {
  .header__button-container {
    display: flex;
  }
}
.header__strapline {
  max-width: 550px;
  margin: 0 0 20px;
  font-weight: 700;
  color: #fff;
}
.header__link {
  display: inline-block;
  border: 0;
}

.sidebar {
  flex: 0 0 12rem;
  margin-top: 20px;
}
@media (min-width: 768px) {
  .sidebar {
    order: -1;
    margin: 0 20px 0 0;
  }
}
.sidebar--filters {
  flex: 0 0 2rem;
  order: -1;
}
@media (min-width: 768px) {
  .sidebar--filters {
    flex: 0 0 12rem;
  }
}
.sidebar__inner {
  padding: 20px;
  background: #cfcfcf;
}
