@import url("https://use.typekit.net/fsb5thn.css");
@font-face {
  font-family: "fontello";
  src: url("../font/fontello.woff?230725") format("woff"), url("../font/fontello.woff2?230725") format("woff2");
  font-weight: normal;
  font-style: normal;
}
.custom-icon {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
}

.custom-icon.arrow:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e801";
  font-size: 1.8rem;
}

.custom-icon.arrow-fat:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e802";
  font-size: 1.8rem;
}

.custom-icon.arrow-down:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e803";
  font-size: 1.8rem;
}

.custom-icon.arrow-long:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e804";
  font-size: 1.8rem;
}

.custom-icon.arrow-stub:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e805";
  font-size: 1.8rem;
}

.custom-icon.calendar:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e806";
  font-size: 1.8rem;
}

.custom-icon.calendar-v2:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e807";
  font-size: 1.8rem;
}

.custom-icon.clock:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e808";
  font-size: 1.8rem;
}

.custom-icon.close:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e809";
  font-size: 1.8rem;
}

.custom-icon.doc-doc:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e810";
  font-size: 1.8rem;
}

.custom-icon.doc-mov:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e811";
  font-size: 1.8rem;
}

.custom-icon.doc-mp3:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e812";
  font-size: 1.8rem;
}

.custom-icon.doc-pdf:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e813";
  font-size: 1.8rem;
}

.custom-icon.doc-ppt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e814";
  font-size: 1.8rem;
}

.custom-icon.doc-xls:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e815";
  font-size: 1.8rem;
}

.custom-icon.download:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e816";
  font-size: 1.8rem;
}

.custom-icon.email:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e82d";
  font-size: 1.8rem;
}

.custom-icon.external:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e817";
  font-size: 1.8rem;
}

.custom-icon.fax:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e818";
  font-size: 1.8rem;
}

.custom-icon.filter:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e819";
  font-size: 1.8rem;
}

.custom-icon.globe:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e820";
  font-size: 1.8rem;
}

.custom-icon.home:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e821";
  font-size: 1.8rem;
}

.custom-icon.hours:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e82c";
  font-size: 1.8rem;
}

.custom-icon.heart:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e822";
  font-size: 1.8rem;
}

.custom-icon.hyperlink:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e823";
  font-size: 1.8rem;
}

.custom-icon.location:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e824";
  font-size: 1.8rem;
}

.custom-icon.mail:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e825";
  font-size: 1.8rem;
}

.custom-icon.marker:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e826";
  font-size: 1.8rem;
}

.custom-icon.menu:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e827";
  font-size: 1.8rem;
}

.custom-icon.pause:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e828";
  font-size: 1.8rem;
}

.custom-icon.phone:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e829";
  font-size: 1.8rem;
}

.custom-icon.phone-alt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e830";
  font-size: 1.8rem;
}

.custom-icon.play:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e831";
  font-size: 1.8rem;
}

.custom-icon.plus:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e832";
  font-size: 1.8rem;
}

.custom-icon.quotation:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e833";
  font-size: 1.8rem;
}

.custom-icon.quotation-v2:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e834";
  font-size: 1.8rem;
}

.custom-icon.search:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e835";
  font-size: 1.8rem;
}

.custom-icon.social-fb:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e836";
  font-size: 1.8rem;
}

.custom-icon.social-i:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e837";
  font-size: 1.8rem;
}

.custom-icon.social-li:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e838";
  font-size: 1.8rem;
}

.custom-icon.social-tt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e839";
  font-size: 1.8rem;
}

.custom-icon.social-x:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e840";
  font-size: 1.8rem;
}

.custom-icon.social-yt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e841";
  font-size: 1.8rem;
}

.custom-icon.social-yt-alt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e842";
  font-size: 1.8rem;
}

.custom-icon.user:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e843";
  font-size: 1.8rem;
}

.custom-icon.zipper:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e844";
  font-size: 1.8rem;
}

html {
  font-size: 100%;
  overflow-x: hidden;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
}

body {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  background: #FBF8F0;
  color: #1B0A41;
  font-size: 1.125rem;
  line-height: 1.8rem;
  margin: 0;
  overflow-x: hidden;
  padding: 0;
  white-space: normal;
}
@media only screen and (max-width: 425px) {
  body {
    word-break: break-word;
  }
}

article a,
.editor-content a,
.wrapper a {
  color: #1B0A41;
  outline: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  overflow-wrap: break-word;
}
article a:hover, article a:active, article a:focus-within, article a:focus,
.editor-content a:hover,
.editor-content a:active,
.editor-content a:focus-within,
.editor-content a:focus,
.wrapper a:hover,
.wrapper a:active,
.wrapper a:focus-within,
.wrapper a:focus {
  text-decoration: underline dashed;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 1em 0;
}

p {
  margin: 2rem 0;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
h5,
h6 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "peachy-keen-jf", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #665AA4;
  font-weight: 400;
  line-height: 1.25em;
}

h1,
.h1 {
  font-size: 2.5rem;
}
@media only screen and (min-width: 768px) {
  h1,
  .h1 {
    font-size: 3rem;
  }
}
@media only screen and (min-width: 1440px) {
  h1,
  .h1 {
    font-size: 3.5rem;
  }
}
@media only screen and (min-width: 1600px) {
  h1,
  .h1 {
    font-size: 4rem;
  }
}

h2,
.h2 {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  h2,
  .h2 {
    font-size: 2.05rem;
  }
}
@media only screen and (min-width: 1440px) {
  h2,
  .h2 {
    font-size: 2.15rem;
  }
}
@media only screen and (min-width: 1600px) {
  h2,
  .h2 {
    font-size: 2.25rem;
  }
}

h3,
.h3 {
  font-size: 1.35rem;
}
@media only screen and (min-width: 768px) {
  h3,
  .h3 {
    font-size: 1.4rem;
  }
}
@media only screen and (min-width: 1440px) {
  h3,
  .h3 {
    font-size: 1.45rem;
  }
}
@media only screen and (min-width: 1600px) {
  h3,
  .h3 {
    font-size: 1.5rem;
  }
}

h4,
.h4 {
  font-size: 1.25rem;
}

h5,
.h5 {
  font-size: 1.2rem;
}

h6,
.h6 {
  font-size: 1.15rem;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

sub,
sup {
  position: relative;
  font-size: 1rem;
}

sub {
  left: 1px;
  bottom: -8px;
}

sup {
  top: -8px;
  left: 1px;
}

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

.alignleft,
.alignright,
.aligncenter {
  border-radius: 1rem;
  max-width: 300px;
  width: auto;
}

.alignleft {
  float: left;
  margin: 0 3rem 2rem 0;
}

.alignright {
  float: right;
  margin: 0 0 2rem 3rem;
}

.aligncenter {
  display: block;
  margin: 0 auto;
  margin-bottom: 3rem;
  text-align: center;
}
.aligncenter .wp-caption-text {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

figure img {
  margin-top: 0;
}
figure .wp-caption-text {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  margin-top: 0.2rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.5rem;
}

.size-full {
  max-width: 100%;
  height: auto;
}

a.primary-button {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  display: inline-flex;
  background: #665AA4;
  border: 0 none;
  border-radius: 100px;
  color: #FFF;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1.2em;
  padding: 1rem 1.5rem;
  position: relative;
  text-decoration: none;
  width: fit-content;
}
a.primary-button:hover, a.primary-button:active, a.primary-button:focus-within, a.primary-button:focus {
  background: #1B0A41;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  a.primary-button {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 2rem 2.5rem;
  }
}

.secondary-button:not(li.secondary-button) {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  display: inline-flex;
  background: #665AA4;
  border: 0 none;
  border-radius: 100px;
  color: #FFF;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1.2em;
  padding: 1rem 1.5rem;
  position: relative;
  text-decoration: none;
  width: fit-content;
  background: rgba(255, 255, 255, 0.6);
  color: #1B0A41;
  font-size: 1.125rem;
  font-weight: 700;
  padding: 1rem 1.5rem;
}
.secondary-button:not(li.secondary-button):hover, .secondary-button:not(li.secondary-button):active, .secondary-button:not(li.secondary-button):focus-within, .secondary-button:not(li.secondary-button):focus {
  background: #1B0A41;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  .secondary-button:not(li.secondary-button) {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 2rem 2.5rem;
  }
}
.secondary-button:not(li.secondary-button):hover, .secondary-button:not(li.secondary-button):active, .secondary-button:not(li.secondary-button):focus-within, .secondary-button:not(li.secondary-button):focus {
  background: #1B0A41;
  color: #FFF;
}
@media only screen and (min-width: 1440px) {
  .secondary-button:not(li.secondary-button) {
    font-size: 1.125rem;
    font-weight: 700;
    padding: 1rem 1.5rem;
  }
}

.editor-content ul,
.editor-content ol {
  margin: 0;
  padding: 0;
  padding-left: 1rem;
}
.editor-content ul li,
.editor-content ol li {
  margin: 1rem 0;
  padding-left: 0.5rem;
}
.editor-content ul li::marker,
.editor-content ol li::marker {
  color: #665AA4;
}
.editor-content ol {
  padding-left: 1.25rem;
}

table {
  font-size: 1rem;
  border-collapse: collapse;
  width: 100%;
  margin-bottom: 2em;
}
table caption {
  margin: 1em 0;
  font-weight: 600;
  font-size: 1.4rem;
}

thead td,
th {
  font-weight: bold;
}

th,
td {
  display: table-cell;
  vertical-align: inherit;
  text-align: inherit;
  padding: 0.5rem;
  text-align: left;
  border: 1px solid #1B0A41;
}

tbody tr:nth-child(odd) {
  background: rgba(0, 0, 0, 0.1);
}

.heading-small {
  margin-bottom: 3rem;
}

hr {
  margin: 4rem 0;
}

blockquote {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 2rem;
  margin: 0;
}
blockquote:before {
  content: "\e834";
  color: #D22F61;
  font-family: fontello;
  font-size: 2.5rem;
  line-height: 1;
  margin-bottom: 0.5rem;
  margin-left: 0.25rem;
}
blockquote p {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "peachy-keen-jf", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #665AA4;
  font-size: 2rem;
  line-height: 1.25em;
  margin: 0;
  max-width: 1030px;
}
@media only screen and (min-width: 1440px) {
  blockquote p {
    font-size: 3rem;
  }
}
blockquote p strong {
  font-weight: 800 !important;
}
blockquote p.author {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #1B0A41;
  font-size: 1.125rem;
  font-style: normal;
}

@media only screen and (max-width: 600px) {
  .alignleft,
  .alignright {
    display: block;
    float: none;
    margin: 0 0 3rem 0;
  }
}
@media (min-width: 1440px) {
  body:after {
    display: none;
    content: "large";
  }
}
@media (max-width: 1439px) {
  body:after {
    display: none;
    content: "small";
  }
}
.gap-xs {
  gap: 1rem;
}

.gap-sm {
  gap: 2rem;
}

.gap-md {
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  .gap-md {
    gap: 4rem;
  }
}

.gap-lg {
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  .gap-lg {
    gap: 4rem;
  }
}
@media only screen and (min-width: 1640px) {
  .gap-lg {
    gap: 10rem;
  }
}

