/* @include transition(all,2s,ease-out); */
/*
 * [Modified] Modern CSS Reset
 * @link https://github.com/hankchizljaw/modern-css-reset
*/
/* Box sizing rules */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
}

html,
body {
  overflow-x: hidden;
}

html {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.5;
  text-rendering: optimizeSpeed;
}

/* Make images easier to work with */
img {
  display: block;
  max-width: 100%;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  * {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  html {
    scroll-behavior: initial;
  }
}
body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh;
  background-color: #f9f9f9;
  color: rgb(56.7, 82.95, 102.9);
  font-family: montserrat, sans-serif;
  line-height: 1.7;
}

.wrapper {
  position: relative;
  width: 90%;
  max-width: 1280px;
  margin: 0 auto;
}

main,
main.tdbc-container {
  padding-top: 0;
  padding-bottom: 5vh;
  background-color: #f9f9f9;
}

body.archive main {
  padding-top: 6rem;
}

footer {
  color: #307bb4;
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
  border-top: solid 1px #307bb4;
  padding-top: 1rem;
}
footer h2 {
  color: #307bb4;
  margin-top: 0;
}
footer a {
  color: #307bb4;
  text-decoration: none;
}
footer a:hover {
  opacity: 0.5;
}

.band {
  padding: 3rem 0;
}
.band.band-copyright {
  padding-top: 1rem;
  color: #307bb4;
  padding: 1rem 0;
}
.band--primary-dark {
  background-color: rgb(36, 92.25, 135);
}
.band--secondary {
  background-color: #223C49;
}
.band--tertiary {
  background-color: #14C8D9;
}
.band--background {
  background-color: #f9f9f9;
}
.band--gray {
  background-color: rgb(99.61, 107.485, 113.47);
}
.band--light {
  background-color: #fff;
}

article {
  max-width: 80ch;
}
article > img {
  margin-right: auto;
  margin-left: auto;
}

.tdbc-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: 120ch;
  margin-right: auto;
  margin-left: auto;
  padding: 1rem;
}

