/* flickity-fade */

.flickity-enabled.is-fade .flickity-slider > * {
  pointer-events: none;
  z-index: 0;
}

.flickity-enabled.is-fade .flickity-slider > .is-selected {
  pointer-events: auto;
  z-index: 1;
}
@charset "UTF-8";
/*
 * Table of Contents
 *
 * This file collects all of the patials used throughout the website.
 *
 *****************************************************************************/
/*
 * Variables
 *
 * This file collects all of the variables used throughout the website.
 *
 *****************************************************************************/
/*
 * Colors
 *
 *********************************************************/
/*
 * Typography
 *
 *********************************************************/
/*
 * Easings
 *
 *********************************************************/
/*
 * Widths & Breakpoints
 *
 *********************************************************/
/*
 * Spacing
 *
 *********************************************************/
/*
 * Z-Index
 *
 *********************************************************/
/*
 * Functions
 *
 * This file collects all of the functions used throughout the website.
 *
 *****************************************************************************/
/*
 * Native `url(..)` function wrapper
 *
 * @param {String} $base - base URL for the asset
 * @param {String} $type - asset type folder (e.g. `fonts/`)
 * @param {String} $path - asset path
 * @return {Url}
 *
 *********************************************************/
/*
 * Returns URL to an image based on its path
 *
 * @param {String} $path - image path
 * @param {String} $base [$base-url] - base URL
 * @return {Url}
 * @require $base-url
 *
 *********************************************************/
/*
 * Returns URL to a font based on its path
 *
 * @param {String} $path - font path
 * @param {String} $base [$base-url] - base URL
 * @return {Url}
 * @require $base-url
 *
 *********************************************************/
/*
 * Returns Z-index depth
 *
 *********************************************************/
/*
 * Returns font size
 *
 *********************************************************/
/*
 * Fallback to PX value for browsers that don't support REM
 *
 *********************************************************/
/*
 * Add white to a color
 *
 * @param {Color} $color
 * @param {Number} $percentage
 * @return {Color}
 *
 *********************************************************/
/*
 * Add black to a color
 *
 * @param {Color} $color
 * @param {Number} $percentage
 * @return {Color}
 *
 *********************************************************/
/*
 * Mixins
 *
 * This file collects all of the mixins used throughout the website.
 *
 *****************************************************************************/
/*
 * Event wrapper
 *
 * @param {Bool} $self [false] - Whether or not to include
 current selector
 *
 *********************************************************/
/*
 * Make a context based selector a little more friendly
 *
 * @param {String} $context
 *
 *********************************************************/
/*
 * Make certain fonts render sharper on OSX
 *
 *********************************************************/
/*
 * Clearfix
 *
 *********************************************************/
/*
 * Maintain aspect ratio on divs with background images
 * (mimic native image scaling)
 *
 * @include responsive-ratio(16,9);
 *
 *********************************************************/
/*
 * Background opacity with fallback for older browsers
 *
 *********************************************************/
/*
 * Create a transparent overlay
 *
 *********************************************************/
/*
 * Visually hide element
 *
 *********************************************************/
/*
 * Visually show element
 *
 *********************************************************/
/*
 * Create background image that centers & covers parent
 * container
 *
 *********************************************************/
/*
 * Add common rules to pseudo elements
 *
 *********************************************************/
/*
 * Enable hardware acceleration
 *
 *********************************************************/
/*
 * Position
 *
 *********************************************************/
/*
 * Size
 *
 *********************************************************/
/*
 * Font Size with PX fallback
 *
 *********************************************************/
/*
 * Margin Auto center
 *
 *********************************************************/
/*
 * Screen-reader text
 *
 *********************************************************/
/*
 * CSS Triangles
 *
 *********************************************************/
/*
 * Spacing
 *
 * Utility classes to put specific spacing values onto elements.
 * The below loop will generate us a suite of responsive classes like.
 *
 *****************************************************************************/