.gap-xl {
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  .gap-xl {
    gap: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .gap-xl {
    gap: 12rem;
  }
}

.margin {
  margin-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin {
    margin-top: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin {
    margin-top: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin {
    margin-top: 10rem;
  }
}
.margin {
  margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin {
    margin-bottom: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin {
    margin-bottom: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin {
    margin-bottom: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin {
    margin-bottom: 10rem;
  }
}

.margin-half {
  margin-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-half {
    margin-top: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-half {
    margin-top: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-half {
    margin-top: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-half {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-half {
    margin-top: 5rem;
  }
}
.margin-half {
  margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-half {
    margin-bottom: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-half {
    margin-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-half {
    margin-bottom: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-half {
    margin-bottom: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-half {
    margin-bottom: 5rem;
  }
}

.margin-huge {
  margin-top: 6rem;
}
@media only screen and (min-width: 768px) {
  .margin-huge {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-huge {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-huge {
    margin-top: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-huge {
    margin-top: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-huge {
    margin-top: 15rem;
  }
}
.margin-huge {
  margin-bottom: 6rem;
}
@media only screen and (min-width: 768px) {
  .margin-huge {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-huge {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-huge {
    margin-bottom: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-huge {
    margin-bottom: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-huge {
    margin-bottom: 15rem;
  }
}

.margin-top {
  margin-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-top {
    margin-top: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-top {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-top {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-top {
    margin-top: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-top {
    margin-top: 10rem;
  }
}

.margin-top-half {
  margin-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-top-half {
    margin-top: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-top-half {
    margin-top: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-top-half {
    margin-top: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-top-half {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-top-half {
    margin-top: 5rem;
  }
}

.margin-top-huge {
  margin-top: 6rem;
}
@media only screen and (min-width: 768px) {
  .margin-top-huge {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-top-huge {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-top-huge {
    margin-top: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-top-huge {
    margin-top: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-top-huge {
    margin-top: 15rem;
  }
}

.margin-bottom {
  margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-bottom {
    margin-bottom: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-bottom {
    margin-bottom: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-bottom {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-bottom {
    margin-bottom: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-bottom {
    margin-bottom: 10rem;
  }
}

.margin-bottom-half {
  margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .margin-bottom-half {
    margin-bottom: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-bottom-half {
    margin-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-bottom-half {
    margin-bottom: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-bottom-half {
    margin-bottom: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-bottom-half {
    margin-bottom: 5rem;
  }
}

.margin-bottom-huge {
  margin-bottom: 6rem;
}
@media only screen and (min-width: 768px) {
  .margin-bottom-huge {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .margin-bottom-huge {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .margin-bottom-huge {
    margin-bottom: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .margin-bottom-huge {
    margin-bottom: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .margin-bottom-huge {
    margin-bottom: 15rem;
  }
}

.padding {
  padding-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding {
    padding-top: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding {
    padding-top: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding {
    padding-top: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding {
    padding-top: 10rem;
  }
}
.padding {
  padding-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding {
    padding-bottom: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding {
    padding-bottom: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding {
    padding-bottom: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding {
    padding-bottom: 10rem;
  }
}

.padding-half {
  padding-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-half {
    padding-top: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-half {
    padding-top: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-half {
    padding-top: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-half {
    padding-top: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-half {
    padding-top: 5rem;
  }
}
.padding-half {
  padding-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-half {
    padding-bottom: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-half {
    padding-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-half {
    padding-bottom: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-half {
    padding-bottom: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-half {
    padding-bottom: 5rem;
  }
}

.padding-huge {
  padding-top: 6rem;
}
@media only screen and (min-width: 768px) {
  .padding-huge {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-huge {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-huge {
    padding-top: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-huge {
    padding-top: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-huge {
    padding-top: 15rem;
  }
}
.padding-huge {
  padding-bottom: 6rem;
}
@media only screen and (min-width: 768px) {
  .padding-huge {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-huge {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-huge {
    padding-bottom: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-huge {
    padding-bottom: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-huge {
    padding-bottom: 15rem;
  }
}

.padding-top {
  padding-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-top {
    padding-top: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-top {
    padding-top: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-top {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-top {
    padding-top: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-top {
    padding-top: 10rem;
  }
}

.padding-top-half {
  padding-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-top-half {
    padding-top: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-top-half {
    padding-top: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-top-half {
    padding-top: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-top-half {
    padding-top: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-top-half {
    padding-top: 5rem;
  }
}

.padding-top-huge {
  padding-top: 6rem;
}
@media only screen and (min-width: 768px) {
  .padding-top-huge {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-top-huge {
    padding-top: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-top-huge {
    padding-top: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-top-huge {
    padding-top: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-top-huge {
    padding-top: 15rem;
  }
}

.padding-bottom {
  padding-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-bottom {
    padding-bottom: 3rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-bottom {
    padding-bottom: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-bottom {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-bottom {
    padding-bottom: 8rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-bottom {
    padding-bottom: 10rem;
  }
}

.padding-bottom-half {
  padding-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
  .padding-bottom-half {
    padding-bottom: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-bottom-half {
    padding-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-bottom-half {
    padding-bottom: 3rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-bottom-half {
    padding-bottom: 4rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-bottom-half {
    padding-bottom: 5rem;
  }
}

.padding-bottom-huge {
  padding-bottom: 6rem;
}
@media only screen and (min-width: 768px) {
  .padding-bottom-huge {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .padding-bottom-huge {
    padding-bottom: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .padding-bottom-huge {
    padding-bottom: 9rem;
  }
}
@media only screen and (min-width: 1640px) {
  .padding-bottom-huge {
    padding-bottom: 12rem;
  }
}
@media only screen and (min-width: 1900px) {
  .padding-bottom-huge {
    padding-bottom: 15rem;
  }
}

.grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
}

@media only screen and (min-width: 1024px) {
  .grid-2 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media only screen and (min-width: 1024px) {
  .grid-2-3 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .grid-2-3 {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
  }
}

@media only screen and (min-width: 1440px) {
  .grid-2-1440 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media only screen and (min-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media only screen and (min-width: 1024px) {
  .grid-3-2 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .grid-3-2 {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  }
}

@media only screen and (min-width: 1024px) {
  .grid-3-4 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .grid-3-4 {
    grid-template-columns: minmax(0, 3fr) minmax(0, 4fr);
  }
}

@media only screen and (min-width: 768px) {
  .grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media only screen and (min-width: 1024px) {
  .grid-4 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media only screen and (min-width: 1440px) {
  .grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media only screen and (min-width: 1024px) {
  .layered {
    grid-column-start: 1;
    grid-row-start: 1;
  }
}

.container {
  box-sizing: border-box;
  margin-left: auto;
  margin-right: auto;
  max-width: calc(1360px + 8rem);
  width: 100%;
}
.container {
  padding-left: 1.5rem;
}
@media only screen and (min-width: 768px) {
  .container {
    padding-left: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .container {
    padding-left: 3rem;
  }
}
@media only screen and (min-width: 1440px) {
  .container {
    padding-left: 4rem;
  }
}
.container {
  padding-right: 1.5rem;
}
@media only screen and (min-width: 768px) {
  .container {
    padding-right: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .container {
    padding-right: 3rem;
  }
}
@media only screen and (min-width: 1440px) {
  .container {
    padding-right: 4rem;
  }
}

.container-1890 {
  max-width: 1890px;
}

.relative {
  position: relative;
}

.desktop-hide {
  display: none;
}

@media only screen and (min-width: 768px) {
  .mobile-only {
    display: none !important;
  }
}

/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: #21759b;
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

.skip-to-content {
  transition: all 0.2s ease-in-out;
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  position: fixed;
  color: #665AA4;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  border: 2px solid #665AA4;
  background-color: white;
  top: 0;
  left: calc(50% - 100px);
  box-shadow: 0 5px 10px rgba(255, 255, 255, 0.1);
  transform: translateY(-100px);
  padding: 1.8rem 2.5rem;
  opacity: 0;
  outline: none;
  z-index: 99999;
}
.skip-to-content:focus {
  opacity: 1;
  transform: translateY(70px);
}

.skip-to-target {
  width: 1px;
  height: 1px;
  clip: rect(1px, 1px, 1px, 1px);
  overflow: hidden;
  outline: none !important;
  box-shadow: none !important;
}

.admin-bar .skip-to-content {
  top: 56px;
}
@media screen and (min-width: 783px) {
  .admin-bar .skip-to-content {
    top: 42px;
  }
}

.breadcrumbs .breadcrumb {
  display: none;
}
@media only screen and (min-width: 768px) {
  .breadcrumbs .breadcrumb {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: unset;
    justify-content: unset;
    flex-wrap: wrap;
    max-width: 1440px;
    margin: 0;
  }
  .breadcrumbs .breadcrumb li {
    color: #1B0A41;
  }
  .breadcrumbs .breadcrumb li a {
    color: #1B0A41;
    overflow-wrap: break-word;
    text-decoration: underline;
    transition: all 0.2s ease-in-out;
    border-bottom: none;
  }
  .breadcrumbs .breadcrumb li a:hover, .breadcrumbs .breadcrumb li a:active, .breadcrumbs .breadcrumb li a:focus-within, .breadcrumbs .breadcrumb li a:focus {
    text-decoration: underline dashed;
  }
  .breadcrumbs .breadcrumb li:not(:last-child):after {
    content: "/";
    margin: 0 0.5rem;
    color: #1B0A41;
  }
}

.breadcrumb {
  margin: 0;
}
.breadcrumb li {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: row;
}

.page-template-donate-page .breadcrumb {
  margin: 0;
  margin-top: -2rem;
}

.blog-archive h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-weight: 700;
}
.blog-archive ul.filter {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
}
@media only screen and (min-width: 1024px) {
  .blog-archive ul.filter {
    margin-bottom: 4rem;
  }
}
.blog-archive ul.filter .secondary-button {
  background: #E3E3F2;
}
.blog-archive ul.filter .secondary-button:hover, .blog-archive ul.filter .secondary-button:active, .blog-archive ul.filter .secondary-button:focus-within, .blog-archive ul.filter .secondary-button:focus {
  background: #1B0A41;
  color: #FFF;
}
.blog-archive ul.filter li.active a {
  background: #1B0A41;
  color: #FFF;
}

#comments {
  border-top: 1px solid #eee;
  padding-top: 3rem;
  margin-top: 3rem;
}
#comments a:not(#submit):hover, #comments a:not(#submit):active, #comments a:not(#submit):focus-within, #comments a:not(#submit):focus {
  border-bottom: 1px solid #665AA4;
}
#comments .comments-title {
  font-size: 1.4rem;
  font-weight: 700;
}
#comments .comment-list {
  list-style-type: none;
  border-bottom: 1px solid #eee;
  padding: 0 0 2rem 1rem;
}
#comments .comment-list li {
  margin-bottom: 2rem;
}
#comments .comment-list li > article {
  margin-bottom: 2rem;
}
#comments .comment-list li .comment-content p {
  margin: 1rem 0;
}
#comments .comment-list li #respond {
  padding-left: 1rem;
  margin: 1rem 0 3rem;
}
#comments .comment-list li #respond #reply-title {
  margin: 0;
}
#comments .comment-list li #respond #reply-title small {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 1rem;
  margin-left: 2rem;
}
#comments .comment-list li #respond #reply-title small #cancel-comment-reply-link {
  color: red;
}
#comments .comment-list li #respond #reply-title small #cancel-comment-reply-link:hover, #comments .comment-list li #respond #reply-title small #cancel-comment-reply-link:active, #comments .comment-list li #respond #reply-title small #cancel-comment-reply-link:focus-within, #comments .comment-list li #respond #reply-title small #cancel-comment-reply-link:focus {
  border-bottom-color: red;
}
#comments #commentform > p {
  margin: 0 0 1rem;
}
#comments #commentform > p:not(.comment-form-cookies-consent):not(.comment-notes):not(.form-submit):not(.logged-in-as) {
  display: flex;
  align-items: unset;
  justify-content: unset;
  flex-direction: column;
}
#comments #commentform > p .required {
  color: red;
  font-weight: 700;
}
#comments #commentform #submit {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  display: inline-flex;
  background: #665AA4;
  border: 0 none;
  border-radius: 100px;
  color: #FFF;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1.2em;
  padding: 1rem 1.5rem;
  position: relative;
  text-decoration: none;
  width: fit-content;
  border: none;
  cursor: pointer;
  padding: 0.8rem 1.6rem;
  margin-top: 0;
}
#comments #commentform #submit:hover, #comments #commentform #submit:active, #comments #commentform #submit:focus-within, #comments #commentform #submit:focus {
  background: #1B0A41;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  #comments #commentform #submit {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 2rem 2.5rem;
  }
}
#comments #reply-title {
  font-size: 1.3rem;
  font-weight: 700;
}

.tribe-events .tribe-events-c-search__button {
  background-color: #665AA4;
}
.tribe-events .tribe-events-c-search__button:hover, .tribe-events .tribe-events-c-search__button:active, .tribe-events .tribe-events-c-search__button:focus-within, .tribe-events .tribe-events-c-search__button:focus {
  background-color: #FBF8F0;
}

.tribe-common--breakpoint-medium.tribe-common .tribe-common-form-control-text__input,
.tribe-common .tribe-common-form-control-text__input {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.tribe-common .tribe-common-h1,
.tribe-common .tribe-common-h2,
.tribe-common .tribe-common-h3,
.tribe-common .tribe-common-h4,
.tribe-common .tribe-common-h5,
.tribe-common .tribe-common-h6,
.tribe-common .tribe-common-h7,
.tribe-common .tribe-common-h8,
.tribe-common h1.tribe-events-single-event-title,
.single-tribe_events .tribe-common-h1,
.single-tribe_events .tribe-common-h2,
.single-tribe_events .tribe-common-h3,
.single-tribe_events .tribe-common-h4,
.single-tribe_events .tribe-common-h5,
.single-tribe_events .tribe-common-h6,
.single-tribe_events .tribe-common-h7,
.single-tribe_events .tribe-common-h8,
.single-tribe_events h1.tribe-events-single-event-title,
.tribe-events .tribe-common-h1,
.tribe-events .tribe-common-h2,
.tribe-events .tribe-common-h3,
.tribe-events .tribe-common-h4,
.tribe-events .tribe-common-h5,
.tribe-events .tribe-common-h6,
.tribe-events .tribe-common-h7,
.tribe-events .tribe-common-h8,
.tribe-events h1.tribe-events-single-event-title {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "peachy-keen-jf", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.tribe-common .tribe-events .tribe-events-c-view-selector__list-item-text,
.tribe-common .tribe-common-b2,
.tribe-common .tribe-events-event-meta,
.tribe-common .tribe-events-content p,
.single-tribe_events .tribe-events .tribe-events-c-view-selector__list-item-text,
.single-tribe_events .tribe-common-b2,
.single-tribe_events .tribe-events-event-meta,
.single-tribe_events .tribe-events-content p,
.tribe-events .tribe-events .tribe-events-c-view-selector__list-item-text,
.tribe-events .tribe-common-b2,
.tribe-events .tribe-events-event-meta,
.tribe-events .tribe-events-content p {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 16px;
}
.tribe-common .tribe-events-c-top-bar__datepicker-time span,
.tribe-common button,
.tribe-common .tribe-common-c-svgicon,
.tribe-common .tribe-events-c-subscribe-dropdown__button-icon,
.single-tribe_events .tribe-events-c-top-bar__datepicker-time span,
.single-tribe_events button,
.single-tribe_events .tribe-common-c-svgicon,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button-icon,
.tribe-events .tribe-events-c-top-bar__datepicker-time span,
.tribe-events button,
.tribe-events .tribe-common-c-svgicon,
.tribe-events .tribe-events-c-subscribe-dropdown__button-icon {
  color: #665AA4;
}
.tribe-common .tribe-events-c-subscribe-dropdown__button:hover,
.tribe-common .tribe-events-c-subscribe-dropdown__button:focus-within,
.tribe-common .tribe-events-calendar-month__day-cell--selected,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:hover,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:focus-within,
.single-tribe_events .tribe-events-calendar-month__day-cell--selected,
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover,
.tribe-events .tribe-events-c-subscribe-dropdown__button:focus-within,
.tribe-events .tribe-events-calendar-month__day-cell--selected {
  background-color: #665AA4 !important;
}
.tribe-common .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-c-subscribe-dropdown__button-text,
.tribe-common .tribe-events-c-subscribe-dropdown__button:hover .tribe-common-c-svgicon,
.tribe-common .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-calendar-month__day-date-daynum,
.tribe-common .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-c-subscribe-dropdown__button-text,
.tribe-common .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-common-c-svgicon,
.tribe-common .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-calendar-month__day-date-daynum,
.tribe-common .tribe-events-calendar-month__day-cell--selected .tribe-events-c-subscribe-dropdown__button-text,
.tribe-common .tribe-events-calendar-month__day-cell--selected .tribe-common-c-svgicon,
.tribe-common .tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__day-date-daynum,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-c-subscribe-dropdown__button-text,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:hover .tribe-common-c-svgicon,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-calendar-month__day-date-daynum,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-c-subscribe-dropdown__button-text,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-common-c-svgicon,
.single-tribe_events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-calendar-month__day-date-daynum,
.single-tribe_events .tribe-events-calendar-month__day-cell--selected .tribe-events-c-subscribe-dropdown__button-text,
.single-tribe_events .tribe-events-calendar-month__day-cell--selected .tribe-common-c-svgicon,
.single-tribe_events .tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__day-date-daynum,
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-c-subscribe-dropdown__button-text,
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover .tribe-common-c-svgicon,
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover .tribe-events-calendar-month__day-date-daynum,
.tribe-events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-c-subscribe-dropdown__button-text,
.tribe-events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-common-c-svgicon,
.tribe-events .tribe-events-c-subscribe-dropdown__button:focus-within .tribe-events-calendar-month__day-date-daynum,
.tribe-events .tribe-events-calendar-month__day-cell--selected .tribe-events-c-subscribe-dropdown__button-text,
.tribe-events .tribe-events-calendar-month__day-cell--selected .tribe-common-c-svgicon,
.tribe-events .tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__day-date-daynum {
  color: white;
}
.tribe-common .tribe-events-calendar-month__day--current button,
.single-tribe_events .tribe-events-calendar-month__day--current button,
.tribe-events .tribe-events-calendar-month__day--current button {
  background-color: #665AA4 !important;
}
.tribe-common .tribe-events-calendar-month__day--current button .tribe-events-calendar-month__day-date-daynum,
.single-tribe_events .tribe-events-calendar-month__day--current button .tribe-events-calendar-month__day-date-daynum,
.tribe-events .tribe-events-calendar-month__day--current button .tribe-events-calendar-month__day-date-daynum {
  color: #FBF8F0;
}
.tribe-common .tribe-events-calendar-list__event-title a,
.tribe-common .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link,
.tribe-common .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link:visited,
.single-tribe_events .tribe-events-calendar-list__event-title a,
.single-tribe_events .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link,
.single-tribe_events .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link:visited,
.tribe-events .tribe-events-calendar-list__event-title a,
.tribe-events .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link,
.tribe-events .tribe-events-calendar-list__event-title .tribe-events-calendar-list__event-title-link:visited {
  color: #665AA4;
}
.tribe-common .tribe-common-l-container,
.single-tribe_events .tribe-common-l-container,
.tribe-events .tribe-common-l-container {
  margin: 0 auto;
  padding: 0;
  width: 90%;
}
.tribe-common .tribe-common-c-btn-border,
.single-tribe_events .tribe-common-c-btn-border,
.tribe-events .tribe-common-c-btn-border {
  border-color: #665AA4;
}
.tribe-common .tribe-events-c-search__button,
.tribe-common button.tribe-events-c-search__button,
.single-tribe_events .tribe-events-c-search__button,
.single-tribe_events button.tribe-events-c-search__button,
.tribe-events .tribe-events-c-search__button,
.tribe-events button.tribe-events-c-search__button {
  background-color: #665AA4;
  color: #1B0A41;
}
.tribe-common .tribe-events-c-search__button:hover, .tribe-common .tribe-events-c-search__button:active, .tribe-common .tribe-events-c-search__button:focus-within, .tribe-common .tribe-events-c-search__button:focus,
.tribe-common button.tribe-events-c-search__button:hover,
.tribe-common button.tribe-events-c-search__button:active,
.tribe-common button.tribe-events-c-search__button:focus-within,
.tribe-common button.tribe-events-c-search__button:focus,
.single-tribe_events .tribe-events-c-search__button:hover,
.single-tribe_events .tribe-events-c-search__button:active,
.single-tribe_events .tribe-events-c-search__button:focus-within,
.single-tribe_events .tribe-events-c-search__button:focus,
.single-tribe_events button.tribe-events-c-search__button:hover,
.single-tribe_events button.tribe-events-c-search__button:active,
.single-tribe_events button.tribe-events-c-search__button:focus-within,
.single-tribe_events button.tribe-events-c-search__button:focus,
.tribe-events .tribe-events-c-search__button:hover,
.tribe-events .tribe-events-c-search__button:active,
.tribe-events .tribe-events-c-search__button:focus-within,
.tribe-events .tribe-events-c-search__button:focus,
.tribe-events button.tribe-events-c-search__button:hover,
.tribe-events button.tribe-events-c-search__button:active,
.tribe-events button.tribe-events-c-search__button:focus-within,
.tribe-events button.tribe-events-c-search__button:focus {
  background-color: #1B0A41;
  color: #FFF;
}
.tribe-common .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-text,
.tribe-common .tribe-events-c-subscribe-dropdown button.tribe-events-c-subscribe-dropdown__button-text,
.tribe-common .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-icon,
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-text,
.single-tribe_events .tribe-events-c-subscribe-dropdown button.tribe-events-c-subscribe-dropdown__button-text,
.single-tribe_events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-icon,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-text,
.tribe-events .tribe-events-c-subscribe-dropdown button.tribe-events-c-subscribe-dropdown__button-text,
.tribe-events .tribe-events-c-subscribe-dropdown .tribe-events-c-subscribe-dropdown__button-icon {
  color: #1B0A41;
}
.tribe-common p,
.single-tribe_events p,
.tribe-events p {
  font-size: 1rem;
}

.faqs {
  display: flex;
  align-items: unset;
  justify-content: unset;
  flex-direction: column;
  position: relative;
}
.faqs .faq {
  border-radius: 0;
  border-bottom: 2px solid rgb(209.5853658537, 209.5853658537, 233.9146341463);
  max-width: 570px;
}
.faqs .faq:last-child {
  border-bottom: none;
}
.faqs .faq .accordion-item {
  list-style: none;
}
.faqs .faq .accordion-item button {
  transition: all 0.2s ease-in-out;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: #E3E3F2;
  position: relative;
  color: #1B0A41;
  font-size: 1.125rem;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  gap: 2rem;
  padding: 1.5rem 0;
  outline: none;
  overflow: hidden;
  text-align: left;
  width: 100%;
}
.faqs .faq .accordion-item button:before {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  aspect-ratio: 1/1;
  backface-visibility: hidden;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTAiIGhlaWdodD0iNTAiIHZpZXdCb3g9IjAgMCA1MCA1MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTUwIDI1QzUwIDM4LjgwNzEgMzMuODA3MSA0OS42ODc1IDIwIDQ5LjY4NzVDNi4xOTI4OCA0OS42ODc1IDAgMzguODA3MSAwIDI1QzAgMTEuMTkyOSA2LjE5Mjg4IDAgMjAgMEMzMy44MDcxIDAgNTAgMTEuMTkyOSA1MCAyNVoiIGZpbGw9IiNEMkQyRjAiLz4KPC9zdmc+Cg==);
  background-size: contain;
  color: #665AA4;
  content: "\e832";
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 12px;
  transform: rotate(0deg);
  width: 3.5rem;
}
.faqs .faq .accordion-item button:hover, .faqs .faq .accordion-item button:active, .faqs .faq .accordion-item button:focus-within, .faqs .faq .accordion-item button:focus {
  background-color: #E3E3F2;
}
.faqs .faq .accordion-item button:active, .faqs .faq .accordion-item button:focus {
  background: #E3E3F2;
  color: #1B0A41;
}
.faqs .faq .accordion-item button:active:after, .faqs .faq .accordion-item button:focus:after {
  color: #1B0A41;
}
.faqs .faq .accordion-item button[aria-expanded=true]:before {
  transform: rotate(-45deg);
}
.faqs dd {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  transition: all 0.5s ease-in-out;
  background: #E3E3F2;
  flex-direction: column;
  gap: 2rem;
  overflow: hidden;
  margin: 0;
  padding: 0;
}
.faqs dd p {
  color: #1B0A41;
  max-width: 100%;
  margin: 0;
}
.faqs dd p a {
  color: #1B0A41;
}
.faqs .faq {
  transition: all 0.5s ease-in-out;
  display: grid;
  grid-template-rows: min-content 0fr;
  overflow: hidden;
}
.faqs .faq.open {
  grid-template-rows: min-content 1fr;
}
.faqs .faq.open dd {
  padding: 0 0 2rem;
}

section.faqs .curved-bubble-top,
section.faqs .curved-bubble-bottom {
  display: block;
  width: 100%;
}
section.faqs .wrapper {
  background: #E3E3F2;
}
@media only screen and (min-width: 1024px) {
  section.faqs .wrapper .container {
    align-items: center;
  }
}
section.faqs .wrapper .images {
  display: block;
  position: relative;
  aspect-ratio: 3/4;
}
section.faqs .wrapper .images:after {
  aspect-ratio: 670/810;
  content: "";
  position: absolute;
  top: -25%;
  left: 30%;
  width: 85%;
  background-image: url("../images/purple-dots.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  z-index: 0;
}
section.faqs .wrapper .images img {
  display: block;
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  object-fit: cover;
  position: absolute;
  width: 100%;
  z-index: 1;
}
section.faqs .wrapper .images img:nth-of-type(1) {
  aspect-ratio: 1/1;
  left: 0;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjc1IiBoZWlnaHQ9IjY2MCIgdmlld0JveD0iMCAwIDY3NSA2NjAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xODQuNDEgMjkuOTE1NEMyNDMuMzk5IC0wLjgxMDA3MyAzMTAuODQ2IC0yLjU2MTg5IDM3NS4wODkgMy41MTc4OEM0NDEuNDYzIDkuNzk3MjYgNTEwLjQwMiAyNC45NTU3IDU2Ni45NiA2MS44MDk5QzU5Ny41MDcgODEuNzE0NyA2MjMuODA4IDEwOC42MzggNjM5LjU0NCAxNDIuNjM3QzY4MS43ODQgMjMzLjkxMiA2ODQuNjkxIDM0NS4yNzEgNjUyLjY1NiA0NDIuMzAzQzY0My4yNzcgNDcwLjY5MiA2MzAuNDYyIDQ5OC4wMjkgNjEzLjc2OSA1MjIuNzkzQzU5Ni43MjQgNTQ4LjA3OSA1NzUuNjY0IDU3MC4zNjEgNTUxLjU3MiA1ODguNTEzQzQ5Ni43MDQgNjI5Ljg4MyA0MjkuODA0IDY1My4xMDggMzYzLjExIDY1OC4yNjFDMjQ3Ljg3OSA2NjcuMTQxIDExMi4zNTQgNjMxLjkyOSA0MS4xMDMzIDUzMy42ODhDMjEuNDExOCA1MDYuNTM3IDcuNjcxOTMgNDc0Ljc4OSAyLjc2MTM0IDQ0MC44MThDLTYuNDQzMjggMzc3LjQxNyAxMC43MTQgMzEzLjE3MSAzMi44ODg2IDI1My42OTlDNTguNzI3NyAxODQuNDA5IDg2LjQ0ODcgMTA3LjUyNyAxNDMuMjEzIDU4LjAwNDlDMTU2LjEwOCA0Ni43NDY1IDE2OS45NDMgMzcuNDg2MSAxODQuNDIxIDI5Ljk1MTNMMTg0LjQxIDI5LjkxNTRaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K);
  top: 0;
  width: 80%;
}
section.faqs .wrapper .images img:nth-of-type(2) {
  aspect-ratio: 430/455;
  bottom: 0;
  left: 0;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDU2IiBoZWlnaHQ9IjQzNCIgdmlld0JveD0iMCAwIDQ1NiA0MzQiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0zNzguMjA2IDQxLjI1MDhDNDExLjY3OSA3MC41ODQ1IDQyOS4xMjEgMTEyLjIxNSA0NDAuODk5IDE1My43NDZDNDUzLjA2OSAxOTYuNjU0IDQ2MC4zMiAyNDMuMzE0IDQ1MS4wMzEgMjg3LjUxMkM0NDYuMDE0IDMxMS4zODQgNDM1LjU4OCAzMzQuMzA5IDQxOC4xODUgMzUyLjM2MkMzNzEuNDY1IDQwMC44MjQgMzAyLjY3NyA0MjkuNjMgMjM0LjM2IDQzMy4xNzVDMjE0LjM3MSA0MzQuMjA4IDE5NC4yMDUgNDMyLjg0NSAxNzQuNzA1IDQyOC40MzhDMTU0Ljc5NCA0MjMuOTQgMTM1Ljc4NSA0MTYuMjA5IDExOC42MTcgNDA1LjU4N0M3OS41MDAzIDM4MS40MDMgNDguNzkxIDM0NS4zMTkgMjkuNDA5IDMwNC45ODNDLTQuMDYzNjQgMjM1LjI4NiAtMTQuOTQwMyAxNDIuMjQ2IDI5LjA5NTQgNzQuMDA2N0M0MS4yNjU1IDU1LjE0NzMgNTcuNzQ3IDM4Ljg4NDYgNzcuNzU2MSAyNy41ODgzQzExNS4wODkgNi40ODEwNiAxNTkuMzQxIDEuNjA2MTMgMjAxLjgyOCAxLjAxNzA2QzI1MS4zMzIgMC4zMzI3NDEgMzA2LjAyOCAtMS4wMTgxOCAzNTAuNjkxIDIyLjM3MkMzNjAuODQzIDI3LjY4MzcgMzY5Ljk3NSAzNC4wNjU2IDM3OC4xODcgNDEuMjY2NkwzNzguMjA2IDQxLjI1MDhaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K);
  width: 52%;
}
section.faqs .wrapper .images img:nth-of-type(3) {
  aspect-ratio: 305/320;
  bottom: 12%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzE2IiBoZWlnaHQ9IjMzNCIgdmlld0JveD0iMCAwIDMxNiAzMzQiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0wLjg2MzE0MyAxODQuMjMzQy0zLjExMzUxIDE1My4xMDQgNy4xMjY3MyAxMjIuOTYzIDIwLjMxMzIgOTUuNTE5M0MzMy45MzYxIDY3LjE2NTEgNTEuOTExNiAzOS4xMjUzIDc3LjQ3NjEgMjAuMTFDOTEuMjgzMyA5LjgzOTc5IDEwNy41MDYgMi41OTU0IDEyNS4xMzggMS4xODMxM0MxNzIuNDczIC0yLjYwNTYgMjIyLjI4MSAxNC4yOTU5IDI2MC4wMzQgNDQuMzI0N0MyNzEuMDc4IDUzLjExMzQgMjgxLjA5NiA2My4yNTA3IDI4OS4zNCA3NC42ODQ2QzI5Ny43NTggODYuMzU5NCAzMDQuMTg5IDk5LjMyMDggMzA4LjI5NSAxMTIuOTVDMzE3LjY2MSAxNDMuOTk0IDMxNy4wMjMgMTc3LjQgMzA4LjQxMiAyMDcuNzYzQzI5My41MjUgMjYwLjIyIDI1NS43OSAzMTQuNDU4IDIwMC42MzEgMzI5Ljk1QzE4NS4zODYgMzM0LjIzMiAxNjkuMDc4IDMzNS4xMjggMTUzLjIyNiAzMzEuNzUzQzEyMy42MzYgMzI1LjQ3MiA5Ny45NzY1IDMwNy4zODQgNzUuMjUyMiAyODcuODU1QzQ4Ljc3NjQgMjY1LjEgMTkuMjQ1IDI0MC4yNzIgNi41NzgwOSAyMDcuMDU3QzMuNjk2NzcgMTk5LjUxIDEuODU0MTEgMTkxLjg3MyAwLjg4MDg4MyAxODQuMjM0TDAuODYzMTQzIDE4NC4yMzNaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K);
  right: 0;
  width: 44%;
}
section.faqs .wrapper .primary-button {
  background: #D2D2F0;
  color: #1B0A41;
  position: relative;
  z-index: 1;
}
section.faqs .wrapper .primary-button:hover, section.faqs .wrapper .primary-button:active, section.faqs .wrapper .primary-button:focus-within, section.faqs .wrapper .primary-button:focus {
  background: #665AA4;
  color: #FFF;
  text-decoration: none;
}
@media only screen and (max-width: 1023px) {
  section.faqs .wrapper .primary-button {
    margin-bottom: 2rem;
  }
}

form p {
  font-size: 1.125rem;
}
form fieldset {
  border: 0 none;
  margin: 0;
  padding: 0;
}
form input,
form textarea {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  border: 1px solid #665AA4;
  border-radius: 20px;
  box-sizing: border-box;
  font-size: 1.2rem;
  line-height: 1.6rem;
  padding: 1.25rem 2rem;
  width: 100%;
}
form .error,
form #ajax-processing {
  display: none;
}
form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button) {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  display: inline-flex;
  background: #665AA4;
  border: 0 none;
  border-radius: 100px;
  color: #FFF;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1.2em;
  padding: 1rem 1.5rem;
  position: relative;
  text-decoration: none;
  width: fit-content;
  border: 0 none;
}
form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button):hover, form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button):active, form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button):focus-within, form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button):focus {
  background: #1B0A41;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  form button:not(.tribe-common-c-btn):not(.subscribe button):not(.search-form button):not(.woocommerce button) {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 2rem 2.5rem;
  }
}

.swiper-gallery-main .swiper-slide {
  display: flex;
  align-items: unset;
  justify-content: unset;
  flex-direction: column;
  position: relative;
}
.swiper-gallery-main .swiper-slide img {
  aspect-ratio: 4/3;
  border-radius: 20px;
  display: block;
  object-fit: cover;
  order: -1;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .swiper-gallery-main .swiper-slide img {
    border-radius: 40px;
  }
}
.swiper-gallery-main .swiper-slide .caption {
  background: #665AA4;
  border-radius: 10px;
  top: calc(100% - 0.75rem);
  color: #FFF;
  margin: 1rem 0;
  padding: 0.5rem 1rem;
  position: absolute;
  width: calc(100% - 2rem);
}
@media only screen and (min-width: 768px) {
  .swiper-gallery-main .swiper-slide .caption {
    bottom: 1rem;
    margin: 1rem;
    top: auto;
    width: calc(100% - 11rem);
  }
}
.swiper-gallery-main .nav-controls {
  bottom: 0;
  height: 100px;
  position: absolute;
  right: 0;
  width: 120px;
  z-index: 10;
}
.swiper-gallery-main .nav-controls button {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #665AA4;
  border: 0 none;
  border-radius: 10px;
  bottom: 2rem;
  color: #FFF;
  padding: 0.5rem 1.5rem;
  top: auto;
}
.swiper-gallery-main .nav-controls button:after {
  font-size: 1.5rem;
}
.swiper-gallery-main .nav-controls button.swiper-button-prev {
  left: auto;
  right: 4rem;
}
.swiper-gallery-main .nav-controls button:hover, .swiper-gallery-main .nav-controls button:active, .swiper-gallery-main .nav-controls button:focus-within, .swiper-gallery-main .nav-controls button:focus {
  background: #665AA4;
}

.swiper.swiper-gallery-thumbs {
  display: none;
  margin-top: 1rem;
}
@media only screen and (min-width: 768px) {
  .swiper.swiper-gallery-thumbs {
    display: block;
  }
}
.swiper.swiper-gallery-thumbs button {
  background: none;
  border: 2px solid #665AA4;
  border-radius: 20px;
  margin: 0;
  overflow: hidden;
  padding: 0;
}
.swiper.swiper-gallery-thumbs button img {
  aspect-ratio: 4/3;
  display: block;
  object-fit: cover;
  opacity: 0.45;
  width: 100%;
}
.swiper.swiper-gallery-thumbs button.swiper-slide-thumb-active {
  border: 4px solid #665AA4;
}
.swiper.swiper-gallery-thumbs button.swiper-slide-thumb-active img {
  opacity: 1;
}

.purple-dots-top-left,
.cyan-dots-top-left,
.magenta-dots-bottom-left {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  aspect-ratio: 760/820;
  position: relative;
}
.purple-dots-top-left:after,
.cyan-dots-top-left:after,
.magenta-dots-bottom-left:after {
  aspect-ratio: 762/780;
  background-image: url("../images/purple-dots-top-left.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: auto;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.purple-dots-top-left a,
.cyan-dots-top-left a,
.magenta-dots-bottom-left a {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 615/650;
  display: block;
  margin: 0 3% 3% 0;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjQ1IiBoZWlnaHQ9IjYzMCIgdmlld0JveD0iMCAwIDY0NSA2MzAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xNzYuNzA5IDI3Ljk2MjZDMjMzLjAzOSAtMS4zODk2OCAyOTcuNDQ0IC0zLjA2MzIgMzU4Ljc5MSAyLjc0NDgzQzQyMi4xNzIgOC43NDM1NSA0ODguMDAzIDIzLjIyNDUgNTQyLjAxMSA1OC40MzE1QzU3MS4xOCA3Ny40NDY2IDU5Ni4yOTUgMTAzLjE2NiA2MTEuMzIyIDEzNS42NDZDNjUxLjY1NyAyMjIuODQxIDY1NC40MzQgMzI5LjIyMyA2MjMuODQzIDQyMS45MThDNjE0Ljg4NiA0NDkuMDM4IDYwMi42NSA0NzUuMTU0IDU4Ni43MDkgNDk4LjgxQzU3MC40MzMgNTIyLjk2NiA1NTAuMzIyIDU0NC4yNTIgNTI3LjMxNiA1NjEuNTkzQzQ3NC45MjIgNjAxLjExNSA0MTEuMDM5IDYyMy4zMDEgMzQ3LjM1MiA2MjguMjI0QzIzNy4zMTcgNjM2LjcwNyAxMDcuOTAyIDYwMy4wNjggMzkuODY0IDUwOS4yMThDMjEuMDYwMyA0ODMuMjgxIDcuOTM5OTggNDUyLjk1MiAzLjI1MDgxIDQyMC40OTlDLTUuNTM4NzkgMzU5LjkzMiAxMC44NDQ5IDI5OC41NTcgMzIuMDE5NyAyNDEuNzQ0QzU2LjY5MzcgMTc1LjU1IDgzLjE2NDggMTAyLjEwNSAxMzcuMzcgNTQuNzk2NkMxNDkuNjg0IDQ0LjA0MTMgMTYyLjg5NSAzNS4xOTQ4IDE3Ni43MiAyNy45OTY4TDE3Ni43MDkgMjcuOTYyNloiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
  object-fit: cover;
  position: absolute;
  width: 85%;
  z-index: 2;
}
.purple-dots-top-left a:before,
.cyan-dots-top-left a:before,
.magenta-dots-bottom-left a:before {
  background-image: url("../images/play-icon.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 95px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 95px;
  z-index: 3;
}
.purple-dots-top-left img,
.cyan-dots-top-left img,
.magenta-dots-bottom-left img {
  display: block;
  height: 100%;
  margin: 0 3% 3% 0;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjQ1IiBoZWlnaHQ9IjYzMCIgdmlld0JveD0iMCAwIDY0NSA2MzAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xNzYuNzA5IDI3Ljk2MjZDMjMzLjAzOSAtMS4zODk2OCAyOTcuNDQ0IC0zLjA2MzIgMzU4Ljc5MSAyLjc0NDgzQzQyMi4xNzIgOC43NDM1NSA0ODguMDAzIDIzLjIyNDUgNTQyLjAxMSA1OC40MzE1QzU3MS4xOCA3Ny40NDY2IDU5Ni4yOTUgMTAzLjE2NiA2MTEuMzIyIDEzNS42NDZDNjUxLjY1NyAyMjIuODQxIDY1NC40MzQgMzI5LjIyMyA2MjMuODQzIDQyMS45MThDNjE0Ljg4NiA0NDkuMDM4IDYwMi42NSA0NzUuMTU0IDU4Ni43MDkgNDk4LjgxQzU3MC40MzMgNTIyLjk2NiA1NTAuMzIyIDU0NC4yNTIgNTI3LjMxNiA1NjEuNTkzQzQ3NC45MjIgNjAxLjExNSA0MTEuMDM5IDYyMy4zMDEgMzQ3LjM1MiA2MjguMjI0QzIzNy4zMTcgNjM2LjcwNyAxMDcuOTAyIDYwMy4wNjggMzkuODY0IDUwOS4yMThDMjEuMDYwMyA0ODMuMjgxIDcuOTM5OTggNDUyLjk1MiAzLjI1MDgxIDQyMC40OTlDLTUuNTM4NzkgMzU5LjkzMiAxMC44NDQ5IDI5OC41NTcgMzIuMDE5NyAyNDEuNzQ0QzU2LjY5MzcgMTc1LjU1IDgzLjE2NDggMTAyLjEwNSAxMzcuMzcgNTQuNzk2NkMxNDkuNjg0IDQ0LjA0MTMgMTYyLjg5NSAzNS4xOTQ4IDE3Ni43MiAyNy45OTY4TDE3Ni43MDkgMjcuOTYyNloiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
  object-fit: cover;
  position: absolute;
  width: 100%;
  z-index: 1;
}
.purple-dots-top-left iframe,
.cyan-dots-top-left iframe,
.magenta-dots-bottom-left iframe {
  aspect-ratio: 16/9;
  display: block;
  height: 100%;
  left: 50%;
  margin: auto;
  object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.cyan-dots-top-left:after {
  background-image: url("../images/cyan-dots-top-left.svg");
}

.magenta-dots-bottom-left {
  aspect-ratio: 700/750;
}
.magenta-dots-bottom-left:after {
  background-image: url("../images/magenta-dots-bottom-left.svg");
  height: 125%;
  left: 45%;
  top: 53%;
  width: 125%;
}
.magenta-dots-bottom-left a {
  aspect-ratio: 590/605;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjA1IiBoZWlnaHQ9IjYxOCIgdmlld0JveD0iMCAwIDYwNSA2MTgiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0yNy4zOTczIDQ0OS4xODZDLTAuNzQ0NTc4IDM5NS4xOCAtMi4zNDkwOCAzMzMuNDMgMy4yMTk0NCAyNzQuNjEzQzguOTcwNzkgMjEzLjg0NiAyMi44NTQ2IDE1MC43MjkgNTYuNjA5OCA5OC45NDg1Qzc0Ljg0MDggNzAuOTgxOCA5OS40OTk5IDQ2LjkwMjUgMTMwLjY0IDMyLjQ5NTVDMjE0LjI0IC02LjE3NjMyIDMxNi4yMzUgLTguODM4NTggNDA1LjEwNyAyMC40OTA4QzQzMS4xMDkgMjkuMDc4MSA0NTYuMTQ4IDQwLjgxIDQ3OC44MjkgNTYuMDkzNUM1MDEuOTg5IDcxLjY5ODUgNTIyLjM5NyA5MC45Nzk3IDUzOS4wMjMgMTEzLjAzN0M1NzYuOTE0IDE2My4yNzEgNTk4LjE4NiAyMjQuNTIgNjAyLjkwNiAyODUuNThDNjExLjAzOSAzOTEuMDc4IDU3OC43ODggNTE1LjE1NiA0ODguODA4IDU4MC4zODlDNDYzLjk0IDU5OC40MTcgNDM0Ljg2MiA2MTAuOTk2IDQwMy43NDcgNjE1LjQ5MkMzNDUuNjc4IDYyMy45MTkgMjg2LjgzNCA2MDguMjExIDIzMi4zNjMgNTg3LjkwOUMxNjguODk5IDU2NC4yNTMgOTguNDgyMiA1MzguODczIDUzLjEyNDggNDg2LjkwNEM0Mi44MTMgNDc1LjA5OCAzNC4zMzEzIDQ2Mi40MzEgMjcuNDMwMSA0NDkuMTc2TDI3LjM5NzMgNDQ5LjE4NloiIGZpbGw9IiNGRjAwMDAiLz4KPC9zdmc+Cg==);
  margin: 0 6% 6% 0;
  width: 78%;
}
.magenta-dots-bottom-left img {
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjA1IiBoZWlnaHQ9IjYxOCIgdmlld0JveD0iMCAwIDYwNSA2MTgiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0yNy4zOTczIDQ0OS4xODZDLTAuNzQ0NTc4IDM5NS4xOCAtMi4zNDkwOCAzMzMuNDMgMy4yMTk0NCAyNzQuNjEzQzguOTcwNzkgMjEzLjg0NiAyMi44NTQ2IDE1MC43MjkgNTYuNjA5OCA5OC45NDg1Qzc0Ljg0MDggNzAuOTgxOCA5OS40OTk5IDQ2LjkwMjUgMTMwLjY0IDMyLjQ5NTVDMjE0LjI0IC02LjE3NjMyIDMxNi4yMzUgLTguODM4NTggNDA1LjEwNyAyMC40OTA4QzQzMS4xMDkgMjkuMDc4MSA0NTYuMTQ4IDQwLjgxIDQ3OC44MjkgNTYuMDkzNUM1MDEuOTg5IDcxLjY5ODUgNTIyLjM5NyA5MC45Nzk3IDUzOS4wMjMgMTEzLjAzN0M1NzYuOTE0IDE2My4yNzEgNTk4LjE4NiAyMjQuNTIgNjAyLjkwNiAyODUuNThDNjExLjAzOSAzOTEuMDc4IDU3OC43ODggNTE1LjE1NiA0ODguODA4IDU4MC4zODlDNDYzLjk0IDU5OC40MTcgNDM0Ljg2MiA2MTAuOTk2IDQwMy43NDcgNjE1LjQ5MkMzNDUuNjc4IDYyMy45MTkgMjg2LjgzNCA2MDguMjExIDIzMi4zNjMgNTg3LjkwOUMxNjguODk5IDU2NC4yNTMgOTguNDgyMiA1MzguODczIDUzLjEyNDggNDg2LjkwNEM0Mi44MTMgNDc1LjA5OCAzNC4zMzEzIDQ2Mi40MzEgMjcuNDMwMSA0NDkuMTc2TDI3LjM5NzMgNDQ5LjE4NloiIGZpbGw9IiNGRjAwMDAiLz4KPC9zdmc+Cg==);
  margin: 0;
  width: 100%;
}

.listing-item a {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
}
.listing-item a:hover, .listing-item a:active, .listing-item a:focus-within, .listing-item a:focus {
  text-decoration: none;
}
.listing-item .thumbnail {
  position: relative;
  width: 100%;
}
.listing-item .thumbnail img {
  aspect-ratio: 4/3;
  border-radius: 1.25rem;
  display: block;
  object-fit: cover;
  width: 100%;
}
.listing-item .thumbnail .category {
  background: #F2F2F2;
  border-radius: 60px;
  bottom: 1rem;
  color: #1B0A41;
  font-size: 1.125rem;
  font-weight: 700;
  left: 1rem;
  padding: 0.5rem 1rem;
  position: absolute;
}
.listing-item .content {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  color: #1B0A41;
  flex-direction: column;
  height: 100%;
  padding: 2rem 0 0;
}
.listing-item .content h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #1B0A41;
  font-weight: 700;
  margin: 0;
}
.listing-item .content .secondary-button {
  background: #E3E3F2;
  margin-top: auto;
}
.listing-item:hover, .listing-item:active, .listing-item:focus-within, .listing-item:focus {
  text-decoration: none;
}
.listing-item:hover .secondary-button, .listing-item:active .secondary-button, .listing-item:focus-within .secondary-button, .listing-item:focus .secondary-button {
  background: #665AA4;
  color: #FFF;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: unset;
  gap: 0.5rem;
  margin: 0;
  text-align: center;
}
.pagination a {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background: #E3E3F2;
  color: #1B0A41;
  border: 1px solid white;
  border-radius: 100%;
  line-height: 40px;
  text-decoration: none !important;
  width: 3rem;
}
.pagination a:hover, .pagination a:active, .pagination a:focus-within, .pagination a:focus {
  background: #665AA4;
  border: 1px solid #665AA4;
  color: white;
}
.pagination .current {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background: #665AA4;
  border: 1px solid #665AA4;
  border-radius: 100%;
  color: white;
  width: 3rem;
}
.pagination .prev,
.pagination .next {
  background: #E3E3F2;
  color: #1B0A41;
}
.pagination .prev .arrow-icon,
.pagination .next .arrow-icon {
  font-size: 0.875rem;
}
.pagination .prev .arrow-icon:before,
.pagination .next .arrow-icon:before {
  content: "\e803";
  font-family: fontello;
}
.pagination .prev .arrow-icon {
  transform: rotate(90deg);
}
.pagination .next .arrow-icon {
  transform: rotate(270deg);
}

.partners-section {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(2, 1fr);
}
@media only screen and (min-width: 768px) {
  .partners-section {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (min-width: 1024px) {
  .partners-section {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .partners-section {
    grid-template-columns: repeat(4, 1fr);
  }
}
.partners-section img {
  aspect-ratio: 3/2;
  display: block;
  object-fit: contain;
  width: 100%;
}

.search-form {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  animation: fadeIn 0.5s ease-in-out forwards;
  background: #E3E3F2;
  box-sizing: border-box;
  display: none;
  gap: 0.5rem;
  margin: 0;
  max-width: 700px;
  right: 4.5rem;
  padding: 0;
  position: absolute;
  width: calc(100% - 9.5rem);
  z-index: 10;
}
@media only screen and (min-width: 768px) {
  .search-form {
    right: 5rem;
    width: calc(100% - 12.5rem);
  }
}
@media only screen and (min-width: 1024px) {
  .search-form {
    right: 6rem;
    width: calc(100% - 12.5rem);
  }
}
@media only screen and (min-width: 1340px) {
  .search-form {
    right: 5rem;
    width: max-content;
  }
}
.search-form input#search-mobile,
.search-form input#search-desktop {
  border: 1px solid #1B0A41;
  border-radius: 0.25rem;
  font-size: 1.125rem;
  margin: 0;
  outline: none;
  padding: 0.25rem 1rem;
  width: 100%;
}
.search-form input#search-mobile::-webkit-input-placeholder,
.search-form input#search-desktop::-webkit-input-placeholder {
  color: #1B0A41;
}
.search-form input#search-mobile:-moz-placeholder,
.search-form input#search-desktop:-moz-placeholder {
  color: #1B0A41;
}
.search-form input#search-mobile::-moz-placeholder,
.search-form input#search-desktop::-moz-placeholder {
  color: #1B0A41;
}
.search-form input#search-mobile:-ms-input-placeholder,
.search-form input#search-desktop:-ms-input-placeholder {
  color: #1B0A41;
}
.search-form input#search-mobile::-ms-input-placeholder,
.search-form input#search-desktop::-ms-input-placeholder {
  color: #1B0A41;
}
.search-form input#search-mobile:focus::placeholder,
.search-form input#search-desktop:focus::placeholder {
  opacity: 0;
}
@media only screen and (min-width: 1340px) {
  .search-form input#search-mobile,
  .search-form input#search-desktop {
    border: 0 none;
  }
}
.search-form.active {
  animation: 0.5s fadeIn ease-in-out forwards;
  display: flex;
}
.search-form.desktop {
  display: none;
}
@media only screen and (min-width: 1340px) {
  .search-form.desktop {
    background: #E3E3F2;
    border-radius: 100px;
    display: flex;
    padding: 0.5rem;
    position: static;
  }
  .search-form.desktop input#search-desktop {
    background: none;
    outline: none;
  }
}

.search-result-type {
  color: #1B0A41;
  font-weight: 700;
  letter-spacing: 4px;
  margin-bottom: 0;
  padding-bottom: 0;
  text-transform: uppercase;
}

.search-results ul,
.search-no-results ul {
  margin: 0;
  padding: 0;
}
.search-results .search-result,
.search-no-results .search-result {
  border-bottom: 1px solid #1B0A41;
  list-style: none;
  margin: 0;
  padding: 1em 0;
}
.search-results .search-result a,
.search-no-results .search-result a {
  color: #1B0A41;
  text-decoration: none !important;
  text-underline-offset: 4px;
}
.search-results .search-result a:hover .arrow-button, .search-results .search-result a:active .arrow-button, .search-results .search-result a:focus-within .arrow-button, .search-results .search-result a:focus .arrow-button,
.search-no-results .search-result a:hover .arrow-button,
.search-no-results .search-result a:active .arrow-button,
.search-no-results .search-result a:focus-within .arrow-button,
.search-no-results .search-result a:focus .arrow-button {
  text-decoration: underline dashed !important;
}
.search-results .search-result a h3,
.search-no-results .search-result a h3 {
  margin: 0;
}
.search-results .search-result a p,
.search-no-results .search-result a p {
  margin: 1em 0;
}

.search-trigger.custom-icon,
.search-submit.custom-icon {
  transition: all 0.2s ease-in-out;
  aspect-ratio: 1/1;
  background: #D2D2F0;
  border: 0 none;
  border-radius: 100%;
  color: #665AA4;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  width: 2.5rem;
  z-index: 1;
}
.search-trigger.custom-icon:after,
.search-submit.custom-icon:after {
  font-size: 1rem;
}
.search-trigger.custom-icon:hover, .search-trigger.custom-icon:active, .search-trigger.custom-icon:focus-within, .search-trigger.custom-icon:focus,
.search-submit.custom-icon:hover,
.search-submit.custom-icon:active,
.search-submit.custom-icon:focus-within,
.search-submit.custom-icon:focus {
  background: #1B0A41;
  color: #FFF;
}
.search-trigger.custom-icon.active:after,
.search-submit.custom-icon.active:after {
  content: "\e809";
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.social-section {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 1rem;
  margin: 0;
  text-decoration: none;
  width: auto;
}
.social-section a {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background: #1B0A41;
  border-radius: 100%;
  height: auto;
  line-height: 1;
  padding: 0;
  width: 3rem;
}
@media only screen and (min-width: 768px) {
  .social-section a {
    width: 4.875rem;
  }
}
.social-section a:after {
  color: #FFF;
  font-size: 1.25rem;
}
@media only screen and (min-width: 768px) {
  .social-section a:after {
    font-size: 1.75rem;
  }
}
.social-section a:hover, .social-section a:active, .social-section a:focus-within, .social-section a:focus {
  background: #E3E3F2;
  text-decoration: none !important;
}
.social-section a:hover:after, .social-section a:active:after, .social-section a:focus-within:after, .social-section a:focus:after {
  color: #1B0A41;
}
.social-section .social .facebook:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e836";
  font-size: 1.8rem;
}
.social-section .social .instagram:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e837";
  font-size: 1.8rem;
}
.social-section .social .linkedin:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e838";
  font-size: 1.8rem;
}
.social-section .social .tiktok:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e839";
  font-size: 1.8rem;
}
.social-section .social .twitter:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e840";
  font-size: 1.8rem;
}
.social-section .social .youtube:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e841";
  font-size: 1.8rem;
}
.social-section .social .youtube-alt:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e842";
  font-size: 1.8rem;
}
.social-section .social .email:after {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
  content: "\e825";
  font-size: 1.8rem;
}

.staff-list .staff-member {
  border-bottom: 1px solid #665AA4;
  padding: 2em 0;
}
.staff-list .staff-member:last-child {
  border-bottom: 0 none;
}
.staff-list .staff-member .staff-member-inner {
  display: grid;
  gap: 2rem;
}
@media only screen and (min-width: 1340px) {
  .staff-list .staff-member .staff-member-inner {
    grid-template-columns: 1fr 1fr;
  }
}
@media only screen and (min-width: 1600px) {
  .staff-list .staff-member .staff-member-inner {
    gap: 4rem;
    grid-template-columns: 1fr 2fr;
  }
}
.staff-list .staff-member .staff-member-inner .name {
  margin-top: 0;
}
.staff-list .staff-member .staff-member-inner .staff-member-image img {
  border-radius: 20px;
  width: 100%;
}
.staff-list .staff-member .position {
  font-size: 1.5rem;
  font-weight: bold;
}
.staff-list .staff-member .social-section {
  margin: 0.5em 0;
  padding: 0;
}
.staff-list .staff-member .social-section .social {
  margin: 0;
  padding: 0;
}
.staff-list .staff-member .social-section a {
  border: 1px solid #665AA4;
  border-radius: 45px;
  height: 45px;
  line-height: 45px;
  text-align: center;
  text-decoration: none;
  width: 45px;
}
.staff-list .staff-member .social-section a:hover, .staff-list .staff-member .social-section a:active, .staff-list .staff-member .social-section a:focus-within, .staff-list .staff-member .social-section a:focus {
  background: #665AA4;
  color: #FFF;
}

.staff {
  position: relative;
}
.staff:before {
  aspect-ratio: 1/1;
  background: url(../images/purple-dots-top.svg);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  z-index: -1;
}
@media only screen and (min-width: 1024px) {
  .staff:before {
    height: 100%;
    top: -25%;
    width: 50%;
  }
}
@media only screen and (min-width: 1440px) {
  .staff:before {
    height: 125%;
    top: -25%;
    width: auto;
  }
}
.staff .swiper .swiper-wrapper {
  /* Current slide fades out as it slides away */
  /* Next slide starts invisible and fades in as it slides into view */
  /* Alternative approach using transform and opacity together */
}
.staff .swiper .swiper-wrapper .swiper-slide {
  display: grid;
}
.staff .swiper .swiper-wrapper .swiper-slide picture {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.staff .swiper .swiper-wrapper .swiper-slide picture img {
  aspect-ratio: 1/1;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTIyIiBoZWlnaHQ9IjQ5NyIgdmlld0JveD0iMCAwIDUyMiA0OTciIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik00NDkuNzcyIDYyLjUyMDNDNDg1LjggOTguODQ0NSA1MDIuMjU3IDE0Ny43ODEgNTEyLjE5IDE5Ni4xMTNDNTIyLjQ1NCAyNDYuMDQ3IDUyNi43MTUgMjk5LjgyNyA1MTIuMTE1IDM0OS4zNjZDNTA0LjIyOSAzNzYuMTIxIDQ5MC4xODggNDAxLjMyOCA0NjguNTI5IDQyMC4zNzlDNDEwLjM4IDQ3MS41MTkgMzI4LjUwOCA0OTguMzUgMjQ5LjQgNDk2LjQ0OEMyMjYuMjUzIDQ5NS44ODYgMjAzLjExNCA0OTIuNTggMTgxLjAxIDQ4NS44NjVDMTU4LjQ0MSA0NzkuMDA5IDEzNy4xOTUgNDY4LjU1IDExOC4zMjggNDU0Ljk1OEM3NS4zMzcgNDI0LjAwOSA0My4wODk2IDM4MC4yMzYgMjQuMjgxMSAzMzIuNjA0Qy04LjE5Nzg5IDI1MC4zMDMgLTEyLjU2MjMgMTQzLjM3NyA0NC4yMjg0IDY5LjQ3NTRDNTkuOTIzNiA0OS4wNTEyIDgwLjM2MzMgMzEuOTU5NyAxMDQuNDM1IDIwLjgzMjJDMTQ5LjM1MSAwLjAzNTQ3MjMgMjAwLjgxOSAtMS42Njk2NiAyNDkuODc2IDEuMzUzODJDMzA3LjAzMyA0Ljg3ODg1IDM3MC4yMzkgOC4wOTYxNSA0MTkuNjk2IDM4LjYyMzJDNDMwLjkzOCA0NS41NTYzIDQ0MC45MSA1My42MjAxIDQ0OS43NDggNjIuNTM2Nkw0NDkuNzcyIDYyLjUyMDNaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K);
  mask-repeat: no-repeat;
  mask-size: contain;
  height: auto;
  object-fit: cover;
  width: 80%;
}
.staff .swiper .swiper-wrapper .swiper-slide .content {
  background: #FBF8F0;
}
.staff .swiper .swiper-wrapper .swiper-slide .content h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
}
.staff .swiper .swiper-wrapper .swiper-slide {
  transition: opacity 1s ease-in-out;
}
.staff .swiper .swiper-wrapper .swiper-slide-active.swiper-slide-prev,
.staff .swiper .swiper-wrapper .swiper-slide-active.swiper-slide-next {
  opacity: 0;
}
.staff .swiper .swiper-wrapper .swiper-slide-next {
  opacity: 0;
}
.staff .swiper .swiper-wrapper .swiper-slide-active {
  opacity: 1;
}
.staff .swiper .swiper-wrapper .swiper-slide {
  transition: all 1s ease-in-out;
}
.staff .swiper .swiper-wrapper .swiper-slide:not(.swiper-slide-active) {
  opacity: 0;
}
@media only screen and (min-width: 1024px) {
  .staff .swiper-navigation {
    display: flex;
    justify-content: space-between;
    margin-left: calc(50% + 3rem);
    width: max-content;
  }
}
@media only screen and (min-width: 1640px) {
  .staff .swiper-navigation {
    margin-left: calc(50% + 6rem);
    margin-top: 0;
  }
}

.subscribe {
  background: #1B0A41;
  box-sizing: border-box;
  color: #665AA4;
  flex-direction: column;
  gap: 1rem;
  margin-left: auto;
  margin-right: auto;
  padding: 2rem 0;
  position: relative;
  width: 100%;
  z-index: 2;
}
@media only screen and (min-width: 1440px) {
  .subscribe {
    padding: 4rem 0;
  }
}
@media only screen and (min-width: 768px) {
  .subscribe .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.subscribe .grid .newsletter-form {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 2rem;
  flex-wrap: wrap;
  margin: 0;
  width: 100%;
}
@media only screen and (min-width: 1024px) {
  .subscribe .grid .newsletter-form {
    flex-grow: 1;
    width: auto;
  }
}
.subscribe .grid .newsletter-form.error .error {
  color: #FFF;
  display: block;
  margin: 0;
  text-align: right;
  width: 100%;
}
.subscribe .grid .newsletter-form #ajax-processing {
  color: #FFF;
}
.subscribe h2 {
  color: #FFF;
  margin: 0;
}
.subscribe .mc-field-group {
  width: 100%;
}
.subscribe input {
  background: none;
  border: 0 none;
  border-radius: 0;
  border-bottom: 1px solid #FFF;
  box-sizing: border-box;
  color: #FFF;
  font-size: 1rem;
  margin: 0;
  max-width: none;
  padding: 0.75rem 0;
  width: 100%;
}
.subscribe input::-webkit-input-placeholder {
  color: #FFF;
}
.subscribe input:-moz-placeholder {
  color: #FFF;
}
.subscribe input::-moz-placeholder {
  color: #FFF;
}
.subscribe input:-ms-input-placeholder {
  color: #FFF;
}
.subscribe input::-ms-input-placeholder {
  color: #FFF;
}
@media only screen and (min-width: 1024px) {
  .subscribe input#email {
    max-width: 500px;
  }
}
.subscribe button {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  background: none;
  border: 2px solid #FFF;
  border-radius: 100px;
  cursor: pointer;
  gap: 1.5rem;
  font-weight: bold;
  line-height: 1;
  margin: 0;
  overflow: hidden;
  padding: 0.5rem 1rem;
  position: relative;
  text-decoration: none;
  width: max-content;
}
.subscribe button:before {
  transition: all 0.2s ease-in-out;
  background: #665AA4;
  border-radius: 1rem;
  bottom: 0;
  content: "";
  height: 0;
  position: absolute;
  width: 100%;
}
.subscribe button:after {
  transition: all 0.2s ease-in-out;
  border-radius: 100px;
  color: #FFF;
  content: "\e806";
  font-size: 0.8rem;
  font-family: fontello;
  padding: 0.45rem 0.3rem;
  transform: rotate(-90deg);
}
.subscribe button span {
  position: relative;
  z-index: 1;
}
.subscribe button:hover:before, .subscribe button:active:before, .subscribe button:focus-within:before, .subscribe button:focus:before {
  height: 100%;
}
.subscribe button:hover:after, .subscribe button:active:after, .subscribe button:focus-within:after, .subscribe button:focus:after {
  color: #1B0A41;
}
.subscribe .subscribe-success {
  margin: 0;
  color: #FFF;
}

.swiper-navigation {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  position: relative;
  z-index: 1;
}
.swiper-navigation .swiper-button-next,
.swiper-navigation .swiper-button-prev {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  aspect-ratio: 1/1;
  background: #E3E3F2;
  color: #1B0A41;
  border: 0 none;
  border-radius: 100%;
  bottom: unset;
  height: auto;
  left: unset;
  margin: 0;
  padding: 0;
  position: relative;
  right: unset;
  top: unset;
  width: 3.25rem;
}
.swiper-navigation .swiper-button-next:after,
.swiper-navigation .swiper-button-prev:after {
  font-size: 1.25rem;
}
.swiper-navigation .swiper-button-next:hover, .swiper-navigation .swiper-button-next:active, .swiper-navigation .swiper-button-next:focus-within, .swiper-navigation .swiper-button-next:focus,
.swiper-navigation .swiper-button-prev:hover,
.swiper-navigation .swiper-button-prev:active,
.swiper-navigation .swiper-button-prev:focus-within,
.swiper-navigation .swiper-button-prev:focus {
  background: #665AA4;
  color: #FFF;
}
.swiper-navigation .swiper-button-prev {
  transform: rotate(0deg);
}

div.swiper-pagination {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  position: static;
}
div.swiper-pagination span.swiper-pagination-bullet {
  background: #E3E3F2;
  border-radius: 1rem;
  height: 1rem;
  margin: 0 !important;
  opacity: 1;
  padding: 0;
  width: 1rem;
}
div.swiper-pagination span.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #E3E3F2;
  width: 2.5rem;
}

.banner .swiper-navigation {
  margin-bottom: 1rem;
}

.swiper {
  max-height: 100vh;
  max-width: 100%;
  min-height: 0;
  min-width: 0;
  width: 100%;
}
.swiper .swiper-slide {
  display: flex;
}

div.testimonial {
  display: grid;
}
@media only screen and (min-width: 1024px) {
  div.testimonial {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  div.testimonial {
    grid-template-columns: 3fr 2fr;
  }
}
div.testimonial blockquote {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: none;
  flex-direction: column;
  gap: 2rem;
  margin: 0;
  padding: 0;
}
div.testimonial blockquote p {
  margin: 0;
}

section.testimonials .container {
  align-items: center;
}
section.testimonials .container .swiper-wrapper {
  align-items: center;
}
@media only screen and (max-width: 767px) {
  section.testimonials .swiper-slide:not(:first-of-type) {
    display: none;
  }
  section.testimonials .swiper-pagination {
    display: none;
  }
}

.video-container {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  margin: 2em 0;
  overflow: hidden;
}

.video-container iframe,
.video-container object,
.video-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#alert-banner {
  background: #1B0A41;
  color: #FFF;
  margin: 0;
  padding: 1.5rem 0;
  position: relative;
  z-index: 5;
}
#alert-banner .container {
  flex-direction: column;
  text-align: center;
}
#alert-banner .container p {
  color: #FFF;
  margin: 0;
  text-decoration: none;
}
#alert-banner .container .heading {
  font-size: 1.25rem;
  font-weight: 700;
}
#alert-banner a {
  text-decoration: none;
}
#alert-banner a:hover p, #alert-banner a:active p, #alert-banner a:focus-within p, #alert-banner a:focus p {
  text-decoration: underline dashed;
}
#alert-banner p {
  text-decoration: underline;
}

header.header {
  position: relative;
  z-index: 10;
}
header.header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 1340px) {
  header.header .container {
    flex-direction: row;
    max-width: calc(1130px + 8rem);
  }
}
header.header .header-top {
  background: #665AA4;
  padding: 1rem 0;
}
@media only screen and (min-width: 1340px) {
  header.header .header-top {
    background: none;
    padding: 0;
    z-index: 2;
    position: relative;
  }
  header.header .header-top .container {
    padding-bottom: 1.5rem;
    padding-top: 1.5rem;
  }
}
header.header .header-top .phone {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: #FFF;
  gap: 0.75rem;
}
header.header .header-top a {
  color: #FFF;
  text-decoration: none;
  text-underline-offset: 4px;
}
header.header .header-top a:hover, header.header .header-top a:active, header.header .header-top a:focus-within, header.header .header-top a:focus {
  text-decoration: underline;
}
header.header .header-top p {
  margin: 0;
}
header.header #top-menu li:last-child a {
  transition: all 0.2s ease-in-out;
  border: 1px solid #FFF;
  border-radius: 100px;
  padding: 0.5rem 1rem;
}
header.header #top-menu li:last-child a:hover, header.header #top-menu li:last-child a:active, header.header #top-menu li:last-child a:focus-within, header.header #top-menu li:last-child a:focus {
  text-decoration: none !important;
  background: #1B0A41;
  color: #FFF;
}
header.header section.header-bottom .container {
  background: #E3E3F2;
  padding-bottom: 1rem;
  padding-top: 1rem;
}
@media only screen and (min-width: 1340px) {
  header.header section.header-bottom .container {
    background: none;
    padding-bottom: 0;
    padding-top: 0;
  }
}
header.header section.header-bottom .container .wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  gap: 2rem;
  width: 100%;
}
@media only screen and (min-width: 1340px) {
  header.header section.header-bottom .container .wrapper {
    background: #E3E3F2;
    border-radius: 1.5rem;
    padding: 1rem 2rem;
    position: relative;
  }
}
header.header section.header-bottom .container .wrapper img {
  display: block;
  max-width: 200px;
  width: 100%;
}

.active-header .header-bottom {
  left: 0;
  position: fixed;
  top: 0;
  transform: translateY(-100%);
  width: 100vw;
  z-index: 10;
}
.active-header .header-top {
  display: none;
}
.active-header.header-scroll-animation .header-bottom {
  transform: none;
  transition: transform 0.3s ease-in-out;
}
@media only screen and (min-width: 1340px) {
  .active-header.header-scroll-animation .header-bottom {
    margin: 1rem 0;
  }
}

body:not(.front-page) header.header .header-top a {
  color: #FFF;
}
body:not(.front-page) header.header .top-menu li:last-child a {
  border: 1px solid #FFF;
}
@media only screen and (min-width: 1340px) {
  body:not(.front-page) header.header {
    margin: 2rem 2rem 0 2rem;
    border-radius: 2rem 2rem 0 0;
    padding-bottom: 10%;
    position: relative;
  }
  body:not(.front-page) header.header:after {
    background-image: url("../images/inner-header.svg");
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 2rem 2rem 0 0;
    content: "";
    height: auto;
    position: absolute;
    bottom: 0;
    height: 100%;
    width: 100%;
    z-index: -1;
  }
}
body:not(.front-page).active-header header.header {
  padding-bottom: 0;
}

#mobile-menu-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background: transparent;
  border: 0 none;
  border-radius: 100%;
  cursor: pointer;
  flex-direction: column;
  position: relative;
  z-index: 4;
}
#mobile-menu-trigger:after {
  font-size: 1.25rem;
}
#mobile-menu-trigger span:not(:last-child) {
  margin-bottom: 0.3rem;
}
#mobile-menu-trigger:hover, #mobile-menu-trigger:active, #mobile-menu-trigger:focus-within, #mobile-menu-trigger:focus {
  color: #1B0A41;
}
@media only screen and (min-width: 1340px) {
  #mobile-menu-trigger {
    display: none;
  }
}

#mobile-menu-close {
  transition: all 0.2s ease-in-out;
  aspect-ratio: 1/1;
  background: none;
  border: 0 none;
  border-radius: 100%;
  color: #665AA4;
  cursor: pointer;
  left: 1.6rem;
  opacity: 0;
  position: absolute;
  visibility: hidden;
  z-index: 4;
}
#mobile-menu-close:after {
  font-size: 1.25rem;
}
#mobile-menu-close:hover, #mobile-menu-close:active, #mobile-menu-close:focus-within, #mobile-menu-close:focus {
  color: #1B0A41;
}
@media only screen and (min-width: 1024px) {
  #mobile-menu-close {
    left: 3.1rem;
  }
}

@media only screen and (max-width: 1339px) {
  nav#navigation {
    transition: all 0.2s ease-in-out;
    display: flex;
    align-items: unset;
    justify-content: unset;
    background-color: #FFF;
    box-sizing: border-box;
    flex-direction: column !important;
    height: 100vh;
    left: 0;
    margin: 0 !important;
    opacity: 0;
    overflow: auto;
    padding: 1rem 1.5rem 4rem;
    position: absolute;
    right: 0;
    text-align: left;
    top: 100%;
    transform: translateX(-100vw);
    visibility: hidden;
    z-index: 5;
    width: 100%;
  }
}
@media only screen and (max-width: 1339px) and (min-width: 1024px) {
  nav#navigation {
    padding: 1rem 3rem 4rem;
  }
}
@media only screen and (max-width: 1339px) {
  nav#navigation img {
    display: none;
  }
  nav#navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    max-width: 280px;
    width: 100%;
  }
  nav#navigation ul > li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 0;
    position: relative;
  }
  nav#navigation ul > li > a {
    transition: all 0.2s ease-in-out;
    color: #665AA4;
    border-bottom: none;
    display: block;
    padding: 0.75rem 0;
    position: relative;
    text-align: left;
    text-decoration: none !important;
  }
  nav#navigation ul > li > a:hover, nav#navigation ul > li > a:active, nav#navigation ul > li > a:focus-within, nav#navigation ul > li > a:focus {
    color: #1B0A41;
  }
  nav#navigation ul > li > a.current-page-ancestor > a, nav#navigation ul > li > a.current-menu-item > a {
    background: #1B0A41;
    color: #FFF;
  }
  nav#navigation ul > li .sub-menu {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    list-style: none;
    margin: 0;
    padding: 0;
    border-left: 1px solid #1B0A41;
    display: none;
    flex-direction: column;
    gap: 1rem;
    margin: 1rem 0 1rem 1rem;
    padding: 0 0 0 1.5rem;
    width: 100%;
  }
  nav#navigation ul > li .sub-menu > li {
    border: 0 none;
    padding: 0;
    position: relative;
    width: 100%;
  }
  nav#navigation ul > li .sub-menu > li .toggle-sub-menu {
    top: 0;
  }
  nav#navigation ul > li .sub-menu > li > a {
    color: #665AA4;
    display: block;
    font-size: 1rem;
    line-height: 1;
    padding: 0;
    text-decoration: none;
  }
  nav#navigation ul > li .sub-menu > li > a:hover, nav#navigation ul > li .sub-menu > li > a:active, nav#navigation ul > li .sub-menu > li > a:focus-within, nav#navigation ul > li .sub-menu > li > a:focus {
    color: #1B0A41;
  }
  nav#navigation ul > li .sub-menu > li:not(.menu-item-has-children) a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
    margin: 0;
    padding: 0;
  }
  nav#navigation ul > li .sub-menu > li .sub-menu {
    margin: 1.5rem 0 1rem;
  }
  nav#navigation ul > li .sub-menu > li.current-menu-item > a {
    text-decoration: underline;
  }
  nav#navigation ul#top-menu {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    border-bottom: 1px solid #E3E3F2;
    gap: 2rem;
    margin-bottom: 1rem;
    max-width: none;
    width: 100%;
  }
  nav#navigation ul#top-menu > li a {
    font-size: 1rem;
  }
  nav#navigation ul#top-menu > li:last-child a {
    border: 0 none !important;
    padding: 0 !important;
  }
  .is-mobile-active {
    overflow: hidden;
  }
  .is-mobile-active .active-header #site-header {
    overflow: unset;
  }
  .is-mobile-active #navigation {
    transform: translateX(0);
    visibility: visible;
    opacity: 1;
  }
  .is-mobile-active #secondary-menu {
    display: flex !important;
  }
  .is-mobile-active #mobile-menu-trigger {
    opacity: 0;
    visibility: hidden;
  }
  .is-mobile-active #mobile-menu-close {
    opacity: 1;
    visibility: visible;
  }
  .toggle-sub-menu {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: 0 none;
    border-radius: 1rem;
    color: #1B0A41;
    cursor: pointer;
    margin-left: 1rem;
    padding: 0.9rem 1rem;
  }
  .toggle-sub-menu .custom-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1/1;
    background: transparent;
    border-radius: 10px;
    pointer-events: none;
  }
  .toggle-sub-menu .custom-icon:after {
    font-size: 1rem;
  }
  .toggle-sub-menu:hover, .toggle-sub-menu:active, .toggle-sub-menu:focus-within, .toggle-sub-menu:focus {
    color: #1B0A41;
  }
  .active-menu .custom-icon:after {
    transform: rotate(-180deg);
  }
  #exit-menu-item {
    transition: all 0.2s ease-in-out;
    font-size: 0;
    position: relative;
    border-bottom: none;
  }
  #exit-menu-item:hover, #exit-menu-item:active, #exit-menu-item:focus-within, #exit-menu-item:focus {
    background-color: #665AA4;
    color: white;
  }
  #exit-menu-item:hover + button .custom-icon, #exit-menu-item:active + button .custom-icon, #exit-menu-item:focus-within + button .custom-icon, #exit-menu-item:focus + button .custom-icon {
    color: white;
  }
  #exit-menu-item {
    opacity: 0;
  }
  #exit-menu-item:focus {
    opacity: 1;
  }
}
@media only screen and (min-width: 1340px) {
  .toggle-sub-menu {
    display: none;
  }
}
.hide {
  display: none !important;
}

.members-area .user {
  display: none;
}

@media only screen and (min-width: 1340px) {
  #exit-menu-item,
  #close-menu-trigger {
    display: none;
  }
  #navigation {
    z-index: 10;
  }
  #navigation #top-menu {
    display: flex;
    align-items: center;
    justify-content: space-between;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 2rem;
    position: absolute;
    right: 0;
    top: -55px;
  }
  #navigation #top-menu li a {
    color: #FFF;
    text-decoration: none;
  }
  #navigation #top-menu li a:hover, #navigation #top-menu li a:active, #navigation #top-menu li a:focus-within, #navigation #top-menu li a:focus {
    text-decoration: underline;
  }
  #navigation #main-menu {
    display: flex;
    align-items: center;
    justify-content: unset;
    list-style: none;
    margin: 0;
    padding: 0;
    border-radius: 1rem;
    height: auto;
    position: relative;
    transition: height 0.25s ease-in-out;
  }
  #navigation #main-menu img {
    display: none;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) {
    padding-left: 2rem;
    position: relative;
  }
}
@media only screen and (min-width: 1340px) and (min-width: 1640px) {
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) {
    padding-left: 3rem;
  }
}
@media only screen and (min-width: 1340px) {
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > a {
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease-in-out;
    font-family: "museo-sans", sans-serif;
    font-weight: 300;
    font-style: normal;
    align-content: center;
    align-items: center;
    border-bottom: 5px solid transparent;
    color: #1B0A41;
    display: inline-flex;
    font-size: 1.125rem;
    padding: 1rem 0;
    position: relative;
    text-decoration: none;
    white-space: nowrap;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button).menu-item-has-children > a:after {
    border-radius: 1rem;
    color: #1B0A41;
    content: "\e803";
    font-family: fontello;
    font-size: 0.7rem;
    line-height: 1;
    margin-left: 0.75rem;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button).current_page_parent > a {
    border-bottom-color: #665AA4;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button).current-menu-item > a {
    border-bottom-color: #665AA4;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button):hover a, #navigation #main-menu > li:not(.custom-menu, .secondary-button):active a, #navigation #main-menu > li:not(.custom-menu, .secondary-button):focus-within a, #navigation #main-menu > li:not(.custom-menu, .secondary-button):focus a {
    border-bottom-color: #665AA4;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button):hover > .sub-menu, #navigation #main-menu > li:not(.custom-menu, .secondary-button):active > .sub-menu, #navigation #main-menu > li:not(.custom-menu, .secondary-button):focus-within > .sub-menu, #navigation #main-menu > li:not(.custom-menu, .secondary-button):focus > .sub-menu {
    opacity: 1;
    visibility: visible;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu {
    display: flex;
    align-items: unset;
    justify-content: unset;
    list-style: none;
    margin: 0;
    padding: 0;
    background: #FFF;
    border: 1px solid #665AA4;
    border-radius: 0 0 0.5rem 0.5rem;
    box-sizing: border-box;
    flex-direction: column;
    margin: 0;
    opacity: 0;
    padding: 1rem;
    position: absolute;
    top: 100%;
    visibility: hidden;
    width: max-content;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li {
    display: block;
    margin: 0.25rem 0;
    padding: 0;
    position: relative;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a {
    align-items: center;
    border-radius: 5px;
    color: #1B0A41;
    display: block;
    line-height: 1.3rem;
    margin: 0;
    padding: 0.75rem 1rem;
    position: relative;
    text-decoration: none;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:hover, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:active, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:focus-within, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:focus {
    background: #665AA4;
    color: #FFF;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:hover:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:active:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:focus-within:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > a:focus:after {
    width: 100%;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu {
    display: flex;
    align-items: unset;
    justify-content: unset;
    transition: all 0.5s ease-in-out;
    background: #665AA4;
    height: 100%;
    left: 100%;
    list-style: none;
    margin: 0;
    padding: 0 0 1rem;
    opacity: 0;
    position: absolute;
    visibility: hidden;
    top: 0;
    transition: opacity 0.5s ease-in;
    transition-delay: 0;
    width: max-content;
    z-index: 10;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li {
    display: block;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a {
    transition: all 0.2s ease-in-out;
    align-items: center;
    background: none;
    border-radius: 10px;
    color: white;
    display: inline-flex;
    font-weight: bold;
    line-height: 1.3rem;
    padding: 0.5rem 1.75rem;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:hover, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:active, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:focus-within, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:focus {
    background: #665AA4;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:hover:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:active:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:focus-within:after, #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li > .sub-menu li a:focus:after {
    border: 1px solid #FFF;
    color: #FFF;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) > .sub-menu > li.current-menu-item a {
    background: #665AA4;
    color: #FFF;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button).menu-item-has-children:last-of-type li > .sub-menu {
    left: auto;
    right: 100%;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) .sub-menu .current-menu-item a:after {
    width: 100%;
  }
  #navigation #main-menu > li:not(.custom-menu, .secondary-button) .sub-menu .current-menu-item a:after {
    border-color: #FFF;
    color: #FFF;
  }
}
.banner {
  position: relative;
}
@media only screen and (min-width: 1024px) {
  .banner .grid {
    align-items: center;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (max-width: 1023px) {
  .banner .grid:first-child {
    order: 1;
  }
}
.banner .grid article {
  z-index: 3;
}
.banner .grid article em, .banner .grid article i {
  color: #1B0A41;
}
.banner .grid picture {
  aspect-ratio: 3/2;
  z-index: 1;
}
.banner .grid picture img {
  height: 100%;
  object-fit: cover;
  position: absolute;
  width: 100%;
}
@media only screen and (max-width: 1023px) {
  .banner .grid:first-of-type picture {
    display: none;
  }
}
@media only screen and (max-width: 1023px) {
  .banner .grid:last-of-type article {
    display: none;
  }
}

section.content .container article {
  overflow: hidden;
  width: 100%;
}
section.content .container article .gallery {
  overflow: hidden;
  width: 100%;
}
section.content .container aside h2 {
  max-width: 450px;
  margin: 0 auto 2rem;
  text-align: center;
}
section.content .container aside .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1rem;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  section.content .container aside .buttons {
    flex-direction: row;
  }
}
section.content .container aside .buttons .primary-button {
  text-decoration: none;
}
section.content .container aside .buttons .primary-button:nth-of-type(1) {
  background: #E3E3F2;
  color: #1B0A41;
}
section.content .container aside .buttons .primary-button:nth-of-type(1):hover, section.content .container aside .buttons .primary-button:nth-of-type(1):active, section.content .container aside .buttons .primary-button:nth-of-type(1):focus-within, section.content .container aside .buttons .primary-button:nth-of-type(1):focus {
  background: #665AA4;
  color: #FFF;
}
section.content .social-sharing .social a {
  color: #1B0A41;
}
section.content .job-listing {
  color: #1B0A41;
  text-decoration: none;
}
section.content .job-listing:hover .secondary-button, section.content .job-listing:active .secondary-button, section.content .job-listing:focus-within .secondary-button, section.content .job-listing:focus .secondary-button {
  color: #FFF;
}
section.content .job-listing:hover .secondary-button:after, section.content .job-listing:active .secondary-button:after, section.content .job-listing:focus-within .secondary-button:after, section.content .job-listing:focus .secondary-button:after {
  height: 100%;
}
section.content .vacancy-overview p {
  margin: 0 0 1rem;
}
section.content .vacancy-overview p .custom-icon {
  margin-right: 10px;
}
section.content .vacancy-overview p .custom-icon:after {
  font-size: 1.2rem;
}
section.content .purple-dots-top-left img,
section.content .cyan-dots-top-left img {
  width: 85%;
}

.page-template-no-sidebar .content-page .container {
  display: block;
  max-width: 1200px;
}

.page-template-default section.content aside h2 {
  max-width: 450px;
  margin: 0 auto 2rem;
  text-align: center;
}
.page-template-default section.content aside .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1rem;
  margin: 0 auto;
}
.page-template-default section.content aside .buttons .primary-button {
  text-decoration: none;
}
.page-template-default section.content aside .buttons .primary-button:nth-of-type(1) {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-default section.content aside .buttons .primary-button:nth-of-type(1):hover, .page-template-default section.content aside .buttons .primary-button:nth-of-type(1):active, .page-template-default section.content aside .buttons .primary-button:nth-of-type(1):focus-within, .page-template-default section.content aside .buttons .primary-button:nth-of-type(1):focus {
  background: #665AA4;
  color: #FFF;
}
.page-template-default section.content aside picture.extra-picture {
  display: block;
  margin-bottom: 2rem;
}
.page-template-default section.content aside picture.extra-picture.margin-top {
  position: relative;
}
.page-template-default section.content aside picture.extra-picture.margin-top:after {
  aspect-ratio: 1160/1610;
  background-image: url("../images/extra-pictures.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  left: 20%;
  position: absolute;
  top: -5rem;
  width: 200%;
  z-index: -1;
}
.page-template-default section.content aside picture.extra-picture img {
  aspect-ratio: 5/4;
  border-radius: 1rem;
  display: block;
  object-fit: cover;
}

section.cta .container {
  align-items: center;
}
section.cta .container .content {
  max-width: 560px;
}
section.cta .container .images {
  position: relative;
  aspect-ratio: 4/5;
}
section.cta .container .images:after {
  aspect-ratio: 195/400;
  content: "";
  position: absolute;
  bottom: 5%;
  left: -10%;
  width: 35%;
  background-image: url("../images/yellow-dots.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  z-index: -1;
}
section.cta .container .images img {
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  object-fit: cover;
  width: 100%;
}
section.cta .container .images img:nth-of-type(1) {
  aspect-ratio: 175/185;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgyIiBoZWlnaHQ9IjE5MiIgdmlld0JveD0iMCAwIDE4MiAxOTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0wLjY1MDc5OCAxMDUuNzI0Qy0xLjY0MDU0IDg3Ljc5OTEgNC4yNTk4NiA3MC40NDM5IDExLjg1NzkgNTQuNjQxN0MxOS43MDczIDM4LjMxNTIgMzAuMDY0OCAyMi4xNjk4IDQ0Ljc5NDkgMTEuMjIwN0M1Mi43NTA3IDUuMzA3MTEgNjIuMDk4MiAxLjEzNTc1IDcyLjI1NzkgMC4zMjI1NjJDOTkuNTMxOSAtMS44NTkwMSAxMjguMjMxIDcuODcyOTYgMTQ5Ljk4NCAyNS4xNjM3QzE1Ni4zNDggMzAuMjI0MiAxNjIuMTIgMzYuMDYxMyAxNjYuODcgNDIuNjQ1QzE3MS43MjEgNDkuMzY3NCAxNzUuNDI2IDU2LjgzMDcgMTc3Ljc5MiA2NC42Nzg0QzE4My4xODkgODIuNTUzNyAxODIuODIxIDEwMS43ODkgMTc3Ljg2IDExOS4yNzJDMTY5LjI4MiAxNDkuNDc3IDE0Ny41MzkgMTgwLjcwNyAxMTUuNzU2IDE4OS42MjhDMTA2Ljk3MyAxOTIuMDkzIDk3LjU3NTUgMTkyLjYwOSA4OC40NDE5IDE5MC42NjZDNzEuMzkyMSAxODcuMDQ5IDU2LjYwNzMgMTc2LjYzNCA0My41MTM2IDE2NS4zODlDMjguMjU4MyAxNTIuMjg3IDExLjI0MjQgMTM3Ljk5MSAzLjk0MzcyIDExOC44NjZDMi4yODM1MiAxMTQuNTIgMS4yMjE3OCAxMTAuMTIzIDAuNjYxMDA4IDEwNS43MjRMMC42NTA3OTggMTA1LjcyNFoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  position: absolute;
  right: 10%;
  width: 38%;
}
section.cta .container .images img:nth-of-type(2) {
  aspect-ratio: 255/250;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjY3IiBoZWlnaHQ9IjI2MSIgdmlld0JveD0iMCAwIDI2NyAyNjEiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik03My4zMjIgMTIuMTQ2NEM5Ni41Njc1IDAuMDQ2ODgyMyAxMjMuMTQ2IC0wLjY0Mjk3NCAxNDguNDYxIDEuNzUxMkMxNzQuNjE3IDQuMjIzOTggMjAxLjc4MyAxMC4xOTMzIDIyNC4wNzEgMjQuNzA2MkMyMzYuMTA4IDMyLjU0NDYgMjQ2LjQ3MiA0My4xNDY3IDI1Mi42NzMgNTYuNTM1NUMyNjkuMzE4IDkyLjQ3ODkgMjcwLjQ2NCAxMzYuMzMxIDI1Ny44NCAxNzQuNTQyQzI1NC4xNDQgMTg1LjcyMSAyNDkuMDk1IDE5Ni40ODcgMjQyLjUxNiAyMDYuMjM4QzIzNS44IDIxNi4xOTYgMjI3LjUwMSAyMjQuOTcgMjE4LjAwNyAyMzIuMTE4QzE5Ni4zODUgMjQ4LjQxIDE3MC4wMjMgMjU3LjU1NiAxNDMuNzQxIDI1OS41ODVDOTguMzMzIDI2My4wODIgNDQuOTI3MyAyNDkuMjE1IDE2Ljg1MDIgMjEwLjUyOUM5LjA5MDU0IDE5OS44MzcgMy42NzYxOSAxODcuMzM1IDEuNzQxMTEgMTczLjk1N0MtMS44ODYwOCAxNDguOTkgNC44NzQ5NyAxMjMuNjkgMTMuNjEzMSAxMDAuMjcxQzIzLjc5NTMgNzIuOTg0OCAzNC43MTkyIDQyLjcwOTIgNTcuMDg3OCAyMy4yMDc5QzYyLjE2OTQgMTguNzc0MyA2Ny42MjEzIDE1LjEyNzcgNzMuMzI2NSAxMi4xNjA1TDczLjMyMiAxMi4xNDY0WiIgZmlsbD0iYmxhY2siLz4KPC9zdmc+Cg==);
  left: 0%;
  position: absolute;
  top: 17%;
  width: 58%;
}
section.cta .container .images img:nth-of-type(3) {
  aspect-ratio: 175/165;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTk1IiBoZWlnaHQ9IjE4MiIgdmlld0JveD0iMCAwIDE5NSAxODIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik03MC40MjMzIDE3OS4zNjVDNTMuMTM5IDE3NC4wOTMgMzkuNzM4IDE2MS41ODYgMjguNDUwMiAxNDguMTY5QzE2Ljc4NzYgMTM0LjMwNyA2LjMyMDEzIDExOC4yMzMgMi4zODYzIDEwMC4zMDVDMC4yNjE1OTQgOTAuNjIyOSAwLjI5NzA3MiA4MC4zODY4IDMuNzI3OTUgNzAuNzg5NUMxMi45Mzk3IDQ1LjAyNTcgMzMuNTk5MSAyMi44NTUyIDU4LjI5OCAxMC4xMjE4QzY1LjUyNTcgNi4zOTc1NyA3My4yMTgzIDMuNTMxNzUgODEuMTcxOSAxLjkwNDY0Qzg5LjI5MzIgMC4yNDI4NDYgOTcuNjE5OSAtMC4wNzA4Njk3IDEwNS43NDcgMC45OTQ2MzlDMTI0LjI2MiAzLjQxNTIzIDE0MS42NDkgMTEuNjUwMSAxNTUuNTUyIDIzLjM1MzZDMTc5LjU3IDQzLjU3OTMgMTk5LjExNiA3Ni4yMjk4IDE5NC4xOTcgMTA4Ljg3MkMxOTIuODM3IDExNy44OTMgMTg5LjQ0OSAxMjYuNjczIDE4My45MjYgMTM0LjIwM0MxNzMuNjI2IDE0OC4yNjMgMTU4LjA1OCAxNTcuNDY3IDE0Mi40MjggMTY0Ljc4N0MxMjQuMjE2IDE3My4zMTYgMTA0LjE5NCAxODIuOTU5IDgzLjc1ODIgMTgxLjc2Qzc5LjExNDEgMTgxLjQ4OSA3NC42Njg4IDE4MC42NTEgNzAuNDI3OSAxNzkuMzU2TDcwLjQyMzMgMTc5LjM2NVoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  position: absolute;
  right: 0;
  top: 33%;
  width: 39%;
}
section.cta .container .images img:nth-of-type(4) {
  aspect-ratio: 310/300;
  bottom: 0;
  left: 32%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzI0IiBoZWlnaHQ9IjMxMiIgdmlld0JveD0iMCAwIDMyNCAzMTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0yNzguNzU1IDM5LjY3OTZDMzAxLjA1OSA2Mi40MzQzIDMxMS4yNDggOTMuMDkwMSAzMTcuMzk3IDEyMy4zNjdDMzIzLjc1MSAxNTQuNjQ3IDMyNi4zODkgMTg4LjMzNyAzMTcuMzUgMjE5LjM3QzMxMi40NjggMjM2LjEzIDMwMy43NzYgMjUxLjkyMSAyOTAuMzY3IDI2My44NTVDMjU0LjM2OCAyOTUuODkxIDIwMy42ODIgMzEyLjY5OSAxNTQuNzA3IDMxMS41MDdDMTQwLjM3OCAzMTEuMTU1IDEyNi4wNTIgMzA5LjA4NCAxMTIuMzY5IDMwNC44NzhDOTguMzk2IDMwMC41ODMgODUuMjQyOSAyOTQuMDMxIDczLjU2MjcgMjg1LjUxNkM0Ni45NDc4IDI2Ni4xMjkgMjYuOTg0IDIzOC43MDggMTUuMzM5OSAyMDguODdDLTQuNzY3MzYgMTU3LjMxMyAtNy40NjkzMyA5MC4zMzExIDI3LjY4OSA0NC4wMzY1QzM3LjQwNTYgMzEuMjQyIDUwLjA1OTUgMjAuNTM1NCA2NC45NjE5IDEzLjU2NDdDOTIuNzY4OCAwLjUzNjg3OCAxMjQuNjMyIC0wLjUzMTMgMTU1LjAwMiAxLjM2MjcxQzE5MC4zODcgMy41NzA5MiAyMjkuNTE3IDUuNTg2MzUgMjYwLjEzNSAyNC43MDk2QzI2Ny4wOTUgMjkuMDUyNyAyNzMuMjY5IDM0LjEwNDEgMjc4Ljc0IDM5LjY4OThMMjc4Ljc1NSAzOS42Nzk2WiIgZmlsbD0iYmxhY2siLz4KPC9zdmc+Cg==);
  position: absolute;
  width: 52%;
}

.posts {
  position: relative;
}
.posts .posts-header {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .posts .posts-header {
    flex-direction: row;
  }
}
.posts .posts-header:before {
  border-radius: 20px;
  content: "";
  display: block;
  height: 7px;
  position: absolute;
  top: 0;
  width: 100%;
}
.posts .posts-header h2 {
  margin: 0;
}
.posts .posts-header .secondary-button {
  background: #E3E3F2;
}
@media only screen and (max-width: 1439px) {
  .posts div.posts {
    padding-right: 0;
  }
}
@media only screen and (min-width: 1440px) {
  .posts div.posts .swiper-wrapper {
    display: grid;
    gap: 2rem;
    grid-template-columns: repeat(3, 1fr);
  }
}
.posts .primary-button {
  background: #FFF;
}
.posts .primary-button:before {
  background: #665AA4;
}
.posts .view-all a {
  align-items: center;
  background: #E3E3F2;
  border-radius: 1rem;
  font-size: 1.5rem;
  justify-content: center;
  width: 100%;
}

.news-items {
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  .news-items {
    gap: 4rem 2rem;
  }
}
@media only screen and (min-width: 1440px) {
  .news-items {
    gap: 6rem 3rem;
  }
}

body.archive.category section.content .container {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 2rem;
}
body.archive.category section.content .container h1 {
  margin: 0;
}

footer.footer section.main {
  background: #665AA4;
  color: #FFF;
}
@media only screen and (min-width: 1440px) {
  footer.footer section.main {
    border-radius: 2rem;
    margin: 0 2rem 2rem;
  }
}
footer.footer section.main .logo img {
  max-width: 320px;
  width: 100%;
}
footer.footer section.main a {
  color: #FFF;
  text-underline-offset: 4px;
  text-decoration: none;
}
footer.footer section.main a:hover, footer.footer section.main a:active, footer.footer section.main a:focus-within, footer.footer section.main a:focus {
  text-decoration: underline dashed;
}
footer.footer section.main h4 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #FFF;
  font-weight: 700;
  margin: 0;
}
footer.footer section.main .container:nth-of-type(2) {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
}
@media only screen and (min-width: 1024px) {
  footer.footer section.main .container:nth-of-type(2) {
    flex-direction: row;
  }
}
footer.footer section.main .container:nth-of-type(2) img {
  display: block;
  height: 40px;
  width: auto;
}
footer.footer section.main .container .brand p {
  margin-top: 0;
}
footer.footer section.main .container .centres {
  flex-shrink: 0;
}
footer.footer section.main .container .centres a {
  display: block;
}
footer.footer section.main .container .footer-nav {
  flex-shrink: 0;
}
footer.footer section.main .container .footer-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
footer.footer section.main .container .footer-nav ul a {
  font-weight: 700;
}
footer.footer section.main .container .footer-nav .sub-menu li a {
  font-weight: 300;
}
footer.footer section.main .container .app {
  flex-shrink: 0;
}
footer.footer section.main .container .app .wrapper {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
footer.footer section.main .container .app p {
  font-weight: 700;
  margin: 0 0 1rem;
}
footer.footer section.main .container .app a {
  text-decoration: none;
}
footer.footer section.main .line-3 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
  gap: 2rem;
  margin-top: 1rem;
}
@media only screen and (min-width: 1024px) {
  footer.footer section.main .line-3 {
    flex-direction: row;
  }
}
footer.footer section.main .line-3 img {
  border-radius: 1rem;
  display: block;
  max-width: 720px;
  width: 100%;
}
footer.footer section.credits .container {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  footer.footer section.credits .container {
    flex-direction: row;
  }
}
@media only screen and (min-width: 1440px) {
  footer.footer section.credits .container {
    gap: 6rem;
  }
}
footer.footer section.credits .container .credits-menu {
  flex-shrink: 0;
  margin-right: auto;
}
footer.footer section.credits .container .credits-menu ul {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  footer.footer section.credits .container .credits-menu ul {
    flex-direction: row;
    gap: 0;
  }
  footer.footer section.credits .container .credits-menu ul li:not(:first-of-type) a {
    border-left: 1px solid #1B0A41;
    margin-left: 1rem;
    padding-left: 1rem;
  }
  footer.footer section.credits .container .credits-menu ul a {
    line-height: 1;
  }
}
footer.footer section.credits .container a {
  color: #1B0A41;
  text-decoration: none;
  text-underline-offset: 4px;
}
footer.footer section.credits .container a:hover, footer.footer section.credits .container a:active, footer.footer section.credits .container a:focus-within, footer.footer section.credits .container a:focus {
  text-decoration: underline dashed;
}
footer.footer section.credits .container cite {
  flex-shrink: 0;
  font-style: normal;
}

.front-page section.background {
  color: #FFF;
  position: relative;
}
@media only screen and (min-width: 1340px) {
  .front-page section.background {
    border-radius: 2rem 2rem 0 0;
    margin-left: 2rem;
    margin-right: 2rem;
    margin-top: 2rem;
    width: calc(100% - 4rem);
  }
}
.front-page section.background:before {
  border-radius: 2rem 2rem 0 0;
  background: rgba(0, 0, 0, 0.65);
  content: "";
  height: 100%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTg3NCIgaGVpZ2h0PSI4NDAiIHZpZXdCb3g9IjAgMCAxODc0IDg0MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTc2Mi45ODcgNzYzLjY2QzM3MC45NzUgOTA2LjIyNCA3OS41NzMzIDgzMi44MSAtOTMuODIzNCA2NDkuMkMtMjY3LjI0NSA0NjUuNTY0IC0zMjIuNzUgMTcxLjU3NyAtMjQyLjY4MiAtMTI3LjI0Qy04Mi41NjEyIC03MjQuODE5IDU2Ny4xNzkgLTEwNzAuMDggMTIwOC42NyAtODk4LjE5NEMxODUwLjE1IC03MjYuMzA5IDIyNDAuMTUgLTEwMi41MzMgMjA4MC4wMSA0OTUuMTIzQzIwMzkuOTggNjQ0LjUyMyAxOTc1Ljc3IDcyMi4wNjMgMTg5Mi41NSA3NTcuOTA3QzE4MDkuMjggNzkzLjc3IDE3MDYuODcgNzg3Ljk0NiAxNTkwLjMgNzcwLjMzNEMxMzU3LjI0IDczNS4xMjIgMTA2Ny43OCA2NTIuODEgNzYyLjk4NyA3NjMuNjZaIiBmaWxsPSJibGFjayIgc3Ryb2tlPSJibGFjayIvPgo8L3N2Zz4K);
  mask-position: center bottom;
  mask-size: cover;
  position: absolute;
  width: 100%;
  z-index: 2;
}
.front-page section.background .background-video {
  border-radius: 2rem 2rem 0 0;
  height: 100%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTg3NCIgaGVpZ2h0PSI4NDAiIHZpZXdCb3g9IjAgMCAxODc0IDg0MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTc2Mi45ODcgNzYzLjY2QzM3MC45NzUgOTA2LjIyNCA3OS41NzMzIDgzMi44MSAtOTMuODIzNCA2NDkuMkMtMjY3LjI0NSA0NjUuNTY0IC0zMjIuNzUgMTcxLjU3NyAtMjQyLjY4MiAtMTI3LjI0Qy04Mi41NjEyIC03MjQuODE5IDU2Ny4xNzkgLTEwNzAuMDggMTIwOC42NyAtODk4LjE5NEMxODUwLjE1IC03MjYuMzA5IDIyNDAuMTUgLTEwMi41MzMgMjA4MC4wMSA0OTUuMTIzQzIwMzkuOTggNjQ0LjUyMyAxOTc1Ljc3IDcyMi4wNjMgMTg5Mi41NSA3NTcuOTA3QzE4MDkuMjggNzkzLjc3IDE3MDYuODcgNzg3Ljk0NiAxNTkwLjMgNzcwLjMzNEMxMzU3LjI0IDczNS4xMjIgMTA2Ny43OCA2NTIuODEgNzYyLjk4NyA3NjMuNjZaIiBmaWxsPSJibGFjayIgc3Ryb2tlPSJibGFjayIvPgo8L3N2Zz4K);
  mask-position: center bottom;
  mask-size: cover;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.front-page section.background .background-video iframe {
  aspect-ratio: 16/9;
  display: block;
  left: 50%;
  position: absolute;
  height: 100%;
  transform: translateX(-50%);
  width: auto;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .front-page section.background .background-video iframe {
    height: auto;
    width: 100%;
  }
}
@media only screen and (min-width: 1340px) {
  .front-page section.background .background-video iframe {
    top: 0;
  }
}
.front-page section.background picture {
  border-radius: 2rem 2rem 0 0;
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.front-page section.background picture img {
  border-radius: 2rem 2rem 0 0;
  display: block;
  height: 100%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTg3NCIgaGVpZ2h0PSI4NDAiIHZpZXdCb3g9IjAgMCAxODc0IDg0MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTc2Mi45ODcgNzYzLjY2QzM3MC45NzUgOTA2LjIyNCA3OS41NzMzIDgzMi44MSAtOTMuODIzNCA2NDkuMkMtMjY3LjI0NSA0NjUuNTY0IC0zMjIuNzUgMTcxLjU3NyAtMjQyLjY4MiAtMTI3LjI0Qy04Mi41NjEyIC03MjQuODE5IDU2Ny4xNzkgLTEwNzAuMDggMTIwOC42NyAtODk4LjE5NEMxODUwLjE1IC03MjYuMzA5IDIyNDAuMTUgLTEwMi41MzMgMjA4MC4wMSA0OTUuMTIzQzIwMzkuOTggNjQ0LjUyMyAxOTc1Ljc3IDcyMi4wNjMgMTg5Mi41NSA3NTcuOTA3QzE4MDkuMjggNzkzLjc3IDE3MDYuODcgNzg3Ljk0NiAxNTkwLjMgNzcwLjMzNEMxMzU3LjI0IDczNS4xMjIgMTA2Ny43OCA2NTIuODEgNzYyLjk4NyA3NjMuNjZaIiBmaWxsPSJibGFjayIgc3Ryb2tlPSJibGFjayIvPgo8L3N2Zz4K);
  mask-position: center bottom;
  mask-size: cover;
  object-fit: cover;
  position: absolute;
  width: 100%;
}
.front-page section.background section.banner article {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: #E3E3F2;
  flex-direction: column;
  gap: 1.5rem;
  position: relative;
  text-align: center;
  z-index: 4;
}
.front-page section.background section.banner article p,
.front-page section.background section.banner article h1 {
  color: #E3E3F2;
  margin: 0;
}
.front-page section.background section.banner article h1 {
  max-width: 1050px;
}
.front-page section.background section.banner article h1 em {
  color: #D2D2F0;
  font-style: normal;
}
.front-page section.background section.banner article p {
  font-size: 1.5rem;
}
.front-page section.content .container {
  align-items: center;
}
.front-page section.content .container .buttons {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .front-page section.content .container .buttons {
    flex-direction: row;
  }
}
.front-page section.content .container .buttons a:first-of-type {
  background: #E3E3F2;
  color: #1B0A41;
}
.front-page section.content .container .buttons a:last-of-type {
  color: #E3E3F2;
}
.front-page section.content .container .buttons a:hover, .front-page section.content .container .buttons a:active, .front-page section.content .container .buttons a:focus-within, .front-page section.content .container .buttons a:focus {
  background: #1B0A41;
  color: #FFF;
}
.front-page section.content .purple-dots-top-left img {
  width: 100%;
}
.front-page section.journey {
  position: relative;
}
.front-page section.journey:after {
  aspect-ratio: 1273/869;
  background-image: url("../images/journey.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: auto;
  display: block;
  position: absolute;
  right: -25%;
  bottom: 0;
  width: 100%;
  z-index: -1;
}
.front-page section.journey h2 {
  margin-left: auto;
  margin-right: auto;
  max-width: 650px;
  text-align: center;
}
.front-page section.journey .container {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.front-page section.journey .container a {
  display: grid;
  gap: 1rem;
  text-decoration: none;
}
@media only screen and (min-width: 768px) {
  .front-page section.journey .container a {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1024px) {
  .front-page section.journey .container a {
    display: flex;
    flex-direction: column;
    width: calc(50% - 0.5rem);
  }
}
@media only screen and (min-width: 1440px) {
  .front-page section.journey .container a {
    flex-direction: row;
  }
}
.front-page section.journey .container a:hover .secondary-button, .front-page section.journey .container a:active .secondary-button, .front-page section.journey .container a:focus-within .secondary-button, .front-page section.journey .container a:focus .secondary-button {
  background: #665AA4;
  color: #FFF;
}
.front-page section.journey .container a picture {
  position: relative;
}
.front-page section.journey .container a picture img {
  aspect-ratio: 420/330;
  border-radius: 1.5rem;
  display: block;
  height: auto;
  object-fit: cover;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .front-page section.journey .container a picture img {
    aspect-ratio: 330/420;
  }
}
@media only screen and (min-width: 1024px) {
  .front-page section.journey .container a picture img {
    aspect-ratio: 420/330;
  }
}
@media only screen and (min-width: 1440px) {
  .front-page section.journey .container a picture {
    width: calc(50% - 0.5rem);
  }
  .front-page section.journey .container a picture img {
    height: 100%;
    position: absolute;
  }
}
.front-page section.journey .container a aside {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  background: #665AA4;
  box-sizing: border-box;
  color: #FFF;
  border-radius: 1.5rem;
  flex-direction: column;
  gap: 2rem;
  padding: 2rem;
}
@media only screen and (min-width: 1024px) {
  .front-page section.journey .container a aside {
    height: 100%;
  }
}
@media only screen and (min-width: 1440px) {
  .front-page section.journey .container a aside {
    min-height: 425px;
    width: calc(50% - 0.5rem);
  }
}
.front-page section.journey .container a aside h2,
.front-page section.journey .container a aside h3,
.front-page section.journey .container a aside p {
  margin: 0;
}
.front-page section.journey .container a aside h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #FFF;
  font-weight: 700;
}
.front-page section.journey .container a aside .secondary-button {
  margin-top: auto;
}
.front-page section.journey .container a:first-of-type aside {
  background: #D22F61;
}
.front-page section.journey .container a:nth-of-type(2) aside {
  background: #27B0D1;
  color: #1B0A41;
}
.front-page section.journey .container a:nth-of-type(2) aside h3 {
  color: #1B0A41;
}
.front-page section.journey .container a:nth-of-type(3) aside {
  background: #FFCA30;
  color: #1B0A41;
}
.front-page section.journey .container a:nth-of-type(3) aside h3 {
  color: #1B0A41;
}
@media only screen and (min-width: 1440px) {
  .front-page section.journey .container a:nth-of-type(3) {
    width: calc(75% - 0.5rem);
  }
  .front-page section.journey .container a:nth-of-type(3) picture {
    width: calc(67% - 0.5rem);
  }
  .front-page section.journey .container a:nth-of-type(3) aside {
    order: -1;
    width: calc(33% - 0.5rem);
  }
  .front-page section.journey .container a:nth-of-type(4) {
    width: calc(25% - 0.5rem);
  }
  .front-page section.journey .container a:nth-of-type(4) aside {
    width: 100%;
  }
}
.front-page section.nearest-centres .container {
  align-items: center;
}
.front-page section.nearest-centres h2 {
  color: #665AA4;
}
.front-page section.nearest-centres .primary-button {
  background: #E3E3F2;
  color: #1B0A41;
}
.front-page section.nearest-centres .primary-button:hover, .front-page section.nearest-centres .primary-button:active, .front-page section.nearest-centres .primary-button:focus-within, .front-page section.nearest-centres .primary-button:focus {
  background: #665AA4;
  color: #FFF;
}
.front-page section.nearest-centres aside {
  display: grid;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .front-page section.nearest-centres aside {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1024px) {
  .front-page section.nearest-centres aside {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .front-page section.nearest-centres aside {
    grid-template-columns: repeat(2, 1fr);
  }
}
.front-page section.nearest-centres aside a {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "peachy-keen-jf", sans-serif;
  font-weight: 400;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  aspect-ratio: 280/300;
  border-radius: 1.5rem;
  box-sizing: border-box;
  color: #FFF;
  flex-wrap: wrap;
  font-size: 2.25rem;
  overflow: hidden;
  padding: 1.5rem;
  position: relative;
  text-decoration: none;
}
@media only screen and (min-width: 768px) {
  .front-page section.nearest-centres aside a {
    font-size: 2.25rem;
  }
}
@media only screen and (min-width: 1024px) {
  .front-page section.nearest-centres aside a {
    font-size: 1.65rem;
  }
}
@media only screen and (min-width: 1440px) {
  .front-page section.nearest-centres aside a {
    font-size: 2.25rem;
  }
}
.front-page section.nearest-centres aside a:before {
  transition: all 0.2s ease-in-out;
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.8));
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
.front-page section.nearest-centres aside a picture {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -2;
}
.front-page section.nearest-centres aside a picture img {
  display: block;
  height: 100%;
  object-fit: cover;
  position: absolute;
  width: 100%;
}
.front-page section.nearest-centres aside a:hover:before, .front-page section.nearest-centres aside a:active:before, .front-page section.nearest-centres aside a:focus-within:before, .front-page section.nearest-centres aside a:focus:before {
  background-image: linear-gradient(rgba(102, 90, 164, 0.2), rgba(102, 90, 164, 0.8));
}

.is-mobile-active .front-page section.background {
  mask-image: none;
}
.is-mobile-active .front-page section.banner article {
  z-index: 1 !important;
}

.page-template-landing section.content article {
  max-width: 620px;
}

.page-template-page-no-sidebar section.content .container {
  display: flex;
  gap: 0;
}
.page-template-page-no-sidebar section.content .container article {
  margin: 0 auto;
  max-width: 1180px;
}

.page:not(.front-page),
.blog {
  background-repeat: no-repeat;
  background-size: 100%;
}

.page-template-default:not(.front-page) .site-main-wrapper,
.single-post .site-main-wrapper,
.page-template-contact-page .site-main-wrapper,
.error404 .site-main-wrapper {
  overflow: hidden;
}
.page-template-default:not(.front-page) .latest-posts,
.single-post .latest-posts,
.page-template-contact-page .latest-posts,
.error404 .latest-posts {
  margin-top: 0;
}

.single-post .content-main {
  overflow: hidden;
}

.page-template-page-no-sidebar section.landing a,
.page-template-default section.landing a {
  position: relative;
}
.page-template-page-no-sidebar section.landing a picture,
.page-template-default section.landing a picture {
  border-radius: 1rem;
  overflow: hidden;
  position: relative;
}
.page-template-page-no-sidebar section.landing a picture:before,
.page-template-default section.landing a picture:before {
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.8));
  border-radius: 1rem;
  content: "";
  height: 100%;
  position: absolute;
  width: 100%;
  z-index: 2;
}
.page-template-page-no-sidebar section.landing a picture img,
.page-template-default section.landing a picture img {
  aspect-ratio: 6/5;
  border-radius: 1rem;
  display: block;
  object-fit: cover;
  position: relative;
  width: 100%;
  z-index: 1;
}
.page-template-page-no-sidebar section.landing a h3,
.page-template-default section.landing a h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #FFF;
  bottom: 2rem;
  left: 2rem;
  margin: 0;
  position: absolute;
  z-index: 3;
}
.page-template-page-no-sidebar section.landing a h3:before,
.page-template-default section.landing a h3:before {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  aspect-ratio: 1/1;
  background: #E3E3F2;
  border-radius: 100%;
  color: #1B0A41;
  content: "\e801";
  font-family: fontello;
  font-size: 1rem;
  margin-bottom: 1rem;
  transform: rotate(-45deg);
  width: 3rem;
}
.page-template-page-no-sidebar section.landing a:hover picture:before, .page-template-page-no-sidebar section.landing a:active picture:before, .page-template-page-no-sidebar section.landing a:focus-within picture:before, .page-template-page-no-sidebar section.landing a:focus picture:before,
.page-template-default section.landing a:hover picture:before,
.page-template-default section.landing a:active picture:before,
.page-template-default section.landing a:focus-within picture:before,
.page-template-default section.landing a:focus picture:before {
  background-image: linear-gradient(rgba(27, 10, 65, 0.2), rgba(27, 10, 65, 0.8));
}
.page-template-page-no-sidebar section.landing a:hover h3:before, .page-template-page-no-sidebar section.landing a:active h3:before, .page-template-page-no-sidebar section.landing a:focus-within h3:before, .page-template-page-no-sidebar section.landing a:focus h3:before,
.page-template-default section.landing a:hover h3:before,
.page-template-default section.landing a:active h3:before,
.page-template-default section.landing a:focus-within h3:before,
.page-template-default section.landing a:focus h3:before {
  transform: rotate(0deg);
}

.blog-archive #site-main-content .container {
  display: grid;
  grid-template-columns: 1fr;
}
.blog-archive #site-main-content .container .breadcrumb {
  margin: 0;
  margin-top: 2rem;
}
@media only screen and (min-width: 1024px) {
  .blog-archive #site-main-content .container .breadcrumb {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1440px) {
  .blog-archive #site-main-content .container .breadcrumb {
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1600px) {
  .blog-archive #site-main-content .container .breadcrumb {
    margin-top: 8rem;
  }
}
.blog-archive #site-main-content .container .news-items {
  display: grid;
  gap: 2rem;
}
@media only screen and (min-width: 1024px) {
  .blog-archive #site-main-content .container .news-items {
    gap: 4rem;
  }
}

.page-template-auto-landing-page .child-pages {
  display: grid;
}
@media only screen and (min-width: 1024px) {
  .page-template-auto-landing-page .child-pages {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .page-template-auto-landing-page .child-pages {
    grid-template-columns: repeat(3, 1fr);
  }
}

.news-items {
  display: grid;
}
@media only screen and (min-width: 1024px) {
  .news-items {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .news-items {
    grid-template-columns: repeat(4, 1fr);
  }
}

#news-panel .container {
  max-width: calc(1645px + 8rem);
}

.page-template-contact-page #contact .container {
  display: grid;
  grid-template-columns: 1fr;
}
@media only screen and (min-width: 1024px) {
  .page-template-contact-page #contact .container {
    grid-gap: 4em;
    grid-template-columns: 1fr 2fr;
  }
}
.page-template-contact-page #contact .content {
  display: grid;
  grid-template-columns: 1fr;
}
@media only screen and (min-width: 1000px) {
  .page-template-contact-page #contact .content {
    grid-gap: 2em;
    grid-template-columns: 1fr 1fr;
  }
}
.page-template-contact-page #contact .icon {
  font-style: normal;
  margin: 0 5px 0 0;
  position: relative;
}
.page-template-contact-page #contact .icon:before {
  content: "";
  font-family: fontello;
}
.page-template-contact-page #contact .ico-phone:before {
  content: "\e801";
}
.page-template-contact-page #contact .ico-email:before {
  content: "\e802";
}
.page-template-contact-page #contact .generic-content {
  padding: 2em 0 0;
}
.page-template-contact-page #contact .social-section {
  margin: 1em 0 2em;
  padding: 0;
}
.page-template-contact-page #contact .social-section .social .social-item {
  color: #665AA4;
}
.page-template-contact-page .locations .location {
  display: grid;
  padding: 2rem 0;
}
@media only screen and (min-width: 1440px) {
  .page-template-contact-page .locations .location {
    grid-template-columns: 2fr 3fr;
  }
}
.page-template-contact-page .locations .location h3 {
  margin-top: 0;
}
.page-template-contact-page .locations .location iframe {
  border-radius: 1rem;
  width: 100%;
}