.tdbc-column-container {
  display: grid;
  grid-gap: 2em;
  /* grid-template-columns: repeat(auto-fit, minmax(40ch, 1fr)); */
  grid-template-columns: 1fr 1fr 1fr;
}
@media (max-width: 767px) {
  .tdbc-column-container {
    grid-template-columns: 1fr;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .tdbc-column-container {
    grid-template-columns: 1fr 1fr;
  }
}

footer .tdbc-column-container {
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 767px) {
  footer .tdbc-column-container {
    grid-template-columns: 1fr;
  }
}

.row-flush {
  display: grid;
  grid-gap: 0;
  grid-template-columns: 2fr 2fr;
}
@media (max-width: 767px) {
  .row-flush {
    grid-template-columns: 1fr;
  }
}
.row-flush.primary__bg {
  color: #fff;
  background-color: #307bb4;
}
.row-flush.primary__bg h2 {
  color: #fff;
}
.row-flush.primary__bg a {
  color: #fff;
  text-decoration: none;
}
.row-flush.primary__bg a:hover {
  opacity: 0.5;
}
.row-flush .text-block {
  padding: 3rem;
}

ul.tdbc-column-container {
  padding-left: 0;
}

body.archive ul.tdbc-column-container {
  margin-top: 3rem;
}

.tdbc-section {
  width: 100%;
}
.tdbc-section--padded {
  padding-top: 10vh;
  padding-bottom: 10vh;
}
.tdbc-section *:last-child {
  margin-bottom: 0;
}

.tdbc-hero {
  display: grid;
  min-height: 40vh;
  place-content: center;
  padding-top: 10vh;
  padding-bottom: 10vh;
  text-align: center;
}

.tdbc-row {
  display: grid;
  grid-gap: 1rem;
}
@media (min-width: 80ch) {
  .tdbc-row {
    grid-auto-flow: column;
    grid-auto-columns: -webkit-max-content;
    grid-auto-columns: max-content;
  }
}
.tdbc-row--center-content {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.tdbc-row--center-alignitems {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

hr {
  margin-top: 4rem;
  margin-bottom: 4rem;
  border: 1px solid #223C49;
}

h1,
.tdbc-h1 {
  /* font-weight: $tdbc-strong-font-weight; */
  line-height: 1.15;
  margin-top: 3.5rem;
  margin-bottom: 2.5rem;
  font-weight: normal;
  color: #307bb4;
  letter-spacing: 1px;
}

h2,
.tdbc-h2 {
  /* font-weight: $tdbc-strong-font-weight; */
  line-height: 1.15;
  margin-top: 3.5rem;
  margin-bottom: 2.5rem;
  font-weight: normal;
  color: #307bb4;
  letter-spacing: 1px;
}

h3,
.tdbc-h3 {
  /* font-weight: $tdbc-strong-font-weight; */
  line-height: 1.15;
  margin-top: 3.5rem;
  margin-bottom: 2.5rem;
  font-weight: normal;
  color: #307bb4;
  letter-spacing: 1px;
}

h4,
.tdbc-h4 {
  /* font-weight: $tdbc-strong-font-weight; */
  line-height: 1.15;
  margin-top: 3.5rem;
  margin-bottom: 2.5rem;
  font-weight: normal;
  color: #307bb4;
  letter-spacing: 1px;
}

h1,
.tdbc-h1 {
  font-size: 4.25rem;
  font-size: min(max(3rem, 5vw), 4.25rem);
}

h2,
.tdbc-h2 {
  font-size: 3rem;
  font-size: min(max(2.5rem, 5vw), 3rem);
}

h3,
.tdbc-h3 {
  font-size: 2rem;
}

h4,
.tdbc-h4,
label {
  font-size: 1.35rem;
  font-weight: 700;
}

p,
li {
  font-size: 1.15rem;
}

p {
  margin: 0 0 1rem;
}

.content > h1:first-child,
.content > h2:first-child {
  margin-top: 0;
}

article > ul > li + li,
article > ol > li + li {
  margin-top: 1rem;
}
article * + h2 {
  margin-top: 4rem;
}
article * + h3 {
  margin-top: 2rem;
}

strong {
  font-weight: 700;
}

.content:not(.item-list) a:not(.tdbc-button) {
  color: #307bb4;
  font-weight: 700;
  text-decoration: none;
  border-bottom: solid 1px #307bb4;
  -webkit-transition: color 0.3s ease-out;
  transition: color 0.3s ease-out;
}
.content:not(.item-list) a:not(.tdbc-button):hover {
  color: #14C8D9;
  border-bottom: solid 1px #14C8D9;
}

pre,
code {
  font-family: Consolas, Monaco, "Andale Mono", "Ubuntu Mono", monospace;
  font-weight: bold;
}

code {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 0.15em;
  background-color: #fff;
  font-size: 0.75em;
  color: rgb(99.61, 107.485, 113.47);
  border: 1px solid rgb(175.9416360053, 181.428413272, 185.5983639947);
  border-radius: 2px;
  line-height: 1.1;
}

pre {
  margin: 0;
  display: inline-block;
}
pre code {
  display: block;
  padding: 0 1rem;
  white-space: pre-wrap;
  font-size: 0.85rem;
  line-height: 1.4;
  overflow-x: auto;
}

blockquote {
  margin-left: 0;
  margin-right: 0;
  padding-left: 1.5rem;
  border-left: 2px solid #223C49;
  color: rgb(99.61, 107.485, 113.47);
}
blockquote,
blockquote p {
  font-size: 1.35rem;
}
blockquote + * {
  margin-top: 3rem;
}

.tdbc-lead {
  font-size: 1.35rem;
  letter-spacing: 0.01em;
  margin-bottom: 1em;
  line-height: 1.3;
}

.tdbc-list-unstyled {
  list-style: none;
  padding: 0;
}

.tdbc-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-item-align: start;
      align-self: start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 120px;
  min-height: 48px;
  padding: 0.25rem 1.5em;
  margin-top: 1rem;
  -webkit-transition: 180ms all ease-in-out;
  transition: 180ms all ease-in-out;
  border-radius: 4px;
  background-color: #307bb4;
  color: #fff;
  font-size: 1.125rem;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  vertical-align: middle;
}
@media screen and (-ms-high-contrast: active) {
  .tdbc-button {
    border: 2px solid currentColor;
  }
}
.tdbc-button:focus {
  outline-color: transparent;
  outline-style: solid;
  -webkit-box-shadow: 0 0 0 3px rgb(33.6, 86.1, 126);
          box-shadow: 0 0 0 3px rgb(33.6, 86.1, 126);
}
.tdbc-button--small {
  min-height: 34px;
  padding: 0.25em 0.75em 0.5em 0.75em;
  font-size: 1rem;
}
.tdbc-button--center {
  -ms-flex-item-align: center;
      align-self: center;
  margin-right: auto;
  margin-left: auto;
}
.tdbc-button__icon {
  width: 1.5em;
  height: 1.5em;
  margin-right: 0.25em;
}
.tdbc-button__icon--end {
  margin-right: 0;
  margin-left: 0.25em;
}
.tdbc-button__icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}
.tdbc-button-outlined {
  border: 2px solid #307bb4;
  background-color: transparent;
  color: #307bb4;
}
.tdbc-button-outlined:hover, .tdbc-button-outlined:focus {
  background-color: rgb(210.4736842105, 229.0263157895, 243.1263157895);
}
.tdbc-button--secondary {
  background-color: #223C49;
}
.tdbc-button--secondary:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(23.8, 42, 51.1);
          box-shadow: 0 0 0 3px rgb(23.8, 42, 51.1);
}
.tdbc-button-outlined--secondary {
  border-color: rgb(61.5542990654, 131.4152336449, 166.3457009346);
  color: #223C49;
}
.tdbc-button-outlined--secondary:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(23.8, 42, 51.1);
          box-shadow: 0 0 0 3px rgb(23.8, 42, 51.1);
}
.tdbc-button-outlined--secondary:hover, .tdbc-button-outlined--secondary:focus {
  background-color: rgb(227.5056074766, 237.2981308411, 242.1943925234);
}
.tdbc-button--light {
  background-color: #fff;
  color: rgba(0, 0, 0, 0.87);
}
.tdbc-button--light:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(178.5, 178.5, 178.5);
          box-shadow: 0 0 0 3px rgb(178.5, 178.5, 178.5);
}
.tdbc-button-outlined--light {
  border-color: white;
  color: #fff;
}
.tdbc-button-outlined--light:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(178.5, 178.5, 178.5);
          box-shadow: 0 0 0 3px rgb(178.5, 178.5, 178.5);
}
.tdbc-button-outlined--light:hover, .tdbc-button-outlined--light:focus {
  background-color: rgba(255, 255, 255, 0.15);
}
.tdbc-button--gray {
  background-color: rgb(99.61, 107.485, 113.47);
}
.tdbc-button--gray:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(69.727, 75.2395, 79.429);
          box-shadow: 0 0 0 3px rgb(69.727, 75.2395, 79.429);
}
.tdbc-button-outlined--gray {
  border-color: rgb(129.7439468463, 153.9871890664, 172.4120531537);
  color: rgb(99.61, 107.485, 113.47);
}
.tdbc-button-outlined--gray:focus {
  -webkit-box-shadow: 0 0 0 3px rgb(69.727, 75.2395, 79.429);
          box-shadow: 0 0 0 3px rgb(69.727, 75.2395, 79.429);
}
.tdbc-button-outlined--gray:hover, .tdbc-button-outlined--gray:focus {
  background-color: rgb(239.1883272011, 240.2856826544, 241.1196727989);
}

