/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./.yarn/__virtual__/css-loader-virtual-bf286824a5/0/cache/css-loader-npm-6.7.3-63aa933400-473cc32b6c.zip/node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./.yarn/__virtual__/postcss-loader-virtual-1b7e30ecb8/0/cache/postcss-loader-npm-7.3.0-788d8ed604-f09fe68bde.zip/node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./.yarn/cache/resolve-url-loader-npm-5.0.0-9b441067c9-6d483733a4.zip/node_modules/resolve-url-loader/index.js??ruleSet[1].rules[1].use[3]!./.yarn/__virtual__/sass-loader-virtual-51a5632b47/0/cache/sass-loader-npm-13.2.2-b5bbed2dce-0368e4eaa4.zip/node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[4]!./.yarn/cache/@splidejs-splide-npm-4.1.4-574032679c-919f6e1e5d.zip/node_modules/@splidejs/splide/dist/css/splide.min.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

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

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  -ms-flex-align: center;
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: -ms-flexbox;
  display: flex;
  height: 2em;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }

  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}
/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./.yarn/__virtual__/css-loader-virtual-bf286824a5/0/cache/css-loader-npm-6.7.3-63aa933400-473cc32b6c.zip/node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./.yarn/__virtual__/postcss-loader-virtual-1b7e30ecb8/0/cache/postcss-loader-npm-7.3.0-788d8ed604-f09fe68bde.zip/node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./.yarn/cache/resolve-url-loader-npm-5.0.0-9b441067c9-6d483733a4.zip/node_modules/resolve-url-loader/index.js??ruleSet[1].rules[1].use[3]!./.yarn/__virtual__/sass-loader-virtual-51a5632b47/0/cache/sass-loader-npm-13.2.2-b5bbed2dce-0368e4eaa4.zip/node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[4]!./.yarn/cache/@splidejs-splide-npm-4.1.4-574032679c-919f6e1e5d.zip/node_modules/@splidejs/splide/dist/css/themes/splide-default.min.css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

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

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  -ms-flex-align: center;
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: -ms-flexbox;
  display: flex;
  height: 2em;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }

  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}
/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./.yarn/__virtual__/css-loader-virtual-bf286824a5/0/cache/css-loader-npm-6.7.3-63aa933400-473cc32b6c.zip/node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./.yarn/__virtual__/postcss-loader-virtual-1b7e30ecb8/0/cache/postcss-loader-npm-7.3.0-788d8ed604-f09fe68bde.zip/node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./.yarn/cache/resolve-url-loader-npm-5.0.0-9b441067c9-6d483733a4.zip/node_modules/resolve-url-loader/index.js??ruleSet[1].rules[1].use[3]!./.yarn/__virtual__/sass-loader-virtual-51a5632b47/0/cache/sass-loader-npm-13.2.2-b5bbed2dce-0368e4eaa4.zip/node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[4]!./src/styles/master.scss ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* ### Bullets */
/* XXS Mobile (min width) */
/* XS Mobile (min width) */
/* XS Mobile (max width) */
/* Mobile (min width) */
/* Mobile (max width) */
/* Mobile (max width) */
/* Tablets (min width) */
/* Tablets (max width) */
/* Small Desktop  (min width) */
/* Small Desktop (max width) */
/* Large Desktop (min width) */
/* Large Desktop (max width) */
/* Extra-Large Desktop (min width) */
/* Extra-Large Desktop (max width) */
/* High Definition (HD) - THIS IS THE LEVEL OF OUR DEFAULT STYLES */
/* Containers - PLEASE USE REMS */
/* Container Padding */
/* Whitespace */
/* Subheader */
/* Base unit used for spacing gutters */
/* Buttons */
/****************************************************************************************************/
/* #region Buttons */
/****************************************************************************************************/
/*
    Button styles were moved from placeholders to here to reduce generated CSS selector length.
    Ideally you should always either use a real <button> or add the .button class(es) where you needed,
    BUT if you really need it (perhaps to override some 3rd-party styles) you can always do this:

    #specific_selector .my-custom-button {
        @include button; // default styles
        // or
        @include button("secondary", true); // predefined styles WITH base button styles
    }

    You can also "extend" button classes defined in global.scss if you need to (similar to the old way).
    This keeps the css nice and light AS LONG as it's not super-nested beneath some comma-separated parents

    #specific_selector .my-custom-button {
        @extend .button.secondary;
    }
*/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Link Styler */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Functions */
/****************************************************************************************************/
/* Remove units from a value */
/* Convert pixels to rems */
/* Convert rems to pixels */
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Shortcut Selectors */
/****************************************************************************************************/
/*
    Set focus styles ONLY for users that need it.
    Will not work on older browsers (see base focus styles for example of overriding).
*/
/*  Just an alias for focusVisible */
/*
    Focus AND Hover
    A shortcut for when you need to share styles between focus and hover.
    Most of the time styles should go into separate focusVisible and/or :hover rules as needed.
*/
/* Select all FontAwesome icons */
/* Shortcut for writing out h1-h6 */
/* Cross-browser placeholders */
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Font Styless & Fluid Type */
/****************************************************************************************************/
/*
$min_width: 320px;
$max_width: 1200px;
$min_font: 16px;
$max_font: 24px;
@include fluid-type($min_width, $max_width, $min_font, $max_font);
*/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Grid Mixins */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Size & Position */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Overlays & Gradients */
/****************************************************************************************************/
/*background-image: linear-gradient(120deg, scrim-gradient($primaryColour));*/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Whitespace  */
/* You shouldn't ever need to use this directly - it's just used to generate our whitespace classes */
/* based on: https://styleguide.pivotal.io/modifiers/whitespace/#classes */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Modifiers  */
/* You shouldn't ever need to use this directly - it's just used to generate our subheader classes */
/* Based content https://frontstuff.io/generate-all-your-utility-classes-with-sass-maps            */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Misc */
/****************************************************************************************************/
/* shared outline styles for focus */
/* #endregion */
/****************************************************************************************************/
/* Force text to wrap with hyphen if to long (example long email) */
a[href^=mailto] {
  overflow-wrap: break-word;
  word-wrap: break-word;
  word-break: break-all;
  word-break: break-word;
  -webkit-hyphens: auto;
          hyphens: auto;
  white-space: unset;
}

.borderBottomShort {
  position: relative;
}
.borderBottomShort:after {
  content: " ";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 3rem;
  height: 1px;
  background-color: #0C3242;
}

.container.edge *.container.full, .container.full {
  padding-left: 5rem;
  padding-right: 5rem;
  /*        @media(max-width:$XL_Max) {
          padding-left: $desktopPadding;
          padding-right: $desktopPadding;
      }*/
}
@media (max-width: 1599px) {
  .container.edge *.container.full, .container.full {
    padding-left: 4rem;
    padding-right: 4rem;
  }
}
@media (max-width: 1299px) {
  .container.edge *.container.full, .container.full {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
@media (max-width: 1024px) {
  .container.edge *.container.full, .container.full {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}
@media (max-width: 767px) {
  .container.edge *.container.full, .container.full {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (max-width: 500px) {
  .container.edge *.container.full, .container.full {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.cardView.testimonial blockquote:before {
  content: " ";
  z-index: 0;
  position: absolute;
  /*            top: 45%;
      left: 40%;
      transform: translateY(-50%) translateX(-50%);*/
  top: 0;
  left: 0;
  /*transform: translateY(-20%) translateX(0);*/
  background-image: url(/CFImages/double-quote.svg);
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
  height: 12rem;
  width: 12rem;
  filter: invert(1);
  opacity: 0.15;
}

.coverImg {
  inset: 0;
  display: block;
  position: absolute;
}

/****************************************************************************************************/
/* #region Flex Grid */
/****************************************************************************************************/
.grid {
  /*width: 100%;*/
  width: initial;
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin: 0 -1rem 0 -1rem;
}
.grid.col {
  width: auto;
}
.grid.grid-nogutter {
  margin: 0;
}
.grid.grid-nogutter > .col {
  margin: 0;
}
.grid.grid-nowrap {
  flex-wrap: nowrap;
}
.grid.featureFirst > .col:first-child {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
  vertical-align: top;
  /*width: calc((1 / 1) * 100% - 1rem);*/
  flex-basis: calc((1 / 1) * 100% - 1rem);
}
.grid:not(.col) {
  flex-grow: 1;
}
.grid > .col {
  margin: 0 1rem 0 1rem;
}

.col {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
  display: flex;
  flex: 1 0 0;
  flex-direction: column;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Grid + Column Alignment */
/****************************************************************************************************/
/* Justify Content Classes */
.grid-start,
.col-top {
  justify-content: flex-start;
}

.grid-end,
.col-bottom {
  justify-content: flex-end;
}

.grid-center,
.col-middle {
  justify-content: center;
}

.grid-evenly,
.col-evenly {
  justify-content: space-evenly;
}

.grid-around,
.col-around {
  justify-content: space-around;
}

.grid-between,
.col-between {
  justify-content: space-between;
}

/* Align Items Classes */
.col-align-start,
.grid-align-start {
  align-items: flex-start;
}

.col-align-end,
.grid-align-end {
  align-items: flex-end;
}

.col-align-center,
.grid-align-center {
  align-items: center;
}

.col-align-stretch,
.grid-align-stretch {
  align-items: stretch;
}

.col-align-baseline,
.grid-align-baseline {
  align-items: baseline;
}

/* Column Self-Alignment Classes */
.col-align-top {
  align-self: flex-start;
}

.col-align-bottom {
  align-self: flex-end;
}

.col-align-middle {
  align-self: center;
}

/* Reordering Columns */
.col-first {
  order: -1;
}

.col-last {
  order: 1;
}

.grid-reverse-columns {
  flex-direction: column-reverse;
}

.grid-reverse-rows {
  flex-direction: row-reverse;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Column Sizing */
/****************************************************************************************************/
.col-fixed {
  flex: initial;
  flex-shrink: 0;
}

.col-auto-width {
  flex: 0 1 auto;
}

.col-grow-2,
.grid.col-grow-2 {
  flex-grow: 2;
}

.col-grow-3,
.grid.col-grow-3 {
  flex-grow: 3;
}

.col-grow-4,
.grid.col-grow-4 {
  flex-grow: 4;
}

.col-grow-5,
.grid.col-grow-5 {
  flex-grow: 5;
}

.col-grow-6,
.grid.col-grow-6 {
  flex-grow: 6;
}

.col-grow-7,
.grid.col-grow-7 {
  flex-grow: 7;
}

.col-grow-8,
.grid.col-grow-8 {
  flex-grow: 8;
}

.col-grow-9,
.grid.col-grow-9 {
  flex-grow: 9;
}

.col-grow-10,
.grid.col-grow-10 {
  flex-grow: 10;
}

.col-grow-11,
.grid.col-grow-11 {
  flex-grow: 11;
}

.col-1 {
  flex-basis: 8.3333333333%;
  max-width: 8.3333333333%;
}

.col-2 {
  flex-basis: 16.6666666667%;
  max-width: 16.6666666667%;
}

.col-3 {
  flex-basis: 25%;
  max-width: 25%;
}

.col-4 {
  flex-basis: 33.3333333333%;
  max-width: 33.3333333333%;
}

.col-5 {
  flex-basis: 41.6666666667%;
  max-width: 41.6666666667%;
}

.col-6 {
  flex-basis: 50%;
  max-width: 50%;
}

.col-7 {
  flex-basis: 58.3333333333%;
  max-width: 58.3333333333%;
}

.col-8 {
  flex-basis: 66.6666666667%;
  max-width: 66.6666666667%;
}

.col-9 {
  flex-basis: 75%;
  max-width: 75%;
}

.col-10 {
  flex-basis: 83.3333333333%;
  max-width: 83.3333333333%;
}

.col-11 {
  flex-basis: 91.6666666667%;
  max-width: 91.6666666667%;
}

.col-12 {
  flex-basis: 100%;
  max-width: 100%;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Responsive Grids */
/****************************************************************************************************/
.grid[data-gutter-width] {
  flex-wrap: nowrap;
}
.sfPageEditor .grid[data-gutter-width] > .col {
  flex-grow: 1 !important;
  flex-shrink: 0 !important;
  flex-basis: 0 !important;
}
.grid[data-gutter-width]:not([data-media-breakpoint]) {
  /*@media (max-width: $M_Max) {
      @extend %colStackedStyles;
  }*/
}
@media (max-width: 1299px) {
  .grid[data-gutter-width][data-media-breakpoint="1299px"], .grid[data-gutter-width][data-media-breakpoint="1300px"] {
    flex-wrap: wrap;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .grid[data-gutter-width][data-media-breakpoint="1299px"] > .col, .grid[data-gutter-width][data-media-breakpoint="1300px"] > .col {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: initial !important;
    flex-basis: initial !important;
  }
}
@media (max-width: 1024px) {
  .grid[data-gutter-width][data-media-breakpoint="1024px"] {
    flex-wrap: wrap;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .grid[data-gutter-width][data-media-breakpoint="1024px"] > .col {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: initial !important;
    flex-basis: initial !important;
  }
}
@media (max-width: 767px) {
  .grid[data-gutter-width][data-media-breakpoint="767px"] {
    flex-wrap: wrap;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .grid[data-gutter-width][data-media-breakpoint="767px"] > .col {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: initial !important;
    flex-basis: initial !important;
  }
}
@media (max-width: 500px) {
  .grid[data-gutter-width][data-media-breakpoint="500px"] {
    flex-wrap: wrap;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .grid[data-gutter-width][data-media-breakpoint="500px"] > .col {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: initial !important;
    flex-basis: initial !important;
  }
}

/*
@media only screen and (max-width: $M_Max) {
    .grid {
        &:not([data-gutter-width]):not(.grid-nowrap) { // only apply to NON-resizable grids
            .col {
                flex: 100%;
                max-width: 100%;
            }
        }
    }
}
*/
/* #endregion */
/****************************************************************************************************/
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  30% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: translateY(0%);
  }
}
@keyframes header-slide-in {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(0%);
  }
}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

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

/* Remove Italic styling */
address {
  font-style: normal;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
  display: block;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/* ### Bullets */
/* XXS Mobile (min width) */
/* XS Mobile (min width) */
/* XS Mobile (max width) */
/* Mobile (min width) */
/* Mobile (max width) */
/* Mobile (max width) */
/* Tablets (min width) */
/* Tablets (max width) */
/* Small Desktop  (min width) */
/* Small Desktop (max width) */
/* Large Desktop (min width) */
/* Large Desktop (max width) */
/* Extra-Large Desktop (min width) */
/* Extra-Large Desktop (max width) */
/* High Definition (HD) - THIS IS THE LEVEL OF OUR DEFAULT STYLES */
/* Containers - PLEASE USE REMS */
/* Container Padding */
/* Whitespace */
/* Subheader */
/* Base unit used for spacing gutters */
/* Buttons */
/* these need to be here for intellisense and go-to-definition to work */
/****************************************************************************************************/
/* #region Document */
/****************************************************************************************************/
::selection {
  background: #555555;
  color: white;
}

::-webkit-input-placeholder {
  color: #555555;
  text-transform: none;
}

:-moz-placeholder {
  color: #555555;
  text-transform: none;
}

::-moz-placeholder {
  color: #555555;
  text-transform: none;
}

:-ms-input-placeholder {
  color: #555555;
  text-transform: none;
}

* {
  box-sizing: border-box;
}

:root {
  --scrollbar-width: 16px;
  --header-height: $headerHeight;
  --card-width: 18rem;
  --column-count: 3;
  --card-gap: 1.5rem;
  color-scheme: normal !important;
  /* For Images */
  --image-width: 0;
  --image-height: 0;
  --image-aspectratio: 1.5;
}

html {
  min-height: auto;
  font-style: normal;
  font-family: Founders-Grotesk-Regular, "Arial", sans-serif;
  font-weight: 400;
  line-height: 1.5;
  scroll-behavior: smooth;
}
html {
  font-size: 18px;
}
@media screen and (min-width: 1025px) {
  html {
    font-size: calc(18px + 2 * ((100vw - 1025px) / 275));
  }
}
@media screen and (min-width: 1300px) {
  html {
    font-size: 20px;
  }
}

body {
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  color: #0C3242;
  font-style: normal;
  font-family: Founders-Grotesk-Regular, "Arial", sans-serif;
  font-weight: 400;
  background-color: #EDEEEF;
}

/* Custom Scrollbar Styles (only works in the latest browsers) */
::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 6px rgba(247, 247, 247, 0.5);
  background-color: #F5F5F5;
}

::-webkit-scrollbar {
  width: 10px;
  background-color: #F7F7F7;
}

::-webkit-scrollbar-thumb {
  background-color: #EDEEEF;
  border: 2px solid #EDEEEF;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Focus Styles */
/****************************************************************************************************/
* {
  outline-offset: 0;
}

*:focus {
  /* simple focus styles (for older browsers without support for :focus-visible */
  outline: 2px solid #BEC7CB;
}

*:focus:not(:focus-visible) {
  /* undo all the above focused button styles */
  outline: none;
}

*:focus-visible {
  /* focus styles for modern browsers */
  outline: 2px solid #BEC7CB;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Text-level Semantics */
/****************************************************************************************************/
p {
  margin: 0 0 1rem 0;
  padding: 0;
  font-size: 1em;
  font-style: normal;
  line-height: 1.5;
}

strong, b {
  /*font-weight: $fontWeightSemiBold;*/
  font-weight: 700;
  font-style: normal;
}

em, i {
  font-style: italic;
}

sup {
  vertical-align: super;
  font-size: 50%;
  font-style: normal;
}

sub {
  vertical-align: sub;
  font-size: 50%;
  font-style: normal;
}

blockquote {
  width: 100%;
  max-width: 100%;
  margin: 2rem auto;
  padding: 3rem 10%;
  position: relative;
  border: none;
  color: inherit;
  text-align: left;
  font-size: 1.2em;
  background-color: #BEC7CB;
}
blockquote p {
  color: inherit;
  font-weight: 700;
  font-style: normal;
}
blockquote > :last-child {
  margin-bottom: 0;
}
blockquote cite {
  font-style: italic;
  font-family: Founders-Grotesk-Light, "Arial", sans-serif;
}
a {
  color: #BEC7CB;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  text-decoration: none;
}

a:hover {
  color: #BEC7CB;
  text-decoration: underline;
}

a:active {
  color: #0C3242;
  text-decoration: none;
}

hr {
  border: none;
  height: 1px;
  margin: 2rem 0;
  background-color: #EDEEEF;
}

li {
  list-style: none;
  font-size: 1em;
  font-style: normal;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
ul li,
ol li {
  list-style: none;
}
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Headings */
/****************************************************************************************************/
span.seperator {
  padding: 0 7px;
  color: #A3A3A3;
}

/* Headings */
h1, h2, h3, h4, h5, h6, .h, .cmsContent.highlightFirstElement > :first-child {
  font-style: normal;
  font-family: Founders-Grotesk-Light, "Arial", sans-serif;
  font-weight: 400;
  line-height: 1.2;
  color: #0C3242;
  margin: 1.4rem 0 1.38rem;
  padding: 0;
  display: block;
}
h1.centered, h2.centered, h3.centered, h4.centered, h5.centered, h6.centered, .h.centered, .cmsContent.highlightFirstElement > .centered:first-child {
  text-align: center;
}

:is(h1, h2, h3, h4, h5, h6, .h) + :is(h1, h2, h3, h4, h5, h6, .h) {
  margin-top: 0;
}

h1 {
  color: #0C3242;
  font-size: 2.8rem;
  line-height: 1;
}

h2 {
  font-size: 2.6rem;
}

h3 {
  font-size: 1.2rem;
}

h4 {
  font-size: 1.266rem;
}

h5 {
  font-size: 1.125rem;
}

h6 {
  font-size: 1rem;
}

/* fake headings (turn any element into a heading, basically). These need to match the above. */
.h1 {
  color: #0C3242 !important;
  font-size: 2.488rem !important;
}

.h2 {
  font-size: 1.602rem !important;
}

.h3, .cmsContent.highlightFirstElement > :first-child {
  font-size: 1.2rem !important;
}

.h4 {
  font-size: 1.266rem !important;
}

.h5 {
  font-size: 1.125rem !important;
}

.h6 {
  font-size: 1rem !important;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Buttons */
/****************************************************************************************************/
.button:not(.sf-button),
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger) {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  /* Outline */
  /* primary colour */
  /* secondary colour */
  /* tertiary colour */
  /* reverse */
  /* outline */
  /* Arrow Icon */
  /* large */
}
.button:not(.sf-button):after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger):after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.button:not(.sf-button):before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger):before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.button:not(.sf-button):hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger):hover:after {
  transform: translateX(0) skewX(-25deg);
}
.button:not(.sf-button):focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger):focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.button:not(.sf-button):active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger):active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
.button:not(.sf-button).primary,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).primary {
  background-color: #0C3242;
  color: white;
  border-color: #0C3242;
}
.button:not(.sf-button).primary:hover, .button:not(.sf-button).primary:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).primary:hover,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).primary:focus {
  color: white;
  background-color: #08222c;
}
.button:not(.sf-button).primary:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).primary:active {
  color: white;
  background-color: #041117;
}
.button:not(.sf-button).secondary,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).secondary {
  background-color: #BEC7CB;
  color: white;
  border-color: #BEC7CB;
}
.button:not(.sf-button).secondary:hover, .button:not(.sf-button).secondary:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).secondary:hover,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).secondary:focus {
  color: white;
  background-color: #b0bbc0;
}
.button:not(.sf-button).secondary:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).secondary:active {
  color: white;
  background-color: #a2afb4;
}
.button:not(.sf-button).tertiary,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).tertiary {
  background-color: #BEC7CB;
  color: white;
  border-color: #BEC7CB;
}
.button:not(.sf-button).tertiary:hover, .button:not(.sf-button).tertiary:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).tertiary:hover,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).tertiary:focus {
  color: white;
  background-color: #b0bbc0;
}
.button:not(.sf-button).tertiary:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).tertiary:active {
  color: white;
  background-color: #a2afb4;
}
.button:not(.sf-button).reverse,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  background-color: transparent;
  color: #0C3242 !important;
  border: none;
  /* Outline */
}
.button:not(.sf-button).reverse:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.button:not(.sf-button).reverse:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.button:not(.sf-button).reverse:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:hover:after {
  transform: translateX(0) skewX(-25deg);
}
.button:not(.sf-button).reverse:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.button:not(.sf-button).reverse:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
.button:not(.sf-button).reverse:hover,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:hover {
  border-color: transparent;
  color: #fff !important;
}
.button:not(.sf-button).reverse:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:before {
  background: #BEC7CB;
}
.button:not(.sf-button).reverse:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:hover:after {
  background: #0C3242;
}
.button:not(.sf-button).reverse:hover:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).reverse:hover:before {
  background-color: #BEC7CB;
}
.button:not(.sf-button).outline,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  /* Outline */
  background-color: transparent;
  color: #0C3242 !important;
  border: 1px solid #0C3242;
}
.button:not(.sf-button).outline:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.button:not(.sf-button).outline:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.button:not(.sf-button).outline:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:hover:after {
  transform: translateX(0) skewX(-25deg);
}
.button:not(.sf-button).outline:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.button:not(.sf-button).outline:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
.button:not(.sf-button).outline:hover,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:hover {
  background-color: #BEC7CB;
  border-color: transparent;
}
.button:not(.sf-button).outline:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:before {
  background: none;
}
.button:not(.sf-button).outline:hover:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).outline:hover:before {
  background-color: #0C3242;
}
.button:not(.sf-button).arrow,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  /* Outline */
}
.button:not(.sf-button).arrow:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.button:not(.sf-button).arrow:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.button:not(.sf-button).arrow:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:hover:after {
  transform: translateX(0) skewX(-25deg);
}
.button:not(.sf-button).arrow:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.button:not(.sf-button).arrow:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
.button:not(.sf-button).arrow:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:after {
  content: " ";
  background-image: url(/CFImages/Icons/arrow-right.svg);
}
.button:not(.sf-button).arrow:hover:after, .button:not(.sf-button).arrow:focus:after, .button:not(.sf-button).arrow:active:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:focus:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).arrow:active:after {
  background-image: url(/CFImages/Icons/arrow-right-white.svg);
}
.button:not(.sf-button).large,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  /* Outline */
}
.button:not(.sf-button).large:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.button:not(.sf-button).large:before,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.button:not(.sf-button).large:hover:after,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large:hover:after {
  transform: translateX(0) skewX(-25deg);
}
.button:not(.sf-button).large:focus,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.button:not(.sf-button).large:active,
button:not(.sf-button):not(.splide__pagination__page):not(.hamburger).large:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}