.post-type-archive-key2_directory .banner {
  z-index: 1;
}
.post-type-archive-key2_directory .banner .grid {
  align-items: center;
}
@media only screen and (min-width: 1440px) {
  .post-type-archive-key2_directory .banner .grid {
    grid-template-columns: 3fr 2fr;
  }
}
.post-type-archive-key2_directory .banner aside {
  flex-direction: column;
}
@media only screen and (max-width: 1023px) {
  .post-type-archive-key2_directory .banner aside {
    display: none;
  }
}
@media only screen and (min-width: 1024px) {
  .post-type-archive-key2_directory .banner aside {
    border-left: 4px solid #665AA4;
    padding-left: 4rem;
  }
}
@media only screen and (min-width: 1600px) {
  .post-type-archive-key2_directory .banner aside {
    padding-left: 6rem;
  }
}
.post-type-archive-key2_directory .banner aside h2 {
  margin: 0;
}
.post-type-archive-key2_directory .banner aside p {
  margin-top: 0;
}
.post-type-archive-key2_directory .filters {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
}
.post-type-archive-key2_directory .filters .filter {
  position: relative;
}
.post-type-archive-key2_directory .filters .filter h3 {
  font-family: "museo-sans", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-family: "museo-sans", sans-serif;
  font-weight: 700;
  font-style: normal;
  transition: all 0.2s ease-in-out;
  display: inline-flex;
  background: #665AA4;
  border: 0 none;
  border-radius: 100px;
  color: #FFF;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 1.2em;
  padding: 1rem 1.5rem;
  position: relative;
  text-decoration: none;
  width: fit-content;
}
.post-type-archive-key2_directory .filters .filter h3:hover, .post-type-archive-key2_directory .filters .filter h3:active, .post-type-archive-key2_directory .filters .filter h3:focus-within, .post-type-archive-key2_directory .filters .filter h3:focus {
  background: #1B0A41;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  .post-type-archive-key2_directory .filters .filter h3 {
    font-size: 1.5rem;
    font-weight: 500;
    padding: 2rem 2.5rem;
  }
}
.post-type-archive-key2_directory .filters .filter h3:after {
  content: "\e806";
  font-family: fontello;
  font-size: 1rem;
  transform: rotate(0deg);
}
.post-type-archive-key2_directory .filters .filter h3:hover, .post-type-archive-key2_directory .filters .filter h3:active, .post-type-archive-key2_directory .filters .filter h3:focus-within, .post-type-archive-key2_directory .filters .filter h3:focus {
  background: #665AA4;
  color: #FFF;
}
.post-type-archive-key2_directory .filters .filter ul {
  list-style: none;
  margin: 0;
  padding: 0;
  background: #FFF;
  opacity: 0;
  flex-direction: column;
  left: 0;
  padding: 1rem;
  position: absolute;
  top: calc(100% - 1rem);
  visibility: hidden;
  width: max-content;
  z-index: 10;
}
.post-type-archive-key2_directory .filters .filter ul.active {
  animation: 1s ease fadein;
  animation-fill-mode: forwards;
  opacity: 1;
  visibility: visible;
}
.post-type-archive-key2_directory .filters .filter ul li {
  cursor: pointer;
  text-underline-offset: 4px;
}
.post-type-archive-key2_directory .filters .filter ul li:hover, .post-type-archive-key2_directory .filters .filter ul li:active, .post-type-archive-key2_directory .filters .filter ul li:focus-within, .post-type-archive-key2_directory .filters .filter ul li:focus {
  text-decoration: underline dashed;
}
.post-type-archive-key2_directory .filters .filter ul li div.active {
  text-decoration: underline dashed;
}
.post-type-archive-key2_directory.sticky {
  top: 0;
  transition: transform 0.5s ease-out;
  position: fixed;
  width: 100%;
  z-index: 3;
}