.tdbc-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  border-radius: 8px;
  background-color: #fff;
  -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, 0.18);
          box-shadow: 0 3px 5px rgba(0, 0, 0, 0.18);
  /* stylelint-disable selector-max-type, selector-no-qualifying-type */
}
.tdbc-card__title {
  color: #307bb4;
  margin-bottom: 1rem;
  font-size: 1.35rem;
  line-height: 1.15;
  text-decoration: none;
}
.tdbc-card a.tdbc-card__title::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: 180ms -webkit-box-shadow ease-in;
  transition: 180ms -webkit-box-shadow ease-in;
  transition: 180ms box-shadow ease-in;
  transition: 180ms box-shadow ease-in, 180ms -webkit-box-shadow ease-in;
  border-radius: 8px;
  content: "";
}
.tdbc-card a.tdbc-card__title:focus {
  outline: none;
}
.tdbc-card a.tdbc-card__title:focus::before {
  -webkit-box-shadow: 0 0 0 3px #307bb4;
          box-shadow: 0 0 0 3px #307bb4;
}
.tdbc-card__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  padding: 24px;
}
.tdbc-card__content h3 {
  margin-top: 0;
}
.tdbc-card__content a:last-child {
  -ms-flex-item-align: start;
      align-self: start;
  margin-top: auto;
}
.tdbc-card__content p {
  position: relative;
  margin: 0 0 1rem;
  z-index: 1;
  line-height: 1.4;
  color: rgb(99.61, 107.485, 113.47);
}
.tdbc-card__content p.venue {
  margin-bottom: 0.25rem;
  color: #307bb4;
}
.tdbc-card__content > ul {
  list-style-type: disc;
  padding-left: 1rem;
}
.tdbc-card__content > ul li + li {
  margin-top: 0.5rem;
}
.tdbc-card:hover a.tdbc-card__title::before {
  -webkit-box-shadow: 0 0 0 3px #307bb4;
          box-shadow: 0 0 0 3px #307bb4;
}
.tdbc-card img:first-child {
  -o-object-fit: cover;
     object-fit: cover;
  max-height: 10em;
  border-radius: 8px 8px 0 0;
}
.tdbc-card--outlined {
  border: 1px solid rgb(223.3766544021, 225.5713653088, 227.2393455979);
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.tdbc-card--plain {
  -webkit-box-shadow: none;
          box-shadow: none;
}

.tdbc-content-maxlength {
  max-width: 80ch;
}

.tdbc-text-align--left {
  text-align: left;
}

.tdbc-text-align--center {
  text-align: center;
}
.tdbc-text-align--center > a {
  -ms-flex-item-align: center !important;
      align-self: center !important;
}

.tdbc-text-align--right {
  text-align: right;
}

.tdbc-background--primary {
  background-color: #307bb4;
}

.tdbc-background--primary-dark {
  background-color: rgb(36, 92.25, 135);
}

.tdbc-background--secondary {
  background-color: #223C49;
}

.tdbc-background--tertiary {
  background-color: #14C8D9;
}

.tdbc-background--background {
  background-color: #f9f9f9;
}

.tdbc-background--gray {
  background-color: rgb(99.61, 107.485, 113.47);
}

.tdbc-background--light {
  background-color: #fff;
}

.tdbc-ink--primary,
a.tdbc-ink--primary {
  color: #307bb4;
}

.tdbc-ink--primary > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-ink--secondary,
a.tdbc-ink--secondary {
  color: #223C49;
}

.tdbc-ink--secondary > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-ink--text,
a.tdbc-ink--text {
  color: rgb(56.7, 82.95, 102.9);
}

.tdbc-ink--text > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-ink--gray > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-ink--light,
a.tdbc-ink--light {
  color: #fff;
}

.tdbc-ink--light > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-ink--dark,
a.tdbc-ink--dark {
  color: rgba(0, 0, 0, 0.87);
}

.tdbc-ink--dark > a:not(.tdbc-button) {
  color: inherit;
}

.tdbc-mx-auto {
  margin-right: auto;
  margin-left: auto;
}

.tdbc-mt-xs {
  margin-top: 0.5rem;
}

.tdbc-mt-sm {
  margin-top: 1rem;
}

.tdbc-mt-md {
  margin-top: 3rem;
}

.tdbc-mt-lg {
  margin-top: 6rem;
}

.tdbc-mt-xl {
  margin-top: 10rem;
}

.tdbc-mt-auto {
  margin-top: "auto";
}

.tdbc-mb-none {
  margin: 0;
}

.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.members-bar {
  padding: 0.35rem 0;
  background-color: rgb(36, 92.25, 135);
}

.dark-teal-bar {
  font-size: 1.35rem;
  padding: 1rem 0;
  background-color: rgb(36, 92.25, 135);
}
.dark-teal-bar a {
  color: #fff;
  text-decoration: none;
}
.dark-teal-bar a:hover {
  color: #223C49;
}

.loader {
  position: fixed;
  background-color: #2d4451;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 991;
  overflow: hidden;
}
.loader.closed {
  -webkit-transition: height 0.6s ease-in-out;
  transition: height 0.6s ease-in-out;
  height: 0;
}
.loader .logo-holder {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100vh;
}
.loader .compass {
  width: 30%;
  height: auto;
  display: none;
}

.colour-1 {
  position: fixed;
  background-color: #377E7F;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 990;
  overflow: hidden;
}
.colour-1.closed {
  -webkit-transition: height 0.6s ease-in-out;
  transition: height 0.6s ease-in-out;
  height: 0;
}

.colour-2 {
  position: fixed;
  background-color: #457aaf;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 989;
  overflow: hidden;
}
.colour-2.closed {
  -webkit-transition: height 0.6s ease-in-out;
  transition: height 0.6s ease-in-out;
  height: 0;
}

.colour-3 {
  position: fixed;
  background-color: #8A8B8B;
  background-color: #FFF;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 988;
  overflow: hidden;
}
.colour-3.closed {
  -webkit-transition: height 0.6s ease-in-out;
  transition: height 0.6s ease-in-out;
  height: 0;
}

#site-header {
  background-color: #223C49;
  position: relative;
}
#site-header header {
  width: 90%;
  max-width: 1280px;
  margin: 0 auto;
  min-height: 12rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 3rem 0 1rem 0;
}
#site-header #mobile-logo {
  text-align: left;
}
#site-header #mobile-logo img {
  display: none;
}
@media (max-width: 767px) {
  #site-header #mobile-logo img {
    display: block;
    height: auto;
    width: 100%;
    max-height: 5rem;
  }
}
#site-header #site-logo {
  height: auto;
  width: 100%;
  max-height: 10rem;
}
@media (max-width: 767px) {
  #site-header #site-logo {
    display: none;
  }
}
#site-header #site-logo svg {
  width: 100%;
  height: auto;
}