@media (min-width: 0) {
  .m-xs-0 {
    margin: 0rem;
  }

  .p-xs-0 {
    padding: 0rem;
  }
}
@media (min-width: 0) {
  .m-xs-1 {
    margin: 1rem;
  }

  .p-xs-1 {
    padding: 1rem;
  }
}
@media (min-width: 0) {
  .m-xs-2 {
    margin: 2rem;
  }

  .p-xs-2 {
    padding: 2rem;
  }
}
@media (min-width: 0) {
  .m-xs-3 {
    margin: 3rem;
  }

  .p-xs-3 {
    padding: 3rem;
  }
}
@media (min-width: 0) {
  .m-xs-4 {
    margin: 4rem;
  }

  .p-xs-4 {
    padding: 4rem;
  }
}
@media (min-width: 0) {
  .m-xs-5 {
    margin: 5rem;
  }

  .p-xs-5 {
    padding: 5rem;
  }
}
@media (min-width: 0) {
  .m-xs-6 {
    margin: 6rem;
  }

  .p-xs-6 {
    padding: 6rem;
  }
}
@media (min-width: 0) {
  .m-xs-7 {
    margin: 7rem;
  }

  .p-xs-7 {
    padding: 7rem;
  }
}
@media (min-width: 0) {
  .m-xs-8 {
    margin: 8rem;
  }

  .p-xs-8 {
    padding: 8rem;
  }
}
@media (min-width: 0) {
  .m-xs-9 {
    margin: 9rem;
  }

  .p-xs-9 {
    padding: 9rem;
  }
}
@media (min-width: 0) {
  .m-xs-10 {
    margin: 10rem;
  }

  .p-xs-10 {
    padding: 10rem;
  }
}
@media (min-width: 0) {
  .mt-xs-0 {
    margin-top: 0rem;
  }

  .pt-xs-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 0) {
  .mt-xs-1 {
    margin-top: 1rem;
  }

  .pt-xs-1 {
    padding-top: 1rem;
  }
}
@media (min-width: 0) {
  .mt-xs-2 {
    margin-top: 2rem;
  }

  .pt-xs-2 {
    padding-top: 2rem;
  }
}
@media (min-width: 0) {
  .mt-xs-3 {
    margin-top: 3rem;
  }

  .pt-xs-3 {
    padding-top: 3rem;
  }
}
@media (min-width: 0) {
  .mt-xs-4 {
    margin-top: 4rem;
  }

  .pt-xs-4 {
    padding-top: 4rem;
  }
}
@media (min-width: 0) {
  .mt-xs-5 {
    margin-top: 5rem;
  }

  .pt-xs-5 {
    padding-top: 5rem;
  }
}
@media (min-width: 0) {
  .mt-xs-6 {
    margin-top: 6rem;
  }

  .pt-xs-6 {
    padding-top: 6rem;
  }
}
@media (min-width: 0) {
  .mt-xs-7 {
    margin-top: 7rem;
  }

  .pt-xs-7 {
    padding-top: 7rem;
  }
}
@media (min-width: 0) {
  .mt-xs-8 {
    margin-top: 8rem;
  }

  .pt-xs-8 {
    padding-top: 8rem;
  }
}
@media (min-width: 0) {
  .mt-xs-9 {
    margin-top: 9rem;
  }

  .pt-xs-9 {
    padding-top: 9rem;
  }
}
@media (min-width: 0) {
  .mt-xs-10 {
    margin-top: 10rem;
  }

  .pt-xs-10 {
    padding-top: 10rem;
  }
}
@media (min-width: 0) {
  .mb-xs-0 {
    margin-bottom: 0rem;
  }

  .pb-xs-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 0) {
  .mb-xs-1 {
    margin-bottom: 1rem;
  }

  .pb-xs-1 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 0) {
  .mb-xs-2 {
    margin-bottom: 2rem;
  }

  .pb-xs-2 {
    padding-bottom: 2rem;
  }
}
@media (min-width: 0) {
  .mb-xs-3 {
    margin-bottom: 3rem;
  }

  .pb-xs-3 {
    padding-bottom: 3rem;
  }
}
@media (min-width: 0) {
  .mb-xs-4 {
    margin-bottom: 4rem;
  }

  .pb-xs-4 {
    padding-bottom: 4rem;
  }
}
@media (min-width: 0) {
  .mb-xs-5 {
    margin-bottom: 5rem;
  }

  .pb-xs-5 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 0) {
  .mb-xs-6 {
    margin-bottom: 6rem;
  }

  .pb-xs-6 {
    padding-bottom: 6rem;
  }
}
@media (min-width: 0) {
  .mb-xs-7 {
    margin-bottom: 7rem;
  }

  .pb-xs-7 {
    padding-bottom: 7rem;
  }
}
@media (min-width: 0) {
  .mb-xs-8 {
    margin-bottom: 8rem;
  }

  .pb-xs-8 {
    padding-bottom: 8rem;
  }
}
@media (min-width: 0) {
  .mb-xs-9 {
    margin-bottom: 9rem;
  }

  .pb-xs-9 {
    padding-bottom: 9rem;
  }
}
@media (min-width: 0) {
  .mb-xs-10 {
    margin-bottom: 10rem;
  }

  .pb-xs-10 {
    padding-bottom: 10rem;
  }
}
@media (min-width: 0) {
  .ml-xs-0 {
    margin-left: 0rem;
  }

  .pl-xs-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 0) {
  .ml-xs-1 {
    margin-left: 1rem;
  }

  .pl-xs-1 {
    padding-left: 1rem;
  }
}
@media (min-width: 0) {
  .ml-xs-2 {
    margin-left: 2rem;
  }

  .pl-xs-2 {
    padding-left: 2rem;
  }
}
@media (min-width: 0) {
  .ml-xs-3 {
    margin-left: 3rem;
  }

  .pl-xs-3 {
    padding-left: 3rem;
  }
}
@media (min-width: 0) {
  .ml-xs-4 {
    margin-left: 4rem;
  }

  .pl-xs-4 {
    padding-left: 4rem;
  }
}
@media (min-width: 0) {
  .ml-xs-5 {
    margin-left: 5rem;
  }

  .pl-xs-5 {
    padding-left: 5rem;
  }
}
@media (min-width: 0) {
  .ml-xs-6 {
    margin-left: 6rem;
  }

  .pl-xs-6 {
    padding-left: 6rem;
  }
}
@media (min-width: 0) {
  .ml-xs-7 {
    margin-left: 7rem;
  }

  .pl-xs-7 {
    padding-left: 7rem;
  }
}
@media (min-width: 0) {
  .ml-xs-8 {
    margin-left: 8rem;
  }

  .pl-xs-8 {
    padding-left: 8rem;
  }
}
@media (min-width: 0) {
  .ml-xs-9 {
    margin-left: 9rem;
  }

  .pl-xs-9 {
    padding-left: 9rem;
  }
}
@media (min-width: 0) {
  .ml-xs-10 {
    margin-left: 10rem;
  }

  .pl-xs-10 {
    padding-left: 10rem;
  }
}
@media (min-width: 0) {
  .mr-xs-0 {
    margin-right: 0rem;
  }

  .pr-xs-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 0) {
  .mr-xs-1 {
    margin-right: 1rem;
  }

  .pr-xs-1 {
    padding-right: 1rem;
  }
}
@media (min-width: 0) {
  .mr-xs-2 {
    margin-right: 2rem;
  }

  .pr-xs-2 {
    padding-right: 2rem;
  }
}
@media (min-width: 0) {
  .mr-xs-3 {
    margin-right: 3rem;
  }

  .pr-xs-3 {
    padding-right: 3rem;
  }
}
@media (min-width: 0) {
  .mr-xs-4 {
    margin-right: 4rem;
  }

  .pr-xs-4 {
    padding-right: 4rem;
  }
}
@media (min-width: 0) {
  .mr-xs-5 {
    margin-right: 5rem;
  }

  .pr-xs-5 {
    padding-right: 5rem;
  }
}
@media (min-width: 0) {
  .mr-xs-6 {
    margin-right: 6rem;
  }

  .pr-xs-6 {
    padding-right: 6rem;
  }
}
@media (min-width: 0) {
  .mr-xs-7 {
    margin-right: 7rem;
  }

  .pr-xs-7 {
    padding-right: 7rem;
  }
}
@media (min-width: 0) {
  .mr-xs-8 {
    margin-right: 8rem;
  }

  .pr-xs-8 {
    padding-right: 8rem;
  }
}
@media (min-width: 0) {
  .mr-xs-9 {
    margin-right: 9rem;
  }

  .pr-xs-9 {
    padding-right: 9rem;
  }
}
@media (min-width: 0) {
  .mr-xs-10 {
    margin-right: 10rem;
  }

  .pr-xs-10 {
    padding-right: 10rem;
  }
}
@media (min-width: 40em) {
  .m-sm-0 {
    margin: 0rem;
  }

  .p-sm-0 {
    padding: 0rem;
  }
}
@media (min-width: 40em) {
  .m-sm-1 {
    margin: 1rem;
  }

  .p-sm-1 {
    padding: 1rem;
  }
}
@media (min-width: 40em) {
  .m-sm-2 {
    margin: 2rem;
  }

  .p-sm-2 {
    padding: 2rem;
  }
}
@media (min-width: 40em) {
  .m-sm-3 {
    margin: 3rem;
  }

  .p-sm-3 {
    padding: 3rem;
  }
}
@media (min-width: 40em) {
  .m-sm-4 {
    margin: 4rem;
  }

  .p-sm-4 {
    padding: 4rem;
  }
}
@media (min-width: 40em) {
  .m-sm-5 {
    margin: 5rem;
  }

  .p-sm-5 {
    padding: 5rem;
  }
}
@media (min-width: 40em) {
  .m-sm-6 {
    margin: 6rem;
  }

  .p-sm-6 {
    padding: 6rem;
  }
}
@media (min-width: 40em) {
  .m-sm-7 {
    margin: 7rem;
  }

  .p-sm-7 {
    padding: 7rem;
  }
}
@media (min-width: 40em) {
  .m-sm-8 {
    margin: 8rem;
  }

  .p-sm-8 {
    padding: 8rem;
  }
}
@media (min-width: 40em) {
  .m-sm-9 {
    margin: 9rem;
  }

  .p-sm-9 {
    padding: 9rem;
  }
}
@media (min-width: 40em) {
  .m-sm-10 {
    margin: 10rem;
  }

  .p-sm-10 {
    padding: 10rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-0 {
    margin-top: 0rem;
  }

  .pt-sm-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-1 {
    margin-top: 1rem;
  }

  .pt-sm-1 {
    padding-top: 1rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-2 {
    margin-top: 2rem;
  }

  .pt-sm-2 {
    padding-top: 2rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-3 {
    margin-top: 3rem;
  }

  .pt-sm-3 {
    padding-top: 3rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-4 {
    margin-top: 4rem;
  }

  .pt-sm-4 {
    padding-top: 4rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-5 {
    margin-top: 5rem;
  }

  .pt-sm-5 {
    padding-top: 5rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-6 {
    margin-top: 6rem;
  }

  .pt-sm-6 {
    padding-top: 6rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-7 {
    margin-top: 7rem;
  }

  .pt-sm-7 {
    padding-top: 7rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-8 {
    margin-top: 8rem;
  }

  .pt-sm-8 {
    padding-top: 8rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-9 {
    margin-top: 9rem;
  }

  .pt-sm-9 {
    padding-top: 9rem;
  }
}
@media (min-width: 40em) {
  .mt-sm-10 {
    margin-top: 10rem;
  }

  .pt-sm-10 {
    padding-top: 10rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-0 {
    margin-bottom: 0rem;
  }

  .pb-sm-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-1 {
    margin-bottom: 1rem;
  }

  .pb-sm-1 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-2 {
    margin-bottom: 2rem;
  }

  .pb-sm-2 {
    padding-bottom: 2rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-3 {
    margin-bottom: 3rem;
  }

  .pb-sm-3 {
    padding-bottom: 3rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-4 {
    margin-bottom: 4rem;
  }

  .pb-sm-4 {
    padding-bottom: 4rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-5 {
    margin-bottom: 5rem;
  }

  .pb-sm-5 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-6 {
    margin-bottom: 6rem;
  }

  .pb-sm-6 {
    padding-bottom: 6rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-7 {
    margin-bottom: 7rem;
  }

  .pb-sm-7 {
    padding-bottom: 7rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-8 {
    margin-bottom: 8rem;
  }

  .pb-sm-8 {
    padding-bottom: 8rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-9 {
    margin-bottom: 9rem;
  }

  .pb-sm-9 {
    padding-bottom: 9rem;
  }
}
@media (min-width: 40em) {
  .mb-sm-10 {
    margin-bottom: 10rem;
  }

  .pb-sm-10 {
    padding-bottom: 10rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-0 {
    margin-left: 0rem;
  }

  .pl-sm-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-1 {
    margin-left: 1rem;
  }

  .pl-sm-1 {
    padding-left: 1rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-2 {
    margin-left: 2rem;
  }

  .pl-sm-2 {
    padding-left: 2rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-3 {
    margin-left: 3rem;
  }

  .pl-sm-3 {
    padding-left: 3rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-4 {
    margin-left: 4rem;
  }

  .pl-sm-4 {
    padding-left: 4rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-5 {
    margin-left: 5rem;
  }

  .pl-sm-5 {
    padding-left: 5rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-6 {
    margin-left: 6rem;
  }

  .pl-sm-6 {
    padding-left: 6rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-7 {
    margin-left: 7rem;
  }

  .pl-sm-7 {
    padding-left: 7rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-8 {
    margin-left: 8rem;
  }

  .pl-sm-8 {
    padding-left: 8rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-9 {
    margin-left: 9rem;
  }

  .pl-sm-9 {
    padding-left: 9rem;
  }
}
@media (min-width: 40em) {
  .ml-sm-10 {
    margin-left: 10rem;
  }

  .pl-sm-10 {
    padding-left: 10rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-0 {
    margin-right: 0rem;
  }

  .pr-sm-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-1 {
    margin-right: 1rem;
  }

  .pr-sm-1 {
    padding-right: 1rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-2 {
    margin-right: 2rem;
  }

  .pr-sm-2 {
    padding-right: 2rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-3 {
    margin-right: 3rem;
  }

  .pr-sm-3 {
    padding-right: 3rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-4 {
    margin-right: 4rem;
  }

  .pr-sm-4 {
    padding-right: 4rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-5 {
    margin-right: 5rem;
  }

  .pr-sm-5 {
    padding-right: 5rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-6 {
    margin-right: 6rem;
  }

  .pr-sm-6 {
    padding-right: 6rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-7 {
    margin-right: 7rem;
  }

  .pr-sm-7 {
    padding-right: 7rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-8 {
    margin-right: 8rem;
  }

  .pr-sm-8 {
    padding-right: 8rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-9 {
    margin-right: 9rem;
  }

  .pr-sm-9 {
    padding-right: 9rem;
  }
}
@media (min-width: 40em) {
  .mr-sm-10 {
    margin-right: 10rem;
  }

  .pr-sm-10 {
    padding-right: 10rem;
  }
}
@media (min-width: 60em) {
  .m-md-0 {
    margin: 0rem;
  }

  .p-md-0 {
    padding: 0rem;
  }
}
@media (min-width: 60em) {
  .m-md-1 {
    margin: 1rem;
  }

  .p-md-1 {
    padding: 1rem;
  }
}
@media (min-width: 60em) {
  .m-md-2 {
    margin: 2rem;
  }

  .p-md-2 {
    padding: 2rem;
  }
}
@media (min-width: 60em) {
  .m-md-3 {
    margin: 3rem;
  }

  .p-md-3 {
    padding: 3rem;
  }
}
@media (min-width: 60em) {
  .m-md-4 {
    margin: 4rem;
  }

  .p-md-4 {
    padding: 4rem;
  }
}
@media (min-width: 60em) {
  .m-md-5 {
    margin: 5rem;
  }

  .p-md-5 {
    padding: 5rem;
  }
}
@media (min-width: 60em) {
  .m-md-6 {
    margin: 6rem;
  }

  .p-md-6 {
    padding: 6rem;
  }
}
@media (min-width: 60em) {
  .m-md-7 {
    margin: 7rem;
  }

  .p-md-7 {
    padding: 7rem;
  }
}
@media (min-width: 60em) {
  .m-md-8 {
    margin: 8rem;
  }

  .p-md-8 {
    padding: 8rem;
  }
}
@media (min-width: 60em) {
  .m-md-9 {
    margin: 9rem;
  }

  .p-md-9 {
    padding: 9rem;
  }
}
@media (min-width: 60em) {
  .m-md-10 {
    margin: 10rem;
  }

  .p-md-10 {
    padding: 10rem;
  }
}
@media (min-width: 60em) {
  .mt-md-0 {
    margin-top: 0rem;
  }

  .pt-md-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 60em) {
  .mt-md-1 {
    margin-top: 1rem;
  }

  .pt-md-1 {
    padding-top: 1rem;
  }
}
@media (min-width: 60em) {
  .mt-md-2 {
    margin-top: 2rem;
  }

  .pt-md-2 {
    padding-top: 2rem;
  }
}
@media (min-width: 60em) {
  .mt-md-3 {
    margin-top: 3rem;
  }

  .pt-md-3 {
    padding-top: 3rem;
  }
}
@media (min-width: 60em) {
  .mt-md-4 {
    margin-top: 4rem;
  }

  .pt-md-4 {
    padding-top: 4rem;
  }
}
@media (min-width: 60em) {
  .mt-md-5 {
    margin-top: 5rem;
  }

  .pt-md-5 {
    padding-top: 5rem;
  }
}
@media (min-width: 60em) {
  .mt-md-6 {
    margin-top: 6rem;
  }

  .pt-md-6 {
    padding-top: 6rem;
  }
}
@media (min-width: 60em) {
  .mt-md-7 {
    margin-top: 7rem;
  }

  .pt-md-7 {
    padding-top: 7rem;
  }
}
@media (min-width: 60em) {
  .mt-md-8 {
    margin-top: 8rem;
  }

  .pt-md-8 {
    padding-top: 8rem;
  }
}
@media (min-width: 60em) {
  .mt-md-9 {
    margin-top: 9rem;
  }

  .pt-md-9 {
    padding-top: 9rem;
  }
}
@media (min-width: 60em) {
  .mt-md-10 {
    margin-top: 10rem;
  }

  .pt-md-10 {
    padding-top: 10rem;
  }
}
@media (min-width: 60em) {
  .mb-md-0 {
    margin-bottom: 0rem;
  }

  .pb-md-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 60em) {
  .mb-md-1 {
    margin-bottom: 1rem;
  }

  .pb-md-1 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 60em) {
  .mb-md-2 {
    margin-bottom: 2rem;
  }

  .pb-md-2 {
    padding-bottom: 2rem;
  }
}
@media (min-width: 60em) {
  .mb-md-3 {
    margin-bottom: 3rem;
  }

  .pb-md-3 {
    padding-bottom: 3rem;
  }
}
@media (min-width: 60em) {
  .mb-md-4 {
    margin-bottom: 4rem;
  }

  .pb-md-4 {
    padding-bottom: 4rem;
  }
}
@media (min-width: 60em) {
  .mb-md-5 {
    margin-bottom: 5rem;
  }

  .pb-md-5 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 60em) {
  .mb-md-6 {
    margin-bottom: 6rem;
  }

  .pb-md-6 {
    padding-bottom: 6rem;
  }
}
@media (min-width: 60em) {
  .mb-md-7 {
    margin-bottom: 7rem;
  }

  .pb-md-7 {
    padding-bottom: 7rem;
  }
}
@media (min-width: 60em) {
  .mb-md-8 {
    margin-bottom: 8rem;
  }

  .pb-md-8 {
    padding-bottom: 8rem;
  }
}
@media (min-width: 60em) {
  .mb-md-9 {
    margin-bottom: 9rem;
  }

  .pb-md-9 {
    padding-bottom: 9rem;
  }
}
@media (min-width: 60em) {
  .mb-md-10 {
    margin-bottom: 10rem;
  }

  .pb-md-10 {
    padding-bottom: 10rem;
  }
}
@media (min-width: 60em) {
  .ml-md-0 {
    margin-left: 0rem;
  }

  .pl-md-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 60em) {
  .ml-md-1 {
    margin-left: 1rem;
  }

  .pl-md-1 {
    padding-left: 1rem;
  }
}
@media (min-width: 60em) {
  .ml-md-2 {
    margin-left: 2rem;
  }

  .pl-md-2 {
    padding-left: 2rem;
  }
}
@media (min-width: 60em) {
  .ml-md-3 {
    margin-left: 3rem;
  }

  .pl-md-3 {
    padding-left: 3rem;
  }
}
@media (min-width: 60em) {
  .ml-md-4 {
    margin-left: 4rem;
  }

  .pl-md-4 {
    padding-left: 4rem;
  }
}
@media (min-width: 60em) {
  .ml-md-5 {
    margin-left: 5rem;
  }

  .pl-md-5 {
    padding-left: 5rem;
  }
}
@media (min-width: 60em) {
  .ml-md-6 {
    margin-left: 6rem;
  }

  .pl-md-6 {
    padding-left: 6rem;
  }
}
@media (min-width: 60em) {
  .ml-md-7 {
    margin-left: 7rem;
  }

  .pl-md-7 {
    padding-left: 7rem;
  }
}
@media (min-width: 60em) {
  .ml-md-8 {
    margin-left: 8rem;
  }

  .pl-md-8 {
    padding-left: 8rem;
  }
}
@media (min-width: 60em) {
  .ml-md-9 {
    margin-left: 9rem;
  }

  .pl-md-9 {
    padding-left: 9rem;
  }
}
@media (min-width: 60em) {
  .ml-md-10 {
    margin-left: 10rem;
  }

  .pl-md-10 {
    padding-left: 10rem;
  }
}
@media (min-width: 60em) {
  .mr-md-0 {
    margin-right: 0rem;
  }

  .pr-md-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 60em) {
  .mr-md-1 {
    margin-right: 1rem;
  }

  .pr-md-1 {
    padding-right: 1rem;
  }
}
@media (min-width: 60em) {
  .mr-md-2 {
    margin-right: 2rem;
  }

  .pr-md-2 {
    padding-right: 2rem;
  }
}
@media (min-width: 60em) {
  .mr-md-3 {
    margin-right: 3rem;
  }

  .pr-md-3 {
    padding-right: 3rem;
  }
}
@media (min-width: 60em) {
  .mr-md-4 {
    margin-right: 4rem;
  }

  .pr-md-4 {
    padding-right: 4rem;
  }
}
@media (min-width: 60em) {
  .mr-md-5 {
    margin-right: 5rem;
  }

  .pr-md-5 {
    padding-right: 5rem;
  }
}
@media (min-width: 60em) {
  .mr-md-6 {
    margin-right: 6rem;
  }

  .pr-md-6 {
    padding-right: 6rem;
  }
}
@media (min-width: 60em) {
  .mr-md-7 {
    margin-right: 7rem;
  }

  .pr-md-7 {
    padding-right: 7rem;
  }
}
@media (min-width: 60em) {
  .mr-md-8 {
    margin-right: 8rem;
  }

  .pr-md-8 {
    padding-right: 8rem;
  }
}
@media (min-width: 60em) {
  .mr-md-9 {
    margin-right: 9rem;
  }

  .pr-md-9 {
    padding-right: 9rem;
  }
}
@media (min-width: 60em) {
  .mr-md-10 {
    margin-right: 10rem;
  }

  .pr-md-10 {
    padding-right: 10rem;
  }
}
@media (min-width: 80em) {
  .m-lg-0 {
    margin: 0rem;
  }

  .p-lg-0 {
    padding: 0rem;
  }
}
@media (min-width: 80em) {
  .m-lg-1 {
    margin: 1rem;
  }

  .p-lg-1 {
    padding: 1rem;
  }
}
@media (min-width: 80em) {
  .m-lg-2 {
    margin: 2rem;
  }

  .p-lg-2 {
    padding: 2rem;
  }
}
@media (min-width: 80em) {
  .m-lg-3 {
    margin: 3rem;
  }

  .p-lg-3 {
    padding: 3rem;
  }
}
@media (min-width: 80em) {
  .m-lg-4 {
    margin: 4rem;
  }

  .p-lg-4 {
    padding: 4rem;
  }
}
@media (min-width: 80em) {
  .m-lg-5 {
    margin: 5rem;
  }

  .p-lg-5 {
    padding: 5rem;
  }
}
@media (min-width: 80em) {
  .m-lg-6 {
    margin: 6rem;
  }

  .p-lg-6 {
    padding: 6rem;
  }
}
@media (min-width: 80em) {
  .m-lg-7 {
    margin: 7rem;
  }

  .p-lg-7 {
    padding: 7rem;
  }
}
@media (min-width: 80em) {
  .m-lg-8 {
    margin: 8rem;
  }

  .p-lg-8 {
    padding: 8rem;
  }
}
@media (min-width: 80em) {
  .m-lg-9 {
    margin: 9rem;
  }

  .p-lg-9 {
    padding: 9rem;
  }
}
@media (min-width: 80em) {
  .m-lg-10 {
    margin: 10rem;
  }

  .p-lg-10 {
    padding: 10rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-0 {
    margin-top: 0rem;
  }

  .pt-lg-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-1 {
    margin-top: 1rem;
  }

  .pt-lg-1 {
    padding-top: 1rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-2 {
    margin-top: 2rem;
  }

  .pt-lg-2 {
    padding-top: 2rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-3 {
    margin-top: 3rem;
  }

  .pt-lg-3 {
    padding-top: 3rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-4 {
    margin-top: 4rem;
  }

  .pt-lg-4 {
    padding-top: 4rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-5 {
    margin-top: 5rem;
  }

  .pt-lg-5 {
    padding-top: 5rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-6 {
    margin-top: 6rem;
  }

  .pt-lg-6 {
    padding-top: 6rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-7 {
    margin-top: 7rem;
  }

  .pt-lg-7 {
    padding-top: 7rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-8 {
    margin-top: 8rem;
  }

  .pt-lg-8 {
    padding-top: 8rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-9 {
    margin-top: 9rem;
  }

  .pt-lg-9 {
    padding-top: 9rem;
  }
}
@media (min-width: 80em) {
  .mt-lg-10 {
    margin-top: 10rem;
  }

  .pt-lg-10 {
    padding-top: 10rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-0 {
    margin-bottom: 0rem;
  }

  .pb-lg-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-1 {
    margin-bottom: 1rem;
  }

  .pb-lg-1 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-2 {
    margin-bottom: 2rem;
  }

  .pb-lg-2 {
    padding-bottom: 2rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-3 {
    margin-bottom: 3rem;
  }

  .pb-lg-3 {
    padding-bottom: 3rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-4 {
    margin-bottom: 4rem;
  }

  .pb-lg-4 {
    padding-bottom: 4rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-5 {
    margin-bottom: 5rem;
  }

  .pb-lg-5 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-6 {
    margin-bottom: 6rem;
  }

  .pb-lg-6 {
    padding-bottom: 6rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-7 {
    margin-bottom: 7rem;
  }

  .pb-lg-7 {
    padding-bottom: 7rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-8 {
    margin-bottom: 8rem;
  }

  .pb-lg-8 {
    padding-bottom: 8rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-9 {
    margin-bottom: 9rem;
  }

  .pb-lg-9 {
    padding-bottom: 9rem;
  }
}
@media (min-width: 80em) {
  .mb-lg-10 {
    margin-bottom: 10rem;
  }

  .pb-lg-10 {
    padding-bottom: 10rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-0 {
    margin-left: 0rem;
  }

  .pl-lg-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-1 {
    margin-left: 1rem;
  }

  .pl-lg-1 {
    padding-left: 1rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-2 {
    margin-left: 2rem;
  }

  .pl-lg-2 {
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-3 {
    margin-left: 3rem;
  }

  .pl-lg-3 {
    padding-left: 3rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-4 {
    margin-left: 4rem;
  }

  .pl-lg-4 {
    padding-left: 4rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-5 {
    margin-left: 5rem;
  }

  .pl-lg-5 {
    padding-left: 5rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-6 {
    margin-left: 6rem;
  }

  .pl-lg-6 {
    padding-left: 6rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-7 {
    margin-left: 7rem;
  }

  .pl-lg-7 {
    padding-left: 7rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-8 {
    margin-left: 8rem;
  }

  .pl-lg-8 {
    padding-left: 8rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-9 {
    margin-left: 9rem;
  }

  .pl-lg-9 {
    padding-left: 9rem;
  }
}
@media (min-width: 80em) {
  .ml-lg-10 {
    margin-left: 10rem;
  }

  .pl-lg-10 {
    padding-left: 10rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-0 {
    margin-right: 0rem;
  }

  .pr-lg-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-1 {
    margin-right: 1rem;
  }

  .pr-lg-1 {
    padding-right: 1rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-2 {
    margin-right: 2rem;
  }

  .pr-lg-2 {
    padding-right: 2rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-3 {
    margin-right: 3rem;
  }

  .pr-lg-3 {
    padding-right: 3rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-4 {
    margin-right: 4rem;
  }

  .pr-lg-4 {
    padding-right: 4rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-5 {
    margin-right: 5rem;
  }

  .pr-lg-5 {
    padding-right: 5rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-6 {
    margin-right: 6rem;
  }

  .pr-lg-6 {
    padding-right: 6rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-7 {
    margin-right: 7rem;
  }

  .pr-lg-7 {
    padding-right: 7rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-8 {
    margin-right: 8rem;
  }

  .pr-lg-8 {
    padding-right: 8rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-9 {
    margin-right: 9rem;
  }

  .pr-lg-9 {
    padding-right: 9rem;
  }
}
@media (min-width: 80em) {
  .mr-lg-10 {
    margin-right: 10rem;
  }

  .pr-lg-10 {
    padding-right: 10rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-0 {
    margin: 0rem;
  }

  .p-xl-0 {
    padding: 0rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-1 {
    margin: 1rem;
  }

  .p-xl-1 {
    padding: 1rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-2 {
    margin: 2rem;
  }

  .p-xl-2 {
    padding: 2rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-3 {
    margin: 3rem;
  }

  .p-xl-3 {
    padding: 3rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-4 {
    margin: 4rem;
  }

  .p-xl-4 {
    padding: 4rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-5 {
    margin: 5rem;
  }

  .p-xl-5 {
    padding: 5rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-6 {
    margin: 6rem;
  }

  .p-xl-6 {
    padding: 6rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-7 {
    margin: 7rem;
  }

  .p-xl-7 {
    padding: 7rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-8 {
    margin: 8rem;
  }

  .p-xl-8 {
    padding: 8rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-9 {
    margin: 9rem;
  }

  .p-xl-9 {
    padding: 9rem;
  }
}
@media (min-width: 112.5em) {
  .m-xl-10 {
    margin: 10rem;
  }

  .p-xl-10 {
    padding: 10rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-0 {
    margin-top: 0rem;
  }

  .pt-xl-0 {
    padding-top: 0rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-1 {
    margin-top: 1rem;
  }

  .pt-xl-1 {
    padding-top: 1rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-2 {
    margin-top: 2rem;
  }

  .pt-xl-2 {
    padding-top: 2rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-3 {
    margin-top: 3rem;
  }

  .pt-xl-3 {
    padding-top: 3rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-4 {
    margin-top: 4rem;
  }

  .pt-xl-4 {
    padding-top: 4rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-5 {
    margin-top: 5rem;
  }

  .pt-xl-5 {
    padding-top: 5rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-6 {
    margin-top: 6rem;
  }

  .pt-xl-6 {
    padding-top: 6rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-7 {
    margin-top: 7rem;
  }

  .pt-xl-7 {
    padding-top: 7rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-8 {
    margin-top: 8rem;
  }

  .pt-xl-8 {
    padding-top: 8rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-9 {
    margin-top: 9rem;
  }

  .pt-xl-9 {
    padding-top: 9rem;
  }
}
@media (min-width: 112.5em) {
  .mt-xl-10 {
    margin-top: 10rem;
  }

  .pt-xl-10 {
    padding-top: 10rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-0 {
    margin-bottom: 0rem;
  }

  .pb-xl-0 {
    padding-bottom: 0rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-1 {
    margin-bottom: 1rem;
  }

  .pb-xl-1 {
    padding-bottom: 1rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-2 {
    margin-bottom: 2rem;
  }

  .pb-xl-2 {
    padding-bottom: 2rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-3 {
    margin-bottom: 3rem;
  }

  .pb-xl-3 {
    padding-bottom: 3rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-4 {
    margin-bottom: 4rem;
  }

  .pb-xl-4 {
    padding-bottom: 4rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-5 {
    margin-bottom: 5rem;
  }

  .pb-xl-5 {
    padding-bottom: 5rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-6 {
    margin-bottom: 6rem;
  }

  .pb-xl-6 {
    padding-bottom: 6rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-7 {
    margin-bottom: 7rem;
  }

  .pb-xl-7 {
    padding-bottom: 7rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-8 {
    margin-bottom: 8rem;
  }

  .pb-xl-8 {
    padding-bottom: 8rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-9 {
    margin-bottom: 9rem;
  }

  .pb-xl-9 {
    padding-bottom: 9rem;
  }
}
@media (min-width: 112.5em) {
  .mb-xl-10 {
    margin-bottom: 10rem;
  }

  .pb-xl-10 {
    padding-bottom: 10rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-0 {
    margin-left: 0rem;
  }

  .pl-xl-0 {
    padding-left: 0rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-1 {
    margin-left: 1rem;
  }

  .pl-xl-1 {
    padding-left: 1rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-2 {
    margin-left: 2rem;
  }

  .pl-xl-2 {
    padding-left: 2rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-3 {
    margin-left: 3rem;
  }

  .pl-xl-3 {
    padding-left: 3rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-4 {
    margin-left: 4rem;
  }

  .pl-xl-4 {
    padding-left: 4rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-5 {
    margin-left: 5rem;
  }

  .pl-xl-5 {
    padding-left: 5rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-6 {
    margin-left: 6rem;
  }

  .pl-xl-6 {
    padding-left: 6rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-7 {
    margin-left: 7rem;
  }

  .pl-xl-7 {
    padding-left: 7rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-8 {
    margin-left: 8rem;
  }

  .pl-xl-8 {
    padding-left: 8rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-9 {
    margin-left: 9rem;
  }

  .pl-xl-9 {
    padding-left: 9rem;
  }
}
@media (min-width: 112.5em) {
  .ml-xl-10 {
    margin-left: 10rem;
  }

  .pl-xl-10 {
    padding-left: 10rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-0 {
    margin-right: 0rem;
  }

  .pr-xl-0 {
    padding-right: 0rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-1 {
    margin-right: 1rem;
  }

  .pr-xl-1 {
    padding-right: 1rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-2 {
    margin-right: 2rem;
  }

  .pr-xl-2 {
    padding-right: 2rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-3 {
    margin-right: 3rem;
  }

  .pr-xl-3 {
    padding-right: 3rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-4 {
    margin-right: 4rem;
  }

  .pr-xl-4 {
    padding-right: 4rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-5 {
    margin-right: 5rem;
  }

  .pr-xl-5 {
    padding-right: 5rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-6 {
    margin-right: 6rem;
  }

  .pr-xl-6 {
    padding-right: 6rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-7 {
    margin-right: 7rem;
  }

  .pr-xl-7 {
    padding-right: 7rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-8 {
    margin-right: 8rem;
  }

  .pr-xl-8 {
    padding-right: 8rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-9 {
    margin-right: 9rem;
  }

  .pr-xl-9 {
    padding-right: 9rem;
  }
}
@media (min-width: 112.5em) {
  .mr-xl-10 {
    margin-right: 10rem;
  }

  .pr-xl-10 {
    padding-right: 10rem;
  }
}
.mb-none {
  margin-bottom: 0 !important;
}

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

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

.mt-none {
  margin-top: 0 !important;
}

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

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

.pl-none {
  padding-left: 0 !important;
}

.pr-none {
  padding-right: 0 !important;
}

/*! Flickity v2.2.1
https://flickity.metafizzy.co
---------------------------------------------- */
.flickity-enabled {
  position: relative;
}

.flickity-enabled:focus {
  outline: none;
}

.flickity-viewport {
  overflow: hidden;
  position: relative;
  height: 100%;
}

.flickity-slider {
  position: absolute;
  width: 100%;
  height: 100%;
}

/* draggable */
.flickity-enabled.is-draggable {
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.flickity-enabled.is-draggable .flickity-viewport {
  cursor: move;
  cursor: -webkit-grab;
  cursor: grab;
}

.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

/* ---- flickity-button ---- */
.flickity-button {
  position: absolute;
  background: hsla(0, 0%, 100%, 0.75);
  border: none;
  color: #333;
}

.flickity-button:hover {
  background: white;
  cursor: pointer;
}

.flickity-button:focus {
  outline: none;
  box-shadow: 0 0 0 5px #19F;
}

.flickity-button:active {
  opacity: 0.6;
}

.flickity-button:disabled {
  opacity: 0.3;
  cursor: auto;
  /* prevent disabled button from capturing pointer up event. #716 */
  pointer-events: none;
}

.flickity-button-icon {
  fill: currentColor;
}

/* ---- previous/next buttons ---- */
.flickity-prev-next-button {
  top: 50%;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  /* vertically center */
  transform: translateY(-50%);
}

.flickity-prev-next-button.previous {
  left: 10px;
}

.flickity-prev-next-button.next {
  right: 10px;
}

/* right to left */
.flickity-rtl .flickity-prev-next-button.previous {
  left: auto;
  right: 10px;
}

.flickity-rtl .flickity-prev-next-button.next {
  right: auto;
  left: 10px;
}

.flickity-prev-next-button .flickity-button-icon {
  position: absolute;
  left: 20%;
  top: 20%;
  width: 60%;
  height: 60%;
}

/* ---- page dots ---- */
.flickity-page-dots {
  position: absolute;
  width: 100%;
  bottom: -25px;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  line-height: 1;
}

.flickity-rtl .flickity-page-dots {
  direction: rtl;
}

.flickity-page-dots .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin: 0 8px;
  background: #333;
  border-radius: 50%;
  opacity: 0.25;
  cursor: pointer;
}

.flickity-page-dots .dot.is-selected {
  opacity: 1;
}

.slbOverlay, .slbWrapOuter, .slbWrap {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.slbOverlay {
  overflow: hidden;
  z-index: 2000;
  background-color: #000;
  opacity: 0.7;
  -webkit-animation: slbOverlay 0.5s;
  animation: slbOverlay 0.5s;
}

.slbWrapOuter {
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 2010;
}

.slbWrap {
  position: absolute;
  text-align: center;
}

.slbWrap:before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

.slbContentOuter {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0px auto;
  padding: 0 1em;
  box-sizing: border-box;
  z-index: 2020;
  text-align: left;
  max-width: 100%;
}

.slbContentEl .slbContentOuter {
  padding: 5em 1em;
}

.slbContent {
  position: relative;
}

.slbContentEl .slbContent {
  -webkit-animation: slbEnter 0.3s;
  animation: slbEnter 0.3s;
  background-color: #fff;
  box-shadow: 0 0.2em 1em rgba(0, 0, 0, 0.4);
}

.slbImageWrap {
  -webkit-animation: slbEnter 0.3s;
  animation: slbEnter 0.3s;
  position: relative;
}

.slbImageWrap:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 5em;
  bottom: 5em;
  display: block;
  z-index: -1;
  box-shadow: 0 0.2em 1em rgba(0, 0, 0, 0.6);
  background-color: #FFF;
}

.slbDirectionNext .slbImageWrap {
  -webkit-animation: slbEnterNext 0.4s;
  animation: slbEnterNext 0.4s;
}

.slbDirectionPrev .slbImageWrap {
  -webkit-animation: slbEnterPrev 0.4s;
  animation: slbEnterPrev 0.4s;
}

.slbImage {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  box-sizing: border-box;
  padding: 5em 0;
  margin: 0 auto;
}

.slbCaption {
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-wrap: normal;
  font-size: 1.4em;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.71429em 0;
  color: #fff;
  color: rgba(255, 255, 255, 0.7);
  text-align: center;
}

.slbCloseBtn, .slbArrow {
  margin: 0;
  padding: 0;
  border: 0;
  cursor: pointer;
  background: none;
}

.slbCloseBtn::-moz-focus-inner, .slbArrow::-moz-focus-inner {
  padding: 0;
  border: 0;
}

.slbCloseBtn:hover, .slbArrow:hover {
  opacity: 0.5;
}

.slbCloseBtn:active, .slbArrow:active {
  opacity: 0.8;
}

.slbCloseBtn {
  -webkit-animation: slbEnter 0.3s;
  animation: slbEnter 0.3s;
  font-size: 3em;
  width: 1.66667em;
  height: 1.66667em;
  line-height: 1.66667em;
  position: absolute;
  right: -0.33333em;
  top: 0;
  color: #fff;
  color: rgba(255, 255, 255, 0.7);
  text-align: center;
}

.slbLoading .slbCloseBtn {
  display: none;
}

.slbLoadingText {
  font-size: 1.4em;
  color: #fff;
  color: rgba(255, 255, 255, 0.9);
}

.slbArrows {
  position: fixed;
  top: 50%;
  left: 0;
  right: 0;
}

.slbLoading .slbArrows {
  display: none;
}

.slbArrow {
  position: absolute;
  top: 50%;
  margin-top: -5em;
  width: 5em;
  height: 10em;
  opacity: 0.7;
  text-indent: -999em;
  overflow: hidden;
}

.slbArrow:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -0.8em 0 0 -0.8em;
  border: 0.8em solid transparent;
}

.slbArrow.next {
  right: 0;
}

.slbArrow.next:before {
  border-left-color: #fff;
}

.slbArrow.prev {
  left: 0;
}

.slbArrow.prev:before {
  border-right-color: #fff;
}

.slbIframeCont {
  width: 80em;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%;
  margin: 5em 0;
}

.slbIframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-shadow: 0 0.2em 1em rgba(0, 0, 0, 0.6);
  background: #000;
}

@-webkit-keyframes slbOverlay {
  from {
    opacity: 0;
  }
  to {
    opacity: 0.7;
  }
}
@keyframes slbOverlay {
  from {
    opacity: 0;
  }
  to {
    opacity: 0.7;
  }
}
@-webkit-keyframes slbEnter {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -1em, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
  }
}
@keyframes slbEnter {
  from {
    opacity: 0;
    transform: translate3d(0, -1em, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@-webkit-keyframes slbEnterNext {
  from {
    opacity: 0;
    -webkit-transform: translate3d(4em, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
  }
}
@keyframes slbEnterNext {
  from {
    opacity: 0;
    transform: translate3d(4em, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@-webkit-keyframes slbEnterPrev {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-4em, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
  }
}
@keyframes slbEnterPrev {
  from {
    opacity: 0;
    transform: translate3d(-4em, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
:root {
  --reflex-columns: 12;
  --reflex-grid-spacing: 1.875rem;
  --reflex-xs: none;
  --reflex-sm: 40em;
  --reflex-md: 60em;
  --reflex-lg: 80em;
  --reflex-xlg: 112.5em;
  --reflex-xxs-max: none-1;
  --reflex-xs-max: 39em;
  --reflex-sm-max: 59em;
  --reflex-md-max: 79em;
  --reflex-lg-max: 111.5em;
}

.container,
.container-full {
  box-sizing: border-box;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1.875rem;
  padding-left: 1.875rem;
}
.container .grid,
.container-full .grid {
  margin-right: -1.875rem;
  margin-left: -1.875rem;
}

.grid {
  box-sizing: border-box;
  display: block;
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin: 0 auto;
  position: relative;
  list-style-type: none;
}
.grid::before, .grid::after {
  box-sizing: border-box;
}

[class*=col-] {
  box-sizing: border-box;
  position: relative;
  width: 100%;
  vertical-align: top;
  padding-left: 1.875rem;
  padding-right: 1.875rem;
}
[class*=col-]::before, [class*=col-]::after {
  box-sizing: border-box;
}
[class*=col-] .grid {
  flex: 1 1 auto;
  margin: -1.875rem;
}

.col-12 {
  width: 100%;
}

.col-11 {
  width: 91.6666666667%;
}

.col-10 {
  width: 83.3333333333%;
}

.col-9 {
  width: 75%;
}

.col-8 {
  width: 66.6666666667%;
}

.col-7 {
  width: 58.3333333333%;
}

.col-6 {
  width: 50%;
}

.col-5 {
  width: 41.6666666667%;
}

.col-4 {
  width: 33.3333333333%;
}

.col-3 {
  width: 25%;
}

.col-2 {
  width: 16.6666666667%;
}

.col-1 {
  width: 8.3333333333%;
}

@media (min-width: none) {
  .col-xs-12 {
    width: 100%;
  }

  .col-xs-11 {
    width: 91.6666666667%;
  }

  .col-xs-10 {
    width: 83.3333333333%;
  }

  .col-xs-9 {
    width: 75%;
  }

  .col-xs-8 {
    width: 66.6666666667%;
  }

  .col-xs-7 {
    width: 58.3333333333%;
  }

  .col-xs-6 {
    width: 50%;
  }

  .col-xs-5 {
    width: 41.6666666667%;
  }

  .col-xs-4 {
    width: 33.3333333333%;
  }

  .col-xs-3 {
    width: 25%;
  }

  .col-xs-2 {
    width: 16.6666666667%;
  }

  .col-xs-1 {
    width: 8.3333333333%;
  }
}
@media (min-width: 40em) {
  .col-sm-12 {
    width: 100%;
  }

  .col-sm-11 {
    width: 91.6666666667%;
  }

  .col-sm-10 {
    width: 83.3333333333%;
  }

  .col-sm-9 {
    width: 75%;
  }

  .col-sm-8 {
    width: 66.6666666667%;
  }

  .col-sm-7 {
    width: 58.3333333333%;
  }

  .col-sm-6 {
    width: 50%;
  }

  .col-sm-5 {
    width: 41.6666666667%;
  }

  .col-sm-4 {
    width: 33.3333333333%;
  }

  .col-sm-3 {
    width: 25%;
  }

  .col-sm-2 {
    width: 16.6666666667%;
  }

  .col-sm-1 {
    width: 8.3333333333%;
  }
}
@media (min-width: 60em) {
  .col-md-12 {
    width: 100%;
  }

  .col-md-11 {
    width: 91.6666666667%;
  }

  .col-md-10 {
    width: 83.3333333333%;
  }

  .col-md-9 {
    width: 75%;
  }

  .col-md-8 {
    width: 66.6666666667%;
  }

  .col-md-7 {
    width: 58.3333333333%;
  }

  .col-md-6 {
    width: 50%;
  }

  .col-md-5 {
    width: 41.6666666667%;
  }

  .col-md-4 {
    width: 33.3333333333%;
  }

  .col-md-3 {
    width: 25%;
  }

  .col-md-2 {
    width: 16.6666666667%;
  }

  .col-md-1 {
    width: 8.3333333333%;
  }
}
@media (min-width: 80em) {
  .col-lg-12 {
    width: 100%;
  }

  .col-lg-11 {
    width: 91.6666666667%;
  }

  .col-lg-10 {
    width: 83.3333333333%;
  }

  .col-lg-9 {
    width: 75%;
  }

  .col-lg-8 {
    width: 66.6666666667%;
  }

  .col-lg-7 {
    width: 58.3333333333%;
  }

  .col-lg-6 {
    width: 50%;
  }

  .col-lg-5 {
    width: 41.6666666667%;
  }

  .col-lg-4 {
    width: 33.3333333333%;
  }

  .col-lg-3 {
    width: 25%;
  }

  .col-lg-2 {
    width: 16.6666666667%;
  }

  .col-lg-1 {
    width: 8.3333333333%;
  }
}
@media (min-width: 112.5em) {
  .col-xlg-12 {
    width: 100%;
  }

  .col-xlg-11 {
    width: 91.6666666667%;
  }

  .col-xlg-10 {
    width: 83.3333333333%;
  }

  .col-xlg-9 {
    width: 75%;
  }

  .col-xlg-8 {
    width: 66.6666666667%;
  }

  .col-xlg-7 {
    width: 58.3333333333%;
  }

  .col-xlg-6 {
    width: 50%;
  }

  .col-xlg-5 {
    width: 41.6666666667%;
  }

  .col-xlg-4 {
    width: 33.3333333333%;
  }

  .col-xlg-3 {
    width: 25%;
  }

  .col-xlg-2 {
    width: 16.6666666667%;
  }

  .col-xlg-1 {
    width: 8.3333333333%;
  }
}
.col-auto {
  flex: 1 0 0px;
}

@media (min-width: none) {
  .col-xs-auto {
    flex: 1 0 0px;
  }
}
@media (min-width: 40em) {
  .col-sm-auto {
    flex: 1 0 0px;
  }
}
@media (min-width: 60em) {
  .col-md-auto {
    flex: 1 0 0px;
  }
}
@media (min-width: 80em) {
  .col-lg-auto {
    flex: 1 0 0px;
  }
}
@media (min-width: 112.5em) {
  .col-xlg-auto {
    flex: 1 0 0px;
  }
}
.order-12 {
  order: 12;
}

.order-11 {
  order: 11;
}

.order-10 {
  order: 10;
}

.order-9 {
  order: 9;
}

.order-8 {
  order: 8;
}

.order-7 {
  order: 7;
}

.order-6 {
  order: 6;
}

.order-5 {
  order: 5;
}

.order-4 {
  order: 4;
}

.order-3 {
  order: 3;
}

.order-2 {
  order: 2;
}

.order-1 {
  order: 1;
}

.order-0 {
  order: 0;
}

@media only screen and (min-width: none) {
  .order-xs-12 {
    order: 12;
  }

  .order-xs-11 {
    order: 11;
  }

  .order-xs-10 {
    order: 10;
  }

  .order-xs-9 {
    order: 9;
  }

  .order-xs-8 {
    order: 8;
  }

  .order-xs-7 {
    order: 7;
  }

  .order-xs-6 {
    order: 6;
  }

  .order-xs-5 {
    order: 5;
  }

  .order-xs-4 {
    order: 4;
  }

  .order-xs-3 {
    order: 3;
  }

  .order-xs-2 {
    order: 2;
  }

  .order-xs-1 {
    order: 1;
  }

  .order-xs-0 {
    order: 0;
  }
}
@media only screen and (min-width: 40em) {
  .order-sm-12 {
    order: 12;
  }

  .order-sm-11 {
    order: 11;
  }

  .order-sm-10 {
    order: 10;
  }

  .order-sm-9 {
    order: 9;
  }

  .order-sm-8 {
    order: 8;
  }

  .order-sm-7 {
    order: 7;
  }

  .order-sm-6 {
    order: 6;
  }

  .order-sm-5 {
    order: 5;
  }

  .order-sm-4 {
    order: 4;
  }

  .order-sm-3 {
    order: 3;
  }

  .order-sm-2 {
    order: 2;
  }

  .order-sm-1 {
    order: 1;
  }

  .order-sm-0 {
    order: 0;
  }
}
@media only screen and (min-width: 60em) {
  .order-md-12 {
    order: 12;
  }

  .order-md-11 {
    order: 11;
  }

  .order-md-10 {
    order: 10;
  }

  .order-md-9 {
    order: 9;
  }

  .order-md-8 {
    order: 8;
  }

  .order-md-7 {
    order: 7;
  }

  .order-md-6 {
    order: 6;
  }

  .order-md-5 {
    order: 5;
  }

  .order-md-4 {
    order: 4;
  }

  .order-md-3 {
    order: 3;
  }

  .order-md-2 {
    order: 2;
  }

  .order-md-1 {
    order: 1;
  }

  .order-md-0 {
    order: 0;
  }
}
@media only screen and (min-width: 80em) {
  .order-lg-12 {
    order: 12;
  }

  .order-lg-11 {
    order: 11;
  }

  .order-lg-10 {
    order: 10;
  }

  .order-lg-9 {
    order: 9;
  }

  .order-lg-8 {
    order: 8;
  }

  .order-lg-7 {
    order: 7;
  }

  .order-lg-6 {
    order: 6;
  }

  .order-lg-5 {
    order: 5;
  }

  .order-lg-4 {
    order: 4;
  }

  .order-lg-3 {
    order: 3;
  }

  .order-lg-2 {
    order: 2;
  }

  .order-lg-1 {
    order: 1;
  }

  .order-lg-0 {
    order: 0;
  }
}
@media only screen and (min-width: 112.5em) {
  .order-xlg-12 {
    order: 12;
  }

  .order-xlg-11 {
    order: 11;
  }

  .order-xlg-10 {
    order: 10;
  }

  .order-xlg-9 {
    order: 9;
  }

  .order-xlg-8 {
    order: 8;
  }

  .order-xlg-7 {
    order: 7;
  }

  .order-xlg-6 {
    order: 6;
  }

  .order-xlg-5 {
    order: 5;
  }

  .order-xlg-4 {
    order: 4;
  }

  .order-xlg-3 {
    order: 3;
  }

  .order-xlg-2 {
    order: 2;
  }

  .order-xlg-1 {
    order: 1;
  }

  .order-xlg-0 {
    order: 0;
  }
}
.offset-11 {
  margin-left: 91.6666666667%;
}

.offset-10 {
  margin-left: 83.3333333333%;
}

.offset-9 {
  margin-left: 75%;
}

.offset-8 {
  margin-left: 66.6666666667%;
}

.offset-7 {
  margin-left: 58.3333333333%;
}

.offset-6 {
  margin-left: 50%;
}

.offset-5 {
  margin-left: 41.6666666667%;
}

.offset-4 {
  margin-left: 33.3333333333%;
}

.offset-3 {
  margin-left: 25%;
}

.offset-2 {
  margin-left: 16.6666666667%;
}

.offset-1 {
  margin-left: 8.3333333333%;
}

@media only screen and (min-width: none) {
  .offset-xs-11 {
    margin-left: 91.6666666667%;
  }

  .offset-xs-10 {
    margin-left: 83.3333333333%;
  }

  .offset-xs-9 {
    margin-left: 75%;
  }

  .offset-xs-8 {
    margin-left: 66.6666666667%;
  }

  .offset-xs-7 {
    margin-left: 58.3333333333%;
  }

  .offset-xs-6 {
    margin-left: 50%;
  }

  .offset-xs-5 {
    margin-left: 41.6666666667%;
  }

  .offset-xs-4 {
    margin-left: 33.3333333333%;
  }

  .offset-xs-3 {
    margin-left: 25%;
  }

  .offset-xs-2 {
    margin-left: 16.6666666667%;
  }

  .offset-xs-1 {
    margin-left: 8.3333333333%;
  }

  .offset-xs-0 {
    margin-left: 0;
  }
}
@media only screen and (min-width: 40em) {
  .offset-sm-11 {
    margin-left: 91.6666666667%;
  }

  .offset-sm-10 {
    margin-left: 83.3333333333%;
  }

  .offset-sm-9 {
    margin-left: 75%;
  }

  .offset-sm-8 {
    margin-left: 66.6666666667%;
  }

  .offset-sm-7 {
    margin-left: 58.3333333333%;
  }

  .offset-sm-6 {
    margin-left: 50%;
  }

  .offset-sm-5 {
    margin-left: 41.6666666667%;
  }

  .offset-sm-4 {
    margin-left: 33.3333333333%;
  }

  .offset-sm-3 {
    margin-left: 25%;
  }

  .offset-sm-2 {
    margin-left: 16.6666666667%;
  }

  .offset-sm-1 {
    margin-left: 8.3333333333%;
  }

  .offset-sm-0 {
    margin-left: 0;
  }
}
@media only screen and (min-width: 60em) {
  .offset-md-11 {
    margin-left: 91.6666666667%;
  }

  .offset-md-10 {
    margin-left: 83.3333333333%;
  }

  .offset-md-9 {
    margin-left: 75%;
  }

  .offset-md-8 {
    margin-left: 66.6666666667%;
  }

  .offset-md-7 {
    margin-left: 58.3333333333%;
  }

  .offset-md-6 {
    margin-left: 50%;
  }

  .offset-md-5 {
    margin-left: 41.6666666667%;
  }

  .offset-md-4 {
    margin-left: 33.3333333333%;
  }

  .offset-md-3 {
    margin-left: 25%;
  }

  .offset-md-2 {
    margin-left: 16.6666666667%;
  }

  .offset-md-1 {
    margin-left: 8.3333333333%;
  }

  .offset-md-0 {
    margin-left: 0;
  }
}
@media only screen and (min-width: 80em) {
  .offset-lg-11 {
    margin-left: 91.6666666667%;
  }

  .offset-lg-10 {
    margin-left: 83.3333333333%;
  }

  .offset-lg-9 {
    margin-left: 75%;
  }

  .offset-lg-8 {
    margin-left: 66.6666666667%;
  }

  .offset-lg-7 {
    margin-left: 58.3333333333%;
  }

  .offset-lg-6 {
    margin-left: 50%;
  }

  .offset-lg-5 {
    margin-left: 41.6666666667%;
  }

  .offset-lg-4 {
    margin-left: 33.3333333333%;
  }

  .offset-lg-3 {
    margin-left: 25%;
  }

  .offset-lg-2 {
    margin-left: 16.6666666667%;
  }

  .offset-lg-1 {
    margin-left: 8.3333333333%;
  }

  .offset-lg-0 {
    margin-left: 0;
  }
}
@media only screen and (min-width: 112.5em) {
  .offset-xlg-11 {
    margin-left: 91.6666666667%;
  }

  .offset-xlg-10 {
    margin-left: 83.3333333333%;
  }

  .offset-xlg-9 {
    margin-left: 75%;
  }

  .offset-xlg-8 {
    margin-left: 66.6666666667%;
  }

  .offset-xlg-7 {
    margin-left: 58.3333333333%;
  }

  .offset-xlg-6 {
    margin-left: 50%;
  }

  .offset-xlg-5 {
    margin-left: 41.6666666667%;
  }

  .offset-xlg-4 {
    margin-left: 33.3333333333%;
  }

  .offset-xlg-3 {
    margin-left: 25%;
  }

  .offset-xlg-2 {
    margin-left: 16.6666666667%;
  }

  .offset-xlg-1 {
    margin-left: 8.3333333333%;
  }

  .offset-xlg-0 {
    margin-left: 0;
  }
}
.wrap {
  flex-wrap: wrap;
}

.no-wrap {
  flex-wrap: nowrap;
}
.no-wrap [class*=col-] {
  flex-shrink: 1;
}

.wrap-reverse {
  flex-wrap: wrap-reverse;
}

.direction-row {
  flex-direction: row;
}

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

.direction-column {
  flex-direction: column;
}

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

.align-start {
  align-items: flex-start;
}

.align-end {
  align-items: flex-end;
}

.align-center {
  align-items: center;
}

.align-baseline {
  align-items: baseline;
}

.align-content-start {
  align-content: flex-start;
}

.align-content-end {
  align-content: flex-end;
}
.align-content-end [class*=col-] {
  vertical-align: bottom;
}

.align-content-center {
  align-content: center;
}

.align-content-space-between {
  align-content: space-between;
}

.align-content-space-around {
  align-content: space-around;
}

.align-self-stretch {
  align-self: stretch;
}

.align-self-start {
  align-self: flex-start;
}

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

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

.align-self-baseline {
  align-self: baseline;
  vertical-align: baseline;
}

.justify-start {
  justify-content: flex-start;
}

.justify-end {
  justify-content: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-space-between {
  justify-content: space-between;
}

.justify-space-around {
  justify-content: space-around;
}

.grid-bleed [class*=col-] {
  padding: 0;
}

.col-grid {
  display: flex;
  flex-direction: column;
}
.col-grid.direction-row {
  flex-direction: row;
}

.col-bleed {
  padding: 0;
}

.col-bleed-x {
  padding: 1.875rem 0;
}

.col-bleed-y {
  padding: 0 1.875rem;
}

.flex-img {
  display: block;
  flex: 0 0 auto;
  max-width: 100%;
  height: auto;
  width: 100%;
}

.flex-footer {
  width: 100%;
  margin-top: auto;
  margin-bottom: 0;
}
.flex-footer > :last-child {
  margin-bottom: 0;
}

@media (max-width: none-1) {
  .hidden-xxs {
    display: none;
  }
}

@media (min-width: none) and (max-width: 39em) {
  .hidden-xs {
    display: none;
  }
}

@media (min-width: 40em) and (max-width: 59em) {
  .hidden-sm {
    display: none;
  }
}

@media (min-width: 60em) and (max-width: 79em) {
  .hidden-md {
    display: none;
  }
}

@media (min-width: 80em) and (max-width: 111.5em) {
  .hidden-lg {
    display: none;
  }
}

@media (min-width: 112.5em) {
  .hidden-xlg {
    display: none;
  }
}

/*
 * SimpleLightbox Overrides
 *
 *****************************************************************************/
.slbElement {
  position: absolute;
  z-index: 9999999;
}

.slbOverlay {
  background-color: #0b2637;
}

.slbContent {
  max-width: 60em;
}

.contentInPopup {
  padding: 1rem;
}

.noticePopup .slbContent {
  max-width: 32em;
}

.slbCloseBtn {
  color: #fff;
  transition: opacity 0.2s linear;
}

/*
 * Base Syles
 *
 * This file contains very basic styles.
 *
 *****************************************************************************/
html {
  font-size: 100%;
}

body {
  line-height: 1.5;
  min-height: 100vh;
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

ul[class],
ol[class] {
  padding: 0;
}

body,
h1,
h2,
h3,
h4,
p,
ul[class],
ol[class],
li,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}

ul[class],
ol[class] {
  list-style: none;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

img {
  display: block;
  max-width: 100%;
}

article > * + * {
  margin-top: 1rem;
}

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

textarea {
  min-height: 150px;
  resize: none;
}

input[type=color],
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week],
input:not([type]),
textarea {
  background: transparent;
  border: none;
  border-radius: 0;
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
}
input[type=color]:focus,
input[type=date]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=email]:focus,
input[type=month]:focus,
input[type=number]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=text]:focus,
input[type=time]:focus,
input[type=url]:focus,
input[type=week]:focus,
input:not([type]):focus,
textarea:focus {
  outline: 0;
}
input[type=color]:required,
input[type=date]:required,
input[type=datetime]:required,
input[type=datetime-local]:required,
input[type=email]:required,
input[type=month]:required,
input[type=number]:required,
input[type=password]:required,
input[type=search]:required,
input[type=tel]:required,
input[type=text]:required,
input[type=time]:required,
input[type=url]:required,
input[type=week]:required,
input:not([type]):required,
textarea:required {
  box-shadow: none;
}

select::-ms-expand {
  display: none;
}

button,
input[type=button],
input[type=reset],
input[type=submit] {
  background-color: transparent;
  border: none;
  color: #000;
  cursor: pointer;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
}
button:active, button:focus,
input[type=button]:active,
input[type=button]:focus,
input[type=reset]:active,
input[type=reset]:focus,
input[type=submit]:active,
input[type=submit]:focus {
  outline: 0;
}

::-webkit-input-placeholder {
  color: #000;
}

::-moz-placeholder {
  color: #000;
}

:-moz-placeholder {
  color: #000;
}

:-ms-input-placeholder {
  color: #000;
}

strong,
b {
  font-weight: 700;
}

em,
i {
  font-style: italic;
}

hr {
  background-color: #cccccc;
  border: 0;
  display: block;
  height: 1px;
  margin: 0;
  padding: 0;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  * {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}
video,
embed {
  display: block;
  margin: 0 auto;
  max-width: 100%;
}

/*
 * Webfonts
 *
 * This file contains all @font-face declarations, if any.
 *
 *****************************************************************************/
/*
 * Typography
 *
 * This file collects some basic typography styles for copy text.
 *
 *****************************************************************************/
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #000;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 400;
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.25;
  margin: 0 0 1rem;
}

h1,
.size-h1 {
  font-size: calc(1.625rem + 4.5vw);
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
  line-height: 1.125;
}
@media (min-width: 1200px) {
  h1,
.size-h1 {
    font-size: 5rem;
  }
}

h2,
.size-h2 {
  font-size: calc(1.35rem + 1.2vw);
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
}
@media (min-width: 1200px) {
  h2,
.size-h2 {
    font-size: 2.25rem;
  }
}

h3,
.size-h3 {
  font-size: calc(1.275rem + 0.3vw);
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
}
@media (min-width: 1200px) {
  h3,
.size-h3 {
    font-size: 1.5rem;
  }
}

h4,
.size-h4 {
  font-size: calc(1.2625rem + 0.15vw);
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
}
@media (min-width: 1200px) {
  h4,
.size-h4 {
    font-size: 1.375rem;
  }
}

h5,
.size-h5 {
  font-size: 1rem;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
}

.kicker {
  font-size: 1.125rem;
  color: inherit;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
}
.kicker--divider {
  margin-bottom: 1.5rem;
  padding-bottom: 1.25rem;
  position: relative;
}
.kicker--divider::after {
  width: 70px;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  background-color: #c1761e;
  content: "";
}
.kicker--divider-navy::after {
  background-color: #0b2637;
}
.kicker--center::after {
  margin-left: auto;
  margin-right: auto;
  right: 0;
}

.heading-divider {
  padding-top: 2rem;
  position: relative;
}
.heading-divider::before {
  width: 70px;
  height: 3px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: #c1761e;
  content: "";
}
.heading-divider--navy::before {
  background-color: #0b2637;
}
.heading-divider--lg {
  margin-top: 1.5rem;
}
.heading-divider--lg::before {
  width: 150px;
}

p {
  font-size: 1.125rem;
  margin-bottom: 1rem;
}
p.lead {
  font-size: calc(1.275rem + 0.3vw);
  font-weight: 400;
  line-height: 1.25;
  margin-bottom: 1.5rem;
}
@media (min-width: 1200px) {
  p.lead {
    font-size: 1.5rem;
  }
}

a {
  color: gray;
  text-decoration: none;
  transition: color 0.2s ease-in-out;
}
a:hover {
  color: #537191;
}

.font-sans {
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
}

.font-serif {
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
}

.callout-text {
  font-size: calc(1.4rem + 1.8vw);
  color: #000;
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
  line-height: 1.25;
  text-transform: uppercase;
}
@media (min-width: 1200px) {
  .callout-text {
    font-size: 2.75rem;
  }
}

/*
 * Helper Classes
 *
 * This file contains CSS helper classes.
 *
 *****************************************************************************/
.clearfix::after {
  clear: both;
  content: "";
  display: table;
}

.hide-text {
  overflow: hidden;
  text-indent: 101%;
  white-space: nowrap;
}

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

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

.text-center {
  text-align: center;
}

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

.d-block {
  display: block;
}

.d-inline {
  display: inline;
}

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

.width-fluid {
  width: 100%;
}

.responsive-container {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}
.responsive-container iframe,
.responsive-container object,
.responsive-container embed,
.responsive-container video,
.responsive-container img {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.bg-white {
  background-color: #fff;
}
.bg-white + .bg-white {
  padding-top: 0;
}

.bg-navy {
  background-color: #0b2637;
  color: #fff;
}
.bg-navy + .bg-navy {
  padding-top: 0;
}
.bg-navy--gradient::after {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../images/bg-gradient-navy.svg") no-repeat center top;
  background-size: cover;
  content: "";
}
.bg-navy .btn:hover, .bg-navy .nf-form-cont .ninja-forms-field[type=button]:hover, .nf-form-cont .bg-navy .ninja-forms-field[type=button]:hover, .bg-navy input[type=button]:hover,
.bg-navy input[type=reset]:hover,
.bg-navy input[type=submit]:hover, .bg-navy .btn:active, .bg-navy .nf-form-cont .ninja-forms-field[type=button]:active, .nf-form-cont .bg-navy .ninja-forms-field[type=button]:active, .bg-navy input[type=button]:active,
.bg-navy input[type=reset]:active,
.bg-navy input[type=submit]:active, .bg-navy .btn:focus, .bg-navy .nf-form-cont .ninja-forms-field[type=button]:focus, .nf-form-cont .bg-navy .ninja-forms-field[type=button]:focus, .bg-navy input[type=button]:focus,
.bg-navy input[type=reset]:focus,
.bg-navy input[type=submit]:focus {
  background-color: #fff;
  border-color: #fff;
  color: #0b2637;
}

.bg-copper {
  background-color: #c1761e;
  color: #fff;
}
.bg-copper + .bg-copper {
  padding-top: 0;
}
.bg-copper--gradient::after {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../images/bg-gradient-copper.svg") no-repeat center top;
  background-size: cover;
  content: "";
}

/*
 * FX
 *
 * This file contains classes for animation effects.
 *
 *****************************************************************************/
.scroll-watch.fx-fade-up {
  opacity: 0;
  transform: translate3d(0, 2rem, 0);
  transition: opacity 1s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.scroll-watch.fx-img-reveal::after {
  background: #537191;
  background: #537191;
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.scroll-watch.fx-img-reveal .img-reveal {
  opacity: 0;
  position: relative;
  transform: scale(1.2);
  transition: opacity 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 2;
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(1) {
    transition-delay: 0.1s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(2) {
    transition-delay: 0.2s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(3) {
    transition-delay: 0.3s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(4) {
    transition-delay: 0.4s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(5) {
    transition-delay: 0.5s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(6) {
    transition-delay: 0.6s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(7) {
    transition-delay: 0.7s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(8) {
    transition-delay: 0.8s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(9) {
    transition-delay: 0.9s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(10) {
    transition-delay: 1s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(11) {
    transition-delay: 1.1s;
  }
}
@media (min-width: 60em) {
  .scroll-watch.fx-stagger:nth-child(12) {
    transition-delay: 1.2s;
  }
}
.scroll-watch.in-view.fx-fade-up {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.scroll-watch.in-view.fx-img-reveal .img-reveal {
  opacity: 1;
  transform: scale(1);
}

.mask-reveal {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: #333;
  transform: translate3d(0, 0, 0);
  transform-origin: top left;
}

/*
 * General Container Elements
 *
 * This file contains the site top-level and general wrapper elements.
 *
 *****************************************************************************/
.site {
  position: relative;
}
@media (max-width: 39.99em) {
  .site::after {
    width: 100%;
    height: 100vh;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
    perspective: 1000;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99;
    background-color: #e1e5ea;
    content: "";
    transform: scaleY(0);
    transform-origin: top left;
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
}

.section {
  position: relative;
}
.section .container,
.section .grid {
  position: relative;
  z-index: 2;
}

.spacer {
  margin-bottom: 3rem;
  margin-top: 3rem;
}

.spacer-x2 {
  margin-bottom: 3rem;
  margin-top: 3rem;
}
@media (min-width: 60em) {
  .spacer-x2 {
    margin-bottom: 5rem;
    margin-top: 5rem;
  }
}

.padder {
  padding-bottom: 3rem;
  padding-top: 3rem;
}

.padder-x2 {
  padding-bottom: 3rem;
  padding-top: 3rem;
}
@media (min-width: 60em) {
  .padder-x2 {
    padding-bottom: 5rem;
    padding-top: 5rem;
  }
}

.container {
  margin-left: auto;
  margin-right: auto;
}
.container.width-sm {
  max-width: 40em;
}
.container.width-md {
  max-width: 60em;
}
.container.width-lg {
  max-width: 80em;
}
.container.width-xl {
  max-width: 112.5em;
}
.container.fluid {
  max-width: none;
}

/*
 * Site Header
 *
 * This file contains styles that are specific to the site header.
 *
 *****************************************************************************/
.site-header {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  perspective: 1000;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  width: 100%;
}
.site-header__layout {
  align-items: center;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  display: flex;
  height: 112px;
  padding: 1rem 1.875rem;
  position: relative;
  transform: translateZ(0);
  transition: background-color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), height 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.site-header__layout::after {
  width: calc(100% - 175px);
  height: 1px;
  position: absolute;
  right: 1.875rem;
  bottom: 35px;
  z-index: 1;
  background-color: #fff;
  content: "";
  transition: opacity 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.site-header__title {
  width: 80px;
  height: 80px;
  flex: 0 0 80px;
  transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.site-header__logo {
  fill: #fff;
  transition: fill 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.site-header__navigation {
  width: 100%;
}
@media (max-width: 39.99em) {
  .site-header__navigation {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    display: flex;
    overflow: auto;
    padding: 100px 1.875rem 1.875rem;
    text-align: center;
  }
}
@media (min-width: 40em) {
  .site-header__navigation {
    transform: translateY(-50%);
    transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
}
@media (max-width: 39.99em) {
  .site-header__navigation .menu {
    margin: auto;
    opacity: 0;
    transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
}
@media (min-width: 40em) {
  .site-header__navigation .menu {
    display: flex;
    justify-content: flex-end;
  }
}
@media (min-width: 40em) {
  .site-header__navigation .menu__item {
    margin-left: 5%;
  }
}
.site-header__navigation .menu__link {
  color: #fff;
  display: block;
}
@media (max-width: 39.99em) {
  .site-header__navigation .menu__link {
    font-size: calc(1.625rem + 4.5vw);
    font-family: "calluna", "Georgia", "Times New Roman", serif;
    font-weight: 400;
    line-height: 1.125;
    color: #0b2637;
    line-height: 1.25;
    padding: 1rem 0;
  }
}
@media (max-width: 39.99em) and (min-width: 1200px) {
  .site-header__navigation .menu__link {
    font-size: 5rem;
  }
}
@media (min-width: 40em) {
  .site-header__navigation .menu__link {
    font-weight: 700;
    letter-spacing: 0.03125rem;
    text-transform: uppercase;
  }
}
.site-header__navigation .menu__link:hover {
  color: #c1761e !important;
}

.main-nav-toggle {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  perspective: 1000;
  position: fixed;
  top: 1rem;
  right: 1.75rem;
  z-index: 99;
  width: 48px;
  height: 48px;
  display: block;
  overflow: hidden;
  padding: 0;
}
@media (min-width: 40em) {
  .main-nav-toggle {
    display: none;
  }
}
.main-nav-toggle .menu-icon {
  width: 30px;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  display: block;
  margin: auto;
}
.main-nav-toggle .menu-icon__slice {
  width: 100%;
  height: 2px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #c1761e;
  display: block;
  margin: auto;
  outline: 1px solid transparent;
  transform: translateZ(0);
  transform-origin: center center;
  transition: all 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.main-nav-toggle .menu-icon__slice:first-child {
  transform: translate3d(0, 8px, 0);
}
.main-nav-toggle .menu-icon__slice:last-child {
  transform: translate3d(0, -8px, 0);
}

.headroom {
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.headroom--not-top .site-header__layout {
  background-color: #fff;
  height: 90px;
}
.headroom--not-top .site-header__layout::after {
  opacity: 0;
}
.headroom--not-top .site-header__title {
  transform: scale(0.8);
}
.headroom--not-top .site-header__logo {
  fill: #537191;
}
@media (min-width: 40em) {
  .headroom--not-top .site-header__navigation {
    transform: translateY(0);
  }
}
.headroom--not-top .site-header__navigation .menu__link {
  color: #000;
}

@media (max-width: 39.99em) {
  body.menu-open {
    overflow: hidden;
  }
  body.menu-open .site::after {
    transform: scaleY(1);
  }
  body.menu-open .site-header__layout {
    background-color: transparent;
  }
  body.menu-open .site-header__layout::after {
    opacity: 0;
  }
  body.menu-open .site-header__logo {
    fill: #537191;
  }
  body.menu-open .site-header__navigation {
    opacity: 1;
    visibility: visible;
    height: 100vh;
  }
  body.menu-open .site-header__navigation .menu {
    opacity: 1;
    transition-delay: 0.3s;
  }
  body.menu-open .menu-icon__slice:first-child {
    transform: translate3d(0, 50%, 0) rotate(-45deg);
  }
  body.menu-open .menu-icon__slice:nth-child(2) {
    opacity: 0;
  }
  body.menu-open .menu-icon__slice:last-child {
    transform: translate3d(0, 50%, 0) rotate(45deg);
  }
}

/*
 * Page Header
 *
 * This file contains styles that are specific to the page header.
 *
 *****************************************************************************/
.page-header {
  background-color: #0b2637;
  position: relative;
  width: 100%;
}
.page-header__text-lockup {
  position: relative;
  z-index: 2;
  color: #fff;
  display: block;
  opacity: 0;
  padding: 1rem 1.875rem;
  z-index: 2;
}
@media (min-width: 60em) {
  .page-header__text-lockup {
    max-width: 75%;
    padding-left: 5%;
    padding-right: 5%;
  }
}
.page-header__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.page-header__image::after {
  background: #0b2637;
  background: rgba(11, 38, 55, 0.7);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.page-header__video {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  overflow: hidden;
}
.page-header__video::after {
  background: #0b2637;
  background: rgba(11, 38, 55, 0.7);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.page-header__video .video-source {
  width: auto;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: -1;
  max-width: none;
  min-height: 100%;
  min-width: 100%;
  transform: translate(-50%, -50%);
}
.page-header--standard {
  width: 100%;
  height: auto;
  padding-bottom: 7.5rem;
  padding-top: 12rem;
}
.page-header--standard::after {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../images/bg-gradient-navy.svg") no-repeat center top;
  background-size: cover;
  content: "";
}
.page-header--standard .page-header__text-lockup {
  transform: translate3d(0, 10%, 0);
}
.page-header--standard.has-feat-item {
  padding-bottom: 5rem;
}
.page-header--single {
  padding-bottom: 3rem;
  padding-top: 7.5rem;
}
.page-header--hero {
  height: 100vh;
}
.page-header--hero .page-header__text-lockup {
  top: 55%;
  transform: translate3d(0, -45%, 0);
}
.page-header--light {
  background-color: #fff;
}
.page-header--light .page-header__text-lockup {
  color: #000;
}

.page-title {
  line-height: 1;
}

.page-headline {
  margin: 0;
}

.featured-post {
  margin: 3rem 5% 0;
  position: relative;
}
.featured-post .property-item {
  margin: 0;
  padding-top: 80%;
}
@media (min-width: 40em) {
  .featured-post .property-item {
    padding-top: 56.25%;
  }
}
.featured-post .property-item__text {
  background-color: #537191;
}

.hero-media {
  opacity: 0;
}

/*
 * Site Footer
 *
 * This file contains styles that are specific to the site footer.
 *
 *****************************************************************************/
.site-footer__layout {
  padding: 3rem 1.875rem;
}
@media (min-width: 60em) {
  .site-footer__layout {
    display: flex;
  }
}
@media (max-width: 59.99em) {
  .site-footer__title {
    margin-bottom: 3rem;
  }
}
@media (min-width: 60em) {
  .site-footer__title {
    flex: 1 1 30%;
  }
}
.site-footer__title-heading {
  line-height: 1.5;
}
.site-footer__column {
  position: relative;
}
@media (max-width: 59.99em) {
  .site-footer__column:not(:last-child) {
    margin-bottom: 3rem;
  }
}
@media (min-width: 60em) {
  .site-footer__column {
    flex: 1 1 10%;
    margin-left: 2.5%;
  }
}
.site-footer__column h5 {
  padding-bottom: 1rem;
  position: relative;
}
.site-footer__column h5::before {
  width: 50px;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  background-color: #c1761e;
  content: "";
}
.site-footer__copyright {
  font-size: 0.875rem;
  background-color: #537191;
  color: #fff;
  padding: 0.5rem 1.875rem;
}
.site-footer a {
  color: #000;
}
.site-footer a:hover {
  color: #c1761e;
}
.site-footer .address {
  display: block;
  line-height: 1.25;
}

/*
 * Button
 *
 * This file contains all styles related to the button component.
 *
 *****************************************************************************/
.btn, .nf-form-cont .ninja-forms-field[type=button], input[type=button],
input[type=reset],
input[type=submit] {
  font-size: 1rem;
  background-color: transparent;
  border: 3px solid #c1761e;
  color: #c1761e;
  display: inline-block;
  font-weight: 600;
  padding: 0.75rem 1.75rem;
  position: relative;
  transition: background-color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), border-color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.btn:hover, .nf-form-cont .ninja-forms-field[type=button]:hover, input[type=button]:hover,
input[type=reset]:hover,
input[type=submit]:hover, .btn:active, .nf-form-cont .ninja-forms-field[type=button]:active, input[type=button]:active,
input[type=reset]:active,
input[type=submit]:active, .btn:focus, .nf-form-cont .ninja-forms-field[type=button]:focus, input[type=button]:focus,
input[type=reset]:focus,
input[type=submit]:focus {
  background-color: #0b2637;
  border-color: #0b2637;
  color: #fff;
}
.btn--sm {
  font-size: 0.875rem;
  padding: 0.5rem 1.7rem;
}
.btn--lrg {
  font-size: 1.125rem;
  padding: 1rem 2rem;
}
.btn--white {
  border-color: #fff;
  color: #fff;
}

.text-link {
  border-bottom: 2px solid #0b2637;
  color: #0b2637;
  font-weight: 600;
  letter-spacing: 0.03125rem;
  padding-bottom: 0.2rem;
  position: relative;
}
.text-link:hover {
  color: #c1761e;
}
.text-link:hover::after {
  transform: translateY(100%) scaleX(1);
  transform-origin: left bottom;
}
.text-link::after {
  width: 100%;
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  background-color: #c1761e;
  content: "";
  transform: translateY(100%) scaleX(0);
  transform-origin: right bottom;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/*
 * Logo
 *
 * This file contains all styles related to the logo component.
 *
 *****************************************************************************/
.logo {
  display: block;
}
.logo-block {
  margin-top: 1rem;
}
.logo-block__img {
  margin-left: auto;
  margin-right: auto;
  max-height: 100px;
  -o-object-fit: contain;
     object-fit: contain;
}

.logo-grid-item:not(:last-child) .logo-block {
  margin-bottom: 1rem;
}

/*
 * Icon
 *
 * This file contains all styles related to an svg icon component.
 *
 *****************************************************************************/
.icon {
  width: 20px;
  height: 20px;
  display: inline-block;
  transition: fill 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.icon--sm {
  width: 16px;
  height: 16px;
}
.icon--lg {
  width: 32px;
  height: 32px;
}
.icon--copper {
  color: #c1761e;
  fill: #c1761e;
}
.icon svg {
  width: 100%;
  height: 100%;
}

.icon-group {
  display: flex;
}
.icon-group.end {
  justify-content: flex-end;
}

/*
 * Card
 *
 * This file contains all styles related to the card component.
 *
 *****************************************************************************/
.card {
  background-color: #fff;
  box-shadow: 0 10px 10px 0 rgba(0, 0, 0, 0.1);
  color: #000;
  display: block;
  margin-bottom: 1rem;
  margin-top: 1rem;
  position: relative;
}
@media (min-width: 60em) {
  .card {
    height: 100%;
  }
}
.card__header {
  margin-bottom: 1rem;
}
.card__footer {
  margin-top: auto;
}
.card__text {
  padding: 1.875rem;
  position: relative;
  z-index: 2;
}
@media (min-width: 60em) {
  .card__text {
    display: flex;
    flex-direction: column;
    height: 100%;
  }
}
.card__title {
  margin-bottom: 2rem;
}
.card__title a {
  color: #000;
}
.card__title a:hover {
  color: #537191;
}
.card__bg-image {
  position: relative;
}
.card__bg-image::after {
  background: #0b2637;
  background: #0b2637;
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
  opacity: 0.35;
  transition: opacity 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.card--bg {
  background-color: transparent;
  min-height: 300px;
}
@media (min-width: 60em) {
  .card--bg {
    padding-top: 133.3333333333%;
  }
}
.card--bg:hover .card__text {
  transform: translateY(-60%);
}
.card--bg:hover .card__bg-image::after {
  opacity: 0.1;
}
.card--bg .card__text {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  z-index: 2;
  color: #fff;
  height: auto;
  margin: auto;
  text-align: center;
  transform: translateY(-50%);
  transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.card--alt-style {
  background-color: transparent;
  box-shadow: none;
  color: inherit;
}
.card--alt-style .card__text {
  height: auto;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
}

/*
 * List
 *
 * This file contains all styles related to lists.
 *
 *****************************************************************************/
ul:not([class]) li,
ol:not([class]) li {
  line-height: 1.5;
  margin: 0 0 0.5rem 0;
}
ul:not([class]) ul li,
ol:not([class]) ul li {
  margin: 0.25rem 0 0.25rem 0.5rem;
}

ul.list li, ul.list__item,
ol.list li,
ol.list__item {
  margin: 0 0 0.25rem 0;
}
ul.list--inline li, ul.list--inline__item,
ol.list--inline li,
ol.list--inline__item {
  display: inline;
}
ul.list--inline li:not(:last-child), ul.list--inline__item:not(:last-child),
ol.list--inline li:not(:last-child),
ol.list--inline__item:not(:last-child) {
  margin-right: 0.5rem;
}
@media (min-width: 60em) {
  ul.list--2-col,
ol.list--2-col {
    -moz-column-gap: 1.875rem;
         column-gap: 1.875rem;
    -moz-columns: auto 2;
         columns: auto 2;
  }
}
ul.list--2-col li,
ol.list--2-col li {
  margin-bottom: 1rem;
}
ul.list--styled li,
ol.list--styled li {
  font-size: 1rem;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  border-bottom: 1px solid #537191;
  position: relative;
}
ul.list--styled li a,
ol.list--styled li a {
  background: url("../images/icon-caret-orange.svg") no-repeat right center;
  color: #000;
  display: block;
  padding: 1rem 1rem 1rem 0;
  position: relative;
}
ul.list--styled li a:hover,
ol.list--styled li a:hover {
  color: #c1761e;
}

/*
 * Form
 *
 * This file contains all styles related to form elements.
 *
 *****************************************************************************/
.form {
  position: relative;
}
.form__wrap {
  background-color: #fff;
  padding: 1.875rem;
}
.form__row {
  margin: 1.5rem 0;
}
.form__field {
  position: relative;
}

label {
  color: #333;
  display: inline-block;
  font-weight: 700;
  margin-bottom: 0.5rem;
}

input[type=color],
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week],
input:not([type]),
textarea {
  font-size: 1rem;
  background: #fff;
  border: 2px solid #999999;
  border-radius: 3px;
  color: #333;
  line-height: 1.25;
  margin: 0;
  padding: 1rem;
  transition: background-color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1), border-color 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
  width: 100%;
}
input[type=color]:focus, input[type=color]:active,
input[type=date]:focus,
input[type=date]:active,
input[type=datetime]:focus,
input[type=datetime]:active,
input[type=datetime-local]:focus,
input[type=datetime-local]:active,
input[type=email]:focus,
input[type=email]:active,
input[type=month]:focus,
input[type=month]:active,
input[type=number]:focus,
input[type=number]:active,
input[type=password]:focus,
input[type=password]:active,
input[type=search]:focus,
input[type=search]:active,
input[type=tel]:focus,
input[type=tel]:active,
input[type=text]:focus,
input[type=text]:active,
input[type=time]:focus,
input[type=time]:active,
input[type=url]:focus,
input[type=url]:active,
input[type=week]:focus,
input[type=week]:active,
input:not([type]):focus,
input:not([type]):active,
textarea:focus,
textarea:active {
  border-color: #cccccc;
}

.submit-wrap {
  position: relative;
}

.nf-form-cont .nf-form-fields-required {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.nf-form-cont .nf-field-container {
  margin-bottom: 1rem;
}
.nf-form-cont .nf-field-container.submit-container {
  margin-bottom: 0;
}
.nf-form-cont .nf-field .nf-field-label {
  color: #333;
  display: inline-block;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.nf-form-cont .nf-error-msg,
.nf-form-cont .nf-form-errors {
  font-size: 0.875rem;
  font-style: italic;
}
.nf-form-cont .nf-error .ninja-forms-field {
  border: 2px solid #e80000;
}
.nf-form-cont .ninja-forms-req-symbol {
  display: none;
}
.nf-form-cont .nf-response-msg {
  color: #333;
}
.nf-form-cont .nf-after-form-content {
  margin-bottom: 0;
}
.nf-form-cont .ninja-forms-field[type=button] {
  -webkit-appearance: none;
}
@media (max-width: 39.99em) {
  .nf-form-cont .one-half,
.nf-form-cont .three-sixths,
.nf-form-cont .two-fourths {
    margin-left: 0 !important;
    width: 100% !important;
  }
}
.nf-form-cont .list-select-wrap > .nf-field-element {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.nf-form-cont .list-select-wrap > .nf-field-element::after {
  width: 0;
  height: 0;
  position: absolute;
  top: 50%;
  right: 25px;
  border-color: #c1761e transparent transparent transparent;
  border-style: solid;
  border-width: 6px 5px 0 5px;
  content: "";
  margin-top: -3px;
  pointer-events: none;
}
.nf-form-cont .list-select-wrap > .nf-field-element select {
  font-size: 1rem;
  background-color: #fff;
  border: 2px solid #999999;
  border-radius: 3px;
  color: #333;
  cursor: pointer;
  display: inline-block;
  font-weight: 700;
  line-height: 1.25;
  outline: 0;
  padding: 1rem;
  width: 100%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.nf-form-cont .select select::-ms-expand {
  display: none;
}
.nf-form-cont .select select:disabled {
  opacity: 0.5;
  pointer-events: none;
}
.nf-form-cont .select select:hover ~ .select-arrow,
.nf-form-cont .select select:focus ~ .select-arrow {
  border-top-color: #c1761e;
}
.nf-form-cont .select select:disabled ~ .select-arrow {
  border-top-color: #cccccc;
}

.filter-container {
  background-color: #c1761e;
}

.searchandfilter > ul {
  display: flex;
  padding: 0;
}
.searchandfilter > ul li {
  flex: 0 1 130px;
  margin: 0;
  padding: 0;
  position: relative;
}
.searchandfilter > ul li[data-sf-field-input-type=select] {
  max-width: 130px;
}
.searchandfilter > ul li[data-sf-field-input-type=select]::after {
  width: 13px;
  height: 9px;
  position: absolute;
  top: 50%;
  right: 0;
  background: url("../images/icon-caret-white.svg") no-repeat center center;
  content: "";
  pointer-events: none;
  transform: translateY(-50%);
}
.searchandfilter > ul li[data-sf-field-input-type=select] label {
  color: #fff;
  display: block;
  position: relative;
}
.searchandfilter > ul li.sf-field-search {
  margin-left: auto;
  max-width: 130px;
}
.searchandfilter > ul li.sf-field-search input[type=text] {
  background-color: transparent;
  border: none;
  color: #fff;
}
.searchandfilter > ul li.sf-field-search input[type=text]::-webkit-input-placeholder {
  color: #fff;
  letter-spacing: 0.0625rem;
  opacity: 1;
  text-transform: uppercase;
}
.searchandfilter > ul li.sf-field-search input[type=text]::-moz-placeholder {
  color: #fff;
  letter-spacing: 0.0625rem;
  opacity: 1;
  text-transform: uppercase;
}
.searchandfilter > ul li.sf-field-search input[type=text]:-moz-placeholder {
  color: #fff;
  letter-spacing: 0.0625rem;
  opacity: 1;
  text-transform: uppercase;
}
.searchandfilter > ul li.sf-field-search input[type=text]:-ms-input-placeholder {
  color: #fff;
  letter-spacing: 0.0625rem;
  opacity: 1;
  text-transform: uppercase;
}
.searchandfilter .sf-input-select {
  font-size: 1rem;
  background-color: #c1761e;
  border: none;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  letter-spacing: 0.0625rem;
  line-height: 1.25;
  outline: 0;
  padding: 1rem 0;
  text-transform: uppercase;
  width: 100%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.searchandfilter .sf-input-select:hover, .searchandfilter .sf-input-select:focus {
  background-color: #c1761e;
  color: #fff;
}
.searchandfilter .sf-input-select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #000;
}
.searchandfilter .sf-input-select::-ms-expand {
  display: none;
}
.searchandfilter .sf-input-select:disabled {
  opacity: 0.5;
  pointer-events: none;
}

/*
 * Text Block
 *
 * This file contains all styles related to text blocks.
 *
 *****************************************************************************/
.text-block__heading {
  flex: 1 1 40%;
  margin-right: 10%;
}
.text-block__text {
  flex: 1 1 50%;
}
.text-block__list {
  display: flex;
  flex-wrap: wrap;
  margin-top: 2rem;
}
.text-block__list-item-heading {
  font-size: 1.125rem;
  margin-bottom: 0.5rem;
}
.text-block__list-item {
  margin-bottom: 1rem;
  margin-top: 1rem;
}
@media (min-width: 60em) {
  .text-block__list-item {
    flex: 1 1 40%;
  }
}
.text-block__list-item:nth-child(odd) {
  margin-right: 5%;
}
@media (min-width: 60em) {
  .text-block--two-col {
    display: flex;
  }
}

/*
 * Blockquote
 *
 * This file contains all styles related to an blockquote component.
 *
 *****************************************************************************/
.blockquote {
  border-bottom: 1px solid #537191;
  border-top: 3px solid #537191;
  padding-bottom: 3rem;
  padding-top: 5rem;
  position: relative;
}
.blockquote__quote {
  font-size: calc(1.2625rem + 0.15vw);
  color: #537191;
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-style: italic;
  line-height: 1.5;
}
@media (min-width: 1200px) {
  .blockquote__quote {
    font-size: 1.375rem;
  }
}
.blockquote__quote::before {
  font-size: calc(1.6375rem + 4.65vw);
  position: relative;
  top: 0;
  left: -0.5rem;
  color: #0b2637;
  content: open-quote;
  display: block;
  line-height: 0;
}
@media (min-width: 1200px) {
  .blockquote__quote::before {
    font-size: 5.125rem;
  }
}
.blockquote__quote::after {
  position: relative;
  top: 0;
  right: 0;
  content: close-quote;
}
.blockquote__source {
  display: inline-block;
  font-style: normal;
  line-height: 1.5;
  position: relative;
}
.blockquote__source::before {
  content: "\2014   ";
}

/*
 * Background Image
 *
 * This file contains all styles related to the bg image component.
 *
 *****************************************************************************/
.bg-image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: transparent no-repeat center center;
}
.bg-image--cover {
  background-size: cover;
}
.bg-image--contain {
  background-size: contain;
}

.img-bg {
  width: 100%;
  height: 100%;
}
.img-bg--cover {
  -o-object-fit: cover;
     object-fit: cover;
}
.img-bg--contain {
  -o-object-fit: contain;
     object-fit: contain;
}

/*
 * Image Block
 *
 * This file contains all styles related to image blocks.
 *
 *****************************************************************************/
.image-block {
  margin: 0 auto;
}
.image-block__wrap {
  position: relative;
}
.image-block__img {
  display: block;
  margin: 0 auto;
  width: 100%;
}
.image-block__caption {
  font-size: 0.875rem;
  border-bottom: 1px solid #537191;
  font-style: italic;
  line-height: 1.25;
  margin: 1rem 0 0 0;
  padding-bottom: 1rem;
}
.image-block--normal {
  max-width: 80em;
  padding-left: 1.875rem;
  padding-right: 1.875rem;
}
.image-block--expanded .image-block__caption {
  margin-left: 1.875rem;
}

.image-wrap {
  overflow: hidden;
  position: relative;
}

/*
 * Accordion
 *
 * This file contains all styles related to the accordion component.
 *
 *****************************************************************************/
.accordion {
  margin: 1rem auto;
}
.accordion__item {
  border-top: 1px solid #537191;
  position: relative;
  transition: background-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94), border-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 2;
}
.accordion__item:hover .accordion__title {
  color: #c1761e;
}
.accordion__item:last-child {
  border-bottom: 1px solid #537191;
}
.accordion__item::after {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background-color: #f5f8fb;
  content: "";
  opacity: 0;
}
.accordion__item.is-open::after {
  opacity: 1;
}
.accordion__item.is-open .accordion__expand::before {
  transform: rotate(180deg);
}
.accordion__toggle {
  cursor: pointer;
  display: block;
  padding: 2rem 2rem 2rem 3rem;
  position: relative;
}
.accordion__expand {
  width: 13px;
  height: 9px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  cursor: pointer;
  display: block;
  margin: auto;
  transform: translate3d(100%, 0, 0);
}
.accordion__expand::before {
  width: 100%;
  height: auto;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: url("../images/icon-caret.svg") no-repeat center;
  content: "";
  margin: auto;
  transform-origin: center center;
  transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.accordion__title {
  font-size: 1rem;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  margin-bottom: 0;
  transition: color 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.accordion__content {
  height: 0;
  overflow: hidden;
  position: relative;
}
.accordion__content-inner {
  padding: 0 2rem 2rem 3rem;
}
.accordion__image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background: transparent none no-repeat center center;
  background-size: cover;
}
@media (min-width: 60em) {
  .accordion--carousel {
    display: flex;
    flex-direction: row-reverse;
  }
}
.accordion--carousel .accordion__carousel {
  position: relative;
  z-index: 2;
}
@media (max-width: 59.99em) {
  .accordion--carousel .accordion__carousel {
    margin-bottom: 2rem;
  }
}
@media (min-width: 60em) {
  .accordion--carousel .accordion__carousel {
    flex: 1 0 40%;
  }
}
@media (min-width: 60em) {
  .accordion--carousel .accordion__wrap {
    flex: 1 0 50%;
    margin-right: 5%;
  }
}

/*
 * Carousel
 *
 * This file contains all styles related to a carousel.
 *
 *****************************************************************************/
.carousel {
  margin-bottom: 5rem;
  padding-bottom: 60%;
}
@media (min-width: 40em) {
  .carousel {
    padding-bottom: 42%;
  }
}
.carousel__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 66.666%;
  height: 100%;
  display: block;
  margin-right: 1.875rem;
  overflow: hidden;
}
.carousel__slide:first-child {
  padding-left: 1.875rem;
}
.carousel__bg-image {
  background: transparent none no-repeat center center;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.carousel__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0;
  transition: opacity 0.4s;
}
.carousel__image.flickity-lazyloaded, .carousel__image.flickity-lazyerror {
  opacity: 1;
}
.carousel .flickity-viewport {
  position: absolute;
  width: 100%;
}
.carousel .flickity-page-dots {
  bottom: -35px;
}
.carousel .flickity-page-dots .dot {
  width: 10%;
  height: 2px;
  background-color: #0b2637;
  border-radius: 0;
  margin: 0;
  opacity: 0.25;
}
.carousel .flickity-page-dots .dot.is-selected {
  opacity: 0.75;
}

.accordion-carousel {
  padding-bottom: 100%;
}
@media (min-width: 60em) {
  .accordion-carousel {
    padding-bottom: 33.333%;
  }
}
.accordion-carousel__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}
.accordion-carousel .flickity-viewport {
  position: absolute;
  width: 100%;
}

.carousel-slideshow__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}
.carousel-slideshow__image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0;
  transition: opacity 0.4s;
}
.carousel-slideshow__image.flickity-lazyloaded, .carousel-slideshow__image.flickity-lazyerror {
  opacity: 1;
}
.carousel-slideshow .flickity-viewport {
  position: absolute;
  width: 100%;
}
.carousel-slideshow .flickity-prev-next-button {
  width: 40px;
  height: 40px;
  transition: background-color 0.3s;
}
.carousel-slideshow .flickity-prev-next-button .flickity-button-icon {
  width: 50%;
  height: 50%;
  left: 25%;
  top: 25%;
}

/*
 * Stat
 *
 * This file contains all styles related to a stat component.
 *
 *****************************************************************************/
.stat {
  margin-bottom: 1rem;
  margin-top: 1rem;
  position: relative;
  text-align: center;
}
.stat__num {
  font-size: calc(1.4rem + 1.8vw);
  color: #c1761e;
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
  line-height: 1.25;
  text-transform: uppercase;
  display: block;
  margin-bottom: 1rem;
}
@media (min-width: 1200px) {
  .stat__num {
    font-size: 2.75rem;
  }
}
.stat__text {
  font-size: 1.125rem;
  color: inherit;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  display: block;
}

/*
 * Table
 *
 * This file contains all styles related to the table component.
 *
 *****************************************************************************/
table {
  border-collapse: collapse;
}

th {
  font-size: 1.125rem;
  color: inherit;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  font-size: 0.875rem;
}
@media (min-width: 60em) {
  th {
    font-size: 1rem;
  }
}

.table {
  background-color: #fff;
  margin: 0;
  max-width: 100%;
  width: 100%;
}

.table > thead > tr > th,
.table > tbody > tr > th,
.table > tfoot > tr > th,
.table > thead > tr > td,
.table > tbody > tr > td,
.table > tfoot > tr > td {
  border-top: 1px solid #537191;
  padding: 1rem 0.5rem;
  text-align: left;
  vertical-align: top;
}
.table > thead > tr > th.align-right,
.table > tbody > tr > th.align-right,
.table > tfoot > tr > th.align-right,
.table > thead > tr > td.align-right,
.table > tbody > tr > td.align-right,
.table > tfoot > tr > td.align-right {
  text-align: right;
}

.table > thead > tr > th {
  padding: 1rem 0.5rem;
}

.table > caption + thead > tr:first-child > th,
.table > colgroup + thead > tr:first-child > th,
.table > thead:first-child > tr:first-child > th,
.table > caption + thead > tr:first-child > td,
.table > colgroup + thead > tr:first-child > td,
.table > thead:first-child > tr:first-child > td {
  border-top: 0;
}

.table > tbody + tbody {
  border-top: 2px solid #537191;
}

.table-condensed > thead > tr > th,
.table-condensed > tbody > tr > th,
.table-condensed > tfoot > tr > th,
.table-condensed > thead > tr > td,
.table-condensed > tbody > tr > td,
.table-condensed > tfoot > tr > td {
  padding: 0.25rem;
}

.table-bordered {
  border: 1px solid #537191;
}

.table-bordered > thead > tr > th,
.table-bordered > tbody > tr > th,
.table-bordered > tfoot > tr > th,
.table-bordered > thead > tr > td,
.table-bordered > tbody > tr > td,
.table-bordered > tfoot > tr > td {
  border: 1px solid #537191;
}

.table-bordered > thead > tr > th,
.table-bordered > thead > tr > td {
  border-bottom-width: 2px;
}

.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: #537191;
}

.table-hover > tbody > tr:hover {
  background-color: #f5f5f5;
}

table col[class*=col-] {
  position: static;
  float: none;
  display: table-column;
}

table td[class*=col-],
table th[class*=col-] {
  position: static;
  float: none;
  display: table-cell;
}

.table-responsive {
  overflow-x: auto;
  min-height: 0.01%;
}

@media screen and (max-width: 767px) {
  .table-responsive {
    background-color: #fff;
    border: 2px solid #537191;
    margin-bottom: 15px;
    overflow-y: hidden;
    width: 100%;
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }

  .table-responsive > .table {
    margin-bottom: 0;
  }

  .table-responsive > .table > thead > tr > th,
.table-responsive > .table > tbody > tr > th,
.table-responsive > .table > tfoot > tr > th,
.table-responsive > .table > thead > tr > td,
.table-responsive > .table > tbody > tr > td,
.table-responsive > .table > tfoot > tr > td {
    white-space: nowrap;
  }

  .table-responsive > .table-bordered {
    border: 0;
  }

  .table-responsive > .table-bordered > thead > tr > th:first-child,
.table-responsive > .table-bordered > tbody > tr > th:first-child,
.table-responsive > .table-bordered > tfoot > tr > th:first-child,
.table-responsive > .table-bordered > thead > tr > td:first-child,
.table-responsive > .table-bordered > tbody > tr > td:first-child,
.table-responsive > .table-bordered > tfoot > tr > td:first-child {
    border-left: 0;
  }

  .table-responsive > .table-bordered > thead > tr > th:last-child,
.table-responsive > .table-bordered > tbody > tr > th:last-child,
.table-responsive > .table-bordered > tfoot > tr > th:last-child,
.table-responsive > .table-bordered > thead > tr > td:last-child,
.table-responsive > .table-bordered > tbody > tr > td:last-child,
.table-responsive > .table-bordered > tfoot > tr > td:last-child {
    border-right: 0;
  }

  .table-responsive > .table-bordered > tbody > tr:last-child > th,
.table-responsive > .table-bordered > tfoot > tr:last-child > th,
.table-responsive > .table-bordered > tbody > tr:last-child > td,
.table-responsive > .table-bordered > tfoot > tr:last-child > td {
    border-bottom: 0;
  }
}
/*
 * Share
 *
 * This file contains all styles related to the social share component.
 *
 *****************************************************************************/
.share__label {
  display: block;
}
.share__link {
  margin-right: 1rem;
}

/*
 * Property Item
 *
 * This file contains all styles related to the property item component.
 *
 *****************************************************************************/
.property-item {
  height: 0;
  margin-bottom: 0.9375rem;
  margin-top: 0.9375rem;
  overflow: hidden;
  padding-top: 80%;
  position: relative;
}
.property-item:hover .property-item__image img {
  transform: scale(1.1) !important;
}
.property-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.property-item__text {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  background-color: #0b2637;
  color: #fff;
  min-width: 200px;
  padding: 1rem 1.875rem;
  z-index: 2;
}
.property-item__title {
  margin-bottom: 0.25rem;
}

@media (min-width: 60em) {
  .property-col:nth-child(odd) .property-item:nth-child(even) {
    padding-top: 60%;
  }
}
@media (max-width: 59.99em) {
  .property-col:nth-child(even) .property-item {
    margin-top: 0;
  }
}
@media (min-width: 60em) {
  .property-col:nth-child(even) .property-item:nth-child(odd) {
    padding-top: 60%;
  }
}

.flex-content .property-item {
  margin-bottom: 1.875rem;
  margin-top: 1.875rem;
}

.bg-navy .property-item__text {
  background-color: #537191;
}

/*
 * Map
 *
 * This file contains all styles related to the map component.
 *
 *****************************************************************************/
.map {
  display: block;
  height: 400px;
}
.map .map-marker {
  width: 24px;
  height: 32px;
  background: url("../images/icon-map-marker.svg") no-repeat center center;
  background-size: contain;
}
.map .mapboxgl-ctrl-bottom-left,
.map .mapboxgl-ctrl-bottom-right {
  display: none;
}

/*
 * Pagination
 *
 * This file contains all styles related to the pagination component.
 *
 *****************************************************************************/
.pagination {
  align-items: center;
  display: flex;
  justify-content: center;
  text-align: center;
}
.pagination__link {
  width: 13px;
  height: 13px;
  cursor: pointer;
  margin: 0 1rem;
  position: relative;
}
.pagination__link.prev::before, .pagination__link.next::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  background: url("../images/icon-caret-orange.svg") no-repeat center center;
  background-size: 8px auto;
  content: "";
}
.pagination__link.prev::before {
  transform: rotate(180deg);
}

/*
 * Profile
 *
 * This file contains all styles related to the profile component.
 *
 *****************************************************************************/
.profile {
  display: block;
  position: relative;
}
.profile:hover .profile__text {
  transform: translate3d(0, -1rem, 0);
}
.profile:hover .profile__image img {
  transform: scale(1.1);
}
.profile::before {
  width: 100%;
  height: 50%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  background: black;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, black 100%);
  content: "";
  opacity: 0.5;
}
.profile__image img {
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.profile__text {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  color: #fff;
  padding: 1rem;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.profile__text .job-title {
  font-size: 1rem;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
}
.profile-bio {
  display: none;
}
.profile-bio-content {
  padding: 1.875rem;
}

/*
 * Flex Content
 *
 * This file contains all styles related to flex content blocks.
 *
 *****************************************************************************/
.flex-content {
  padding-bottom: 3rem;
  padding-top: 3rem;
  position: relative;
}
@media (min-width: 60em) {
  .flex-content {
    padding-bottom: 5rem;
    padding-top: 5rem;
  }
}
.flex-content--stats.bg-navy::after {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background: url("../images/bg-gradient-navy.svg") no-repeat center top;
  background-size: cover;
  content: "";
  opacity: 1;
}
.flex-content--text-carousel {
  padding-bottom: 0;
  padding-top: 0;
}
.flex-content--text-carousel .carousel-text-wrap {
  display: flex;
  flex-direction: column;
  min-height: 80vh;
  position: relative;
}
.flex-content--text-carousel .carousel-text-wrap .carousel-slideshow {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.flex-content--text-carousel .carousel-text-wrap .carousel-slideshow::after {
  background: #0b2637;
  background: rgba(11, 38, 55, 0.7);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.flex-content--text-carousel .carousel-text-wrap .text-wrap {
  position: relative;
  z-index: 2;
  color: #fff;
  margin-bottom: auto;
  margin-left: auto;
  margin-top: auto;
  padding: 1.875rem;
}
@media (min-width: 60em) {
  .flex-content--text-carousel .carousel-text-wrap .text-wrap {
    width: 50%;
  }
}

/*
 * Page: Home
 *
 * This file contains styles that are specific to the home page.
 *
 *****************************************************************************/
/*
 * Page: News
 *
 * This file contains styles that are specific to the news page.
 *
 *****************************************************************************/
.news .post-list .article {
  border-bottom: 1px solid #537191;
  margin-bottom: 3.5rem;
  padding-bottom: 3.5rem;
}
@media (min-width: 60em) {
  .news .post-list .article {
    display: flex;
    flex-wrap: wrap;
  }
}
@media (max-width: 59.99em) {
  .news .post-list .article .post-meta {
    margin-bottom: 2rem;
  }
}
@media (min-width: 60em) {
  .news .post-list .article .post-meta {
    flex: 0 1 20%;
  }
}
.news .post-list .article .post-title a {
  color: #000;
}
.news .post-list .article .post-title a:hover {
  color: #537191;
}
@media (min-width: 60em) {
  .news .post-list .article .post-excerpt {
    flex: 1 1 70%;
    margin-left: 10%;
  }
}

.post-category {
  font-size: 1.125rem;
  color: #c1761e;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  border-top: 1px solid #c1761e;
  display: inline-block;
  margin-bottom: 0.5rem;
  padding-top: 0.5rem;
}

.post-date {
  font-size: 1.125rem;
  color: #999999;
  font-family: "futura-pt", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-weight: 600;
  letter-spacing: 0.0625rem;
  text-transform: uppercase;
  font-size: 1rem;
}

/*
 * Page: Single Post
 *
 * This file contains styles that are specific to a post page.
 *
 *****************************************************************************/
.single-post .site-header .site-header__layout {
  background-color: #fff;
}
.single-post .site-header .site-header__layout::after {
  background-color: #e1e5ea;
}
.single-post .site-header .site-header__logo {
  fill: #537191;
}
.single-post .site-header .site-header__navigation .menu__link {
  color: #000;
}
.single-post .post-content {
  padding-top: 3rem;
}
.single-post .post-sidebar {
  margin-bottom: 3rem;
}
.single-post .post-body .container {
  padding-left: 0;
  padding-right: 0;
}
.single-post .post-body .flex-content:first-child {
  padding-top: 0;
}

/*
 * Page: Single Property
 *
 * This file contains styles that are specific to a property page.
 *
 *****************************************************************************/
.single-property .property-description p {
  font-size: calc(1.275rem + 0.3vw);
  font-family: "calluna", "Georgia", "Times New Roman", serif;
  font-weight: 400;
}
@media (min-width: 1200px) {
  .single-property .property-description p {
    font-size: 1.5rem;
  }
}
.single-property .property-details {
  margin-top: 3rem;
}
.single-property .property-details-row {
  border-bottom: 1px solid #537191;
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 0;
}