.dark .button, .dark button {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  background-color: #BEC7CB;
  border: 1px solid #BEC7CB;
  color: white;
  /* Outline */
  /* Arrow Icon */
}
.dark .button:after, .dark button:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
.dark .button:before, .dark button:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
.dark .button:hover:after, .dark button:hover:after {
  transform: translateX(0) skewX(-25deg);
}
.dark .button:focus, .dark button:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
.dark .button:active, .dark button:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
.dark .button:hover, .dark .button:focus, .dark button:hover, .dark button:focus {
  border-color: #a2afb4;
  background-color: #a2afb4;
}
.dark .button:active, .dark button:active {
  border-color: #a2afb4;
  background-color: #a2afb4;
}
.dark .button.arrow:after, .dark button.arrow:after {
  content: " ";
  background-image: url(/CFImages/Icons/arrow-right-white.svg);
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Hyperlinks + Special Links */
/****************************************************************************************************/
/* Special Links */
/* Non-link elements with onclick functionality */
.clickable {
  cursor: pointer;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Images */
/****************************************************************************************************/
img {
  width: auto;
  height: auto;
}

/* As a NATIVE picture img */
.imgWrapper {
  width: 100%;
  /* if wrapped in hyperlink */
}
.imgWrapper img {
  max-width: 100%;
  height: 100%;
  width: 100%;
  aspect-ratio: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.imgWrapper a img {
  max-width: 100%;
}

/* As BACKGROUND image */
.bgImgWrapper {
  max-width: 100%;
  z-index: 0;
  overflow: hidden;
  position: relative;
}
.bgImgWrapper:before {
  /* sets the height and then effectively removes itself from flow so as not to interfere with siblings */
  float: left;
  width: 1px;
  height: 0;
  content: "";
  margin-left: -1px;
  padding-top: 56.25%;
}
.bgImgWrapper:after {
  /* to clear float */
  content: "";
  display: table;
  clear: both;
}
.bgImgWrapper .bgImg {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  position: absolute;
}
.bgImgWrapper .bgImg {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.bgImgWrapper a {
  width: 100%;
  height: 100%;
  display: block;
}

/* As fullscreenimage */
.backstretch .overlay {
  inset: 0;
  position: absolute;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region TYPOGRAPHY CMS Content Styles */
/****************************************************************************************************/
.cmsContent {
  color: #0C3242;
  font-size: 1em;
  line-height: 1.5;
  /* Headings */
  /* Links */
  /*    a[1="_blank"]:not(.button):after {
      content: " ";
      position: relative;
      display: inline-block;
      font-size: .6em;
      padding-left: .5rem;
  }*/
  /* Paragraphs */
  /* SHARED list styles */
  /* Unordered Lists Styles ONLY */
  /* Make sure what you're adding belongs here, and not in the SHARED list styles above */
  /* Ordered Lists */
  /* Make sure what you're adding belongs here, and not in the SHARED list styles above */
  /* Misc content elements */
  /* last child selector */
  /*
  > :last-child {
  }
  */
}
.cmsContent img {
  max-width: 100%;
}
.cmsContent em, .cmsContent i {
  font-style: italic;
}
.cmsContent h1, .cmsContent h2, .cmsContent h3, .cmsContent h4, .cmsContent h5, .cmsContent h6, .cmsContent .h, .cmsContent.highlightFirstElement > :first-child {
  color: #0C3242;
  /*&:first-child {
      margin-top: 0;
  }*/
}
.cmsContent h3 {
  font-weight: 700;
}
.cmsContent a {
  color: #0C3242;
  text-decoration: none;
  font-weight: 700;
}
.cmsContent a:hover, .cmsContent a:focus {
  text-decoration: underline;
}
.cmsContent a:active {
  color: #a2afb4;
  text-decoration: underline;
}
.cmsContent .socialLinks a[target=_blank]:after {
  content: none;
}
.cmsContent p {
  line-height: 1.5;
}
.cmsContent ul,
.cmsContent ol {
  margin: 1rem 0;
  /* SHARED list item styles */
  /* SHARED nested list styles */
  /* Special lists:   Alpha & Roman Numerals */
}
.cmsContent ul li,
.cmsContent ol li {
  margin: 0 0 0.8em;
  position: relative;
  padding: 0 0 0 1.75rem;
}
.cmsContent ul ol,
.cmsContent ul ul,
.cmsContent ol ol,
.cmsContent ol ul {
  margin: 0.4rem 0;
}
.cmsContent ul ol > li,
.cmsContent ul ul > li,
.cmsContent ol ol > li,
.cmsContent ol ul > li {
  background: none;
}
.cmsContent ul ol > li:before,
.cmsContent ul ul > li:before,
.cmsContent ol ol > li:before,
.cmsContent ol ul > li:before {
  color: #0C3242;
}
.cmsContent ul.roman > li,
.cmsContent ol.roman > li {
  padding-left: 2rem;
}
.cmsContent ul.roman > li:before,
.cmsContent ol.roman > li:before {
  content: counter(customListCounter, lower-roman) ".";
}
.cmsContent ul.alpha > li:before, .cmsContent ul.lettered > li:before,
.cmsContent ol.alpha > li:before,
.cmsContent ol.lettered > li:before {
  content: counter(customListCounter, lower-alpha) ".";
}
.cmsContent ul.upper > li:before, .cmsContent ul.uppercase > li:before,
.cmsContent ol.upper > li:before,
.cmsContent ol.uppercase > li:before {
  text-transform: uppercase;
}
.cmsContent ul.reset li,
.cmsContent ol.reset li {
  padding-left: 0;
}
.cmsContent ul.reset li:before,
.cmsContent ol.reset li:before {
  display: none;
}
.cmsContent ul {
  list-style-type: none;
}
.cmsContent ul > li {
  list-style-type: none;
  font-size: 1em;
  position: relative;
  /* bullet icon */
}
.cmsContent ul > li:before {
  content: " ";
  top: initial;
  left: 0;
  width: 1em;
  height: 1.4em;
  color: #0C3242;
  content: "";
  display: block;
  position: absolute;
  line-height: inherit;
  background-image: url(/CFImages/Icons/bullet-square-solid.svg);
  background-size: 0.4em auto;
  background-repeat: no-repeat;
  background-position: center;
}
.cmsContent ol {
  counter-reset: customListCounter 0;
  list-style-position: outside;
}
.cmsContent ol > li {
  list-style-type: none;
  list-style-position: inside;
  counter-increment: customListCounter;
}
.cmsContent ol > li:before {
  top: initial;
  left: 0.4rem;
  content: counter(customListCounter) ".";
  color: #0C3242;
  position: absolute;
  font-weight: 400;
}
.cmsContent address {
  margin: 0.5rem 0 1rem;
}
.cmsContent mark {
  color: white;
  background-color: #555555;
}
.cmsContent pre {
  white-space: pre-wrap;
  background-color: #efefef;
  padding: 2rem;
}
.cmsContent.highlight > p:nth-of-type(1), .highlight .cmsContent > p:nth-of-type(1) {
  font-size: 1.466rem;
  font-weight: 300;
  line-height: 1.4;
  margin: 0 0 1.38rem;
}
.cmsContent.highlightFirstElement > :first-child {
  margin: 0 0 1.38rem;
}
.cmsContent.highlightFirstElement > :first-child > * {
  font: inherit;
  line-height: inherit;
}

.dark, .dark .cmsContent {
  color: white;
  /* SHARED list styles */
  /* Unordered Lists Styles ONLY */
  /* Make sure what you're adding belongs here, and not in the SHARED list styles above */
  /* Ordered Lists */
  /* Make sure what you're adding belongs here, and not in the SHARED list styles above */
}
.dark ::selection, .dark .cmsContent ::selection {
  background: #1057AD;
  color: white;
}
.dark h1, .dark h2, .dark h3, .dark h4, .dark h5, .dark h6, .dark p, .dark ul li, .dark address, .dark .cmsContent h1, .dark .cmsContent h2, .dark .cmsContent h3, .dark .cmsContent h4, .dark .cmsContent h5, .dark .cmsContent h6, .dark .cmsContent p, .dark .cmsContent ul li, .dark .cmsContent address {
  color: white;
}
.dark a:link, .dark a:visited, .dark .cmsContent a:link, .dark .cmsContent a:visited {
  color: white;
}
.dark a:hover, .dark a:active, .dark a:focus, .dark .cmsContent a:hover, .dark .cmsContent a:active, .dark .cmsContent a:focus {
  color: #BEC7CB;
  text-decoration: underline;
}
.dark a.button:hover, .dark a.button:active, .dark a.button:focus, .dark .cmsContent a.button:hover, .dark .cmsContent a.button:active, .dark .cmsContent a.button:focus {
  color: white;
}
.dark ul,
.dark ol, .dark .cmsContent ul,
.dark .cmsContent ol {
  /* SHARED nested list styles */
}
.dark ul ol > li:before,
.dark ul ul > li:before,
.dark ol ol > li:before,
.dark ol ul > li:before, .dark .cmsContent ul ol > li:before,
.dark .cmsContent ul ul > li:before,
.dark .cmsContent ol ol > li:before,
.dark .cmsContent ol ul > li:before {
  color: white;
}
.dark ul > li, .dark .cmsContent ul > li {
  /* bullet icon */
}
.dark ul > li:before, .dark .cmsContent ul > li:before {
  color: white;
  background-image: url(/CFImages/Icons/bullet-square-solid-white.svg);
}
.dark ol > li:before, .dark .cmsContent ol > li:before {
  color: white;
}
.dark mark, .dark .cmsContent mark {
  color: white;
  background-color: #1057AD;
}
.dark pre, .dark .cmsContent pre {
  background-color: black;
  color: white;
}
.dark blockquote, .dark .cmsContent blockquote {
  background-color: black;
  color: white;
}
.dark blockquote p, .dark .cmsContent blockquote p {
  color: white;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Icons / FontAwesome / Kendo Icons */
/****************************************************************************************************/
/* A trick for prefetching icons we know we need to prevent the flash-of-unstyled-icon on hover */
body::after {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  z-index: -1;
  content: url(/CFImages/Icons/chevron-down.svg) url(/CFImages/Icons/chevron-up.svg) url(/CFImages/Icons/audio.svg) url(/CFImages/Icons/plus.svg) url(/CFImages/Icons/minus.svg);
}

/* Any and all FontAwesome icons */
[class^=fa-], [class*=" fa-"] {
  color: inherit;
}

/* shared Kendo widget icon styles (works with navigation css file) */
.k-icon {
  width: 3rem;
  height: 3rem;
  /* Expand / Collapse Arrows */
}
.k-icon:before {
  content: " ";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 0.6rem;
}
.k-icon.k-menu-expand-arrow:before, .k-icon.k-i-expand:before {
  background-image: url(/CFImages/Icons/plus.svg);
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.k-state-active .k-icon.k-menu-expand-arrow:before, .k-state-active .k-icon.k-i-expand:before {
  transform: rotate(360deg);
  background-image: url(/CFImages/Icons/minus.svg);
}
.k-icon.k-i-collapse:before {
  background-image: url(/CFImages/Icons/minus.svg);
}
.k-state-active .k-icon.k-i-collapse:before {
  background-image: url(/CFImages/Icons/plus.svg);
}

/* selected element icon (needs to be white because dark background */
li.k-item.selected > div .k-icon:first-of-type.k-i-expand:before {
  background-image: url(/CFImages/Icons/plus.svg);
}
li.k-item.selected > div .k-icon:first-of-type.k-i-collapse:before {
  background-image: url(/CFImages/Icons/minus.svg);
}

/* Custom icons element with background svgs*/
.icon {
  display: inline-block;
  font-size: 1em;
}
.icon:before {
  content: " ";
  width: 1.4em;
  height: 1.4em;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.icon.audio:before {
  background-image: url(/CFImages/Icons/audio.svg);
}
.icon.print:before {
  background-image: url(/CFImages/Icons/print.svg);
}
.icon.bookmark:before {
  background-image: url(/CFImages/Icons/bookmark.svg);
}
.icon.share:before {
  background-image: url(/CFImages/Icons/share.svg);
}
.icon.vcard:before {
  background-image: url(/CFImages/Icons/vcard.svg);
}
.icon.video:before {
  background-image: url(/CFImages/Icons/video.svg);
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Skip-to-Content + Sticky Links */
/****************************************************************************************************/
#skiptocontent a {
  left: -999px;
  position: absolute;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  z-index: -999;
}
#skiptocontent a:focus, #skiptocontent a:active {
  top: auto;
  left: auto;
  width: 30%;
  height: auto;
  z-index: 999;
  overflow: auto;
  margin: 10px 35%;
  padding: 5px;
  color: white;
  font-size: 1.2rem;
  text-align: center;
  border: 4px solid #555555;
  border-radius: 15px;
  background-color: black;
}

/* #endregion */
/**

/****************************************************************************************************/
/* #region Layout / Structure */
/****************************************************************************************************/
/*Sticky Footer Items */
body {
  display: flex;
  flex-direction: column;
}

#wrapper {
  overflow: hidden;
  height: auto !important;
  flex: 1 0 auto;
}
.k-ie11 #wrapper {
  flex: inherit;
}
.transparentHeader #wrapper {
  padding-top: 0 !important;
}
.transparentHeader #wrapper header:not(.up) .topHeader {
  background-color: transparent;
}

.pageWrapper {
  position: relative;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  left: 0;
}

.sfPageEditor .opacityWrapper > * {
  opacity: 1 !important;
  transform: translatey(0) !important;
}

.opacityWrapper > * {
  opacity: 0;
  transform: translatey(10%);
  transition: opacity 1s, transform 0.5s;
}
.opacityWrapper.inViewport > * {
  opacity: 1;
  transform: translatey(0);
}
.opacityWrapper.inViewport h2:after {
  width: 3rem;
}

.wrapperPadding {
  padding: 2rem 0;
}

.primaryWrapper {
  background-color: #0C3242;
}
.primaryWrapper.wrapper {
  padding: 2rem 0rem 5rem;
}

.secondaryWrapper {
  background-color: #BEC7CB;
}
.secondaryWrapper.wrapper {
  padding: 2rem 0rem 5rem;
}

.twoToneWrapper {
  background: linear-gradient(90deg, transparent 50%, #BEC7CB 50%);
}
@media only screen and (max-width: 767px) {
  .twoToneWrapper {
    background: transparent;
  }
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Containers */
/****************************************************************************************************/
.container {
  width: 80rem;
  max-width: 100%;
  margin: 0 auto;
  position: relative;
  max-width: calc(100vw - (5rem * 2) - var(--scrollbar-width));
}
@media (max-width: 1299px) {
  .container {
    max-width: calc(100vw - (3rem * 2) - var(--scrollbar-width));
  }
}
@media (max-width: 1024px) {
  .container {
    max-width: calc(100vw - (2rem * 2) - var(--scrollbar-width));
  }
}
@media (max-width: 767px) {
  .container {
    max-width: calc(100vw - (25px * 2) - var(--scrollbar-width));
  }
}
@media (max-width: 500px) {
  .container {
    max-width: calc(100vw - (1rem * 2) - var(--scrollbar-width));
  }
}
.container .container {
  padding-left: 0;
  padding-right: 0;
}
.container.wide {
  width: calc(90rem);
}
.container.narrow {
  width: calc(60rem);
}
.container.full {
  width: 100%;
  max-width: 100%;
}
.container.full > .container.full:not(.force) {
  padding-left: 0;
  padding-right: 0;
}
.container.full.force {
  width: calc(100vw - var(--scrollbar-width));
}
.container.edge {
  width: 100vw;
  max-width: calc(100vw);
  max-width: calc(100vw - var(--scrollbar-width));
  left: 50%;
  position: relative;
  transform: translateX(-50%);
  margin-left: 0;
  margin-right: 0;
}
.container.edge.full {
  width: 100vw;
  max-width: 100vw;
}
.container.force {
  max-width: 100vw;
  left: 50%;
  position: relative;
  transform: translateX(-50%);
  margin-left: 0;
  margin-right: 0;
}

/* pad an element, pushing content in to align with the main container - this needs to be updated to match global padding settings*/
.padLeft {
  padding-left: calc((100vw - 80rem) / 2) !important;
  padding-left: calc((100vw - 80rem - var(--scrollbar-width)) / 2) !important;
}
@media (max-width: 1574px) {
  .padLeft {
    padding-left: 4rem !important;
  }
}
@media (max-width: 1299px) {
  .padLeft {
    padding-left: 3rem !important;
  }
}
@media (max-width: 1024px) {
  .padLeft {
    padding-left: 2rem !important;
  }
}
@media (max-width: 767px) {
  .padLeft {
    padding-left: 25px !important;
  }
}
@media (max-width: 500px) {
  .padLeft {
    padding-left: 1rem !important;
  }
}

.padRight {
  padding-right: calc((100vw - 80rem) / 2) !important;
  padding-right: calc((100vw - 80rem - var(--scrollbar-width)) / 2) !important;
}
@media (max-width: 1574px) {
  .padRight {
    padding-right: 4rem !important;
  }
}
@media (max-width: 1299px) {
  .padRight {
    padding-right: 3rem !important;
  }
}
@media (max-width: 1024px) {
  .padRight {
    padding-right: 2rem !important;
  }
}
@media (max-width: 767px) {
  .padRight {
    padding-right: 25px !important;
  }
}
@media (max-width: 500px) {
  .padRight {
    padding-right: 1rem !important;
  }
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Site Header */
/****************************************************************************************************/
#header {
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  position: absolute;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
#header.up {
  position: fixed;
  animation: header-slide-in 300ms ease;
  width: 100%;
  background-color: rgba(201, 209, 212, 0.8);
}
#header .searchHiddenWrapper {
  /* refer to "region Site Search" styles below */
  display: none;
}
#header .topHeader {
  position: relative;
  padding: 1.5rem 0;
}
#header .topHeader p {
  margin: 0;
}
#header .topHeader .topHeaderGrid .logo img {
  width: 100%;
  height: auto;
  min-width: 150px;
}
#header .topHeader .topHeaderGrid .topHeaderGridRight {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
}
#header .topHeader .topHeaderGrid .topHeaderGridRight .navigation {
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  gap: 1rem;
}
#header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent {
  color: #0C3242;
}
#header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent a {
  color: #0C3242;
  margin: 0 0.5rem;
}
#header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent a:hover {
  color: #000;
  text-decoration: none;
}
@media (max-width: 767px) {
  #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .findALawyer {
    display: none;
  }
}
#header .header {
  padding: 0;
  z-index: 100;
  color: white;
  position: relative;
  background-color: white;
}
#header .header .menu {
  display: flex;
  justify-content: center;
  flex-direction: row;
  align-items: flex-end;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Page Topper (Banner) */