.animate {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/*--keyframe pointer --*/
.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

#house-1 {
  -webkit-animation-delay: 2.8s;
  animation-delay: 2.8s;
}

#house-2 {
  -webkit-animation-delay: 3.2s;
  animation-delay: 3.2s;
}

#house-3 {
  -webkit-animation-delay: 3.6s;
  animation-delay: 3.6s;
}

#house-4 {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}

#house-5 {
  -webkit-animation-delay: 4.4s;
  animation-delay: 4.4s;
}

#house-6 {
  -webkit-animation-delay: 4.8s;
  animation-delay: 4.8s;
}

#house-7 {
  -webkit-animation-delay: 5.2s;
  animation-delay: 5.2s;
}

#house-8 {
  -webkit-animation-delay: 5.6s;
  animation-delay: 5.6s;
}

#house-9 {
  -webkit-animation-delay: 6s;
  animation-delay: 6s;
}

#house-10,
#crane {
  -webkit-animation-delay: 6.4s;
  animation-delay: 6.4s;
}

#line {
  -webkit-animation-delay: 7.2s;
  animation-delay: 7.2s;
}

.houseLower {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation: houseLower 2s linear forwards;
          animation: houseLower 2s linear forwards;
  opacity: 0;
}

@-webkit-keyframes houseLower {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
  to {
    -webkit-transform: translateY(46px);
            transform: translateY(46px);
    opacity: 1;
  }
}

@keyframes houseLower {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
  to {
    -webkit-transform: translateY(46px);
            transform: translateY(46px);
    opacity: 1;
  }
}
.footer-items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#site-description {
  color: #fff;
  font-size: 2rem;
  font-weight: normal;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

blockquote.display {
  font-size: 2rem;
  padding: 0;
  border: 0;
  text-align: center;
}
blockquote.display h1 {
  font-family: montserrat, sans-serif;
  font-style: italic;
  font-size: 4.25rem;
  margin-bottom: 0.5rem;
  line-height: 1.1;
}
blockquote.display span.attribution {
  font-size: 1rem;
}
blockquote.testimonial {
  text-align: left;
  color: #307bb4;
  border-left: 2px solid #223C49;
}
blockquote.testimonial h3 {
  font-family: montserrat, sans-serif;
  font-family: montserrat, sans-serif;
  font-style: italic;
  text-transform: none;
  letter-spacing: normal !important;
  font-size: 2.025rem;
  color: #307bb4;
  line-height: 1.3;
}
blockquote.testimonial span.attribution {
  font-size: 1.15rem;
  color: #307bb4;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.message {
  background-color: rgb(247, 244, 244);
  border-bottom: solid 1px #888;
  padding: 0.5rem;
  margin: 1rem 0 3rem 0;
}

.outer {
  margin: 0 3rem;
}

.pull-text-and-image-row {
  position: relative;
  overflow: hidden;
  margin: 6rem 0;
}

.text-and-image-row {
  margin: 3rem 0;
}
.text-and-image-row a {
  text-decoration: none;
}