.key2-directory {
  position: relative;
}
@media only screen and (min-width: 1440px) {
  .key2-directory:before {
    aspect-ratio: 1/1;
    background: url("../images/olive-dots.svg");
    background-size: contain;
    content: "";
    position: absolute;
    right: 0;
    top: -20vw;
    width: 30%;
    z-index: -1;
  }
}

.key2-directory-items {
  position: relative;
}
.key2-directory-items .loading {
  height: 100vh;
  position: absolute;
  width: 100%;
}
@media only screen and (min-width: 1440px) {
  .key2-directory-items .loading {
    width: 80%;
  }
}
.key2-directory-items .loading.active {
  background-color: #FBF8F0;
  background-image: url(../images/loading.svg);
  background-repeat: no-repeat;
  background-size: 15% 15%;
  background-position: top center;
}
.key2-directory-items #main {
  display: grid;
}
@media only screen and (min-width: 768px) {
  .key2-directory-items #main {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 1440px) {
  .key2-directory-items #main {
    grid-template-columns: repeat(3, 1fr);
    padding-right: 20%;
  }
}

.single-key2_directory .banner .regions,
.single-key2_directory .banner .types {
  color: #665AA4;
  font-weight: bold;
}
.single-key2_directory .banner .types {
  margin-bottom: 0;
}
.single-key2_directory .banner .regions {
  margin-top: 0;
}
.single-key2_directory .buttons {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
}
.single-key2_directory .buttons .primary-button:first-of-type {
  background: #665AA4;
  color: #FFF;
}
@media only screen and (min-width: 1440px) {
  .single-key2_directory .other-services .swiper {
    padding-right: 20%;
  }
  .single-key2_directory .other-services .swiper-wrapper {
    display: grid;
    gap: 4rem;
    grid-template-columns: repeat(3, 1fr);
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.page-template-our-centres section.nearest-centres a {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  transition: all 0.2s ease-in-out;
  border-radius: 1rem;
  overflow: hidden;
  position: relative;
  text-decoration: none;
}
@media only screen and (min-width: 1440px) {
  .page-template-our-centres section.nearest-centres a {
    aspect-ratio: 16/9;
  }
}
.page-template-our-centres section.nearest-centres a:before {
  transition: all 0.2s ease-in-out;
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.8));
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
.page-template-our-centres section.nearest-centres a picture {
  height: 100%;
  width: 100%;
  position: absolute;
  z-index: -2;
}
.page-template-our-centres section.nearest-centres a picture img {
  display: block;
  height: 100%;
  width: 100%;
}
.page-template-our-centres section.nearest-centres a .content {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  color: #FFF;
  flex-direction: column;
  gap: 0.5rem;
  padding: 2rem;
  text-decoration: none;
}
.page-template-our-centres section.nearest-centres a .content h3 {
  color: #FFF;
  margin: 0;
}
.page-template-our-centres section.nearest-centres a .content p {
  margin: 0;
}
.page-template-our-centres section.nearest-centres a:hover:before, .page-template-our-centres section.nearest-centres a:active:before, .page-template-our-centres section.nearest-centres a:focus-within:before, .page-template-our-centres section.nearest-centres a:focus:before {
  background-image: linear-gradient(rgba(27, 10, 65, 0.2), rgba(27, 10, 65, 0.8));
}

.page-template-centre section.content .wrapper p.details {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
}
.page-template-centre section.content .wrapper p.details span {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background-image: url("../images/centre-detail.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 3rem;
}
.page-template-centre section.content .wrapper p.details span:after {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #FFF;
  font-size: 1.5rem;
}
.page-template-centre section.content .wrapper p.details.phone span {
  transform: rotate(90deg);
}
.page-template-centre section.content .wrapper p.details.phone span:after {
  transform: rotate(-90deg);
}
.page-template-centre section.content .wrapper p.details.email span {
  transform: rotate(180deg);
}
.page-template-centre section.content .wrapper p.details.email span:after {
  font-size: 1rem;
  transform: rotate(-180deg);
}
.page-template-centre section.content .wrapper p.details.hours span {
  transform: rotate(270deg);
}
.page-template-centre section.content .wrapper p.details.hours span:after {
  font-size: 1.25rem;
  transform: rotate(-270deg);
}
.page-template-centre section.content .wrapper .buttons {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.content .wrapper .buttons {
    flex-direction: row;
  }
}
.page-template-centre section.content .wrapper .buttons .primary-button {
  text-decoration: none;
}
.page-template-centre section.content .wrapper .buttons .primary-button:first-of-type {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-centre section.content .wrapper .buttons .primary-button:first-of-type:hover, .page-template-centre section.content .wrapper .buttons .primary-button:first-of-type:active, .page-template-centre section.content .wrapper .buttons .primary-button:first-of-type:focus-within, .page-template-centre section.content .wrapper .buttons .primary-button:first-of-type:focus {
  background: #1B0A41;
  color: #FFF;
}
.page-template-centre section.explore .item {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
}
.page-template-centre section.explore .item a {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.page-template-centre section.explore .item a:before {
  background-image: url("../images/play-icon.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 95px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 95px;
  z-index: 3;
}
.page-template-centre section.explore .item a:after {
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.8));
  bottom: 0;
  border-radius: 1rem;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}
.page-template-centre section.explore .item a img {
  aspect-ratio: 1/1;
  border-radius: 1rem;
  display: block;
  height: 100%;
  left: 0;
  object-fit: cover;
  position: relative;
  top: 0;
  width: 100%;
  z-index: -2;
}
.page-template-centre section.explore .item a:hover:after, .page-template-centre section.explore .item a:active:after, .page-template-centre section.explore .item a:focus-within:after, .page-template-centre section.explore .item a:focus:after {
  background: linear-gradient(rgba(27, 10, 65, 0.2), rgba(27, 10, 65, 0.8));
}
.page-template-centre section.explore .item p {
  font-weight: 700;
  margin: 1rem 0 0;
}
.page-template-centre section.icons {
  position: relative;
}
@media only screen and (min-width: 1440px) {
  .page-template-centre section.icons:after {
    aspect-ratio: 1273/869;
    background-image: url("../images/journey.svg");
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: block;
    height: auto;
    left: 50%;
    position: absolute;
    top: 40%;
    transform: translate(-50%, -50%);
    width: 100%;
    z-index: -4;
  }
}
.page-template-centre section.icons .container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.icons .container {
    gap: 6rem;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (min-width: 1024px) {
  .page-template-centre section.icons .container {
    flex-wrap: nowrap;
  }
}
@media only screen and (min-width: 1340px) {
  .page-template-centre section.icons .container {
    gap: 4rem;
    grid-template-columns: repeat(6, 1fr);
  }
}
@media only screen and (min-width: 1640px) {
  .page-template-centre section.icons .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6rem;
  }
}
.page-template-centre section.icons .container .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1rem;
}
.page-template-centre section.icons .container .icon picture {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  padding: 2rem;
}
.page-template-centre section.icons .container .icon img {
  aspect-ratio: 1/1;
  height: 100px;
  width: 100px;
}
.page-template-centre section.icons .container .icon p {
  font-weight: 700;
  text-align: center;
}
.page-template-centre section.icons .container .icon:nth-child(1n) picture {
  background-image: url("../images/yellow.svg");
}
.page-template-centre section.icons .container .icon:nth-child(2) picture, .page-template-centre section.icons .container .icon:nth-child(5n) picture {
  background-image: url("../images/cyan.svg");
}
.page-template-centre section.icons .container .icon:nth-child(3n) picture {
  background-image: url("../images/maroon.svg");
}
.page-template-centre section.choose {
  background: #665AA4;
  background-image: url("../images/choose.svg");
  background-position: top right;
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 2rem;
  margin-left: 2rem;
  margin-right: 2rem;
}
.page-template-centre section.choose .container {
  align-items: center;
  color: #FFF;
}
.page-template-centre section.choose .container .content {
  max-width: 560px;
}
.page-template-centre section.choose .container .content h2 {
  color: #FFF;
  margin-top: 0;
}
.page-template-centre section.choose .container .images {
  position: relative;
  aspect-ratio: 4/5;
  z-index: 1;
}
.page-template-centre section.choose .container .images:after {
  aspect-ratio: 195/400;
  content: "";
  position: absolute;
  bottom: 5%;
  left: -10%;
  width: 35%;
  background-image: url("../images/yellow-dots.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  z-index: -1;
}
.page-template-centre section.choose .container .images img {
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  object-fit: cover;
  width: 100%;
}
.page-template-centre section.choose .container .images img:nth-of-type(1) {
  aspect-ratio: 175/185;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgyIiBoZWlnaHQ9IjE5MiIgdmlld0JveD0iMCAwIDE4MiAxOTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0wLjY1MDc5OCAxMDUuNzI0Qy0xLjY0MDU0IDg3Ljc5OTEgNC4yNTk4NiA3MC40NDM5IDExLjg1NzkgNTQuNjQxN0MxOS43MDczIDM4LjMxNTIgMzAuMDY0OCAyMi4xNjk4IDQ0Ljc5NDkgMTEuMjIwN0M1Mi43NTA3IDUuMzA3MTEgNjIuMDk4MiAxLjEzNTc1IDcyLjI1NzkgMC4zMjI1NjJDOTkuNTMxOSAtMS44NTkwMSAxMjguMjMxIDcuODcyOTYgMTQ5Ljk4NCAyNS4xNjM3QzE1Ni4zNDggMzAuMjI0MiAxNjIuMTIgMzYuMDYxMyAxNjYuODcgNDIuNjQ1QzE3MS43MjEgNDkuMzY3NCAxNzUuNDI2IDU2LjgzMDcgMTc3Ljc5MiA2NC42Nzg0QzE4My4xODkgODIuNTUzNyAxODIuODIxIDEwMS43ODkgMTc3Ljg2IDExOS4yNzJDMTY5LjI4MiAxNDkuNDc3IDE0Ny41MzkgMTgwLjcwNyAxMTUuNzU2IDE4OS42MjhDMTA2Ljk3MyAxOTIuMDkzIDk3LjU3NTUgMTkyLjYwOSA4OC40NDE5IDE5MC42NjZDNzEuMzkyMSAxODcuMDQ5IDU2LjYwNzMgMTc2LjYzNCA0My41MTM2IDE2NS4zODlDMjguMjU4MyAxNTIuMjg3IDExLjI0MjQgMTM3Ljk5MSAzLjk0MzcyIDExOC44NjZDMi4yODM1MiAxMTQuNTIgMS4yMjE3OCAxMTAuMTIzIDAuNjYxMDA4IDEwNS43MjRMMC42NTA3OTggMTA1LjcyNFoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  position: absolute;
  right: 10%;
  width: 38%;
}
.page-template-centre section.choose .container .images img:nth-of-type(2) {
  aspect-ratio: 255/250;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjY3IiBoZWlnaHQ9IjI2MSIgdmlld0JveD0iMCAwIDI2NyAyNjEiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik03My4zMjIgMTIuMTQ2NEM5Ni41Njc1IDAuMDQ2ODgyMyAxMjMuMTQ2IC0wLjY0Mjk3NCAxNDguNDYxIDEuNzUxMkMxNzQuNjE3IDQuMjIzOTggMjAxLjc4MyAxMC4xOTMzIDIyNC4wNzEgMjQuNzA2MkMyMzYuMTA4IDMyLjU0NDYgMjQ2LjQ3MiA0My4xNDY3IDI1Mi42NzMgNTYuNTM1NUMyNjkuMzE4IDkyLjQ3ODkgMjcwLjQ2NCAxMzYuMzMxIDI1Ny44NCAxNzQuNTQyQzI1NC4xNDQgMTg1LjcyMSAyNDkuMDk1IDE5Ni40ODcgMjQyLjUxNiAyMDYuMjM4QzIzNS44IDIxNi4xOTYgMjI3LjUwMSAyMjQuOTcgMjE4LjAwNyAyMzIuMTE4QzE5Ni4zODUgMjQ4LjQxIDE3MC4wMjMgMjU3LjU1NiAxNDMuNzQxIDI1OS41ODVDOTguMzMzIDI2My4wODIgNDQuOTI3MyAyNDkuMjE1IDE2Ljg1MDIgMjEwLjUyOUM5LjA5MDU0IDE5OS44MzcgMy42NzYxOSAxODcuMzM1IDEuNzQxMTEgMTczLjk1N0MtMS44ODYwOCAxNDguOTkgNC44NzQ5NyAxMjMuNjkgMTMuNjEzMSAxMDAuMjcxQzIzLjc5NTMgNzIuOTg0OCAzNC43MTkyIDQyLjcwOTIgNTcuMDg3OCAyMy4yMDc5QzYyLjE2OTQgMTguNzc0MyA2Ny42MjEzIDE1LjEyNzcgNzMuMzI2NSAxMi4xNjA1TDczLjMyMiAxMi4xNDY0WiIgZmlsbD0iYmxhY2siLz4KPC9zdmc+Cg==);
  left: 0%;
  position: absolute;
  top: 17%;
  width: 58%;
}
.page-template-centre section.choose .container .images img:nth-of-type(3) {
  aspect-ratio: 175/165;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTk1IiBoZWlnaHQ9IjE4MiIgdmlld0JveD0iMCAwIDE5NSAxODIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik03MC40MjMzIDE3OS4zNjVDNTMuMTM5IDE3NC4wOTMgMzkuNzM4IDE2MS41ODYgMjguNDUwMiAxNDguMTY5QzE2Ljc4NzYgMTM0LjMwNyA2LjMyMDEzIDExOC4yMzMgMi4zODYzIDEwMC4zMDVDMC4yNjE1OTQgOTAuNjIyOSAwLjI5NzA3MiA4MC4zODY4IDMuNzI3OTUgNzAuNzg5NUMxMi45Mzk3IDQ1LjAyNTcgMzMuNTk5MSAyMi44NTUyIDU4LjI5OCAxMC4xMjE4QzY1LjUyNTcgNi4zOTc1NyA3My4yMTgzIDMuNTMxNzUgODEuMTcxOSAxLjkwNDY0Qzg5LjI5MzIgMC4yNDI4NDYgOTcuNjE5OSAtMC4wNzA4Njk3IDEwNS43NDcgMC45OTQ2MzlDMTI0LjI2MiAzLjQxNTIzIDE0MS42NDkgMTEuNjUwMSAxNTUuNTUyIDIzLjM1MzZDMTc5LjU3IDQzLjU3OTMgMTk5LjExNiA3Ni4yMjk4IDE5NC4xOTcgMTA4Ljg3MkMxOTIuODM3IDExNy44OTMgMTg5LjQ0OSAxMjYuNjczIDE4My45MjYgMTM0LjIwM0MxNzMuNjI2IDE0OC4yNjMgMTU4LjA1OCAxNTcuNDY3IDE0Mi40MjggMTY0Ljc4N0MxMjQuMjE2IDE3My4zMTYgMTA0LjE5NCAxODIuOTU5IDgzLjc1ODIgMTgxLjc2Qzc5LjExNDEgMTgxLjQ4OSA3NC42Njg4IDE4MC42NTEgNzAuNDI3OSAxNzkuMzU2TDcwLjQyMzMgMTc5LjM2NVoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  position: absolute;
  right: 0;
  top: 33%;
  width: 39%;
}
.page-template-centre section.choose .container .images img:nth-of-type(4) {
  aspect-ratio: 310/300;
  bottom: 0;
  left: 32%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzI0IiBoZWlnaHQ9IjMxMiIgdmlld0JveD0iMCAwIDMyNCAzMTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0yNzguNzU1IDM5LjY3OTZDMzAxLjA1OSA2Mi40MzQzIDMxMS4yNDggOTMuMDkwMSAzMTcuMzk3IDEyMy4zNjdDMzIzLjc1MSAxNTQuNjQ3IDMyNi4zODkgMTg4LjMzNyAzMTcuMzUgMjE5LjM3QzMxMi40NjggMjM2LjEzIDMwMy43NzYgMjUxLjkyMSAyOTAuMzY3IDI2My44NTVDMjU0LjM2OCAyOTUuODkxIDIwMy42ODIgMzEyLjY5OSAxNTQuNzA3IDMxMS41MDdDMTQwLjM3OCAzMTEuMTU1IDEyNi4wNTIgMzA5LjA4NCAxMTIuMzY5IDMwNC44NzhDOTguMzk2IDMwMC41ODMgODUuMjQyOSAyOTQuMDMxIDczLjU2MjcgMjg1LjUxNkM0Ni45NDc4IDI2Ni4xMjkgMjYuOTg0IDIzOC43MDggMTUuMzM5OSAyMDguODdDLTQuNzY3MzYgMTU3LjMxMyAtNy40NjkzMyA5MC4zMzExIDI3LjY4OSA0NC4wMzY1QzM3LjQwNTYgMzEuMjQyIDUwLjA1OTUgMjAuNTM1NCA2NC45NjE5IDEzLjU2NDdDOTIuNzY4OCAwLjUzNjg3OCAxMjQuNjMyIC0wLjUzMTMgMTU1LjAwMiAxLjM2MjcxQzE5MC4zODcgMy41NzA5MiAyMjkuNTE3IDUuNTg2MzUgMjYwLjEzNSAyNC43MDk2QzI2Ny4wOTUgMjkuMDUyNyAyNzMuMjY5IDM0LjEwNDEgMjc4Ljc0IDM5LjY4OThMMjc4Ljc1NSAzOS42Nzk2WiIgZmlsbD0iYmxhY2siLz4KPC9zdmc+Cg==);
  position: absolute;
  width: 52%;
}
.page-template-centre section.pricing {
  position: relative;
  text-align: center;
}
.page-template-centre section.pricing:after {
  aspect-ratio: 2045/1490;
  background: url("../images/pricing.svg");
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 120%;
  content: "";
  left: 2rem;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
.page-template-centre section.pricing .wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.pricing .wrapper {
    flex-direction: row;
  }
}
.page-template-centre section.pricing .wrapper .item {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
  background: url("../images/price-pink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-direction: column;
  width: 15rem;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.pricing .wrapper .item {
    width: 17.5rem;
  }
}
.page-template-centre section.pricing .wrapper .item .h2,
.page-template-centre section.pricing .wrapper .item .h1 {
  color: #1B0A41;
  margin: 0;
}
.page-template-centre section.pricing .wrapper .item em {
  font-size: 1.5rem;
}
.page-template-centre section.pricing .wrapper .item:nth-of-type(2) {
  background-image: url("../images/price-cyan.svg");
}
.page-template-centre section.pricing .wrapper .item:nth-of-type(3) {
  background-image: url("../images/price-yellow.svg");
}
.page-template-centre section.pricing .disclaimer {
  font-size: 0.875rem;
  line-height: 1.2em;
  margin: 2rem auto;
  max-width: 1000px;
}
.page-template-centre section.pricing .buttons {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.pricing .buttons {
    align-items: center;
    flex-direction: row;
    justify-content: center;
  }
}
.page-template-centre section.pricing .buttons .primary-button {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-centre section.pricing .buttons .primary-button:hover, .page-template-centre section.pricing .buttons .primary-button:active, .page-template-centre section.pricing .buttons .primary-button:focus-within, .page-template-centre section.pricing .buttons .primary-button:focus {
  background: #665AA4;
  color: #FFF;
}
.page-template-centre section.discover .pages {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .page-template-centre section.discover .pages {
    flex-direction: row;
  }
}
.page-template-centre section.discover .pages a {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease-in-out;
  background: #D22F61;
  border-radius: 1rem;
  flex-direction: column;
  padding: 2rem;
  text-decoration: none;
}
.page-template-centre section.discover .pages a picture {
  margin: 0 auto;
  text-align: center;
}
.page-template-centre section.discover .pages a picture img {
  aspect-ratio: 1/1;
  margin: 0 auto;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgyIiBoZWlnaHQ9IjE5MiIgdmlld0JveD0iMCAwIDE4MiAxOTIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0wLjY1MDc5OCAxMDUuNzI0Qy0xLjY0MDU0IDg3Ljc5OTEgNC4yNTk4NiA3MC40NDM5IDExLjg1NzkgNTQuNjQxN0MxOS43MDczIDM4LjMxNTIgMzAuMDY0OCAyMi4xNjk4IDQ0Ljc5NDkgMTEuMjIwN0M1Mi43NTA3IDUuMzA3MTEgNjIuMDk4MiAxLjEzNTc1IDcyLjI1NzkgMC4zMjI1NjJDOTkuNTMxOSAtMS44NTkwMSAxMjguMjMxIDcuODcyOTYgMTQ5Ljk4NCAyNS4xNjM3QzE1Ni4zNDggMzAuMjI0MiAxNjIuMTIgMzYuMDYxMyAxNjYuODcgNDIuNjQ1QzE3MS43MjEgNDkuMzY3NCAxNzUuNDI2IDU2LjgzMDcgMTc3Ljc5MiA2NC42Nzg0QzE4My4xODkgODIuNTUzNyAxODIuODIxIDEwMS43ODkgMTc3Ljg2IDExOS4yNzJDMTY5LjI4MiAxNDkuNDc3IDE0Ny41MzkgMTgwLjcwNyAxMTUuNzU2IDE4OS42MjhDMTA2Ljk3MyAxOTIuMDkzIDk3LjU3NTUgMTkyLjYwOSA4OC40NDE5IDE5MC42NjZDNzEuMzkyMSAxODcuMDQ5IDU2LjYwNzMgMTc2LjYzNCA0My41MTM2IDE2NS4zODlDMjguMjU4MyAxNTIuMjg3IDExLjI0MjQgMTM3Ljk5MSAzLjk0MzcyIDExOC44NjZDMi4yODM1MiAxMTQuNTIgMS4yMjE3OCAxMTAuMTIzIDAuNjYxMDA4IDEwNS43MjRMMC42NTA3OTggMTA1LjcyNFoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  object-fit: cover;
  width: 75%;
}
.page-template-centre section.discover .pages a h3 {
  color: #FFF;
  margin: 0;
}
.page-template-centre section.discover .pages a:nth-of-type(2) {
  background: #27B0D1;
}
.page-template-centre section.discover .pages a:nth-of-type(2) h3 {
  color: #1B0A41;
}
.page-template-centre section.discover .pages a:nth-of-type(3) {
  background: #FFCA30;
}
.page-template-centre section.discover .pages a:nth-of-type(3) h3 {
  color: #1B0A41;
}
.page-template-centre section.discover .pages a:hover, .page-template-centre section.discover .pages a:active, .page-template-centre section.discover .pages a:focus-within, .page-template-centre section.discover .pages a:focus {
  background: #665AA4;
}
.page-template-centre section.discover .pages a:hover h3, .page-template-centre section.discover .pages a:active h3, .page-template-centre section.discover .pages a:focus-within h3, .page-template-centre section.discover .pages a:focus h3 {
  color: #FFF;
}
.page-template-centre section.ready {
  text-align: center;
}
.page-template-centre section.ready h2 {
  color: #1B0A41;
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
}
.page-template-centre section.ready .primary-button {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-centre section.ready .primary-button:hover, .page-template-centre section.ready .primary-button:active, .page-template-centre section.ready .primary-button:focus-within, .page-template-centre section.ready .primary-button:focus {
  background: #665AA4;
  color: #FFF;
}

.page-template-separated .buttons {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .page-template-separated .buttons {
    flex-direction: row;
  }
}
.page-template-separated .buttons .primary-button:first-of-type {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-separated .buttons .primary-button:first-of-type:hover, .page-template-separated .buttons .primary-button:first-of-type:active, .page-template-separated .buttons .primary-button:first-of-type:focus-within, .page-template-separated .buttons .primary-button:first-of-type:focus {
  background: #1B0A41;
  color: #FFF;
}
.page-template-separated main:not(.simple) .separated h2 {
  text-align: center;
}
.page-template-separated main:not(.simple) .separated section.separated-item {
  position: relative;
}
.page-template-separated main:not(.simple) .separated section.separated-item:not(:last-of-type) {
  padding-top: 4rem;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item:not(:last-of-type) {
    padding-bottom: 0;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item:last-of-type {
  margin-bottom: 4rem;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item:last-of-type {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .page-template-separated main:not(.simple) .separated section.separated-item:last-of-type {
    margin-bottom: 8rem;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item .container {
  align-items: center;
}
.page-template-separated main:not(.simple) .separated section.separated-item .container h2 {
  text-align: left;
}
.page-template-separated main:not(.simple) .separated section.separated-item .container picture {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  aspect-ratio: 760/780;
  order: -1;
  position: relative;
  z-index: 2;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item .container picture {
    order: unset;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item .container picture:after {
  aspect-ratio: 762/780;
  background-image: url("../images/purple-dots-top-left.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: auto;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.page-template-separated main:not(.simple) .separated section.separated-item .container picture img {
  display: block;
  height: 100%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjQ1IiBoZWlnaHQ9IjYzMCIgdmlld0JveD0iMCAwIDY0NSA2MzAiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xNzYuNzA5IDI3Ljk2MjZDMjMzLjAzOSAtMS4zODk2OCAyOTcuNDQ0IC0zLjA2MzIgMzU4Ljc5MSAyLjc0NDgzQzQyMi4xNzIgOC43NDM1NSA0ODguMDAzIDIzLjIyNDUgNTQyLjAxMSA1OC40MzE1QzU3MS4xOCA3Ny40NDY2IDU5Ni4yOTUgMTAzLjE2NiA2MTEuMzIyIDEzNS42NDZDNjUxLjY1NyAyMjIuODQxIDY1NC40MzQgMzI5LjIyMyA2MjMuODQzIDQyMS45MThDNjE0Ljg4NiA0NDkuMDM4IDYwMi42NSA0NzUuMTU0IDU4Ni43MDkgNDk4LjgxQzU3MC40MzMgNTIyLjk2NiA1NTAuMzIyIDU0NC4yNTIgNTI3LjMxNiA1NjEuNTkzQzQ3NC45MjIgNjAxLjExNSA0MTEuMDM5IDYyMy4zMDEgMzQ3LjM1MiA2MjguMjI0QzIzNy4zMTcgNjM2LjcwNyAxMDcuOTAyIDYwMy4wNjggMzkuODY0IDUwOS4yMThDMjEuMDYwMyA0ODMuMjgxIDcuOTM5OTggNDUyLjk1MiAzLjI1MDgxIDQyMC40OTlDLTUuNTM4NzkgMzU5LjkzMiAxMC44NDQ5IDI5OC41NTcgMzIuMDE5NyAyNDEuNzQ0QzU2LjY5MzcgMTc1LjU1IDgzLjE2NDggMTAyLjEwNSAxMzcuMzcgNTQuNzk2NkMxNDkuNjg0IDQ0LjA0MTMgMTYyLjg5NSAzNS4xOTQ4IDE3Ni43MiAyNy45OTY4TDE3Ni43MDkgMjcuOTYyNloiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
  object-fit: cover;
  position: absolute;
  width: 85%;
  z-index: 1;
}
.page-template-separated main:not(.simple) .separated section.separated-item .container .wrapper {
  padding: 0 0 4rem;
}
@media only screen and (min-width: 768px) {
  .page-template-separated main:not(.simple) .separated section.separated-item .container .wrapper {
    padding: 0 0 6rem;
  }
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item .container .wrapper {
    padding: 6rem 0;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item:last-of-type .wrapper {
  padding: 0;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-1:before {
  background-image: url(../images/white-bg.svg);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: auto 100%;
  content: "";
  display: block;
  height: 30%;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  z-index: 1;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-1:before {
    background-size: 100% 100%;
    width: 100%;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-1:after {
  background: #FFF;
  bottom: 0;
  content: "";
  height: 71%;
  position: absolute;
  width: 100%;
  z-index: 1;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-1 picture {
  aspect-ratio: 597/524;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-1 picture:after {
  aspect-ratio: 597/524;
  background-image: url("../images/blue-bg-yellow-dots.svg");
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-1 picture img {
  aspect-ratio: 530/570;
  left: 15%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTY0IiBoZWlnaHQ9IjUzNCIgdmlld0JveD0iMCAwIDU2NCA1MzQiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik00ODUuODg3IDY3LjYzQzUyNC44MTggMTA2LjY2IDU0Mi42MDEgMTU5LjI0MiA1NTMuMzM1IDIxMS4xNzRDNTY0LjQyNiAyNjQuODI4IDU2OS4wMyAzMjIuNjE1IDU1My4yNTMgMzc1Ljg0NEM1NDQuNzMzIDQwNC41OTIgNTI5LjU2IDQzMS42NzcgNTA2LjE1NSA0NTIuMTQ4QzQ0My4zMjEgNTA3LjA5NyAzNTQuODUyIDUzNS45MjcgMjY5LjM2OSA1MzMuODgzQzI0NC4zNTcgNTMzLjI3OSAyMTkuMzUzIDUyOS43MjYgMTk1LjQ2OCA1MjIuNTExQzE3MS4wOCA1MTUuMTQ1IDE0OC4xMjIgNTAzLjkwNyAxMjcuNzM0IDQ4OS4zMDJDODEuMjc5NCA0NTYuMDQ4IDQ2LjQzMzUgNDA5LjAxNCAyNi4xMDk0IDM1Ny44MzRDLTguOTg2ODIgMjY5LjQwMSAtMTMuNzAzIDE1NC41MSA0Ny42NjQxIDc1LjEwMzJDNjQuNjI0IDUzLjE1NzUgODYuNzEwNyAzNC43OTI4IDExMi43MjIgMjIuODM2M0MxNjEuMjU4IDAuNDkwMzcyIDIxNi44NzMgLTEuMzQxODIgMjY5Ljg4MyAxLjkwNjg5QzMzMS42NDYgNS42OTQ1MSAzOTkuOTQ1IDkuMTUxNDkgNDUzLjM4OCA0MS45NTI2QzQ2NS41MzUgNDkuNDAyMyA0NzYuMzExIDU4LjA2NjcgNDg1Ljg2MSA2Ny42NDc1TDQ4NS44ODcgNjcuNjNaIiBmaWxsPSJibGFjayIvPgo8L3N2Zz4K);
  top: 5%;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-2, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6 {
  background: #E3E3F2;
  z-index: 2;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-2:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-2:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6:after {
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 3rem;
  position: absolute;
  width: 100%;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-2:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6:before {
  background-image: url("../images/purple-light-top.svg");
  top: -3rem;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-2, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6 {
    padding-top: 0;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-2 picture img, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6 picture img {
  aspect-ratio: 511/537;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTMzIiBoZWlnaHQ9IjUyMSIgdmlld0JveD0iMCAwIDUzMyA1MjEiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xNDYuMTM1IDIzLjUwNjdDMTkyLjcxMyAtMC43NDU5OTcgMjQ1Ljk2OSAtMi4xMjg3NyAyOTYuNjk2IDIuNjcwMkMzNDkuMTA1IDcuNjI2NzIgNDAzLjU0IDE5LjU5MTggNDQ4LjE5OCA0OC42ODIxQzQ3Mi4zMTggNjQuMzkzNSA0OTMuMDg1IDg1LjY0NDggNTA1LjUxMSAxMTIuNDgyQzUzOC44NjMgMTg0LjUyOCA1NDEuMTU5IDI3Mi40MjcgNTE1Ljg2NCAzNDkuMDE4QzUwOC40NTggMzcxLjQyNiA0OTguMzQgMzkzLjAwNSA0ODUuMTU4IDQxMi41NTFDNDcxLjcgNDMyLjUxIDQ1NS4wNzEgNDUwLjA5OCA0MzYuMDQ3IDQ2NC40MjZDMzkyLjcyMyA0OTcuMDgxIDMzOS44OTkgNTE1LjQxNCAyODcuMjM3IDUxOS40ODFDMTk2LjI1MSA1MjYuNDkgODkuMjM4OSA0OTguNjk2IDMyLjk3OTQgNDIxLjE1MUMxNy40MzA5IDM5OS43MiA2LjU4MTgzIDM3NC42NiAyLjcwNDQxIDM0Ny44NDVDLTQuNTYzNiAyOTcuODAxIDguOTgzODkgMjQ3LjA4OSAyNi40OTMgMjAwLjE0N0M0Ni44OTU2IDE0NS40NTMgNjguNzg0MyA4NC43Njc4IDExMy42MDUgNDUuNjc4N0MxMjMuNzg4IDM2Ljc5MiAxMzQuNzEyIDI5LjQ4MjQgMTQ2LjE0NCAyMy41MzQ5TDE0Ni4xMzUgMjMuNTA2N1oiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  right: 10%;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-2 picture:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-6 picture:after {
  aspect-ratio: 1/1;
  background-image: url("../images/yellow-bg-purple-dots.svg");
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 {
  background: #E3E3F2;
  padding-bottom: 4rem;
  z-index: 2;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7:before {
  background-image: url(../images/sand-bg.svg);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: auto 100%;
  content: "";
  display: block;
  height: 30%;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-3:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7:before {
    background-size: 100% 100%;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7:after {
  background: #FBF8F0;
  bottom: 0;
  content: "";
  height: 71%;
  position: absolute;
  width: 100%;
  z-index: 1;
}
@media only screen and (min-width: 1800px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-3:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7:before {
    height: 80%;
  }
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-3:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7:after {
    height: 21%;
  }
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-3 .wrapper, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 .wrapper {
    width: 80%;
  }
}
@media only screen and (min-width: 1900px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-3 .wrapper, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 .wrapper {
    width: 100%;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3 picture, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 picture {
  aspect-ratio: 749/698;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3 picture:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 picture:after {
  aspect-ratio: 749/698;
  background-image: url("../images/magenta-dots-bottom-left.svg");
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-3 picture img, .page-template-separated main:not(.simple) .separated section.separated-item.separated-7 picture img {
  bottom: 2%;
  left: 15%;
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNjA1IiBoZWlnaHQ9IjYxOCIgdmlld0JveD0iMCAwIDYwNSA2MTgiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0yNy4zOTczIDQ0OS4xODZDLTAuNzQ0NTc4IDM5NS4xOCAtMi4zNDkwOCAzMzMuNDMgMy4yMTk0NCAyNzQuNjEzQzguOTcwNzkgMjEzLjg0NiAyMi44NTQ2IDE1MC43MjkgNTYuNjA5OCA5OC45NDg1Qzc0Ljg0MDggNzAuOTgxOCA5OS40OTk5IDQ2LjkwMjUgMTMwLjY0IDMyLjQ5NTVDMjE0LjI0IC02LjE3NjMyIDMxNi4yMzUgLTguODM4NTggNDA1LjEwNyAyMC40OTA4QzQzMS4xMDkgMjkuMDc4MSA0NTYuMTQ4IDQwLjgxIDQ3OC44MjkgNTYuMDkzNUM1MDEuOTg5IDcxLjY5ODUgNTIyLjM5NyA5MC45Nzk3IDUzOS4wMjMgMTEzLjAzN0M1NzYuOTE0IDE2My4yNzEgNTk4LjE4NiAyMjQuNTIgNjAyLjkwNiAyODUuNThDNjExLjAzOSAzOTEuMDc4IDU3OC43ODggNTE1LjE1NiA0ODguODA4IDU4MC4zODlDNDYzLjk0IDU5OC40MTcgNDM0Ljg2MiA2MTAuOTk2IDQwMy43NDcgNjE1LjQ5MkMzNDUuNjc4IDYyMy45MTkgMjg2LjgzNCA2MDguMjExIDIzMi4zNjMgNTg3LjkwOUMxNjguODk5IDU2NC4yNTMgOTguNDgyMiA1MzguODczIDUzLjEyNDggNDg2LjkwNEM0Mi44MTMgNDc1LjA5OCAzNC4zMzEzIDQ2Mi40MzEgMjcuNDMwMSA0NDkuMTc2TDI3LjM5NzMgNDQ5LjE4NloiIGZpbGw9IiNGRjAwMDAiLz4KPC9zdmc+Cg==);
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8 {
  background: white;
  position: relative;
  z-index: 3;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-4:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8:after {
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 3rem;
  position: absolute;
  width: 100%;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4:before, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8:before {
  background-image: url("../images/white-top.svg");
  top: -3rem;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8:after {
  background-image: url("../images/white-bottom.svg");
  bottom: -3rem;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4 picture, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8 picture {
  aspect-ratio: 632/561;
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4 picture:after, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8 picture:after {
  aspect-ratio: 632/561;
  background-image: url("../images/purple-bg-purple-dots.svg");
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-4 picture img, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8 picture img {
  mask-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTMzIiBoZWlnaHQ9IjUyMSIgdmlld0JveD0iMCAwIDUzMyA1MjEiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xNDYuMjAzIDIzLjM0ODVDMTkyLjc4MSAtMC45MDQyIDI0Ni4wMzcgLTIuMjg2OTcgMjk2Ljc2NCAyLjUxMkMzNDkuMTczIDcuNDY4NTIgNDAzLjYwOCAxOS40MzM2IDQ0OC4yNjYgNDguNTIzOUM0NzIuMzg2IDY0LjIzNTMgNDkzLjE1NCA4NS40ODY2IDUwNS41NzkgMTEyLjMyM0M1MzguOTMxIDE4NC4zNyA1NDEuMjI4IDI3Mi4yNjkgNTE1LjkzMiAzNDguODZDNTA4LjUyNiAzNzEuMjY4IDQ5OC40MDggMzkyLjg0NiA0ODUuMjI3IDQxMi4zOTNDNDcxLjc2OCA0MzIuMzUyIDQ1NS4xMzkgNDQ5Ljk0IDQzNi4xMTYgNDY0LjI2OEMzOTIuNzkyIDQ5Ni45MjMgMzM5Ljk2NyA1MTUuMjU1IDI4Ny4zMDYgNTE5LjMyM0MxOTYuMzE5IDUyNi4zMzIgODkuMzA3MyA0OTguNTM4IDMzLjA0NzcgNDIwLjk5M0MxNy40OTkyIDM5OS41NjIgNi42NTAxOSAzNzQuNTAyIDIuNzcyNzcgMzQ3LjY4N0MtNC40OTUyNCAyOTcuNjQzIDkuMDUyMjUgMjQ2LjkzMSAyNi41NjE0IDE5OS45ODhDNDYuOTY0IDE0NS4yOTUgNjguODUyNiA4NC42MDk2IDExMy42NzQgNDUuNTIwNUMxMjMuODU2IDM2LjYzMzggMTM0Ljc4IDI5LjMyNDIgMTQ2LjIxMiAyMy4zNzY3TDE0Ni4yMDMgMjMuMzQ4NVoiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  right: 12%;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main:not(.simple) .separated section.separated-item.separated-4 .wrapper, .page-template-separated main:not(.simple) .separated section.separated-item.separated-8 .wrapper {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}
.page-template-separated main:not(.simple) .separated section.separated-item.separated-5 {
  z-index: 3;
}
.page-template-separated main .wrapper {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-direction: column;
  gap: 2rem;
  position: relative;
  z-index: 2;
}
.page-template-separated main .wrapper h2,
.page-template-separated main .wrapper h3,
.page-template-separated main .wrapper h4,
.page-template-separated main .wrapper h5,
.page-template-separated main .wrapper h6,
.page-template-separated main .wrapper p {
  color: #1B0A41;
  margin: 0;
}
.page-template-separated main .wrapper ul {
  margin-bottom: 0;
  margin-top: 0;
}
.page-template-separated main .wrapper .buttons .secondary-button {
  background: #D2D2F0;
}
.page-template-separated main .wrapper .buttons .secondary-button:hover, .page-template-separated main .wrapper .buttons .secondary-button:active, .page-template-separated main .wrapper .buttons .secondary-button:focus-within, .page-template-separated main .wrapper .buttons .secondary-button:focus {
  background: #665AA4;
}
.page-template-separated main .cta {
  position: relative;
  text-align: center;
  z-index: 5;
}
.page-template-separated main .cta h2 {
  margin-left: auto;
  margin-right: auto;
  max-width: 450px;
}
.page-template-separated main .cta .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1rem;
}
@media only screen and (min-width: 768px) {
  .page-template-separated main .cta .buttons {
    flex-direction: row;
  }
}
.page-template-separated main .cta .buttons .primary-button:first-of-type {
  background: #E3E3F2;
  color: #1B0A41;
}
.page-template-separated main .cta .buttons .primary-button:first-of-type:hover, .page-template-separated main .cta .buttons .primary-button:first-of-type:active, .page-template-separated main .cta .buttons .primary-button:first-of-type:focus-within, .page-template-separated main .cta .buttons .primary-button:first-of-type:focus {
  background: #1B0A41;
  color: #FFF;
}
.page-template-separated main.simple section.separated section.separated-item {
  margin-bottom: 2rem;
  margin-top: 2rem;
}
@media only screen and (min-width: 768px) {
  .page-template-separated main.simple section.separated section.separated-item {
    margin-bottom: 4rem;
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main.simple section.separated section.separated-item {
    margin-bottom: 6rem;
    margin-top: 6rem;
  }
}
@media only screen and (min-width: 1440px) {
  .page-template-separated main.simple section.separated section.separated-item {
    margin-bottom: 8rem;
    margin-top: 8rem;
  }
}
.page-template-separated main.simple section.separated section.separated-item .container {
  align-items: center;
}
.page-template-separated main.simple section.separated section.separated-item .container picture {
  height: 100%;
  position: relative;
}
.page-template-separated main.simple section.separated section.separated-item .container picture img {
  aspect-ratio: 4/3;
  border-radius: 1rem;
  display: block;
  object-fit: cover;
  width: 100%;
}
@media only screen and (min-width: 1024px) {
  .page-template-separated main.simple section.separated section.separated-item .container picture img {
    aspect-ratio: unset;
    height: 100%;
    position: absolute;
  }
}
.page-template-separated main.simple .separated-2 picture,
.page-template-separated main.simple .separated-6 picture {
  position: relative;
}
.page-template-separated main.simple .separated-2 picture:after,
.page-template-separated main.simple .separated-6 picture:after {
  aspect-ratio: 1160/1610;
  background-image: url("../images/extra-pictures.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  left: 85%;
  position: absolute;
  top: -10rem;
  width: 200%;
  z-index: -1;
}
.page-template-separated main.simple section.cta .container {
  position: relative;
}
.page-template-separated main.simple section.cta .container:after {
  aspect-ratio: 1160/1610;
  background-image: url("../images/extra-pictures.svg");
  background-repeat: no-repeat;
  background-size: contain;
  top: 50%;
  content: "";
  display: block;
  position: absolute;
  right: 85%;
  transform: translateY(-50%) rotate(180deg);
  width: 100%;
  z-index: -1;
}
.page-template-separated footer.footer {
  position: relative;
  z-index: 5;
}