/****************************************************************************************************/
/* Usually nested in the topper */
.topperSection {
  position: relative;
  margin: 0;
  background-color: #0C3242;
  background-image: linear-gradient(10deg, rgba(100, 134, 156, 0.2) 73%, transparent calc(73% + 1px)), linear-gradient(-18deg, rgba(190, 199, 203, 0.2) 63%, transparent calc(63% + 1px));
  background-size: 100% 300%;
}
@media (max-width: 1599px) {
  .topperSection {
    background-image: linear-gradient(10deg, rgba(100, 134, 156, 0.2) 73%, transparent calc(73% + 1px)), linear-gradient(-23deg, rgba(190, 199, 203, 0.2) 63%, transparent calc(63% + 1px));
  }
}
@media (max-width: 1024px) {
  .topperSection {
    background-image: linear-gradient(19deg, rgba(100, 134, 156, 0.2) 73%, transparent calc(73% + 1px)), linear-gradient(-26deg, rgba(190, 199, 203, 0.2) 66%, transparent calc(66% + 1px));
  }
}
@media (max-width: 767px) {
  .topperSection {
    background-image: linear-gradient(27deg, rgba(100, 134, 156, 0.2) 73%, transparent calc(73% + 1px)), linear-gradient(-26deg, rgba(190, 199, 203, 0.2) 66%, transparent calc(66% + 1px));
  }
}
.detailPage:not(.simple) .topperSection {
  background-color: #0C3242;
  background-image: none;
}
.topperSection .topperContent {
  padding: 6rem 0 1rem;
  text-align: left;
}
.topperSection .topperContent .meta {
  text-transform: uppercase;
  font-size: 0.8rem;
}
.topperSection .topperContent .meta .contentTypeLabels {
  color: #fff;
  font-size: inherit;
}
.topperSection .topperContent .meta .dates {
  color: #fff;
}
.topperSection .topperContent .meta .separator {
  margin: 0 0.4rem;
  color: #fff;
}
.topperSection .topperContent .authorTeam {
  color: #fff;
  margin-bottom: 1rem;
}
.topperSection .topperContent .authorTeam a {
  color: #fff;
  text-decoration: none;
  font-weight: bold;
}
.topperSection .topperContent h1 {
  font-size: 4rem;
  margin-top: 0;
  color: #fff;
}
.topperSection .topperContent hr {
  margin: 2rem 0 0;
}
.topperSection:has(.topperImage) {
  overflow: hidden;
  min-height: 500px;
}
.topperSection:has(.topperImage) .topperImage {
  position: absolute;
  height: 100%;
  width: 100%;
}
.topperSection:has(.topperImage) .topperImage .imgWrapper {
  height: 100%;
  width: 100%;
}
.topperSection:has(.topperImage) .topperImage .imgWrapper:after {
  top: 0;
  left: 0;
  width: 100%;
  height: 200%;
  content: "";
  z-index: 0;
  position: absolute;
  mix-blend-mode: darken;
  filter: saturate(1.5);
  background: radial-gradient(circle at 85% 25%, rgba(12, 50, 66, 0) 15%, #0C3242 42%, #0C3242 100%);
}
.topperSection:has(.topperImage) .topperContent h1 {
  color: #fff;
}
.topperSection:has(.topperImage) .topperContent .meta {
  color: #BEC7CB;
}
.topperSectionBottom h2 {
  margin: 0;
}
.topperSectionBottom .meta {
  font-size: 0.8rem;
}
.topperSectionBottom .meta .contentTypeLabels {
  font-size: inherit;
}
.topperSectionBottom .meta h3 {
  margin-bottom: 0;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Site Main Content */
/****************************************************************************************************/
main .bd .breadCrumbInner {
  padding: 2rem 0;
  font-size: 0.7rem;
  display: flex;
}
main .bd .breadCrumbInner a {
  color: #555555;
  text-decoration: none;
  font-weight: 400;
}
main .bd .breadCrumbInner > *:last-child {
  color: #0C3242;
}
main .bd .breadCrumbInner > *:not(:last-child) {
  color: #555555;
  font-weight: 400;
}
main .bd .breadCrumbInner > *:not(:last-child):hover, main .bd .breadCrumbInner > *:not(:last-child):focus {
  text-decoration: underline;
}
main .bd .breadCrumbInner span.separator {
  margin: 0 0.6em;
}
main .bd .mainContent {
  padding: 0 0 3rem;
}
main .bd .mainContent .sfContentBlock img {
  max-width: 100%;
}
main .bd .sideContent h2 {
  border-bottom: solid 1px #0C3242;
  font-size: 2rem;
  margin-top: 1.4rem;
}
main .bd .sideContent .cardView.expertise h3 a {
  color: #0C3242;
  font-weight: 300;
}
main .bd .sideContent .cardView.expertise h3 a:hover {
  text-decoration: underline;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Site Footer */
/****************************************************************************************************/
/* all footer sections */
/* NOTE USE mixin utility classes of mvxl or pvxl etc on Templates to contol padding and margins */
.siteFooter {
  position: relative;
  z-index: 1;
}
.siteFooter .preFooter {
  background-color: rgba(190, 199, 203, 0.1);
}
.siteFooter .mainFooter {
  background-color: #0C3242;
  font-size: 80%;
}
.siteFooter .mainFooter .cmsContent a {
  font-weight: normal;
}
.siteFooter .mainFooter .cmsContent p {
  margin: 0;
  margin-top: 0.5rem;
  line-height: 1.2;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterLeft h4 {
  text-transform: uppercase;
  margin-bottom: 0.75rem;
  font-size: 0.9rem;
  font-weight: 700;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterMiddle nav.topLevelSimple ul li {
  margin-top: 0.5rem;
  line-height: 1;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterMiddle nav.topLevelSimple ul li a {
  font-size: 0.7rem;
  margin-right: 1rem;
  opacity: 1;
  letter-spacing: 0.1rem;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterMiddle nav.topLevelSimple ul li:last-of-type {
  display: none;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .socials .cmsContent {
  display: flex;
  gap: 1rem;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .socials .cmsContent .button {
  width: 100%;
  max-width: 300px;
  background-color: #0C3242;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .socials .cmsContent .socialLinks li:first-of-type {
  font-size: 0.7rem;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  padding-top: 0.4rem;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .socials .cmsContent .socialLinks li:not(li:first-of-type) + li {
  border-left: solid 1px #BEC7CB;
  padding-left: 0.75rem;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .logo a {
  display: flex;
  justify-content: flex-end;
}
.siteFooter .mainFooter .mainFooterGrid .mainFooterRight .logo a img {
  width: 100%;
  max-width: 250px;
}
.siteFooter .copyrightFooter .container.full {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Sticky Sidebar (Scroll Nav) */
/****************************************************************************************************/
.sticky-wrapper {
  position: relative;
}

.stickySidebar {
  padding: 0;
  position: relative;
  height: calc(100vh - 300px);
  overflow: auto;
  display: flex;
  width: 100%;
  justify-content: flex-start;
}
.stickySidebar.stuck {
  position: fixed;
  top: 250px;
  z-index: 10;
}
.stickySidebar ul.scrollingSideBar {
  padding: 1.5rem;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px;
}
.stickySidebar ul.scrollingSideBar li {
  position: relative;
  padding: 0.4rem 0;
}
.stickySidebar ul.scrollingSideBar li a {
  padding: 0 1.5rem 0 0;
  font-size: 1rem;
  color: #0D0D0D;
  text-decoration: none;
  display: block;
  width: 100%;
}
.stickySidebar ul.scrollingSideBar li a:focus, .stickySidebar ul.scrollingSideBar li a:hover, .stickySidebar ul.scrollingSideBar li a:active {
  color: #0D0D0D;
  padding: 0 0 0 1.5rem;
  font-weight: 600;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.stickySidebar ul.scrollingSideBar li a:focus:before, .stickySidebar ul.scrollingSideBar li a:hover:before, .stickySidebar ul.scrollingSideBar li a:active:before {
  content: "";
  position: absolute;
  width: 0.4rem;
  height: 0.4rem;
  top: 50%;
  left: 0%;
  transform: rotate(180deg) translateX(-50%) translateY(50%);
  background-size: 100% auto;
  background-position: center;
  background-image: url(/CFImages/Icons/chevron-right-secondary.svg);
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Universal Styles - Shared across cardViews and detailViews */
/****************************************************************************************************/
.audioButton {
  padding: 0rem;
}

.audioPlayerWrapper .playAudio {
  border: none;
  border-radius: 3px;
  cursor: pointer;
  margin: 0;
  padding: 0;
  color: #000 !important;
  display: inline;
  font-size: 1.3rem;
  background-color: transparent !important;
}
.audioPlayerWrapper .playAudio:before {
  background-color: transparent;
}
.audioPlayerWrapper .playAudio:hover, .audioPlayerWrapper .playAudio:active {
  opacity: 0.8;
}

.viewMoreOuter {
  margin: 0rem auto 3rem;
  text-align: center;
}

/* #region Dates */
span.dates {
  /*text-transform: uppercase;*/
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}
span.dates time {
  font-size: inherit;
  /*text-transform: uppercase;*/
}

/* #endregion */
/* #region Content Type Labels */
.contentTypeLabels {
  color: #0C3242;
  display: inline-block;
  font-family: Founders-Grotesk-Light, "Arial", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.35em;
  letter-spacing: 0.15em;
  font-size: 0.7rem;
}
.contentTypeLabels span.labelValuesSeperator:before {
  content: ": ";
}
.contentTypeLabels a {
  color: inherit;
  text-decoration: none;
}
.contentTypeLabels span.subType {
  display: inline-block;
}

.meta {
  color: #0C3242;
  font-weight: 700;
  font-size: 0.9rem;
  margin-bottom: 0.6rem;
}
.meta .separator {
  color: inherit;
  margin: 0 0.2rem;
}

/* #endregion */
/* #region Iframes + Videos + Embeds */
.embedWrapper {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  padding-top: 25px;
  height: 0;
}
.embedWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* #endregion */
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Social & Sharing Links */
/****************************************************************************************************/
.printAndShare {
  display: flex;
}

ul.socialLinks, .cmsContent ul.socialLinks {
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: -0.5rem;
  margin-right: -0.5rem;
  box-sizing: border-box;
  font-size: 1.2rem;
  flex-wrap: nowrap;
  justify-content: flex-start;
  list-style: none;
  margin: 0;
}
ul.socialLinks > li, .cmsContent ul.socialLinks > li {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
  vertical-align: top;
  flex: 0 1 auto;
  width: auto;
}
ul.socialLinks li, .cmsContent ul.socialLinks li {
  list-style: none;
  margin-bottom: 0;
  display: flex;
  align-items: center;
}
ul.socialLinks li:first-child, .cmsContent ul.socialLinks li:first-child {
  margin-left: 0;
}
ul.socialLinks li:not(li:first-of-type) + li, .cmsContent ul.socialLinks li:not(li:first-of-type) + li {
  border-left: solid 1px #CCCCCC;
  padding-left: 0.75rem;
}

/** ShareThis (social sharing links) *****************************************************************/
.shareThis .sharingLinks {
  display: none;
}

ul.sharingLinks {
  background-color: white;
  display: flex;
  padding: 0 1rem 1rem 0.5rem;
}
ul.sharingLinks li button {
  cursor: pointer;
  border: none;
  padding: 0;
  background-color: transparent;
  background-image: none;
  color: #A3A3A3;
  font-size: 0.5rem;
  text-transform: capitalize !important;
}
ul.sharingLinks li button svg {
  font-size: 0.5rem;
  margin-right: 0.5rem;
}
ul.sharingLinks li button i {
  color: inherit;
}
ul.sharingLinks li button:hover, ul.sharingLinks li button:focus ul.sharingLinks li button:active {
  color: #707070;
  background-color: transparent;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Sliders - .sliderView  Currently using SPLIDE */
/****************************************************************************************************/
/* Splide sliders */
.splide {
  visibility: visible;
  /* Show only the first slide ONLY until the slider is initialized */
  /* slider initialized */
  /* Arrows */
}
.splide:not(.is-active) .splide__list {
  width: 100%;
}
.splide:not(.is-active) .splide__slide {
  width: 100%;
  display: flex;
}
.splide:not(.is-active) .splide__slide:not(:first-child) {
  display: none;
}
.splide:not(.is-active) .splide__arrow {
  display: none;
}
.splide.is-active .splide__slide {
  display: flex;
}
.splide .splide__list.sliderView > li.splide__slide {
  margin: 0;
  width: auto;
}
.splide .splide__arrow {
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: transparent;
  color: white;
}
.splide .splide__arrow.splide__arrow--next svg {
  transform: translateX(10%);
  margin-left: 0;
}
.splide .splide__arrow.splide__arrow--prev svg {
  transform: translateX(-10%);
  margin-left: 0;
}
.splide.wrapper {
  position: relative;
}
.splide .sliderFooter {
  position: relative;
  display: flex;
  justify-content: flex-end;
  margin-top: 2rem;
}
.splide .sliderFooter:has(.viewAllMoreWrapper) {
  justify-content: space-between;
}
.splide .sliderFooter .splide__arrows {
  display: flex;
  align-self: flex-end;
}
.splide .sliderFooter .splide__arrows .splide__arrow {
  position: relative;
  border: solid 1px #0C3242;
  border-radius: inherit;
  /*height: 50px;
  width: 50px;*/
  margin: 0 0 0 0.5rem;
  padding: 0.9rem;
  color: #0C3242 !important;
  transform: none;
}
.splide .sliderFooter .splide__arrows .splide__arrow:before {
  background-color: transparent;
}
.primaryWrapper .splide .sliderFooter .splide__arrows .splide__arrow {
  color: #fff;
  border: solid 1px #fff;
}
.splide .sliderFooter .splide__arrows .splide__arrow:hover {
  background-color: #BEC7CB;
  border-color: #BEC7CB;
  color: #0C3242;
}
.splide .sliderFooter .splide__arrows .splide__arrow.splide__arrow--next {
  right: 0;
}
.splide .sliderFooter .splide__arrows .splide__arrow.splide__arrow--prev {
  left: 0;
}
.splide .sliderFooter .splide__arrows .splide__arrow svg {
  margin-left: 0;
}
.splide .sliderFooter .splide__arrows.hiddenArrows {
  display: none;
}
.splide .sliderFooter .viewAllMoreWrapper {
  text-align: left;
}

.splide.rankingsWrapper .splide__track, .splide.insightsWrapper .splide__track {
  border-right: solid 1px #CCCCCC;
}
.splide.rankingsWrapper .slide.is-visible, .splide.insightsWrapper .slide.is-visible {
  border-left: solid 1px #CCCCCC;
}

.slider .slide {
  min-height: 500px;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Single Slide Styles */
/****************************************************************************************************/
.slide article .innerContent {
  position: relative;
  height: 100%;
}
.slide article .innerContent .itemImage {
  position: relative;
}
.slide article .innerContent .itemImage .bgImgWrapper:before {
  /* sets the height and then effectively removes itself from flow so as not to interfere with siblings */
  float: left;
  width: 1px;
  height: 0;
  content: "";
  margin-left: -1px;
  padding-top: 56.25%;
}
.slide article .innerContent .itemImage .bgImgWrapper:after {
  /* to clear float */
  content: "";
  display: table;
  clear: both;
}
.slide article .innerContent .itemImage .bgImgWrapper a {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  position: absolute;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Home Slider Only */
/****************************************************************************************************/
.homeSlideshow {
  position: relative;
  background-color: #0C3242;
}
.homeSlideshow .splide__arrows {
  display: none;
}
.homeSlideshow ul.splide__pagination {
  width: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  right: initial;
  bottom: initial;
  transform: translateX(-50%) translateY(-100%);
  display: flex;
  flex-direction: column;
  width: 80rem;
  align-items: flex-end;
  max-width: calc(100% - 4rem);
}
.homeSlideshow ul.splide__pagination li .splide__pagination__page {
  width: 0.5rem;
  height: 0.5rem;
  margin: 0.5rem 0;
  background-color: #A3A3A3;
}
.homeSlideshow ul.splide__pagination li .splide__pagination__page.is-active {
  /* transform: scale(1);
  min-height: 30rem;
  background-color: $primaryColour;*/
}
.homeSlideshow .splide__slide {
  position: relative;
  height: calc(100vh - 122px);
  min-height: 30rem;
  padding: 3rem 0;
}
.homeSlideshow .splide__slide .cardContent {
  height: 100%;
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  /*opacity: 0;*/
  overflow: hidden;
  margin-top: calc(-122px / 2);
  margin-right: 4rem;
}
.homeSlideshow .splide__slide .cardContent h1 {
  color: #BEC7CB;
  font-size: 4rem;
  font-weight: 300;
  margin-bottom: 0;
}
.homeSlideshow .splide__slide .cardContent h1 .showFirst {
  opacity: 0;
}
.homeSlideshow .splide__slide .cardContent h1 .showSecond {
  opacity: 0;
}
.homeSlideshow .splide__slide .cardContent h2 {
  opacity: 0;
  color: #fff;
  margin: 0;
  font-style: italic;
  font-size: 4rem;
  padding-right: 1rem;
}
.homeSlideshow .splide__slide .cardContent .summary {
  font-size: 1.4rem;
  font-weight: 100;
  width: 50rem;
  text-align: center;
}
.homeSlideshow .splide__slide .cardContent .button {
  margin-top: 2rem;
  opacity: 0;
}
.homeSlideshow .splide__slide.is-active .cardContent h1 .showSecond {
  opacity: 1;
  transition: opacity 1s ease 0.4s;
}
.homeSlideshow .splide__slide.is-active .cardContent .clip {
  overflow: hidden;
}
.homeSlideshow .splide__slide.is-active .cardContent h2.slide-up {
  opacity: 1;
  animation: 0.75s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1.3s 1 normal both running slide-up;
}
.homeSlideshow .splide__slide.is-active .cardContent .button {
  opacity: 1;
  transition: opacity 1s ease 2.7s;
}
.homeSlideshow .splide__slide.is-active .cardContent.delay h1 .showFirst {
  opacity: 1;
  transition: opacity 1s ease 0.4s;
}
.homeSlideshow .splide__slide.is-active .cardContent.delay h1 .showSecond {
  transition: opacity 1s ease 1.15s;
}
.homeSlideshow .splide__slide.is-active .cardContent.delay h2.slide-up {
  animation: 0.75s cubic-bezier(0.25, 0.46, 0.45, 0.94) 2s 1 normal both running slide-up;
}
.homeSlideshow .splide__slide.is-active .cardContent.delay .button {
  transition: opacity 1s ease 3.25s;
}
.homeSlideshow .button.arrowOnly {
  position: absolute;
  bottom: 4rem;
  left: 50%;
  border: none;
  padding: 0;
  font-size: 2rem;
  animation-name: bounceInSmall;
  animation-duration: 3s;
  animation-delay: 0s;
  animation-timing-function: ease;
  animation-fill-mode: both;
  backface-visibility: hidden;
  animation-iteration-count: infinite;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region LIST VIEWS - .listView THIS ONLY CONTROL THE GRIDS and number of ITEMS - NOT THE CARDS */
/****************************************************************************************************/
.listView {
  display: grid;
  position: relative;
  grid-template-columns: repeat(auto-fill, minmax(min(var(--card-width), 100%), 1fr));
  gap: var(--card-gap);
  margin-bottom: 2rem;
  --listViewArticleIndex: none;
}

/* ### Content Specific Sizing of Grids if required exact dimensions can be paired with default or fixedSizeScales or .fixedSize ### */
/* fixedSize class is a card that has a fixed pixel width that never scales and only wraps (should always be less than 320px) */
.listView.fixedSize {
  grid-template-columns: repeat(auto-fill, minmax(var(--card-width), var(--card-width)));
}

.listView.fixedSizeScales {
  grid-template-columns: repeat(auto-fit, minmax(min(var(--card-width), 100%), 1fr));
}

/* defined number of columns class */
.listView.gridCols {
  grid-template-columns: repeat(var(--column-count), 1fr);
}

.listView.gridCols.oneCol {
  --column-count: 1;
}

.listView.gridCols.twoCol {
  --column-count: 2;
}

.listView.gridCols.threeCol {
  --column-count: 3;
}

.listView.gridCols.fourCol {
  --column-count: 4;
}

.listView.gridCols.fiveCol {
  --column-count: 5;
}

.listView.gridCols.sixCol {
  --column-count: 6;
}

/* Responsive resizing of gridsCols */
@media (max-width: 1299px) {
  .listView.gridCols {
    /* Go down to 4 */
    /* Go down to 3 */
  }
  .listView.gridCols.fiveCol, .listView.gridCols.sixCol {
    --column-count: 4;
  }
  .listView.gridCols.fourCol {
    --column-count: 3;
  }
}
@media (max-width: 1024px) {
  /* Go down to 3 */
  .listView.gridCols.fiveCol, .listView.gridCols.sixCol {
    --column-count: 3;
  }

  /* Go down to 2 */
  .listView.gridCols.fourCol, .listView.gridCols.threeCol {
    --column-count: 2;
  }
}
@media (max-width: 767px) {
  /* Go down to 2 */
  .listView.gridCols.fiveCol, .listView.gridCols.sixCol {
    --column-count: 2;
  }
}
@media (max-width: 500px) {
  /* Go down to 1 */
  .listView.gridCols.twoCol, .listView.gridCols.threeCol, .listView.gridCols.fourCol, .listView.gridCols.fiveCol, .listView.gridCols.sixCol {
    --column-count: 1;
  }
}
/****************************************************************************************************/
/****************************************************************************************************/
/* #region CARDS - .cardView */
/****************************************************************************************************/
/* Card View Animations */
.listView.insights, .listView.rankings {
  --card-gap: 2rem 0;
}
.listView.insights li, .listView.rankings li {
  border-left: solid 1px #CCCCCC;
  border-right: solid 1px #CCCCCC;
  margin-left: -1px !important;
}
.listView.insights li:first-of-type, .listView.rankings li:first-of-type {
  margin-left: 0;
}

/* Shared/Common Card Views Styles */
.cardView {
  height: 100%;
  width: 100%;
  /* Title */
  /* Dates */
  /* Authors */
  /* Summary */
}
.cardView h3 {
  color: #0C3242;
}
.cardView h3 a {
  color: #0C3242;
  text-decoration: none;
}
.cardView .cardContent {
  padding: 1.5rem;
}

.cardView.imageCard {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-radius: 5px;
  box-shadow: 0 20px 40px -14px rgba(0, 0, 0, 0.25);
}
.cardView.imageCard .imgWrapper {
  position: relative;
  max-height: 250px;
  overflow: hidden;
}
.cardView.imageCard .imgWrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1.4;
}
.cardView.imageCard span.featured {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  padding: 4px 8px;
  border-radius: 0.25rem;
  background-color: #0C3242;
  font-size: 0.9rem;
  color: #fff;
  text-transform: uppercase;
}
.cardView.imageCard .cardContent {
  position: relative;
  padding: 1.5rem 1rem;
}
.cardView.imageCard.withScrollbar {
  /* scrollbar option*/
}
.cardView.imageCard.withScrollbar .cardContent {
  margin: 1.5rem 0.75rem 1.5rem 0.25rem;
  padding-top: 0;
  max-height: 400px;
  overflow-y: scroll;
}
.cardView.imageCard.withScrollbar .cardContent::-webkit-scrollbar {
  width: 0.375rem;
}
.cardView.imageCard.withScrollbar .cardContent::-webkit-scrollbar-track {
  box-shadow: 0;
  border-radius: 1rem;
}
.cardView.imageCard.withScrollbar .cardContent::-webkit-scrollbar-thumb {
  background: #CCCCCC;
  border-radius: 1rem;
}
.cardView.imageCard:hover .imgWrapper img {
  transition: all 0.6s ease;
  transform: scale(1.2);
}

.cardView.imageOverlayCard {
  position: relative;
  height: 100%;
  min-height: 200px;
}
.cardView.imageOverlayCard .overlayWrapper {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
  /* zoom in the image */
}
.cardView.imageOverlayCard .overlayWrapper .imgWrapper {
  width: 100%;
  height: 100%;
}
.cardView.imageOverlayCard .overlayWrapper .imgWrapper img {
  transition: all 0.6s ease;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 0%;
     object-position: 50% 0%;
}
.cardView.imageOverlayCard .overlayWrapper:hover .imgWrapper img {
  transform: scale(1.2);
}
.cardView.imageOverlayCard .overlayWrapper .overlay {
  position: absolute;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
/* Content Specfic Card Views Styles */
/* Team Card View */
.cardView.teammember {
  /* content wrapper  */
}
.cardView.teammember .hoverWrapper {
  position: relative;
  overflow: hidden;
  --teamCardFontSize: 2.3rem;
}
.cardView.teammember .hoverWrapper .hoverContent {
  position: absolute;
  width: 100%;
  top: calc(100% - (2 * var(--teamCardFontSize)) - 2rem);
  padding: 1rem 1rem;
  opacity: 1;
  z-index: 2;
  background: linear-gradient(0deg, #0c3242 0%, rgba(12, 50, 66, 0) 98%);
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  /* designations */
  /* audio */
  /* position */
  /* email & phone etc */
}
.cardView.teammember .hoverWrapper .hoverContent h3 {
  font-size: var(--teamCardFontSize);
  color: #fff;
  margin: 0 0 1rem 0;
  /* word-spacing: 100vw;*/
  color: #fff;
  line-height: 1;
}
.cardView.teammember .hoverWrapper .hoverContent h3 a {
  color: #fff;
}
.cardView.teammember .hoverWrapper .hoverContent .designations {
  color: #0C3242;
  display: block;
  margin: 0;
  padding-left: 1rem;
}
.cardView.teammember .hoverWrapper .hoverContent .audioPlayerWrapper .playAudio {
  font-size: 1.1rem;
}
.cardView.teammember .hoverWrapper .hoverContent .position {
  color: #0C3242;
  display: block;
  margin-bottom: 1rem;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  padding-bottom: 1rem;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo li {
  font-size: 0.9rem;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo li .prefixLabel {
  font-weight: 700;
  color: #fff;
  display: inline-block;
  margin-right: 0.3em;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo li a {
  font-family: inherit;
  color: #fff;
  text-decoration: none;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo li a:focus, .cardView.teammember .hoverWrapper .hoverContent .contactInfo li a:hover {
  text-decoration: none;
}
.cardView.teammember .hoverWrapper .hoverContent .contactInfo li a:active {
  text-decoration: none;
}
.cardView.teammember .hoverWrapper:hover .hoverContent {
  top: inherit;
  bottom: 0;
}
.cardView.teammember .cardContent {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 0 1rem;
}
.cardView.teammember .spaceFiller {
  height: 1.5rem;
}

/* Expertise: Card View*/
.cardView.expertise {
  border-bottom: solid 1px #0C3242;
}
.cardView.expertise h3 {
  color: #0C3242;
  margin-top: 0;
  padding-bottom: 1rem;
  text-decoration: none;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  height: 100%;
}
.cardView.expertise h3 a {
  color: inherit;
  text-decoration: none;
}
.cardView.expertise h3 a:focus, .cardView.expertise h3 a:hover {
  color: black;
}
.cardView.expertise h3 a:active {
  color: black;
}
.cardView.expertise h3:hover svg {
  transform: rotate(45deg);
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.cardView.expertise h3 svg {
  font-size: 0.9rem;
  padding-bottom: 0.25rem;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}

/* Insight CardView */
.cardView.insight, .cardView.ranking {
  padding: 1rem 1.5rem 1.5rem 1rem;
  overflow: hidden;
  position: relative;
  z-index: 1;
  color: #0C3242;
}
.cardView.insight .dates, .cardView.ranking .dates {
  font-size: 0.8rem;
  color: #0C3242;
}
.cardView.insight:after, .cardView.ranking:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 100%;
  background: #0C3242;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-15deg);
  transition: transform 0.25s;
}
.cardView.insight:before, .cardView.ranking:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 98%;
  height: 100%;
  background: #0C3242;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(200%) skewX(-15deg);
  transition: transform 0.5s;
  background-color: #BEC7CB;
}
.cardView.insight:hover:before, .cardView.ranking:hover:before {
  transform: translateX(90%) skewX(-15deg);
}
.cardView.insight:hover:after, .cardView.ranking:hover:after {
  transform: translateX(0) skewX(-15deg);
}
.cardView.insight:hover, .cardView.ranking:hover {
  color: #fff;
}
.cardView.insight:hover h3 a, .cardView.ranking:hover h3 a {
  color: #fff;
}
.cardView.insight:hover .dates, .cardView.ranking:hover .dates {
  font-size: 0.8rem;
  color: #fff;
}
.cardView.insight:hover .contentTypeLabels, .cardView.ranking:hover .contentTypeLabels {
  color: #fff;
}

.cardView.insight.case h3 {
  font-weight: 700;
}

/* Ranking CardView */
.cardView.ranking {
  margin: 0;
  position: relative;
  padding: 2rem;
  position: relative;
}
.cardView.ranking .cardContent {
  display: flex;
  flex-direction: column;
  padding: 1rem 0.25rem;
  /* optional item */
}
.cardView.ranking .cardContent span {
  display: block;
  margin: 0;
}
.cardView.ranking .cardContent h3.rankingAccolade {
  margin: 0.5rem 0;
}
.cardView.ranking .cardContent span.yearAwarded {
  position: absolute;
  bottom: 1rem;
}
.cardView.ranking:hover .cardContent {
  color: #fff;
}
.cardView.ranking:hover .cardContent span.rankingPublisher {
  color: #fff;
}
.cardView.ranking:hover .cardContent h3.rankingAccolade {
  color: #fff;
}

/* Testimonial CardView */
.cardView.testimonial blockquote {
  margin: 0;
}
.cardView.testimonial blockquote cite {
  display: block;
  margin-top: 1.4rem;
  font-size: 1rem;
}

/* Global Alert CardView */
.cardView.globalalert {
  padding: 0.5rem 0;
  position: relative;
  display: flex;
  align-items: center;
}
.cardView.globalalert .alertIcon {
  padding-right: 1rem;
}
.cardView.globalalert .alertIcon svg {
  font-size: 1.2rem;
  color: white;
}
.cardView.globalalert .alertContent a.alertLabelLink {
  text-decoration: underline;
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.9rem;
}
.cardView.globalalert .alertContent .optionalContent {
  font-size: 0.8rem;
}
.cardView.globalalert .alertContent .optionalContent p {
  margin: 0;
  font-size: 0.8rem;
}
.cardView.globalalert .alertContent .optionalContent a {
  text-decoration: underline;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region DETAIL VIEWS - .detailView */
/****************************************************************************************************/
/* Shared detailView Styles */
.detailView {
  /* Social */
}
.detailView .overview {
  margin-top: 0;
}
.detailView .overview .readMoreButtonWrapper {
  margin-top: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.detailView .overview .readMoreButtonWrapper .toggleReadMore {
  margin: 0 auto;
}
.detailView div.socialAndSharing {
  display: flex;
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: -0.5rem;
  margin-right: -0.5rem;
  box-sizing: border-box;
  padding: 1rem 0;
}
.detailView div.socialAndSharing > ul {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
  vertical-align: top;
  flex: 0 1 auto;
  width: auto;
}
.detailView div.socialAndSharing ul.socialLinks {
  font-size: 1.8rem;
}
.detailView div.socialAndSharing ul.socialLinks li {
  align-items: flex-end;
}
.detailView div.socialAndSharing ul.socialLinks li + li {
  border-left: solid 1px #BEC7CB;
  padding-left: 0.75rem;
}
.detailView div.socialAndSharing ul.sharingLinks {
  font-size: 1.8rem;
}
.detailView div.socialAndSharing ul.sharingLinks li {
  align-items: flex-end;
}
.detailView .sidebarGrid {
  display: flex;
  justify-content: flex-start;
  align-content: flex-start;
}
.detailView .sidebarGrid .mainContent {
  width: calc(100% - 30%);
  min-width: calc(100% - 450px);
  background-color: #EDEEEF;
  padding-right: 4rem;
  padding-bottom: 0;
}
.detailView .sidebarGrid .mainContent > :first-child {
  margin-top: 2rem;
}
.detailView .sidebarGrid .sideContent {
  width: 100%;
  min-width: 350px;
  padding-left: 2rem;
  padding: 5rem 0 2rem 2rem;
}
.detailView .sidebarGrid .sideContent .sideContentInner > :first-child {
  margin-top: 2rem;
}
.detailView .sidebarGrid .sideContent .sideContentInner > :last-child {
  margin-bottom: 4rem;
}
.detailView .sidebarGrid.small .mainContent {
  width: calc(100% - 100px);
  min-width: calc(100% - 150px);
}
.detailView .sidebarGrid.small .sideContent {
  padding-top: 1rem;
  min-width: 100px;
}
@media only screen and (max-width: 1024px) {
  .detailView .sidebarGrid .mainContent {
    width: calc(100% - 300px);
    min-width: calc(100% - 300px);
  }
  .detailView .sidebarGrid .sideContent {
    width: 100%;
    min-width: 300px;
  }
}
@media only screen and (max-width: 767px) {
  .detailView .sidebarGrid {
    flex-direction: column;
  }
  .detailView .sidebarGrid .mainContent {
    width: 100% !important;
    min-width: 100%;
    padding-right: 0 !important;
  }
  .detailView .sidebarGrid .sideContent {
    width: 100% !important;
    min-width: 100%;
    padding: 0;
  }
}

/* Content Specfic detailView Styles */
/* Team Detail View */
.detailView.teammember .bioTopContent {
  position: relative;
  width: 100%;
  display: block;
  color: #fff;
  overflow: hidden;
  z-index: 1;
  box-shadow: 0px 12px 17px -14px rgba(0, 0, 0, 0.81);
}
.detailView.teammember .bioTopContent .bioMobileButtons {
  visibility: hidden;
  position: absolute;
  top: 2rem;
  right: 1rem;
  z-index: 5;
}
@media only screen and (max-width: 650px) {
  .detailView.teammember .bioTopContent .bioMobileButtons {
    visibility: visible;
  }
  .detailView.teammember .bioTopContent .bioMobileButtons a {
    background-color: #0C3242;
    border-radius: 100%;
    height: 2rem;
    width: 2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 0.5rem;
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  }
  .detailView.teammember .bioTopContent .bioMobileButtons a:before {
    content: none;
  }
  .detailView.teammember .bioTopContent .bioMobileButtons a svg {
    color: #fff;
  }
  .detailView.teammember .bioTopContent .bioMobileButtons a:hover {
    transform: scale(1.2);
  }
}
.detailView.teammember .bioTopContent .bioPhotoWrapper {
  flex: auto;
  display: flex;
  flex-direction: row-reverse;
  width: 100%;
  flex-basis: auto;
  background: linear-gradient(25deg, #CCCCCC 0%, #EDEEEF 100%);
  position: relative;
}
.detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper {
  width: 60%;
  max-height: 800px;
}
.detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper img {
  aspect-ratio: 1;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 15%);
          mask-image: linear-gradient(to right, transparent 0%, black 15%);
  -o-object-position: 0 0%;
     object-position: 0 0%;
}
.detailView.teammember .bioTopContent .bioContact {
  position: absolute;
  left: 5rem;
  width: 60%;
  color: #0C3242;
  display: flex;
  flex-direction: column;
  font-size: 90%;
  top: 50%;
  transform: translatey(-50%);
}
.detailView.teammember .bioTopContent .bioContact * {
  color: inherit;
}
.detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  margin: 1rem 0 0 0;
  /* title */
  /* designations */
}
.detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1 {
  position: relative;
  font-size: 4em;
  margin: 0;
}
.detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1 span {
  font-size: 60%;
  font-weight: 300;
}
.detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1:after {
  content: none;
}
.detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation .designations {
  color: #BEC7CB;
  display: block;
  margin: 0;
}
.detailView.teammember .bioTopContent .bioContact .audioPlayerWrapper .playAudio {
  font-size: 1.1rem;
  padding: 0;
  margin: 0;
  background-color: none;
  border: none;
  color: #0C3242;
}
.detailView.teammember .bioTopContent .bioContact .audioPlayerWrapper .playAudio svg {
  color: #0C3242;
}
.detailView.teammember .bioTopContent .bioContact .audioPlayerWrapper .playAudio:after {
  content: none;
}
.detailView.teammember .bioTopContent .bioContact .audioPlayerWrapper .playAudio:before {
  content: none;
}
.detailView.teammember .bioTopContent .bioContact h2 {
  margin: 0 0 0.5rem;
}
.detailView.teammember .bioTopContent .bioContact .contactInfo {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin: 1.5rem 0 0.5rem;
}
.detailView.teammember .bioTopContent .bioContact .contactInfo .prefixLabel {
  color: #0C3242;
  font-weight: 700;
}
.detailView.teammember .bioTopContent .bioContact .professionalCorporation {
  padding-right: 2rem;
  margin-top: 1rem;
  line-height: 1;
}
.detailView.teammember .bioTopContent .bioContact .printAndShare {
  font-size: 1.5rem;
}
.detailView.teammember .bioTopContent .bioContact .printAndShare a {
  margin-right: 0.75rem;
}
.detailView.teammember .bioTopContent .bioContact .printAndShare a:hover {
  color: black;
  cursor: pointer;
}
.detailView.teammember .bioTopContent .bioContact .printAndShare a + a {
  border-left: solid 1px #0C3242;
  padding-left: 0.75rem;
}
.detailView.teammember .bioTopContent .bioContact ul.socialLinks {
  justify-content: flex-start;
}
.detailView.teammember .bioTopContent .bioContact ul.socialLinks li {
  display: inline-block;
  font-size: 1rem;
  margin-left: 0;
  margin-right: 2rem;
}
.detailView.teammember .bioTopContent .bioContact ul.socialLinks li a:hover {
  color: #0C3242;
}
.detailView.teammember .expertisesWrapper .listView {
  gap: 0;
}
.detailView.teammember .expertisesWrapper .listView li .cardView.expertise {
  border: 0;
}
.detailView.teammember .expertisesWrapper .listView li .cardView.expertise h3 {
  padding: 0;
  margin: 0;
  font-size: 1rem;
  font-family: Founders-Grotesk-Regular, "Arial", sans-serif;
}
.detailView.teammember .expertisesWrapper .listView li .cardView.expertise h3 svg {
  display: none;
}

/* #endregion */
/****************************************************************************************************/
/* Insight Detail View */
.detailView.insight .topperSection .topperContent .topperTitle h1 {
  margin-top: 0;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Expertises + Sectors  */
/****************************************************************************************************/
/* expertise tree view */
/* expertise tree view */
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Documents */
/****************************************************************************************************/
.document {
  font-size: 0.8rem;
  background-color: #F7F7F7;
}
.document a {
  width: 100%;
  display: block;
  padding: 1rem 1.4rem 0.8rem 1.4rem;
  text-decoration: none !important;
  border-bottom: 1px solid #0C3242;
  color: #0C3242;
}
.document a .iconExtension {
  width: 1.5rem;
  flex-grow: 0;
  flex-basis: auto;
  align-items: center;
  justify-content: center;
  color: #0C3242;
}
.document a .iconExtension svg {
  color: inherit;
  font-size: 2rem;
}
.document a .documentDetails .titleLink {
  margin: 0;
  padding: 0;
  font-size: 1.2rem;
}
.document a .documentDetails .grid {
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: -0.5rem;
  margin-right: -0.5rem;
  box-sizing: border-box;
  display: flex;
}
.document a .documentDetails .grid > .col {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
  vertical-align: top;
  flex: 0 1 auto;
  width: auto;
}
.document a .documentDetails span.col {
  margin: 0 1rem 0 0;
  flex-basis: auto;
  flex-grow: 0;
}
.document a .typeIcon {
  display: block;
}
.document a .hoverIcon {
  display: none;
}
.document a .textExtension {
  font-size: 1rem;
}
.document a:focus:focus-visible {
  background-color: #eaeaea;
  border-color: #BEC7CB;
}
.document a:focus:focus-visible .grid .col.iconExtension {
  color: #0C3242;
}
.document a:focus:focus-visible .grid .col.iconExtension svg.typeIcon {
  display: none;
}
.document a:focus:focus-visible .grid .col.iconExtension svg.hoverIcon {
  display: block;
}
.document a:hover {
  background-color: #eaeaea;
  border-color: #BEC7CB;
}
.document a:hover .grid .col.iconExtension {
  color: #0C3242;
}
.document a:hover .grid .col.iconExtension svg.typeIcon {
  display: none;
}
.document a:hover .grid .col.iconExtension svg.hoverIcon {
  display: block;
}

.documents {
  margin: 1rem 0;
}
.documents ul li {
  color: #0C3242;
  display: block;
  margin: 0;
  font-size: 1rem;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  background-color: transparent;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Filtered Content Items */
/****************************************************************************************************/
.fieldGroups {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 1.2rem;
}
.fieldGroups > fieldset {
  flex: 1 1 0;
  margin: 0;
  padding: 0;
  border: none;
}
.fieldGroups > fieldset legend {
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  border: 0;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute;
  background-color: #fff;
  color: #000;
}
.fieldGroups .k-dropdown {
  width: 100%;
}
.fieldGroups .k-dropdown:hover, .fieldGroups .k-dropdown.k-state-border-down {
  background-color: #0C3242;
}
.fieldGroups .k-dropdown:hover .k-dropdown-wrap, .fieldGroups .k-dropdown.k-state-border-down .k-dropdown-wrap {
  border-color: #A3A3A3;
}
.fieldGroups .k-dropdown:hover .k-dropdown-wrap .k-input, .fieldGroups .k-dropdown.k-state-border-down .k-dropdown-wrap .k-input {
  color: #fff;
}
.fieldGroups .k-dropdown:hover .k-dropdown-wrap .k-select .k-icon:before, .fieldGroups .k-dropdown.k-state-border-down .k-dropdown-wrap .k-select .k-icon:before {
  background-image: url(/CFImages/Icons/plus-white.svg);
}
.fieldGroups .k-dropdown .k-dropdown-wrap {
  border: 1px solid #0C3242;
  border-radius: 0;
  box-shadow: none;
  background: none;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.fieldGroups .k-dropdown .k-dropdown-wrap .k-input {
  padding: 1.6rem 1.2rem;
  font-size: 1rem;
  color: #555555;
  -webkit-user-select: none;
          user-select: none;
}
.fieldGroups .k-dropdown .k-dropdown-wrap .k-select {
  padding-right: 1.2rem;
}
.fieldGroups .k-dropdown .k-dropdown-wrap .k-select .k-icon {
  width: 0.6rem;
  height: 0.6rem;
}
.fieldGroups .k-dropdown .k-dropdown-wrap .k-select .k-icon:before {
  background-image: url(/CFImages/Icons/plus.svg);
  background-size: 0.6rem auto;
}
.fieldGroups.checkboxes {
  flex-wrap: wrap;
}
.fieldGroups.checkboxes fieldset legend {
  width: 100%;
  height: auto;
  position: relative;
  margin: 0;
  padding: 0;
  overflow: initial;
}
.fieldGroups.checkboxes fieldset ul.grid.checkboxes {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
}
.fieldGroups.checkboxes fieldset ul.grid.checkboxes li.field.col {
  flex: 0;
  font-size: 0.9rem;
}

.k-list-container {
  border: 1px solid #A3A3A3;
  border-top-width: 0;
  background-color: #BEC7CB;
}

.k-list-optionlabel, .k-list .k-item {
  padding: 0.8rem 1rem;
  color: #0C3242;
  font-weight: bold;
  font-size: 0.9rem;
}
.k-list-optionlabel.k-state-selected, .k-list .k-item.k-state-selected {
  background-color: #fff;
  color: #0C3242;
}
.k-list-optionlabel.k-state-selected:hover, .k-list .k-item.k-state-selected:hover {
  background-color: #0C3242;
  color: #fff;
}

/* Filters */
.filtersContainer {
  display: block;
  margin: 0 auto;
  margin: 0 auto 2rem;
}
.filtersContainer #contentFilters-1 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.filtersContainer #activeFilters .activeFilterTag {
  padding-bottom: 1rem;
}
.filtersContainer fieldset legend {
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  border: 0;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute;
  background-color: #fff;
  color: #000;
}
.filtersContainer .filtersOnly {
  display: flex;
  gap: 1.2rem;
}
.filtersContainer .advancedFiltersContainer {
  width: 100%;
}
.filtersContainer .advancedFiltersContainer .button {
  margin: 0 !important;
  height: 100% !important;
}

/* Keyword Search */
.keywordSearchWrapper {
  position: relative;
  width: 100%;
}
.keywordSearchWrapper input[type=search] {
  border: none;
  border: 1px solid #0C3242;
  box-sizing: border-box;
  height: 3.4rem;
  /* the animated underline */
}
.keywordSearchWrapper input[type=search] + .textFieldUnderline {
  width: 100%;
  height: 1px;
  display: block;
  margin: 0;
  margin-top: -1px;
  background-size: 200%;
  background-position: 100% 0%;
  /*background-image: linear-gradient(to right, #0C3242, #0C3242 50%, transparent 50%, transparent 75%);*/
  background-image: linear-gradient(to right, #A3A3A3, #A3A3A3 50%, transparent 50%, transparent 75%);
  position: relative;
  z-index: 10;
}
.keywordSearchWrapper input[type=search]:focus, .keywordSearchWrapper input[type=search]:active, .keywordSearchWrapper input[type=search]:hover {
  outline: none !important;
  /*border-bottom: 2px solid $primaryColour;*/
}
.keywordSearchWrapper input[type=search]:focus + .textFieldUnderline, .keywordSearchWrapper input[type=search]:active + .textFieldUnderline, .keywordSearchWrapper input[type=search]:hover + .textFieldUnderline {
  background-position: 0% 0%;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
  transition-duration: 250ms;
}
.keywordSearchWrapper .buttons {
  position: absolute;
  right: 0;
  top: 0;
  left: auto;
  bottom: 1px;
  display: flex;
  align-items: stretch;
}
.keywordSearchWrapper .buttons .clearSearch {
  display: none;
  opacity: 0;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.keywordSearchWrapper .buttons .clearSearch .icon:before {
  background-size: 1rem auto;
}
.keywordSearchWrapper .buttons button:not(.sf-button) {
  border: none;
  padding: 0;
  background-color: white;
  width: 4rem;
  margin-top: 0;
  top: 1px;
}
.keywordSearchWrapper .buttons button:not(.sf-button) svg {
  margin: 0;
}
.keywordSearchWrapper input[type=search]:not(:placeholder-shown) ~ .buttons .clearSearch {
  display: block;
  opacity: 1;
}

/* Search by initial (alphabet) */
.searchByInitialContainer {
  margin: 1rem 0 0 0;
  display: flex;
  justify-content: center;
}
.searchByInitialContainer .alphaList a {
  cursor: pointer;
  text-decoration: none;
  border: 1px solid #BEC7CB;
  padding: 0.25rem 0.25rem;
  min-width: 1.5rem;
  min-height: 0.25rem;
  margin-bottom: 0.5rem;
  display: inline-flex;
  justify-content: center;
}
.searchByInitialContainer .alphaList a.initialFilter.selected {
  background-color: #BEC7CB;
  color: white;
}
.searchByInitialContainer .alphaList a.initialFilter:hover {
  background-color: #BEC7CB;
  color: white;
}
.searchByInitialContainer .alphaList a.disabledFilter {
  color: #707070;
  cursor: not-allowed;
  opacity: 0.5;
  text-decoration: none;
  border-color: #707070;
}

/* Filtered Content Wrapper */
.filteredContent {
  min-height: 30rem;
}
.filteredContent .buttonsContainer .button i {
  margin-left: 2rem;
}
.filteredContent .buttonsContainer .button:not(:last-child) {
  margin-right: 1rem;
}
.filteredContent .loadMoreContainer {
  text-align: center;
  margin: 4rem 0 0;
}
.filteredContent .loadMoreContainer button .icon {
  font-size: 0.8rem;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 0.6rem;
  margin-right: 0.6rem;
}
.filteredContent .permanentLinkField {
  display: flex;
}
.filteredContent .permanentLinkField button {
  padding: 0.6rem 1rem;
  margin: 0;
}
.filteredContent .permanentLinkField button svg {
  margin: 0;
}

/* Filtered Content withSidebar */
.filteredContent.withSidebar {
  /* Checkboxes */
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid {
  display: grid;
  grid-template-columns: 1fr 3fr;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filterHeader h3 {
  text-transform: uppercase;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer {
  /*Filters are below */
  background-color: white;
  box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px;
  padding: 0 0 1rem 0;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer {
  /* section title */
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .filterSectionTitle {
  display: block;
  margin: 0 0 1rem 0;
  padding: 0.5rem 1rem;
  border-bottom: 1px solid #A3A3A3;
  border-top: 1px solid #A3A3A3;
  background-color: #EDEEEF;
  color: #0C3242;
  font-size: 14px;
  font-weight: bold;
  text-transform: uppercase;
  text-align: center;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 0;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown {
  width: 100%;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown:hover .k-dropdown-wrap, .filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown.k-state-border-down .k-dropdown-wrap {
  border-color: #A3A3A3;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown .k-dropdown-wrap {
  border: 1px solid #0C3242;
  border-radius: 0;
  box-shadow: none;
  background: none;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown .k-dropdown-wrap .k-input {
  padding: 1.6rem 1.2rem;
  font-size: 1rem;
  color: #555555;
  -webkit-user-select: none;
          user-select: none;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown .k-dropdown-wrap .k-select {
  padding-right: 1.2rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown .k-dropdown-wrap .k-select .k-icon {
  width: 0.6rem;
  height: 0.6rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups .k-dropdown .k-dropdown-wrap .k-select .k-icon:before {
  background-image: url(/CFImages/Icons/plus.svg);
  background-size: 0.6rem auto;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes {
  flex-wrap: no-wrap;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset {
  flex: 1 1 0;
  margin: 0 0 1rem 0;
  padding: 0 1rem 0 1rem;
  border-bottom: 1px solid #CCCCCC;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggle {
  position: relative;
  width: 100%;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggle:after {
  content: " ";
  position: absolute;
  top: 0rem;
  right: 0.8rem;
  color: #BEC7CB;
  background-image: url(/CFImages/Icons/chevron-down.svg);
  background-size: 0.6rem auto;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #EDEEEF;
  width: 0.6rem;
  height: 0.6rem;
  border: 1px solid #EDEEEF;
  border-radius: 5px;
  padding: 3px;
  cursor: pointer;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggle legend {
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 700;
  display: block;
  margin: 0 0 0.5rem 0;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggle.active:after {
  background-image: url(/CFImages/Icons/chevron-up.svg);
  background-color: #BEC7CB;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent {
  border: 1px solid #CCCCCC;
  border-radius: 5px;
  /* only show when active */
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
  /* The search input for each filter */
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent.active {
  height: auto;
  opacity: 1;
  overflow: auto;
  max-height: 260px;
  padding: 0.5rem 0;
  margin-bottom: 1rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent input.option-filter-textbox {
  width: calc(100% - 2rem);
  margin-left: 1rem;
  border-radius: 5px;
  height: auto;
  padding: 0.5rem 1rem;
  margin-bottom: 0.5rem;
  font-size: 0.8rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent div.rangeWrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0.5rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent div.rangeWrapper input {
  border-radius: 5px;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent div.rangeWrapper span.minMaxSeperator {
  padding: 0 0.5rem;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent div.rangeWrapper span.minMaxSeperator:before {
  content: "-";
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent span.rangeValuesText {
  text-align: center;
  display: block;
  font-size: 12px;
  color: #707070;
  margin: 0.5rem 0;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent ul.checkboxes {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  width: 100%;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent ul.checkboxes li.field.col {
  position: relative;
  flex: 0;
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  margin: 0;
  border-bottom: 1px solid #EDEEEF;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent ul.checkboxes li.field.col:last-child {
  border-bottom: none;
}
.filteredContent.withSidebar .filteredContentOuterGrid.grid .filtersContainer .advancedFiltersContainer .fieldGroups.checkboxes fieldset .filterToggleContent ul.checkboxes li.field.col:hover {
  background-color: #EDEEEF;
}
.filteredContent.withSidebar input[type=checkbox] {
  width: 20px;
  height: 20px;
  cursor: pointer;
  position: absolute;
  top: 8px;
  -webkit-appearance: inherit;
          appearance: inherit;
  border-radius: 3px;
  /* disabled */
}
.filteredContent.withSidebar input[type=checkbox] + label {
  padding-left: 2rem;
}
.filteredContent.withSidebar input[type=checkbox]:focus {
  outline: none !important;
}
.filteredContent.withSidebar input[type=checkbox]:checked {
  background-color: #BEC7CB;
  border-color: #BEC7CB;
  background-image: url(/CFImages/Icons/check-white.svg);
}
.filteredContent.withSidebar input[type=checkbox]:disabled {
  color: #A3A3A3;
}

/* Active filters tags/pills */
#filtersDisplayContainer:has(.activeFilterTag) {
  margin: 1rem 0;
}
#filtersDisplayContainer .activeFilterGroup {
  display: inline-flex;
  flex-wrap: wrap;
}
#filtersDisplayContainer .activeFilterGroup .activeFilterTag {
  border: 1px solid #EDEEEF;
  padding: 0.4rem 1rem;
  cursor: pointer;
  position: relative;
  padding-right: 2.4rem;
  margin-bottom: 0.6rem;
  -webkit-user-select: none;
          user-select: none;
  margin-right: 1rem;
  color: #707070;
}
#filtersDisplayContainer .activeFilterGroup .activeFilterTag:not(:last-of-type) {
  margin-right: 0.6rem;
}
#filtersDisplayContainer .activeFilterGroup .activeFilterTag:after {
  top: 50%;
  content: " ";
  right: 0.8rem;
  color: #BEC7CB;
  background-image: url(/CFImages/Icons/plus.svg);
  background-size: 0.6rem auto;
  background-position: center;
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
  transform-origin: center;
  width: 0.6rem;
  height: 0.6rem;
  position: absolute;
}
#filtersDisplayContainer .activeFilterGroup .activeFilterTag:hover, #filtersDisplayContainer .activeFilterGroup .activeFilterTag:focus {
  border-color: #A3A3A3;
}
#filtersDisplayContainer .activeFilterGroup .activeFilterTag:active {
  border-color: #A3A3A3;
}

.filtersPopupWrapper {
  width: 100%;
  left: 0 !important;
}
.filtersPopupWrapper .advancedFiltersContainer {
  margin: 0 auto;
  display: block !important;
}

#loadingIndicator {
  height: 200px;
  display: none;
  margin-top: 2rem;
}
#loadingIndicator svg {
  margin: 0 auto;
}
#loadingIndicator.loading {
  content: "loading";
  line-height: 200px;
  text-align: center;
  display: block;
}

#loadingCounter {
  margin: 2rem 0 2rem;
  color: #707070;
  font-style: italic;
}

#filteredContentResult li.noResults {
  color: #707070;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0;
  flex: initial;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#filteredContentResult li.noResults .message {
  font-style: italic;
}
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Popups / Modals (SHARED) */
/****************************************************************************************************/
.popup_wrapper .button.close {
  top: -2rem;
  right: 0;
  width: 2rem;
  height: 2rem;
  position: absolute;
  border: none;
  padding: 0;
  border-radius: 0;
  background-color: white;
  border: 1px solid #0C3242;
}
.popup_wrapper .button.close:before {
  background-image: url(/CFImages/Icons/plus.svg);
  background-size: 1rem auto;
  background-position: center;
  background-repeat: no-repeat;
  transform: rotate(45deg);
  transform-origin: center;
  content: " ";
  display: inline-block;
  position: absolute;
  inset: 0;
}
.popup_wrapper .button.close:focus, .popup_wrapper .button.close:hover {
  background-color: transparent;
}
.popup_wrapper .button.close:focus:before, .popup_wrapper .button.close:hover:before {
  /*background-image: url(/CFImages/Icons/plus-white.svg);*/
}
.popup_wrapper .button.close:active {
  background-color: transparent;
}
.popup_wrapper .button.close:active:before {
  /*background-image: url(/CFImages/Icons/plus-white.svg);*/
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Forms + Inputs / Fields */
/****************************************************************************************************/
label {
  cursor: pointer;
}

/* Text Fields */
input {
  color: #555555;
  width: 100%;
  height: 3.15rem;
  max-width: 100%;
  padding: 0.2rem 1rem;
  padding-right: 3rem;
  text-overflow: ellipsis;
  border: 1px solid #0C3242;
  background-color: transparent;
  font-weight: 100;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
  /*    &:hover, &:focus {
      @include placeholder {
          opacity: 0.4;
      }
  }*/
}
input::-webkit-input-placeholder {
  opacity: 1;
  -webkit-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
input:-moz-placeholder {
  opacity: 1;
  -moz-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
input::-moz-placeholder {
  opacity: 1;
  -moz-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
input:-ms-input-placeholder {
  opacity: 1;
  -ms-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
input:focus:focus-visible {
  outline: 1px solid #BEC7CB;
  outline-offset: 0;
}
textarea {
  width: 100%;
  min-height: 5rem;
  display: block;
  border: 1px solid #0C3242;
  font-weight: 100;
}
textarea:hover::-webkit-input-placeholder, textarea:focus::-webkit-input-placeholder {
  opacity: 0.4;
}
textarea:hover:-moz-placeholder, textarea:focus:-moz-placeholder {
  opacity: 0.4;
}
textarea:hover::-moz-placeholder, textarea:focus::-moz-placeholder {
  opacity: 0.4;
}
textarea:hover:-ms-input-placeholder, textarea:focus:-ms-input-placeholder {
  opacity: 0.4;
}
textarea:focus {
  outline: 1px solid #BEC7CB;
  outline-offset: 0;
}

/* Select Lists */
select {
  width: 100%;
  height: 3.15rem;
  max-width: 100%;
  color: #555555;
  cursor: pointer;
  border: 1px solid #0C3242;
  padding: 0.2rem 1rem;
  padding-right: 1.6rem;
  font-size: 1rem;
  font-weight: 100;
  line-height: 1;
  /* Firefox */
  -webkit-appearance: none;
  /* Safari and Chrome */
  appearance: none;
  background-size: 0.8rem auto;
  background-image: url(/CFImages/Icons/plus.svg);
  background-repeat: no-repeat;
  background-position: right 1rem center;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
}
select:hover {
  border-color: rgba(12, 50, 66, 0.7);
}
select:focus {
  outline: none;
  outline: 1px solid #BEC7CB;
  outline-offset: 0;
}
select > option {
  text-transform: none;
}
select > option:checked, select > option:hover {
  background-color: #EDEEEF;
}

/* Checkboxes */
input[type=checkbox] {
  width: 1px;
  height: 1px;
  margin-right: -1px;
  cursor: pointer;
  position: absolute;
  /* disabled */
}
input[type=checkbox] + label {
  cursor: pointer;
  display: inline-block;
  position: relative;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  padding-left: 2rem;
}
input[type=checkbox] + label::selection {
  color: inherit;
  background-color: transparent;
}
input[type=checkbox] + label:before, input[type=checkbox] + label:after {
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: inline-block;
  position: absolute;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  margin-right: 0.4rem;
  width: 1em;
  height: 1em;
}
input[type=checkbox] + label:before {
  content: " ";
  background-color: white;
}
input[type=checkbox] + label:after {
  content: " ";
  background-image: none;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 80% auto;
  border: 1px solid #0C3242;
  border-color: #707070;
}
input[type=checkbox] + label:hover, input[type=checkbox] + label:focus {
  color: #BEC7CB;
}
input[type=checkbox] + label:hover:after, input[type=checkbox] + label:focus:after {
  border-color: #BEC7CB;
}
input[type=checkbox]:focus {
  outline: none !important;
}
input[type=checkbox]:focus:focus-visible + label {
  outline: 2px solid #BEC7CB;
}
input[type=checkbox]:checked + label:after {
  background-image: url(/CFImages/Icons/check.svg);
}
input[type=checkbox]:disabled {
  color: #A3A3A3;
}
input[type=checkbox]:disabled + label {
  color: #A3A3A3;
}
input[type=checkbox]:disabled + label:after {
  filter: grayscale(1);
  opacity: 0.6;
  border-color: #A3A3A3;
}
input[type=checkbox]:disabled + label:hover, input[type=checkbox]:disabled + label:focus {
  color: #A3A3A3;
}
input[type=checkbox]:disabled + label:hover:after, input[type=checkbox]:disabled + label:focus:after {
  border-color: #A3A3A3;
}

/* Radio Buttons */
input[type=radio] {
  height: 1em;
  cursor: pointer;
  display: inline-block;
  width: auto;
}

/*  */
form {
  /* Form-only Buttons */
}
form label {
  cursor: pointer;
}
form fieldset {
  padding: 0;
  border: none;
}
/* clears the ‘X’ from Internet Explorer */
input[type=search]::-ms-clear {
  display: none;
  width: 0;
  height: 0;
}

input[type=search]::-ms-reveal {
  display: none;
  width: 0;
  height: 0;
}

/* clears the ‘X’ from Chrome */
input[type=search]::-webkit-search-decoration, input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-results-button, input[type=search]::-webkit-search-results-decoration {
  display: none;
}

.hiddenForHumans {
  position: absolute !important;
  z-index: -10 !important;
  pointer-events: none !important;
  visibility: hidden !important;
  width: 0;
  height: 0;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Sitefinity Forms Only */
/****************************************************************************************************/
[data-sf-role=form-container] fieldset {
  margin: 1rem 0;
}
[data-sf-role=form-container] fieldset legend {
  padding: 0 0.4rem;
}

/* Sitefinity File Upload field */
[data-sf-role=file-field-inputs] {
  cursor: pointer;
}
[data-sf-role=file-field-inputs] input[type=file] {
  /* Default / Base button styles - only include these when you really need them */
  /* This is what you'll get when you just call @include button; (but you should avoid using this mixin altogether if you can) */
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  /*padding: 0.9rem 1.4em;*/
  padding: 0.8em 2em;
  margin-top: 1em;
  font-size: 0.9rem;
  font-weight: 300;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none !important;
  border: 1px solid #BEC7CB;
  border-radius: 0;
  background-color: transparent;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  white-space: nowrap;
  letter-spacing: 0.1em;
  height: auto;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  overflow: hidden;
  z-index: 2;
  /* FontAwesome Icons in markup */
  /*[class*="fa-"] {
      margin-left: 0.6rem;
  }*/
  /* Reverse (flip the colours of the standard button */
  /* Outline */
}
[data-sf-role=file-field-inputs] input[type=file]:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 98%;
  height: 110%;
  background: #BEC7CB;
  z-index: -1;
  transform-origin: 0 0;
  transform: translateX(-100%) skewX(-25deg);
  transition: transform 0.25s;
}
[data-sf-role=file-field-inputs] input[type=file]:before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: #0C3242;
  z-index: -1;
  transition: transform 0.5s;
}
[data-sf-role=file-field-inputs] input[type=file]:hover:after {
  transform: translateX(0) skewX(-25deg);
}
[data-sf-role=file-field-inputs] input[type=file]:focus {
  color: white;
  background-color: #b0bbc0;
  text-decoration: none !important;
}
[data-sf-role=file-field-inputs] input[type=file]:active {
  color: white;
  text-decoration: none !important;
  background-color: #a2afb4;
}
[data-sf-role=file-field-inputs] input[type=file]::-webkit-file-upload-button {
  visibility: hidden;
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  border: 0;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute;
  background-color: #fff;
  color: #000;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/*#region Site Search */
/****************************************************************************************************/
.searchHiddenWrapper {
  background-color: white;
  padding: 0.5rem 0;
}
.searchHiddenWrapper .form-inline {
  width: 100%;
}
.searchHiddenWrapper .searchHidden {
  display: flex;
  align-items: center;
  justify-content: center;
}
.searchHiddenWrapper .searchHidden .formGroup {
  display: flex;
  width: 80%;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search] {
  width: 90%;
  color: #0C3242;
  background-color: transparent;
  border: 1px solid #0C3242;
  padding: 0.2rem 3rem 0.2rem 1em;
  font-size: 1rem;
  background-repeat: no-repeat;
  background-position: right 1em center;
  text-overflow: ellipsis;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]::-webkit-input-placeholder {
  opacity: 1;
  -webkit-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  color: #0C3242;
  text-transform: none;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:-moz-placeholder {
  opacity: 1;
  -moz-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  color: #0C3242;
  text-transform: none;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]::-moz-placeholder {
  opacity: 1;
  -moz-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  color: #0C3242;
  text-transform: none;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:-ms-input-placeholder {
  opacity: 1;
  -ms-transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  color: #0C3242;
  text-transform: none;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:hover::-webkit-input-placeholder, .searchHiddenWrapper .searchHidden .formGroup input[type=search]:focus::-webkit-input-placeholder {
  opacity: 0.4;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:hover:-moz-placeholder, .searchHiddenWrapper .searchHidden .formGroup input[type=search]:focus:-moz-placeholder {
  opacity: 0.4;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:hover::-moz-placeholder, .searchHiddenWrapper .searchHidden .formGroup input[type=search]:focus::-moz-placeholder {
  opacity: 0.4;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:hover:-ms-input-placeholder, .searchHiddenWrapper .searchHidden .formGroup input[type=search]:focus:-ms-input-placeholder {
  opacity: 0.4;
}
.searchHiddenWrapper .searchHidden .formGroup input[type=search]:focus {
  outline: 2px solid #BEC7CB;
}
.searchHiddenWrapper .searchHidden .formGroup .sfsearchSubmit {
  color: #0C3242;
  background: transparent;
  margin: 0 0 0 -2.5rem;
  padding: 0.25rem 0.5rem;
  font-size: 1.1rem;
  border: none;
}
.searchHiddenWrapper .searchHidden .formGroup .sfsearchSubmit svg {
  margin: 0;
}
.searchHiddenWrapper .searchHidden .formGroup .sfsearchSubmit:hover {
  cursor: pointer;
  color: #0C3242;
}
.searchHiddenWrapper button.searchCollapse {
  border: none;
}
.searchHiddenWrapper button.searchCollapse [class*=fa-] {
  margin-left: 0;
}

.searchSorting {
  width: 600px;
  max-width: 100%;
  padding-bottom: 2rem;
}

.searchResults > ul.grid {
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: -1rem;
  margin-right: -1rem;
  box-sizing: border-box;
}
.searchResults > ul.grid > .col {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 1rem;
  margin-right: 1rem;
  vertical-align: top;
  /*width: calc((1 / 3) * 100% - 2rem);*/
  flex-basis: calc((1 / 3) * 100% - 2rem);
}
.searchResults .cardView.searchdefault {
  padding: 2rem 3rem;
}
.searchResults h3 a {
  color: #0C3242;
}
.searchResults .nonDynamic {
  padding: 2rem;
}
.searchResults .nonDynamic a {
  word-break: break-all;
}
@media only screen and (max-width: 1024px) {
  .searchResults > ul.grid {
    display: flex;
    flex: 0 1 auto;
    flex-wrap: wrap;
    flex-direction: row;
    margin-left: -1rem;
    margin-right: -1rem;
    box-sizing: border-box;
  }
  .searchResults > ul.grid > .col {
    flex: 0 0 auto;
    /*order: 0;*/
    width: initial;
    max-width: 100%;
    margin-left: 1rem;
    margin-right: 1rem;
    vertical-align: top;
    /*width: calc((1 / 2) * 100% - 2rem);*/
    flex-basis: calc((1 / 2) * 100% - 2rem);
  }
}
@media only screen and (max-width: 650px) {
  .searchResults > ul.grid {
    display: flex;
    flex: 0 1 auto;
    flex-wrap: wrap;
    flex-direction: row;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
  }
  .searchResults > ul.grid > .col {
    flex: 0 0 auto;
    /*order: 0;*/
    width: initial;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    vertical-align: top;
    /*width: calc((1 / 1) * 100%);*/
    flex-basis: calc((1 / 1) * 100%);
  }
}
.searchResults ul.grid .col {
  margin-bottom: 1rem;
}

div.searchPager {
  margin: 2rem 0;
  text-align: center;
}
div.searchPager ul.pagination {
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: -0.5rem;
  margin-right: -0.5rem;
  box-sizing: border-box;
  justify-content: center;
}
div.searchPager ul.pagination > li {
  flex: 0 0 auto;
  /*order: 0;*/
  width: initial;
  max-width: 100%;
  margin-left: 0.5rem;
  margin-right: 0.5rem;
  vertical-align: top;
  flex: 0 1 auto;
  width: auto;
}
div.searchPager ul.pagination li {
  margin-top: 1rem;
}
div.searchPager ul.pagination li.active a {
  color: #BEC7CB;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Global Alerts */
/****************************************************************************************************/
/* refer to class .dark for a lot of the styles */
.alertsHeader {
  height: auto;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Accordions + FAQs */
/****************************************************************************************************/
.accordionGroup {
  visibility: hidden;
}

.accordionGroup.k-group {
  margin-bottom: 3rem;
  border-bottom: solid 1px #BEC7CB;
  visibility: visible;
}
.accordionGroup.k-group .k-item {
  width: 100%;
  white-space: normal;
  border-top: solid 1px #BEC7CB;
  /*&[data-expanded="true"] {
     .k-in {
          background-color:yellow;
      }
  }*/
}
.accordionGroup.k-group .k-item .k-in {
  width: 100%;
  display: block;
  color: #0C3242;
  text-decoration: none;
  font-size: 1.2rem;
  padding: 1rem 2.5rem 1rem 0.5rem;
}
.accordionGroup.k-group .k-item .k-in.k-state-focused {
  box-shadow: none;
}
.accordionGroup.k-group .k-item .k-in.k-state-selected {
  background-color: transparent;
}
.accordionGroup.k-group .k-item .k-icon {
  right: 1rem;
}
.accordionGroup.k-group .k-item svg {
  right: 1rem;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.accordionGroup.k-group .k-item:hover svg {
  transform: translate(7px, -50%);
}
.accordionGroup.k-group .k-item .k-content {
  display: block;
  padding: 1rem;
  white-space: normal;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Toggle Sections */
/****************************************************************************************************/
.toggleContent {
  display: none;
}
.toggleContent:active {
  display: block;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Image Galleries */
/****************************************************************************************************/
.imageGallery.slider {
  max-width: 100%;
}
.imageGallery.slider .gallerySlider .splide__arrows {
  opacity: 0;
}
.imageGallery.slider .gallerySlider:hover .splide__arrows {
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  opacity: 1;
}
.imageGallery.slider .gallerySlider .splide__slide {
  min-height: 600px;
  height: 70vh;
  max-height: 700px;
  max-width: 100vw;
  /*            &:hover {
      .descriptionWrapper {
          opacity: 1;
          .description {
          }
      }
  }*/
}
.imageGallery.slider .gallerySlider .splide__slide > a {
  cursor: zoom-in;
  position: absolute;
  inset: 0;
}
.imageGallery.slider .gallerySlider .splide__slide img {
  -o-object-fit: scale-down;
     object-fit: scale-down;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 13%;
     object-position: 50% 13%;
  height: 100%;
  width: 100%;
}
.imageGallery.slider .gallerySlider .splide__slide .descriptionWrapper {
  position: absolute;
  top: auto;
  left: 0;
  right: 0;
  width: 100%;
  bottom: 0;
  z-index: 2;
  color: black;
  max-width: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  /*                opacity: 0;
  transition: $transitionQuint;*/
}
.imageGallery.slider .gallerySlider .splide__slide .descriptionWrapper .description {
  font-size: 0.9rem;
  padding: 2rem;
  display: inline-block;
}
.imageGallery.slider .gallerySlider .splide__slide .descriptionWrapper .description > :last-child {
  margin-bottom: 0;
}
.imageGallery.slider .gallerySlider,
.imageGallery.slider .gallerySliderNav {
  padding-top: 1rem;
}
@media (max-width: 767px) {
  .imageGallery.slider .gallerySliderNav {
    display: none;
  }
}
.imageGallery.slider .gallerySliderNav .splide__slide {
  /*opacity: 0.8;*/
  border: 2px solid white;
  /*            .bgImgWrapper {
      position: relative;
      @include aspectRatioBox(4 3);
      opacity: 0.9;

      div.bgImg {
      }
  }

  img {
      opacity: 0.8;
  }*/
}
.imageGallery.slider .gallerySliderNav .splide__slide.is-active {
  border: 2px solid #BEC7CB;
}
.imageGallery.slider .gallerySliderNav .splide__slide:before {
  content: " ";
  background-color: #F7F7F7;
  position: absolute;
  inset: 0;
  z-index: -1;
}
.imageGallery.slider .gallerySliderNav .splide__slide:after {
  content: " ";
  position: absolute;
  inset: 0;
  z-index: 10;
  background-color: rgba(255, 255, 255, 0.1);
  pointer-events: none;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
}
.imageGallery.slider .gallerySliderNav .splide__slide:focus:focus-visible {
  /*opacity: 1;*/
  /*                img,
  .bgImgWrapper {
      opacity: 1;
  }*/
}
.imageGallery.slider .gallerySliderNav .splide__slide:focus:focus-visible:after {
  background-color: rgba(255, 255, 255, 0);
}
.imageGallery.slider .gallerySliderNav .splide__slide:hover {
  /*opacity: 1;*/
  /*                img,
  .bgImgWrapper {
      opacity: 1;
  }*/
}
.imageGallery.slider .gallerySliderNav .splide__slide:hover:after {
  background-color: rgba(255, 255, 255, 0);
}

.fancybox-caption {
  display: none !important;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Page - Home Page */
/****************************************************************************************************/
.homePage {
  background: linear-gradient(180deg, #0c3242 0%, #0c3242 300px, #edeeef 300px, #edeeef 100%);
}
.homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent {
  color: #fff;
}
.homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent a {
  color: #fff;
  margin: 0 0.5rem;
}
.homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation .cmsContent a:hover {
  text-decoration: none;
  color: #BEC7CB;
}
.homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation button.hamburger .hamburger-inner, .homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation button.hamburger .hamburger-inner:after, .homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation button.hamburger .hamburger-inner:before {
  background-color: #fff;
}
.homePage #header .topHeader .topHeaderGrid .topHeaderGridRight .navigation button.hamburger.open {
  background-color: #0C3242;
}
.homePage #header.up {
  background-color: #0C3242;
}
.homePage .hideOnHome {
  display: none;
}
.homePage .opacityWrapper {
  border-bottom: solid 1px #CCCCCC;
}
.homePage .aboutUsWrapper .imageRight img {
  height: 500px;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-clip-path: polygon(25% 0%, 100% 0%, 100% 99%, 0% 100%);
          clip-path: polygon(25% 0%, 100% 0%, 100% 99%, 0% 100%);
}
.homePage .aboutUsWrapper .cmsContent {
  padding-right: 1rem;
}
.homePage .aboutUsWrapper .cmsContent h2 {
  margin-top: 5rem;
}
.homePage .teammembersWrapper.splide .splide__track {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.homePage .teammembersWrapper.splide .splide__track .slide {
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
}
.homePage .teammembersWrapper.splide .splide__track .slide:hover {
  transform: scale(1.2);
  z-index: 100;
}
.homePage .expertisesWrapper .k-treeview {
  height: 400px;
  direction: rtl;
  padding-left: 2rem;
}
.homePage .expertisesWrapper .k-treeview::-webkit-scrollbar {
  width: 4px;
}
.homePage .expertisesWrapper .k-treeview::-webkit-scrollbar-track {
  background-color: #EDEEEF;
  background: linear-gradient(90deg, #edeeef 46%, #cccccc 46%, #cccccc calc(46% + 1px), #edeeef calc(46% + 1px));
}
.homePage .expertisesWrapper .k-treeview::-webkit-scrollbar-thumb {
  background-color: #0C3242;
  border: none;
}
.homePage .expertisesWrapper .k-treeview ul.accordionGroup {
  direction: ltr;
}

/* Lawyer Search (FindASearch) */
.findASearch {
  margin: 0 auto 9em;
  text-align: center;
  width: 28rem;
  max-width: 100%;
}
.findASearch input[type=text] {
  color: #707070;
  width: 100%;
  height: 3.15rem;
  max-width: 100%;
  padding: 0.2rem 1rem;
  padding-right: 3rem;
  text-overflow: ellipsis;
  background-color: white;
  font-size: 1.2rem;
  font-weight: 300;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  background-image: url(/CFImages/Icons/search.svg);
  background-repeat: no-repeat;
  background-position: center right 1rem;
  outline-offset: -2px;
  border: none;
  padding-left: 0;
  box-sizing: border-box;
  height: 3.4rem;
}
.findASearch input[type=text]:focus {
  outline: none !important;
}
.findASearch .k-widget {
  /* the animated underline */
}
.findASearch .k-widget + .textFieldUnderline {
  width: 100%;
  height: 1px;
  display: block;
  margin: 0;
  margin-top: -1px;
  background-size: 200%;
  background-position: 100% 0%;
  /*background-image: linear-gradient(to right, #0C3242, #0C3242 50%, transparent 50%, transparent 75%);*/
  background-image: linear-gradient(to right, #A3A3A3, #A3A3A3 50%, transparent 50%, transparent 75%);
  position: relative;
  z-index: 10;
}
.findASearch .k-widget:focus, .findASearch .k-widget:active, .findASearch .k-widget:hover, .findASearch .k-widget.k-state-focused {
  outline: none !important;
  /*border-bottom: 2px solid $primaryColour;*/
}
.findASearch .k-widget:focus + .textFieldUnderline, .findASearch .k-widget:active + .textFieldUnderline, .findASearch .k-widget:hover + .textFieldUnderline, .findASearch .k-widget.k-state-focused + .textFieldUnderline {
  background-position: 0% 0%;
  transition: all 0.2s cubic-bezier(0.86, 0, 0.07, 1), font-size 0s linear, padding 0s linear, margin 0s linear;
  transition-duration: 250ms;
}
.findASearch .k-widget.k-autocomplete {
  width: 100%;
  color: #707070;
  border: none;
  border-bottom: 1px solid #0C3242;
  box-shadow: none;
}
.findASearch #findALawyerDropdownContainer .k-list .k-item:first-of-type {
  display: none !important;
}
.findAnything fieldset {
  border: none;
  padding: 0;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Page - Misc Pages (and child pages) */
/****************************************************************************************************/
.contactWrapper .socialLinks li:first-of-type {
  font-size: 0.7rem;
}

.contactMapWrapper {
  overflow: hidden;
}
.contactMapWrapper .cmsContent, .contactMapWrapper picture {
  max-height: 500px;
}
.contactMapWrapper img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/* #endregion */
/****************************************************************************************************/
/* #region Insights (shared styles) - Cards and Detail View  */
/****************************************************************************************************/
.wrapper.careersWrapper .k-treeview .listView.careers {
  --card-width: 100%;
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item {
  margin-bottom: 0.5rem;
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-icon:before {
  background-image: url(/CFImages/Icons/plus-white.svg);
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-icon.k-i-collapse:before {
  background-image: url(/CFImages/Icons/minus-white.svg);
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-in {
  width: 100%;
  background-color: #BEC7CB;
  padding: 1rem 2rem;
  white-space: normal;
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-in h4 {
  margin: 0;
  padding: 0;
  color: #fff;
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-content {
  display: block;
  background-color: #EDEEEF;
  padding: 2rem;
  white-space: normal;
}
.wrapper.careersWrapper .k-treeview .listView.careers .k-item .k-content .k-in {
  display: none;
}

/* #endregion */
/****************************************************************************************************/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region PDF Generation (Printable Bios) */
/****************************************************************************************************/
#printModal_background {
  background: none !important;
}

#printModal {
  display: none;
}

.printModalWrapper #printModal {
  display: block;
}

#printModal {
  width: 36rem;
  background-color: white;
  padding: 4rem;
  padding-top: 3rem;
  border: 1px solid #0C3242;
}
#printModal .top p {
  font-style: italic;
}
#printModal .bottom {
  margin: 1.4rem 0 1.1rem;
}
#printModal .bottom .options ul li {
  display: flex;
  align-items: center;
  margin-bottom: 0.4em;
}
#printModal .label {
  font-family: Founders-Grotesk-Light, "Arial", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.35em;
  letter-spacing: 0.25em;
  font-size: 0.7rem;
  color: #0C3242;
  margin-top: 0;
}
#printModal h3 {
  color: #BEC7CB;
  margin-top: 0;
  margin-bottom: 0.6rem;
}
#printModal .button.close {
  inset: initial;
  top: 2.6rem;
  right: 2.6rem;
  margin: 0;
}
#printModal button[type=submit] {
  margin-left: auto;
  padding: 0.8em 2em 0.8em 1.6em;
}
#printModal button[type=submit] .icon, #printModal button[type=submit] svg {
  margin-right: 1rem;
  font-size: 1.5rem;
}
#printModal button[type=submit] .fa-file-download {
  display: none;
}
#printModal button[type=submit]:focus .fa-file-pdf, #printModal button[type=submit]:hover .fa-file-pdf {
  display: none;
}
#printModal button[type=submit]:focus .fa-file-download, #printModal button[type=submit]:hover .fa-file-download {
  display: inline-block;
}

html.popup_visible_printModal #wrapper > main {
  filter: blur(5px);
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Utility Classes - Visibility */
/****************************************************************************************************/
.sr-only {
  clip: rect(0, 0, 0, 0);
  width: 1px;
  height: 1px;
  border: 0;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute;
  background-color: #fff;
  color: #000;
}

.hidden {
  display: none !important;
}

.forcedHide {
  display: none !important;
}

.hideOnDesktop {
  display: none !important;
}

.hideOnMobile {
  display: inline-block;
}

.printOnly {
  display: none;
}

.mobileOnly {
  display: none;
  height: 0;
  width: 0;
}
@media (max-width: 767px) {
  .mobileOnly {
    display: block;
  }
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Utility Classes - Position, Display, Float */
/****************************************************************************************************/
/* Floating */
.float-none {
  float: none;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

/* Positioning */
.position-absolute {
  position: absolute;
}

.position-relative {
  position: relative;
}

.position-fixed {
  position: fixed;
}

/* Display */
.display-flex {
  display: flex;
}

.display-block {
  display: block;
}

.display-inline-block {
  display: inline-block;
}

.display-inline {
  display: inline;
}

.display-none {
  display: none;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Utility Classes - Text Alignment */
/****************************************************************************************************/
.txt-c, table .txt-c, table tr .txt-c, table tr td.txt-c {
  text-align: center !important;
}

.txt-l, table .txt-l, table tr .txt-l, table tr td.txt-l {
  text-align: left !important;
}

.txt-r, table .txt-r, table tr .txt-r, table tr td.txt-r {
  text-align: right !important;
}

.txt-t, table .txt-t, table tr .txt-t, table tr td.txt-t, table tr th.txt-t {
  vertical-align: top !important;
}

.txt-b, table .txt-b, table tr .txt-b, table tr td.txt-b, table tr th.txt-b {
  vertical-align: bottom !important;
}

.txt-m, table .txt-m, table tr .txt-m, table tr td.txt-m, table tr th.txt-m {
  vertical-align: middle !important;
}

/* Table cell content alignment */
/* horizontal alignment */
/* vertical alignment */
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Utility Classes */
/****************************************************************************************************/
/* ##### Whitespace (padding + margin) ##### */
/*    Examples:
    .mtxl - margin-top-extra-large (add an extra large margin-top)
    .pan  - padding-all-none       (remove padding on all sides)
    .mvs  - margin-vertical-small  (add small margins on the top and bottom)
*/
.pan {
  padding: 0 !important;
}

.man {
  margin: 0 !important;
}

.pvn {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.mvn {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.phn {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.mhn {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.ptn {
  padding-top: 0 !important;
}

.mtn {
  margin-top: 0 !important;
}

.prn {
  padding-right: 0 !important;
}

.mrn {
  margin-right: 0 !important;
}

.pbn {
  padding-bottom: 0 !important;
}

.mbn {
  margin-bottom: 0 !important;
}

.pln {
  padding-left: 0 !important;
}

.mln {
  margin-left: 0 !important;
}

.paxs {
  padding: 0.25rem !important;
}

.maxs {
  margin: 0.25rem !important;
}

.pvxs {
  padding-top: 0.25rem !important;
  padding-bottom: 0.25rem !important;
}

.mvxs {
  margin-top: 0.25rem !important;
  margin-bottom: 0.25rem !important;
}

.phxs {
  padding-left: 0.25rem !important;
  padding-right: 0.25rem !important;
}

.mhxs {
  margin-left: 0.25rem !important;
  margin-right: 0.25rem !important;
}

.ptxs {
  padding-top: 0.25rem !important;
}

.mtxs {
  margin-top: 0.25rem !important;
}

.prxs {
  padding-right: 0.25rem !important;
}

.mrxs {
  margin-right: 0.25rem !important;
}

.pbxs {
  padding-bottom: 0.25rem !important;
}

.mbxs {
  margin-bottom: 0.25rem !important;
}

.plxs {
  padding-left: 0.25rem !important;
}

.mlxs {
  margin-left: 0.25rem !important;
}

.pas {
  padding: 0.5rem !important;
}

.mas {
  margin: 0.5rem !important;
}

.pvs {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

.mvs {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}

.phs {
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

.mhs {
  margin-left: 0.5rem !important;
  margin-right: 0.5rem !important;
}

.pts {
  padding-top: 0.5rem !important;
}

.mts {
  margin-top: 0.5rem !important;
}

.prs {
  padding-right: 0.5rem !important;
}

.mrs {
  margin-right: 0.5rem !important;
}

.pbs {
  padding-bottom: 0.5rem !important;
}

.mbs {
  margin-bottom: 0.5rem !important;
}

.pls {
  padding-left: 0.5rem !important;
}

.mls {
  margin-left: 0.5rem !important;
}

.pam {
  padding: 1rem !important;
}

.mam {
  margin: 1rem !important;
}

.pvm {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.mvm {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.phm {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.mhm {
  margin-left: 1rem !important;
  margin-right: 1rem !important;
}

.ptm {
  padding-top: 1rem !important;
}

.mtm {
  margin-top: 1rem !important;
}

.prm {
  padding-right: 1rem !important;
}

.mrm {
  margin-right: 1rem !important;
}

.pbm {
  padding-bottom: 1rem !important;
}

.mbm {
  margin-bottom: 1rem !important;
}

.plm {
  padding-left: 1rem !important;
}

.mlm {
  margin-left: 1rem !important;
}

.pal {
  padding: 2rem !important;
}

.mal {
  margin: 2rem !important;
}

.pvl {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

.mvl {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}

.phl {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}

.mhl {
  margin-left: 2rem !important;
  margin-right: 2rem !important;
}

.ptl {
  padding-top: 2rem !important;
}

.mtl {
  margin-top: 2rem !important;
}

.prl {
  padding-right: 2rem !important;
}

.mrl {
  margin-right: 2rem !important;
}

.pbl {
  padding-bottom: 2rem !important;
}

.mbl {
  margin-bottom: 2rem !important;
}

.pll {
  padding-left: 2rem !important;
}

.mll {
  margin-left: 2rem !important;
}

.paxl {
  padding: 3rem !important;
}

.maxl {
  margin: 3rem !important;
}

.pvxl {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.mvxl {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.phxl {
  padding-left: 3rem !important;
  padding-right: 3rem !important;
}

.mhxl {
  margin-left: 3rem !important;
  margin-right: 3rem !important;
}

.ptxl {
  padding-top: 3rem !important;
}

.mtxl {
  margin-top: 3rem !important;
}

.prxl {
  padding-right: 3rem !important;
}

.mrxl {
  margin-right: 3rem !important;
}

.pbxl {
  padding-bottom: 3rem !important;
}

.mbxl {
  margin-bottom: 3rem !important;
}

.plxl {
  padding-left: 3rem !important;
}

.mlxl {
  margin-left: 3rem !important;
}

.paxxl {
  padding: 5rem !important;
}

.maxxl {
  margin: 5rem !important;
}

.pvxxl {
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}

.mvxxl {
  margin-top: 5rem !important;
  margin-bottom: 5rem !important;
}

.phxxl {
  padding-left: 5rem !important;
  padding-right: 5rem !important;
}

.mhxxl {
  margin-left: 5rem !important;
  margin-right: 5rem !important;
}

.ptxxl {
  padding-top: 5rem !important;
}

.mtxxl {
  margin-top: 5rem !important;
}

.prxxl {
  padding-right: 5rem !important;
}

.mrxxl {
  margin-right: 5rem !important;
}

.pbxxl {
  padding-bottom: 5rem !important;
}

.mbxxl {
  margin-bottom: 5rem !important;
}

.plxxl {
  padding-left: 5rem !important;
}

.mlxxl {
  margin-left: 5rem !important;
}

.paxxxl {
  padding: 7rem !important;
}

.maxxxl {
  margin: 7rem !important;
}

.pvxxxl {
  padding-top: 7rem !important;
  padding-bottom: 7rem !important;
}

.mvxxxl {
  margin-top: 7rem !important;
  margin-bottom: 7rem !important;
}

.phxxxl {
  padding-left: 7rem !important;
  padding-right: 7rem !important;
}

.mhxxxl {
  margin-left: 7rem !important;
  margin-right: 7rem !important;
}

.ptxxxl {
  padding-top: 7rem !important;
}

.mtxxxl {
  margin-top: 7rem !important;
}

.prxxxl {
  padding-right: 7rem !important;
}

.mrxxxl {
  margin-right: 7rem !important;
}

.pbxxxl {
  padding-bottom: 7rem !important;
}

.mbxxxl {
  margin-bottom: 7rem !important;
}

.plxxxl {
  padding-left: 7rem !important;
}

.mlxxxl {
  margin-left: 7rem !important;
}

.paxxxxl {
  padding: 9rem !important;
}

.maxxxxl {
  margin: 9rem !important;
}

.pvxxxxl {
  padding-top: 9rem !important;
  padding-bottom: 9rem !important;
}

.mvxxxxl {
  margin-top: 9rem !important;
  margin-bottom: 9rem !important;
}

.phxxxxl {
  padding-left: 9rem !important;
  padding-right: 9rem !important;
}

.mhxxxxl {
  margin-left: 9rem !important;
  margin-right: 9rem !important;
}

.ptxxxxl {
  padding-top: 9rem !important;
}

.mtxxxxl {
  margin-top: 9rem !important;
}

.prxxxxl {
  padding-right: 9rem !important;
}

.mrxxxxl {
  margin-right: 9rem !important;
}

.pbxxxxl {
  padding-bottom: 9rem !important;
}

.mbxxxxl {
  margin-bottom: 9rem !important;
}

.plxxxxl {
  padding-left: 9rem !important;
}

.mlxxxxl {
  margin-left: 9rem !important;
}

/* ##### subheaders ##### */
/*    Examples: .subheader-s .subheader-m .subheader-l */
.subheader-xs {
  font-size: 1rem !important;
}
.subheader-s {
  font-size: 1.25rem !important;
}
.subheader-m {
  font-size: 1.5rem !important;
}
.subheader-l {
  font-size: 2rem !important;
}
.subheader-xl {
  font-size: 3rem !important;
}

/* ##### txt colours ##### (replaces old txtGrey txtPrimary etc.)*/
/*    Examples: .txt-primary .txt-secondary .txt-grey .txt-grey-dark */
.txt-white {
  color: #fff !important;
}
.txt-black {
  color: #000 !important;
}
.txt-primary {
  color: #0C3242 !important;
}
.txt-primary-light {
  color: #14536d !important;
}
.txt-primary-dark {
  color: black !important;
}
.txt-secondary {
  color: #BEC7CB !important;
}
.txt-secondary-light {
  color: #dadfe2 !important;
}
.txt-secondary-dark {
  color: #a2afb4 !important;
}
.txt-tertiary {
  color: #BEC7CB !important;
}
.txt-tertiary-light {
  color: #dadfe2 !important;
}
.txt-tertiary-dark {
  color: #a2afb4 !important;
}
.txt-grey {
  color: #707070 !important;
}
.txt-grey-dark {
  color: #555555 !important;
}
.txt-grey-xdark {
  color: #222222 !important;
}
.txt-grey-light {
  color: #A3A3A3 !important;
}
.txt-grey-xlight {
  color: #CCCCCC !important;
}
.txt-grey-xxlight {
  color: #EDEEEF !important;
}
.txt-grey-xxxlight {
  color: #F7F7F7 !important;
}

/* ##### bg colours ##### (replaces old bgGrey bgDark etc.) */
/*    Examples: .bg-primary .bg-secondary .bg-dark .bg-light .bg-grey .bg-grey-dark .bg-grey-xdark */
.bg-white {
  background-color: #fff !important;
}
.bg-black {
  background-color: #000 !important;
}
.bg-dark {
  background-color: #555555 !important;
}
.bg-light {
  background-color: #EDEEEF !important;
}
.bg-offwhite {
  background-color: #F6F6F6 !important;
}
.bg-primary {
  background-color: #0C3242 !important;
}
.bg-primary-light {
  background-color: #14536d !important;
}
.bg-primary-dark {
  background-color: black !important;
}
.bg-secondary {
  background-color: #BEC7CB !important;
}
.bg-secondary-light {
  background-color: #dadfe2 !important;
}
.bg-secondary-dark {
  background-color: #a2afb4 !important;
}
.bg-tertiary {
  background-color: #BEC7CB !important;
}
.bg-tertiary-light {
  background-color: #dadfe2 !important;
}
.bg-tertiary-dark {
  background-color: #a2afb4 !important;
}
.bg-grey {
  background-color: #707070 !important;
}
.bg-grey-dark {
  background-color: #555555 !important;
}
.bg-grey-xdark {
  background-color: #222222 !important;
}
.bg-grey-light {
  background-color: #A3A3A3 !important;
}
.bg-grey-xlight {
  background-color: #CCCCCC !important;
}
.bg-grey-xxlight {
  background-color: #EDEEEF !important;
}
.bg-grey-xxxlight {
  background-color: #F7F7F7 !important;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Utility Classes - Misc */
/****************************************************************************************************/
/* (simple, single-purpose classes intended for use in Siteifnity editors, etc) */
.border {
  border: 1px solid #0C3242;
}

.borderTop {
  border-top: solid 1px #CCCCCC;
}

.borderLeft {
  border-left: solid 1px #CCCCCC;
}

.borderRight {
  border-right: solid 1px #CCCCCC;
}

.equalTopMargins > :first-child {
  margin-top: 1rem;
}

.pullQuote {
  padding: 30px 50px;
  border-top: 1px solid black;
  border-bottom: 1px solid black;
  font-size: 1.3em;
  font-weight: 700;
}

.subtle {
  color: #186383;
  font-size: 0.8em;
}

.wrapper.related h2 {
  margin-top: 4rem;
}

.twoColumn {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 4rem;
}
@media only screen and (max-width: 767px) {
  .twoColumn {
    grid-template-columns: 1fr;
  }
}

/* #endregion */
/****************************************************************************************************/
/*Filtered content*/
.pagination-page {
  color: #0C3242;
}
.pagination-page .selected {
  color: #ffffff;
  background-color: #940e14;
  padding: 4px;
  text-align: center;
  width: 30px;
  height: 30px;
  border-radius: 90px;
  display: inline-block;
  line-height: 100%;
}

#ClearFiltersWrapper {
  position: fixed;
  z-index: 10000;
  display: flex;
  align-content: center;
  align-items: center;
  justify-content: center;
  width: 45px;
  height: 45px;
  right: 5%;
  bottom: 10%;
  background: #0C3242;
  border: solid #fff 1px;
  border-radius: 40px;
  box-shadow: 5px 5px 15px 5px rgba(0, 0, 0, 0.2);
  color: #fff;
  opacity: 0.45;
  transition: all linear 0.15s;
  cursor: pointer;
}
#ClearFiltersWrapper span.horizontal-slash {
  position: absolute;
  transform: rotate(35deg);
  height: 3px;
  width: 100%;
  background: #fff;
}

#ClearFiltersWrapper:hover {
  opacity: 1;
}

.goToPageLbl {
  display: block;
  max-width: 100px;
  padding: 3px;
  border-radius: 5px;
  text-align: center;
  margin: 15px auto;
  position: relative;
  transition: all linear 0.15s;
}
.goToPageLbl select {
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  z-index: 999;
  margin: 0 auto;
  height: auto;
}
.goToPageLbl .goToDropdown {
  height: 0px;
  max-width: 80px;
  margin: 0 auto;
  overflow-x: hidden;
  overflow-y: hidden;
}
.goToPageLbl .goToDropdown.active {
  height: 140px;
  border: solid #0C3242 1px;
  border-radius: 6px;
  overflow-y: auto;
}
.goToPageLbl li {
  margin-right: 3px;
}
.goToPageLbl li.selected {
  background: #F7F7F7;
}

.goToPageLbl:hover {
  color: #0C3242;
}

/* #endregion */
/****************************************************************************************************/
@keyframes slide-up {
  0% {
    transform: translateY(1000px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes fadeToGreyscaleWhite {
  0% {
    filter: grayscale(0) brightness(1);
  }
  1% {
    filter: grayscale(1) brightness(1);
  }
  100% {
    filter: grayscale(1) brightness(200);
  }
}
@keyframes bounceInSmall {
  0% {
    opacity: 1;
    transform: translateY(0px);
  }
  20% {
    opacity: 1;
    transform: translateY(-5px);
  }
  30% {
    opacity: 1;
    transform: translateY(10px);
  }
  40% {
    opacity: 1;
    transform: translateY(0);
  }
}
/****************************************************************************************************/
/* #region Kendo Navigation top-level widget overrides */
/****************************************************************************************************/
/****************************************************************************************************/
/* Kendo Menu Widget */
/*.k-menu {
    &.k-menu-horizontal {
        border: none;
        background: none;
    }

    .k-item {
        .k-link {
            &:focus {
                outline: none;
            }

            &:focus-visible {
                outline: 2px solid red;
            }
        }
    }

    &:not(.k-context-menu) {
        > .k-item {
            &.k-state-focused {
                outline: none;
                box-shadow: none;
            }

            > a.k-state-active {
                color: white;
            }

            .k-group {
                visibility: visible !important;
            }
        }

        &:focus {

            > .k-item {

                &.k-state-focused {
                    outline: none;
                    box-shadow: none;
                }
            }

            &:focus-visible {
                outline: 1px dashed $greyLight;
                outline-offset: 0;

                > .k-item.k-state-focused {
                    outline: $outline;
                    box-shadow: none;
                }
            }
        }
    }
}*/
/****************************************************************************************************/
/* Kendo Treeview (shared, general treeview styles) */
/* remember - these styles will affect ANY kendo treeview. So if you're making heavy changes then you probably want to target your specific treeview */
.k-treeview {
  padding: 0;
  /*    overflow-y: auto;
  overflow-x: hidden;*/
}
.k-treeview .k-item {
  color: inherit;
  position: relative;
  padding: 0;
  font-size: 1rem;
  border: none;
}
.k-treeview .k-item .k-icon {
  right: 5%;
  position: absolute;
  z-index: 3;
}
.k-treeview .k-item .k-icon:before {
  color: #fff;
  content: " ";
  font-size: 1rem;
}
.k-treeview .k-link {
  color: inherit;
  width: 100%;
  font-size: inherit;
  padding: 0;
  white-space: normal;
}
.k-treeview .k-link.k-state-hover, .k-treeview .k-link.k-state-active, .k-treeview .k-link.k-state-selected, .k-treeview .k-link.k-state-focused {
  background: none;
  box-shadow: none;
  text-decoration: none;
}
.k-treeview:focus:focus-visible .k-state-focused {
  outline: 2px solid #BEC7CB;
  outline-offset: 0;
}

/* #endregion */
/****************************************************************************************************/
/* CF Default Menu */
/*nav.mainNavWrapper {

    .rootMenuItem > ul {
        display: none;
    }


    ul.mainNav {
        display: none;
    }

    ul.mainNav.initialized {
        display: flex;
    }

    ul.mainNav.k-menu, ul.mainNav.k-menu:not(.k-context-menu) {
        display: flex;
        gap: 1rem;
        z-index: 2;
        margin-top: .5rem;
        justify-content: center;

        &:not(.k-widget) {
            ul {
                position: absolute;
                visibility: hidden;
                pointer-events: none;
            }
        }

        li.rootMenuItem {
            border: none;
            background: none;
            text-align: left;

            &:after {
                width: 50px;
                height: 2px;
                left: 50%;
                bottom: 0;
                opacity: 1;
                content: "";
                position: absolute;
                transform: translateX(-50%);
                background-color: $primaryColour;
                transition: $transition;
            }

            > a {
                color: $greyDark;*/
/*padding: 0 1rem;*/
/*font-weight: 900;
border: none;
background: none;
font-size: .8rem;
text-transform: uppercase;

&:focus, &:active {*/
/*outline: 2px solid $focusColour;
outline-offset: 2px;*/
/*}*/
/* The down icons */
/*.k-icon {
        margin: -2px -5px 0 5px;
        color: $secondaryColour;

        .k-icon:before {
            color: #fff;
        }
    }

    &.k-state-active {
        background: none;
        color: $primaryColour;
    }
}*/
/* hover state */
/*&.k-state-hover {
        > a {
            color: $secondaryColour;
        }

        &:after {
            width: calc(100% - 1rem);
            background-color: $secondaryColour;
        }
    }
}*/
/* Sub elements */
/*ul {
    border: none;
    padding: .5rem;
    position: absolute;
    background-color: #fff;

    > li {
        border: none;
        background: none;

        > a {
            min-width: 180px;
            color: $primaryColour;
            border: none;
            padding: .5rem 2rem .5rem 1rem;
            background: none;
            font-weight: 700;
            font-size:.7rem;
            text-transform: uppercase;*/
/* The down icons */
/*.k-icon {
        //margin: -7px -5px 0 5px;
        margin: 0;
    }
}*/
/* hover state */
/*&.k-state-hover {
            background-color: $primaryColour;

            a.k-link {
                color: #fff;
            }
        }
    }

    ul {
        margin-left: 5px;
        margin-top: -5px;
    }
}*/
/* selected states (CFAdded selected or childSelected classes) */
/*// selected item
.rootMenuItem.k-item.selected {
    a.k-link.selected {
    }

    &:after {
        opacity: 1;
    }
}
// Has a child item selected
.rootMenuItem.childSelected {
    a.k-link.childSelected {
    }

    &:after {
        opacity: 1;
    }
}
// selected Item
li.selected {

    a.selected {
    }
}
// Has a child item selected*/
/*.k-group .k-item.childSelected {

}*/
/*}
}*/
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Hamburger */
/****************************************************************************************************/
button.hamburger {
  width: 60px;
  height: 45px;
  border: none;
  padding: 22px 25px;
  margin: 0;
  position: relative;
  z-index: 500;
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear;
  background: none;
}
button.hamburger:hover {
  cursor: pointer;
  background-color: #BEC7CB;
}
button.hamburger .hamburger-inner, button.hamburger .hamburger-inner:after, button.hamburger .hamburger-inner:before {
  position: absolute;
  width: 34px;
  height: 2px;
  transition-timing-function: ease;
  transition-duration: 0.15s;
  transition-property: transform;
  background-color: #0C3242;
}
button.hamburger .hamburger-inner {
  top: 50%;
  left: 50%;
  display: block;
  transform: translate(-50%, -50%) rotate(0deg);
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition-duration: 75ms;
  width: 50%;
}
button.hamburger .hamburger-inner:before {
  top: -10px;
  transition: top 75ms ease 0.12s, opacity 75ms ease;
}
button.hamburger .hamburger-inner:after {
  bottom: -10px;
}
button.hamburger .hamburger-inner:after, button.hamburger .hamburger-inner:before {
  display: block;
  content: "";
}
button.hamburger.open {
  z-index: 10000;
  background-color: #CCCCCC;
}
button.hamburger.open .hamburger-inner {
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transform: translate(-50%, -50%) rotate(45deg);
  width: 58%;
}
button.hamburger.open .hamburger-inner:before {
  top: 0;
  transition: top 75ms ease, opacity 75ms ease 0.12s, color 75ms ease-in;
  opacity: 0;
}
button.hamburger.open .hamburger-inner:after {
  bottom: 0;
  transition: bottom 75ms ease, transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
  transform: rotate(-90deg);
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Mobile Menu */
/****************************************************************************************************/
/* sometimes a duplicate of the header, sometimes just a container for the mobile nav */
.mobileHeader {
  position: fixed;
  z-index: 1000;
}
/* tweak other elements when the mobile nav is open */
body.withNavOpen #header {
  top: 0;
  left: 0;
  right: 0;
  bottom: initial;
  position: fixed;
}

/* the mobile nav menu */
nav.mobileNav {
  top: 0;
  right: 0;
  width: 40rem;
  max-width: 100%;
  height: 100%;
  position: fixed;
  padding: 200px 2rem 2rem 2rem;
  overflow-x: hidden;
  overflow-y: auto;
  min-height: 100vh;
  transform: translateX(100%);
  transition: all 0.2s ease, font-size 0s linear, padding 0s linear, margin 0s linear, outline 0s linear, visibility linear 0s;
  visibility: hidden;
  background-color: #BEC7CB;
}
nav.mobileNav.open {
  transform: translateX(0%);
  visibility: visible;
}
nav.mobileNav .k-treeview {
  color: white;
  height: 100%;
}
nav.mobileNav .k-treeview .mainNav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 2rem;
  /*            column-count: 2;
  column-gap: 2rem;*/
}
@media (max-width: 650px) {
  nav.mobileNav .k-treeview .mainNav li:nth-child(even) {
    order: 1;
  }
  nav.mobileNav .k-treeview .mainNav li:nth-child(odd) {
    order: 0;
  }
}
nav.mobileNav .k-treeview .mainNav .k-item {
  font-size: 1.5rem;
  color: #0C3242;
  border-bottom: solid 1px #0C3242;
  padding-bottom: 1rem;
}
nav.mobileNav .k-treeview .mainNav .k-item .k-group .k-item {
  font-size: 1.1rem;
  margin-top: 1rem;
  border: none;
  margin-top: 0.5rem;
  padding: 0 1rem 0.25rem;
}
nav.mobileNav .k-treeview .mainNav .k-item .k-group .k-item.k-last {
  border-bottom: none;
  padding-bottom: 0;
}
nav.mobileNav .k-treeview .mainNav .k-item .k-icon {
  right: 0%;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Kendo TreeView inside sideContent */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Kendo TreeView inside sideContent */
/****************************************************************************************************/
.sideContent nav {
  width: 100%;
  margin-top: 2rem;
}
@media (max-width: 1024px) {
  .sideContent nav {
    margin-top: 0;
  }
}
.sideContent nav ul.mainTreeView {
  visibility: hidden;
}
.sideContent nav .k-treeview {
  background-color: #BEC7CB;
  padding: 1rem;
}
.sideContent nav .k-treeview ul.mainTreeView {
  border: solid 1px #0C3242;
  padding: 0;
}
.sideContent nav .k-treeview ul.mainTreeView.k-group {
  visibility: visible;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item.selected > div .k-icon:first-of-type.k-i-collapse:before {
  background-image: url(/CFImages/Icons/minus.svg);
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item.selected > div .k-icon:first-of-type.k-i-expand:before {
  background-image: url(/CFImages/Icons/plus.svg);
}
.sideContent nav .k-treeview ul.mainTreeView li + li {
  border-top: solid 1px #0C3242;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item {
  /* above the link */
  padding: 0;
  /*.k-top, .k-mid, .k-bot {
      padding: 2px;
  }*/
  /* link styles */
  /* These are any nested groups */
  /* The selected li */
  /* This is the expanded li item */
  /* expand collapse icons */
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item a.k-link {
  color: #0C3242;
  font-size: 1rem;
  padding: 0.5rem;
  white-space: normal;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item a.k-link:focus:focus-visible {
  background-color: #EDEEEF;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item a.k-link:hover {
  background-color: #EDEEEF;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item ul.k-group {
  border-top: solid 1px #0C3242;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item ul.k-group li.k-item {
  padding: 0;
  /* Level 2 Nest */
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item ul.k-group li.k-item a.k-link {
  font-size: 0.9rem;
  padding-left: 1rem;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item ul.k-group li.k-item a.k-link:after {
  width: 8px;
  height: 8px;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item ul.k-group li.k-item ul.k-group li.k-item a.k-link {
  padding-left: 4rem;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item.selected {
  /* link styles (both the li and a have class of selected on them) */
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item.selected a.k-link.selected {
  color: #0C3242 !important;
}
.sideContent nav .k-treeview ul.mainTreeView li.k-item[aria-expanded=true] {
  font-weight: 700;
  color: #0C3242;
}
/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Top Level Simple */
/****************************************************************************************************/
nav.topLevelSimple {
  width: 100%;
}
nav.topLevelSimple ul {
  display: inline-grid;
  justify-content: space-between;
  grid-template-columns: repeat(2, 1fr);
}
nav.topLevelSimple ul a {
  text-decoration: none;
  text-transform: uppercase;
  color: #fff !important;
  opacity: 0.9;
}
nav.topLevelSimple ul a:hover {
  color: #BEC7CB !important;
}

/* #endregion */
/****************************************************************************************************/
/****************************************************************************************************/
/* #region Tabs / Tabstrip */
/****************************************************************************************************/
.tabstrip {
  display: none;
}

.tabstrip.k-widget {
  display: block;
}
.tabstrip.k-widget .button .k-flat {
  display: none;
}
.tabstrip.k-widget.k-tabstrip {
  background: none;
  border: none;
  font-size: inherit;
  padding-top: 1rem;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items {
  border: none;
  background: none;
  gap: 1rem;
  flex-wrap: wrap;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item {
  border: solid 1px #0C3242;
  background: none;
  border-radius: 0;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item .k-loading {
  border: none;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item .k-link {
  color: #0C3242;
  padding: 0.75rem 2.5rem;
  font-size: 0.8rem;
  background: none;
  text-transform: uppercase;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item.k-last .k-link {
  border: none;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item.k-state-active .k-link {
  color: #fff;
  background-color: #0C3242;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item.k-state-hover {
  border-color: #BEC7CB;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item.k-state-hover .k-link {
  color: #fff;
  background-color: #BEC7CB;
}
.tabstrip.k-widget.k-tabstrip .k-tabstrip-items .k-item:active .k-link {
  color: #fff;
}
.tabstrip.k-widget.k-tabstrip:focus {
  box-shadow: none;
}
.tabstrip.k-widget.k-tabstrip:focus:focus-visible {
  outline: 2px solid #BEC7CB;
  outline-color: #A3A3A3;
  outline-style: dashed;
}
.tabstrip.k-widget.k-tabstrip:focus:focus-visible .k-item.k-state-active {
  outline: 2px solid #BEC7CB;
}
.tabstrip.k-widget.k-tabstrip .k-content {
  border: none;
  padding: 3rem 0 1rem;
  background-color: transparent;
  overflow: hidden;
}
.tabstrip.k-widget.k-tabstrip .k-content.k-state-active {
  background-color: transparent;
}
.tabstrip.k-widget.k-tabstrip .k-content:focus {
  outline: none;
}
.tabstrip.k-widget.k-tabstrip .k-content:focus:focus-visible {
  outline: 2px solid #BEC7CB;
  outline-offset: 0;
}
@media only screen and (max-width: 767px) {
  .tabstrip.k-widget.k-tabstrip .k-content {
    padding-bottom: 0;
  }
}

/* #endregion */
/****************************************************************************************************/
/* 
Media queries for tablet and mobile (general guidelines for breakpoints globally set in the _variables file) 
Mobile ($S_Max)   Tablet ($M_Min and $M_Max)  Small Desktop ($L_Min and $L_Max)  Large Desktop ($XL_Min - This is the standard for all styles)
*/
/* Large Desktop (switch between simple and mobile nav) */
/* Small Desktop (switch between simple and mobile nav) */
@media only screen and (max-width: 1299px) {
  h2 {
    font-size: 2rem;
  }

  .site-footer .mainFooter .mainFooterGrid .footerLeft {
    padding-top: 2rem;
    padding-bottom: 2rem;
    /* the background */
  }
  .site-footer .mainFooter .mainFooterGrid .footerLeft:before {
    right: -100vw;
  }
  .site-footer .mainFooter .mainFooterGrid .footerLeft .footerLeftGrid {
    display: flex;
    flex-direction: row;
  }
  .site-footer .mainFooter .mainFooterGrid .footerLeft .footerLeftGrid .logoAndAddress {
    width: 50%;
    flex: initial;
  }
  .site-footer .mainFooter .mainFooterGrid .footerLeft .footerLeftGrid .studentLinks {
    width: 50%;
    flex: initial;
  }
  .site-footer .mainFooter .mainFooterGrid .footerRight {
    padding-left: 0;
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
  .site-footer .mainFooter .mainFooterGrid .footerRight .footerSitemapGrid {
    width: 100%;
  }

  .detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1 {
    font-size: 2.4rem;
  }
  .detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper img {
    aspect-ratio: 6/5;
  }
}
/* Tablet */
@media only screen and (max-width: 1024px) {
  #header .topHeader .topHeaderGridLeft img {
    width: 250px;
  }
  #header .header {
    display: none;
    height: 0;
    width: 0;
    padding: 0;
  }

  .sideContent {
    margin-bottom: 2rem !important;
  }
  .sideContent.ptxxl {
    padding-top: 0 !important;
  }

  .homeSlideshow .splide__slide .cardContent h1, .homeSlideshow .splide__slide .cardContent h2 {
    font-size: 3.2rem;
  }

  .homePage .teammembersWrapper.splide .splide__track .slide:hover {
    transform: none;
  }

  .siteFooter .mainFooter .mainFooterGrid nav.topLevelSimple {
    margin: 2rem 0;
  }
  .siteFooter .mainFooter .mainFooterGrid .mainFooterLeft h4 {
    margin-bottom: 1rem;
  }
  .siteFooter .mainFooter .mainFooterGrid .mainFooterRight .socials .cmsContent .button {
    font-size: 0.7rem;
  }
  .siteFooter .mainFooter .mainFooterGrid .mainFooterRight .logo a {
    margin-top: 2rem;
    justify-content: flex-start;
    max-width: 200px;
  }

  .copyright .col-align-end {
    align-items: flex-start;
  }

  .detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper img {
    aspect-ratio: 1;
  }
  .detailView.teammember .bioTopContent .bioContact {
    padding-left: 2rem;
    left: 0;
    width: 50%;
  }
  .detailView.teammember .bioTopContent .bioContact * {
    font-size: 0.9rem;
  }
  .detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1 {
    font-size: 2.4em;
  }
  .detailView.teammember .bioTopContent .bioContact h3 {
    font-size: 1.2rem;
  }

  .filtersContainer #contentFilters-1 {
    display: flex;
    flex-wrap: wrap;
  }

  .contactWrapper .borderRight {
    padding-bottom: 1rem;
  }
}
/* Mobile Only */
@media only screen and (max-width: 767px) {
  .topperSection .topperContent h1 {
    font-size: 3rem;
  }
}
/* XS Mobile Only */
@media only screen and (max-width: 650px) {
  nav.mobileNav .k-treeview .mainNav {
    grid-template-columns: 1fr;
  }

  .detailView.teammember .breadCrumb {
    display: none;
  }
  .detailView.teammember .mainContent {
    margin-top: 1.2rem;
  }
  .detailView.teammember .bioTopContent .bioPhotoWrapper {
    flex-direction: column-reverse;
  }
  .detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper {
    width: 100%;
  }
  .detailView.teammember .bioTopContent .bioPhotoWrapper .imgWrapper img {
    -o-object-position: inherit;
       object-position: inherit;
    -webkit-mask-image: none;
            mask-image: none;
  }
  .detailView.teammember .bioTopContent .bioContact {
    position: inherit;
    padding: 1rem 1rem;
    left: 0;
    width: 100%;
    bottom: inherit;
    transform: translateY(0);
  }
  .detailView.teammember .bioTopContent .bioContact .nameDesignationsPronunciation h1 {
    font-size: 2em;
  }

  #wrapper .button:not(.sf-button), #wrapper button:not(.sf-button):not(.splide__pagination__page):not(.hamburger) {
    white-space: normal !important;
    font-size: 0.7rem;
  }

  .fieldGroups {
    flex-wrap: wrap;
  }

  .homeSlideshow .splide__slide .cardContent h1, .homeSlideshow .splide__slide .cardContent h2 {
    font-size: 2.2rem;
  }
}
/* ### Bullets */
/* XXS Mobile (min width) */
/* XS Mobile (min width) */
/* XS Mobile (max width) */
/* Mobile (min width) */
/* Mobile (max width) */
/* Mobile (max width) */
/* Tablets (min width) */
/* Tablets (max width) */
/* Small Desktop  (min width) */
/* Small Desktop (max width) */
/* Large Desktop (min width) */
/* Large Desktop (max width) */
/* Extra-Large Desktop (min width) */
/* Extra-Large Desktop (max width) */
/* High Definition (HD) - THIS IS THE LEVEL OF OUR DEFAULT STYLES */
/* Containers - PLEASE USE REMS */
/* Container Padding */
/* Whitespace */
/* Subheader */
/* Base unit used for spacing gutters */
/* Buttons */
@media print {
  .noPrint {
    display: none;
  }

  .printOnly {
    display: block;
    height: auto;
    width: auto;
  }

  a[href]:after {
    content: none !important;
  }

  /* Hide these elements */
  .topHeader {
    display: none !important;
  }

  .mobile,
.topHeader,
header nav,
header .search,
footer,
video, audio, object, embed {
    display: none !important;
    height: 0 !important;
  }

  header .header.stuck {
    position: relative !important;
  }

  img {
    max-width: 100%;
  }

  @page {
    margin: 0.5cm;
  }
  body {
    line-height: 1.5;
  }

  h1 {
    font-size: 21pt;
  }

  h2 {
    font-size: 15pt;
    margin-top: 25px;
  }

  h3 {
    font-size: 13pt;
    margin-top: 20px;
  }

  p a {
    color: black;
    word-wrap: break-word;
  }
  p a:after {
    content: " " attr(href) ")";
  }
  p a[href^="#"]:after {
    display: none;
  }
  p a[href^="http://"]:after, p a a[href^="https://"]:after {
    content: " (" attr(href) ")";
  }

  .pageTopper {
    min-height: 0;
  }
  .pageTopper .topperImage {
    display: none;
  }

  .resources .innerContent .itemImage {
    display: none;
  }

  .filteredContent .filtersContainer, .filteredContent #loadingIndicator, .filteredContent #loadMoreContainer {
    display: none !important;
  }

  .viewMoreOuter {
    display: none;
  }

  .teammembers .teammember .bgImgWrapper {
    display: none;
  }

  .teammember .topperGrid {
    height: auto;
  }
  .teammember .topperGrid .bioTopContent.flexCol {
    color: #000;
    background-color: #fff;
  }
  .teammember .topperGrid .bioTopContent.flexCol .bioContact {
    text-align: left;
    flex-direction: column;
    display: flex;
    justify-content: center;
    height: 100%;
  }
  .teammember .topperGrid .bioTopContent.flexCol .bioContact h1 {
    color: #000;
  }
  .teammember .topperGrid .bioTopContent.flexCol .bioContact a:link, .teammember .topperGrid .bioTopContent.flexCol .bioContact a:visited, .teammember .topperGrid .bioTopContent.flexCol .bioContact a:active {
    color: #000;
  }
  .teammember .topperGrid .bioTopContent.flexCol .bioContact .offices ul li {
    border-right: 1px solid #000;
  }
  .teammember .topperGrid .bioTopContent.flexCol .bioContact .offices ul li a {
    color: #000;
  }
  .teammember .bgImgWrapper {
    display: none;
    height: 0;
  }

  .expertise.detailView .pageTopper, .sector.detailView .pageTopper, .solution.detailView .pageTopper {
    min-height: 0;
    padding-top: 2rem;
  }
  .expertise.detailView .pageTopper .topperImage, .sector.detailView .pageTopper .topperImage, .solution.detailView .pageTopper .topperImage {
    display: none;
  }
}
.printWrapper {
  background-color: #fff;
  font-size: 15px !important;
  /* Shared List views and cards */
  /* Two Column Table */
  /* bottom table (for resource etc) */
  /* Team Bio Specific Styles*/
  /* Related Cards*/
}
.printWrapper a {
  color: #0C3242;
}
.printWrapper .cmsContent {
  color: #0C3242;
}
.printWrapper .cmsContent a {
  color: #0C3242;
}
.printWrapper .cmsContent.highlightFirstElement > :first-child {
  margin: 0 0 1rem;
}
.printWrapper table {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  border: none;
  border-collapse: inherit;
  border-spacing: 0;
  border-color: inherit;
  vertical-align: inherit;
  text-align: left;
  font-weight: inherit;
}
.printWrapper table tr td {
  vertical-align: top;
}
.printWrapper table tr td.alignBottom {
  vertical-align: bottom;
}
.printWrapper table tr td.alignMiddle {
  vertical-align: middle;
}
.printWrapper p, .printWrapper li {
  font-size: 14px;
  word-break: break-word;
}
.printWrapper .cmsContent p, .printWrapper .cmsContent li {
  font-size: 1rem;
  line-height: 1.2rem;
}
.printWrapper h1, .printWrapper h2, .printWrapper h3, .printWrapper h4, .printWrapper h5 {
  text-align: left;
}
.printWrapper h1:first-child,
.printWrapper h2:first-child,
.printWrapper h3:first-child,
.printWrapper h4:first-child,
.printWrapper h5:first-child,
.printWrapper h6:first-child,
.printWrapper .h:first-child,
.printWrapper .cmsContent.highlightFirstElement > :first-child {
  margin-top: revert;
}
.printWrapper h1 {
  font-size: 1.5rem !important;
}
.printWrapper h2 {
  font-size: 1.2rem !important;
  margin: 0;
  padding: 0;
  break-inside: avoid;
  margin: 1rem 0 1.4rem 0;
}
.printWrapper h2:after {
  content: "";
  display: block;
  height: 120px;
  position: relative;
  margin-bottom: -120px;
}
.printWrapper h2.smallMargin:after {
  content: "";
  display: block;
  height: 180px;
  margin-bottom: -180px;
}
.printWrapper h2.mediumMargin:after {
  content: "";
  display: block;
  height: 300px;
  margin-bottom: -300px;
}
.printWrapper h2.superMargin:after {
  content: "";
  display: block;
  height: 500px;
  margin-bottom: -500px;
}
.printWrapper .avoidPageBreak {
  page-break-inside: avoid;
}
.printWrapper .container {
  width: 100%;
  padding: 0;
  margin: 0;
  max-width: 100% !important;
}
.printWrapper .baseFont {
  font-family: Founders-Grotesk-Regular, "Arial", sans-serif;
}
.printWrapper .viewAllMoreWrapper {
  display: none;
}
.printWrapper .listView {
  display: block;
  gap: initial;
  margin: 0 !important;
}
.printWrapper .listView li {
  margin: 0;
  padding: 0;
  break-inside: avoid;
}
.printWrapper .mainContent {
  padding: 0.5rem 1.5rem 1.5rem 0;
  font-size: 15px !important;
  line-height: 1 !important;
}
.printWrapper table.mainGrid tr td {
  vertical-align: top;
  border: none;
  border-spacing: 0px;
}
.printWrapper table.mainGrid .secondaryContent {
  font-size: 15px !important;
  padding: 0.5rem 1rem 2rem 1rem;
}
.printWrapper table.mainGrid .secondaryContent h2 {
  border-bottom: solid 1px #0C3242;
  font-size: 16px;
  margin-top: 1.4rem;
}
.printWrapper table.mainGrid .secondaryContent h3 {
  font-size: 16px !important;
}
.printWrapper table.mainGrid .secondaryContent p strong {
  font-size: 16px !important;
}
.printWrapper table.mainGrid .secondaryContent strong {
  font-size: inherit !important;
  font-family: Founders-Grotesk-Regular, "Arial", sans-serif;
}
.printWrapper table.mainGrid .secondaryContent ul {
  margin-bottom: 2rem;
}
.printWrapper table.mainGrid .secondaryContent ul li {
  font-size: 14px;
  line-height: 1.1 !important;
}
.printWrapper table.mainGrid .secondaryContent .cmsContent a {
  font-weight: normal;
}
.printWrapper table.fullGrid {
  width: 100%;
}
.printWrapper table.fullGrid section h2 {
  margin-top: 2rem;
  border-top: 1px solid #0C3242;
  padding-top: 1rem;
}
.printWrapper .detailView.teammember .bioTopContent {
  margin-bottom: 0;
  background: linear-gradient(25deg, #CCCCCC 0%, #EDEEEF 100%);
  box-shadow: none;
  /* top table (for contact and image) */
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid {
  border-spacing: 0px;
  width: 100%;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid div.bioContact {
  position: relative;
  display: block;
  transform: none;
  height: auto;
  width: 100%;
  border: none;
  margin: 0;
  padding-left: 2rem;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid .audioPlayerWrapper {
  display: none !important;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid div.pronounsWrapper ul li {
  font-size: 12px;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid .bioPhotoWrapper {
  background: none;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid .bioPhotoWrapper .imgWrapper {
  width: 100%;
  padding: 0;
}
.printWrapper .detailView.teammember .bioTopContent table.topGrid .bioPhotoWrapper .imgWrapper img {
  -o-object-fit: contain;
     object-fit: contain;
  aspect-ratio: 1 !important;
}
.printWrapper .detailView.teammember .mainGrid .mainContent .readMoreContent.cmsContent.highlightFirstElement > :first-child {
  font-size: 16px !important;
}
.printWrapper .detailView.teammember .mainGrid .mainContent p, .printWrapper .detailView.teammember .mainGrid .mainContent ul li, .printWrapper .detailView.teammember .mainGrid .mainContent ol li, .printWrapper .detailView.teammember .mainGrid .mainContent a {
  font-size: 14px !important;
  line-height: 1.1 !important;
}
.printWrapper .detailView.teammember .mainGrid .secondaryContent {
  background: #EDEEEF;
}
.printWrapper .detailView.teammember .mainGrid .secondaryContent .logoWrapper {
  padding: 0;
  margin: 0.5rem 0 1rem 0;
}
.printWrapper .detailView.teammember .mainGrid .secondaryContent .logoWrapper img {
  width: 100%;
}
.printWrapper .detailView.teammember .fullGrid p, .printWrapper .detailView.teammember .fullGrid ul li, .printWrapper .detailView.teammember .fullGrid ol li, .printWrapper .detailView.teammember .fullGrid a {
  font-size: 14px !important;
  line-height: 1.1 !important;
}
.printWrapper .listView.rankings {
  display: grid;
  --card-width: 45%;
  gap: 1rem;
}
.printWrapper .listView.rankings li {
  border-right: none;
}
.printWrapper .listView.rankings .cardView.ranking {
  padding: 0 0 2rem 0;
  margin-bottom: 0rem;
}
.printWrapper .listView.rankings .cardView.ranking .cardContent {
  padding: 0.75rem;
}
.printWrapper .listView.rankings .cardView.ranking:after, .printWrapper .listView.rankings .cardView.ranking:before {
  content: none;
}
.printWrapper .listView.rankings .cardView.ranking .meta.rankingPublisher {
  font-size: 12px;
  font-weight: normal;
}
.printWrapper .listView.rankings .cardView.ranking h3.rankingAccolade {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.1;
}
.printWrapper .listView.insights {
  display: grid;
  --card-width: 30%;
  gap: 1rem;
}
.printWrapper .listView.insights li {
  border-right: none;
}
.printWrapper .listView.insights .cardView.insight {
  margin-bottom: 0rem;
  padding: 0.75rem;
}
.printWrapper .listView.insights .cardView.insight .contentTypeLabels {
  font-size: 12px;
  font-weight: normal;
  text-transform: none;
  margin: 0;
}
.printWrapper .listView.insights .cardView.insight .meta {
  font-size: 12px;
}
.printWrapper .listView.insights .cardView.insight:after, .printWrapper .listView.insights .cardView.insight:before {
  content: none;
}
.printWrapper .listView.insights .cardView.insight h3 {
  font-size: 14px;
  margin: 0.5rem 0;
}
.printWrapper .listView.insights .cardView.insight h3 a {
  font-weight: 700;
}

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