.pull-text-and-image-row .text {
  color: #fff;
  padding: 3rem;
  margin-right: 50%;
  position: absolute;
  bottom: 2rem;
  left: 0;
  z-index: 2;
}
.pull-text-and-image-row .text h3 {
  font-size: 1.35rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.text-and-image-row .text {
  /* background-color: tdbc-color(background); */
  padding: 3rem;
}

.pull-text-and-image-row img {
  margin-left: 25%;
  -o-object-fit: fill;
     object-fit: fill;
  overflow: hidden;
}

h3,
body .gform_wrapper h3.gform_title {
  font-size: 1.35rem;
  font-weight: normal !important;
  text-transform: uppercase;
  letter-spacing: 0.2em !important;
}

h3:after,
body .gform_wrapper h3.gform_title:after {
  content: " ";
  width: 4rem;
  display: block;
  margin: 0;
  padding-top: 1rem;
  border-bottom: 3px solid #223C49;
}

.text-and-image-row.reverse-out {
  color: #fff;
  background-color: #307bb4;
}
.text-and-image-row.reverse-out .text {
  background-color: #307bb4;
}
.text-and-image-row.reverse-out h3 {
  color: #fff;
}
.text-and-image-row.reverse-out h3:after {
  border-bottom: 1px solid #223C49;
}
.text-and-image-row.reverse-out a {
  color: #fff;
  text-decoration: none;
}
.text-and-image-row.reverse-out a:hover {
  border-bottom: 1px solid #14C8D9;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.colour-options {
  margin: 3rem 2rem;
  color: #307bb4;
  font-size: 2rem;
}
.colour-options .block {
  padding: 1rem;
  height: 15rem;
}

.content {
  background-color: #fff;
  padding: 3rem 6rem 6rem 6rem;
  margin: 1rem 0 6rem 0;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .content {
    padding: 3rem;
  }
}
@media (max-width: 767px) {
  .content {
    padding: 1rem;
  }
}

.image-full-width {
  margin: 3rem 0;
}

.intro {
  font-size: 1.35rem;
  color: #307bb4;
  line-height: 1.5;
  margin: 3rem 0;
}
.intro a {
  text-decoration: none;
  color: #307bb4;
}
.intro a:hover {
  color: #223C49;
}

ul.people-list {
  padding-left: 0;
  margin-left: 0;
  list-style: none;
  width: 100%;
  display: grid;
  grid-gap: 2em;
  grid-template-columns: repeat(auto-fit, minmax(30ch, 1fr));
}
ul.people-list li {
  padding-left: 0;
  margin-left: 0;
  text-align: center;
}
ul.people-list li h3 {
  margin-bottom: 0.5rem;
}
ul.people-list li h3:after {
  content: none;
}
ul.people-list li img {
  margin: 0 auto 1.5rem auto;
}
ul.people-list li a {
  text-decoration: none;
}
ul.people-list li .instrument {
  color: rgb(99.61, 107.485, 113.47);
}

.assymetric-block.image-left {
  display: grid;
  grid-gap: 2em;
  grid-template-columns: 7fr 5fr;
}

.assymetric-block.image-right {
  display: grid;
  grid-gap: 2em;
  grid-template-columns: 5fr 7fr;
}

.acf-map {
  width: 100%;
  height: 40rem;
  font-size: 1.15rem;
}
.acf-map h3 {
  font-size: 1.15rem;
  margin: 0.5rem 0 1rem 0;
}
.acf-map p {
  margin: 0 0 0.125rem 0;
  font-size: 1rem !important;
}

/* Remove info window X */
.gm-style-iw button {
  display: none !important;
}

.view-all {
  margin-top: 6rem;
}

.view-all a {
  text-decoration: none;
  border-radius: 32px;
  margin-top: 2rem;
  color: #fff;
  background-color: #307bb4;
}
.view-all a:hover {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  opacity: 1;
  background-color: #14C8D9;
}

.wp-block-embed-youtube iframe,
.map-embed iframe {
  width: 100%;
  height: 35rem;
  display: block;
}

/* Gravity forms: what a shit show! */
body .gform_wrapper .gform_footer input[type=submit] {
  margin-top: 2rem;
}

body .gform_wrapper .gform_body input[type=text],
body .gform_wrapper .gform_body input[type=email],
body .gform_wrapper .gform_body textarea,
body .gform_wrapper .gform_body .StripeElement,
input[type=text],
textarea {
  border: solid 1px #14C8D9;
  padding: 0.75rem;
  height: auto;
}

input[type=text].full,
textarea.full {
  width: 100%;
  display: block;
  margin-bottom: 3rem;
}

body .gform_wrapper .gform_body .StripeElement {
  padding: 1.125rem 0.75rem;
  font-size: 1.15rem;
  line-height: 1.8;
}

body .gform_wrapper .gform_body .gform_button,
body .gform_wrapper .gform_footer input.button,
body .gform_wrapper .gform_footer input[type=submit],
body .gform_wrapper .gform_page_footer input.button,
body .gform_wrapper .gform_page_footer input[type=submit],
input[type=submit],
button[type=submit] {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-item-align: start;
      align-self: start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 60px;
  min-height: 48px;
  padding: 0 1.5em 0.25em 1.5em;
  margin-top: 1rem;
  -webkit-transition: 180ms all ease-in-out;
  transition: 180ms all ease-in-out;
  border-radius: 4px;
  background-color: #307bb4;
  color: #fff;
  font-size: 1.125rem;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  vertical-align: middle;
  border: none;
}

body .gform_wrapper input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]) {
  padding: 0.75rem;
}

body .gform_wrapper .gfield_label,
body .gform_wrapper .field_sublabel_below .ginput_complex.ginput_container label,
body .gform_wrapper ul.gfield_checkbox li label,
body .gform_wrapper ul.gfield_radio li label {
  margin-top: 0;
  padding: 0;
  border: none;
}

body .gform_wrapper .top_label .gfield_label,
body .gform_wrapper legend.gfield_label {
  font-size: 1.15rem;
  font-weight: 700;
}

body .gform_wrapper ul.gfield_checkbox li label,
body .gform_wrapper ul.gfield_radio li label {
  margin-top: 0;
  text-transform: none;
  letter-spacing: none;
}

body body .gchoice_select_all,
body .gform_wrapper ul.gfield_checkbox li input[type=checkbox]:checked + label,
body .gform_wrapper ul.gfield_radio li input[type=radio]:checked + label {
  font-weight: normal;
}

body .gform_wrapper ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

h4 + h5 {
  font-size: 1.15rem;
  font-weight: normal;
  margin: 0;
  color: rgb(99.61, 107.485, 113.47);
}

.in-depth {
  font-size: 0.85rem;
  display: inline-block;
  color: #307bb4;
  padding: 0.25rem 0.75rem 0.35rem 0.75rem;
  background-color: #14C8D9;
}

.tdbc-card .in-depth {
  margin: 0 0 12px 24px;
}

.in-depth + h1 {
  margin-top: 3rem;
}

p.article-meta {
  color: #14C8D9;
  margin-bottom: 2rem;
}

.toc {
  color: #fff;
  position: absolute;
  bottom: -4rem;
  right: 0;
  width: 40%;
  min-width: 30rem;
  z-index: 2;
  height: auto;
  background-color: #307bb4;
  padding: 3rem;
  border-radius: 8px;
}
@media (max-width: 767px) {
  .toc {
    position: static;
    width: 100%;
    min-width: 100%;
    border-radius: 0;
    padding: 3rem 1rem;
  }
}
.toc h2 {
  font-size: 2rem;
  margin: 0 0 1rem 0;
  color: #fff;
}
.toc ul {
  margin: 0;
}
.toc a {
  color: #fff;
  text-decoration: none;
}
.toc a:hover {
  color: #14C8D9;
}

body .gform_wrapper select,
body .gform_wrapper.gf_browser_chrome select,
select {
  font-size: 1.15rem;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  color: rgb(99.61, 107.485, 113.47);
  border: solid 1px #14C8D9;
  line-height: 1;
  outline: 0;
  padding: 1rem 3rem 1.25rem 0.75rem;
  background-color: #fff;
  background-image: linear-gradient(#14C8D9, #14C8D9), linear-gradient(-135deg, transparent 50%, #14C8D9 50%), linear-gradient(-225deg, transparent 50%, #14C8D9 50%), linear-gradient(#14C8D9 42%, #307bb4 42%);
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: 1px 100%, 40px 42px, 40px 42px, 40px 100%;
  background-position: right 40px center, right bottom, right bottom, right bottom;
}

body .gform_wrapper.gf_browser_chrome .ginput_complex .ginput_right select,
body .gform_wrapper.gf_browser_chrome .ginput_complex select {
  text-indent: 0;
  line-height: 1;
  margin-bottom: 0;
  margin-top: 0;
}

body .gform_wrapper .gform_footer {
  margin-top: 0;
}

body .gform_wrapper select:hover,
select:hover {
  background-image: linear-gradient(#14C8D9, #14C8D9), linear-gradient(-135deg, transparent 50%, #14C8D9 50%), linear-gradient(-225deg, transparent 50%, #14C8D9 50%), linear-gradient(#14C8D9 42%, #307bb4 42%);
}

body .gform_wrapper select:active,
select:active {
  background-image: linear-gradient(#14C8D9, #14C8D9), linear-gradient(-135deg, transparent 50%, #14C8D9 50%), linear-gradient(-225deg, transparent 50%, #14C8D9 50%), linear-gradient(#14C8D9 42%, #307bb4 42%);
  color: #fff;
  border-color: #14C8D9;
  background-color: #14C8D9;
}

/* Hide price label  on proiducts */
.ginput_product_price_label {
  display: none;
}

/* Custom forms */
form.custom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 1rem;
}
form.custom label {
  display: block;
}
form.custom div {
  margin: 0;
}
@media (max-width: 767px) {
  form.custom div {
    grid-column: 1/3;
  }
}
form.custom div.error {
  color: rgb(192, 20, 20);
}
form.custom div.full-width {
  grid-column: 1/3;
}
form.custom input[type=text],
form.custom input[type=email],
form.custom input[type=file],
form.custom textarea {
  border: solid 1px #14C8D9;
  padding: 0.75rem;
  height: auto;
  width: 100%;
  margin-top: 0.5rem;
}
form.custom button[type=submit] {
  margin-top: 2rem;
  justify-self: start !important;
}

/*

	!CAROUSELS

*/
.carousel {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
}
.carousel .image {
  height: 55vh;
  min-height: 36rem;
  width: 100%;
  background-position: center center;
  background-size: cover;
}
.carousel .carousel__content {
  position: absolute;
  top: 15vh;
  left: 0;
  width: 45%;
  z-index: 50;
  color: #fff;
  background-color: rgba(48, 123, 180, 0.75);
  padding: 1.5rem 3rem;
  display: none;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .carousel .carousel__content {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .carousel .carousel__content {
    width: 100%;
  }
}
.carousel .carousel__content h2,
.carousel .carousel__content h3 {
  color: #fff;
  margin: 0 0 0.5rem 0;
  font-size: 2rem;
}
.carousel .carousel__content p {
  margin: 0;
}

.bx-controls {
  position: absolute;
  bottom: 1em;
  left: 2em;
  z-index: 51;
}

.bx-controls a {
  display: inline-block;
  text-align: center;
  text-indent: -9999px;
  overflow: hidden;
  border-radius: 100%;
  border: solid 0.125em #fff;
  background: transparent;
  color: #ccc;
  width: 1em;
  height: 1em;
}

.bx-pager-item {
  display: inline;
  float: none;
  _float: left;
  *float: left;
  margin-right: 0.5em;
}

.bx-pager-item a.active {
  background-color: #fff;
}

/* !VIDEO OVERLAY */
.video-overlay {
  position: relative;
  margin: 6rem 0;
  font-size: 1rem;
}
.video-overlay .video-holder {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  z-index: 0;
}
.video-overlay .video-holder video.background-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.video-overlay .video-holder video.html5-video {
  -o-object-fit: cover;
     object-fit: cover;
}
.video-overlay .overlay {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 60%;
  position: relative;
  background-color: rgba(48, 123, 180, 0.75);
  padding: 3rem;
}
@media (max-width: 767px) {
  .video-overlay .overlay {
    width: 100%;
  }
}
.video-overlay .overlay .overlay__text {
  color: #fff;
}
.video-overlay .overlay .overlay__text h2 {
  color: #fff;
  margin-top: 0;
}

/* !COUNTERS */
.counters {
  position: relative;
  margin: -3rem 0 3rem 0;
  padding: 0;
  z-index: 100;
  display: grid;
  grid-gap: 1rem;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  text-align: center;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .counters {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 767px) {
  .counters {
    margin: 3rem 0;
    grid-template-columns: 1fr;
  }
}
.counters .counter__col {
  list-style: none;
  color: #fff;
  background-color: #307bb4;
  padding: 3rem 1rem 1rem 1rem;
}
.counters .counter__col.odd {
  background-color: #223C49;
}
.counters .counter__col h3 {
  color: #fff;
  font-size: 4.25rem;
  letter-spacing: -0.01em !important;
  margin: 0;
}
.counters .counter__col h3:after {
  border: none;
}

/* !DOWNLOADS */
.downloads h2 {
  font-size: 2rem;
  position: relative;
  padding: 1rem 3rem 1rem 0;
  border-bottom: solid 1px #307bb4;
}
.downloads h2:hover {
  cursor: pointer;
}
.downloads h2::-moz-selection {
  background: none;
}
.downloads h2::selection {
  background: none;
}
.downloads h2:after {
  position: absolute;
  top: 2rem;
  right: 1rem;
  display: block;
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  background: url(../img/toggle-arrow.svg) no-repeat;
}
.downloads h4 {
  margin: 3rem 0 1rem 0;
}
.downloads ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0;
}
.downloads ul li {
  padding: 0.5rem 0;
  border-bottom: solid 1px #eee;
}
.downloads ul li a {
  border-bottom: none;
  text-decoration: none;
}

.wp-block-group {
  padding: 3rem 0;
  width: 100%;
  text-align: center;
}
.wp-block-group a {
  font-weight: 700;
  color: #307bb4;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.wp-block-group a:hover {
  color: #223C49;
}
.wp-block-group h2 {
  margin-top: 0;
}
.wp-block-group.reverse {
  color: #fff;
  background-color: #307bb4;
}
.wp-block-group.reverse h2 {
  color: #fff;
}
.wp-block-group.reverse a {
  color: #fff;
}
.wp-block-group.reverse a:hover {
  color: rgba(255, 255, 255, 0.6);
}
.wp-block-group .wp-block-columns {
  width: 90%;
  max-width: 1280px;
  text-align: left;
  margin: 3rem auto;
}

@media (max-width: 767px) {
  div#n2-ss-4 .n-uc-193f426838213-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-eWZTIDcPxIio-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-193f426838213-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-ypzvHx9eIgHA-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-x5pVjuwx1FJT-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-1fOomBrWymo9-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-7mcfHirxAvz0-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-PLNcZgLe5NAL-inner > .n2-ss-layer-row-inner,
  div#n2-ss-4 .n-uc-Eemzn4fSailu-inner > .n2-ss-layer-row-inner {
    -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
  }
}

.image-tint {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 30em;
  z-index: 10;
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.247059)), color-stop(30%, rgba(0, 0, 0, 0)));
  background-image: linear-gradient(rgba(0, 0, 0, 0.247059) 0%, rgba(0, 0, 0, 0) 30%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#40000000", endColorstr="#00000000",GradientType=0 ); /* IE6-9 */
}

.image-grid {
  /* padding: 4px;   */
}

.image-grid .image-wrapper {
  margin: -1px;
}

.feature-image {
  height: 45vh;
  width: 100%;
  background-position: top center;
  background-size: cover;
}
@media (min-width: 1400px) {
  .feature-image {
    height: 55vh;
  }
}

.image {
  height: 14rem;
  width: 100%;
  background-position: top center;
  background-size: cover;
}

.gallery-item {
  text-align: center;
  margin: 0;
}

.wp-caption {
  margin: 0.5em 0;
  font-size: 0.75em;
  line-height: 1.2;
}

.gallery-item a {
  border: none;
}

figure {
  margin: 2rem 0;
}

figure.aligncenter {
  padding: 2rem;
}

img {
  vertical-align: middle; /* Removes white space underneath */
}

.acf-map img {
  max-width: inherit !important;
}

.content img,
.content-full-img img,
.project-image img,
.comment-content img,
.imagegallery img,
.widget img,
.wp-bespoke-img,
.feature-image img {
  max-width: 100%; /* Fluid images for posts, comments, and widgets */
  height: auto;
}

img[class*=align],
img[class*=wp-image-] {
  height: auto; /* Make sure images with WordPress-added height and width >attributes are scaled correctly */
}

img.size-full {
  max-width: 100%;
  width: auto; /* Prevent stretching of full-size images with height and >>width attributes in IE8 */
}

.wp-caption {
  max-width: 100%;
}

.full-image-band {
  font-size: 1em;
  margin: 0;
  height: 30em;
}

.half-image-band {
  font-size: 1em;
  margin: 0;
  height: 22em;
}

.wp-image-circular,
.size-round-small {
  border-radius: 100%;
}

nav {
  width: 100%;
}
nav ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

#menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 10rem 3rem 3rem 3rem;
  height: 100%;
  width: auto;
  z-index: 900;
  color: #fff;
  min-height: 400px;
  overflow-y: auto;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  opacity: 0;
  visibility: hidden;
  background-color: #307bb4;
}
#menu-overlay.open {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 1400px) {
  #menu-overlay.open {
    opacity: 0;
    visibility: hidden;
  }
}

nav.overlay-menu {
  background-color: none;
}
nav.overlay-menu.overlay-members {
  margin-top: 1rem;
  padding-top: 0.5rem;
  border-top: solid 1px #fff;
}
nav.overlay-menu ul {
  margin: 0;
  padding: 0;
}
nav.overlay-menu ul li a {
  font-size: 2rem;
  color: #fff;
  text-decoration: none;
}
nav.overlay-menu ul li a:hover {
  color: #223C49;
}

nav.primary-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
nav.primary-menu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
nav.primary-menu ul li {
  margin: 0 0 0 2rem;
}
nav.primary-menu ul li a {
  font-size: 1.15rem;
  color: #fff;
  text-decoration: none;
}
nav.primary-menu ul li a:hover {
  color: #223C49;
}

.primary-menu-trigger {
  display: none;
}

nav.members-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: no-wrap;
      flex-wrap: no-wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: 0 1rem;
}
nav.members-menu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
nav.members-menu ul li {
  margin-left: 1rem;
  color: #fff;
  font-size: 1rem;
}
nav.members-menu ul li a {
  color: #fff;
  text-decoration: none;
}
nav.members-menu ul li a:hover {
  color: #223C49;
}

@media (max-width: 1200px) {
  nav.primary-menu {
    display: none;
  }
  .primary-menu-trigger {
    display: block;
    position: absolute;
    top: 3.75rem;
    right: 1rem;
    height: 2rem;
    width: auto;
    cursor: pointer;
    z-index: 901;
    -webkit-transition: opacity 0.25s ease;
    transition: opacity 0.25s ease;
  }
  .primary-menu-trigger:focus {
    background-color: transparent;
  }
  .primary-menu-trigger::-moz-selection {
    background-color: transparent;
  }
  .primary-menu-trigger::selection {
    background-color: transparent;
  }
  .primary-menu-trigger:before {
    content: "MENU";
    display: inline-block;
    vertical-align: top;
    color: #fff;
    margin-right: 10px;
    font-size: 1rem;
    letter-spacing: 2.4px;
  }
  .primary-menu-trigger div {
    position: relative;
    display: inline-block;
    height: 2rem;
    width: 2rem;
  }
  .primary-menu-trigger:hover {
    opacity: 0.5;
  }
  .primary-menu-trigger.active .top {
    -webkit-transform: translateY(11px) translateX(0) rotate(45deg);
            transform: translateY(11px) translateX(0) rotate(45deg);
    background: #fff;
  }
  .primary-menu-trigger.active .middle {
    opacity: 0;
    background: #fff;
  }
  .primary-menu-trigger.active .bottom {
    -webkit-transform: translateY(-11px) translateX(0) rotate(-45deg);
            transform: translateY(-11px) translateX(0) rotate(-45deg);
    background: #fff;
  }
  .primary-menu-trigger span {
    background: #fff;
    border: none;
    height: 3px;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transition: all 0.35s ease;
    transition: all 0.35s ease;
    cursor: pointer;
    z-index: 200;
  }
  .primary-menu-trigger .top {
    top: 0;
  }
  .primary-menu-trigger .middle {
    top: 11px;
  }
  .primary-menu-trigger .bottom {
    top: 22px;
  }
}
footer .socials-menu ul:before {
  content: " ";
  width: 0;
  display: none;
  margin: 0;
  padding-top: 0;
  border-bottom: none;
}
footer .socials-menu ul:after {
  content: " ";
  width: 4rem;
  display: block;
  margin: 2rem 0 3rem 0;
  padding-top: 1rem;
  border-bottom: 1px solid #223C49;
}
footer .socials-menu ul {
  margin: 0 3rem 3rem 0;
}

#site-header .menu-horizontal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 70%;
  position: absolute;
  top: 3.5rem;
  right: 5%;
  z-index: 901;
}
#site-header .menu-horizontal .sub-menu-toggle {
  display: none;
}
#site-header .menu-horizontal li {
  position: relative;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: 0.25rem 0 1rem 0;
  margin: 0 1.75rem 0 0;
  font-size: 1rem;
  line-height: 1.3;
}
#site-header .menu-horizontal li.support {
  display: none;
}
#site-header .menu-horizontal li .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  min-width: 12rem;
  max-width: 20rem;
  padding: 1rem;
  margin: 0;
  text-align: left;
  background-color: #fff;
  color: #502F92;
}
#site-header .menu-horizontal li .sub-menu li {
  padding: 0.5rem 0;
}
#site-header .menu-horizontal li .sub-menu a {
  color: #307bb4;
  text-decoration: none;
  text-transform: uppercase;
  font-size: 0.825rem;
  letter-spacing: 0.2em;
}
#site-header .menu-horizontal li .sub-menu a:hover {
  color: #14C8D9;
}
#site-header .menu-horizontal li .sub-menu:before {
  position: absolute;
  content: "";
  top: -1rem;
  left: 1rem;
  width: 0;
  height: 0;
  border: 10px solid transparent; /* arrow size */
  border-bottom-color: #fff; /* arrow color */
}
#site-header .menu-horizontal a {
  color: #fff;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.2em;
}
#site-header .menu-horizontal a:hover {
  color: #14C8D9;
}
#site-header .menu-horizontal .sub-menu {
  visibility: hidden;
}

.footer-menu {
  /* display: flex;
  flex-wrap: wrap; */
}
.footer-menu li {
  padding: 0;
  margin: 0 0 1rem 0;
}
.footer-menu a {
  color: #fff;
  text-decoration: none;
}
.footer-menu a:hover {
  opacity: 0.5;
}

.tabs {
  width: 100%;
  float: none;
  position: relative;
  text-align: left;
}
.tabs .tablist {
  margin: 0 0 1rem 0;
  padding: 0;
}
.tabs .tab-holder {
  float: left;
  width: 100%;
  display: block;
  margin: 0;
  padding: 0;
}
.tabs input[type=radio] {
  position: absolute;
  top: 0;
  left: -9999px;
}
.tabs .tab-buttons {
  margin-left: 3rem;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .tabs .tab-buttons {
    margin-left: 0;
  }
}
@media (max-width: 767px) {
  .tabs .tab-buttons {
    margin-left: 0;
  }
}
.tabs label {
  display: inline-block;
  padding: 1rem 1.5rem;
  border-radius: 2px 2px 0 0;
  font-weight: normal;
  text-transform: uppercase;
  cursor: pointer;
  position: relative;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  color: #307bb4;
  background-color: rgb(234.3, 241.8, 247.5);
  border: solid 1px #307bb4;
  border-bottom: none;
  letter-spacing: 1px;
  font-size: 0.85rem;
}
@media (max-width: 767px) {
  .tabs label {
    margin-bottom: 0.5rem;
    border-bottom: solid 1px #307bb4;
  }
}
.tabs label.active {
  color: #fff;
  background-color: #307bb4;
}
.tabs label:focus {
  outline: none;
}
.tabs .tab-content {
  z-index: 2;
  display: none;
  overflow: hidden;
  width: 100%;
  height: auto;
  padding: 3rem;
  /* position: absolute; */
  top: 53px;
  left: 0;
  border-top: solid 2px #307bb4;
  background-color: #fff;
}
@media (min-width: 768px) and (max-width: 1023px) {
  .tabs .tab-content {
    padding: 1rem 0;
  }
}
@media (max-width: 767px) {
  .tabs .tab-content {
    padding: 1rem 0;
  }
}
.tabs [id^=tab]:checked + label {
  top: 0;
  padding-top: 17px;
}
.tabs [id^=tab]:checked ~ [id^=tab-content] {
  display: block;
}
.tabs p.link {
  clear: both;
  margin: 380px 0 0 15px;
}
.tabs p.link a {
  text-transform: uppercase;
  text-decoration: none;
  display: inline-block;
  color: #fff;
  padding: 5px 10px;
  margin: 0 5px;
}/*# sourceMappingURL=ottersbrook-base.css.map */