/**
 * The breakpoint keys.
 * @var breakpoints
 * @since 1.0.0
 */
/**
 * The grid breakpoints.
 * @var grid
 * @since 1.0.0
 */
/**
 * Transition speed and curves.
 * @var transitions
 * @since 1.0.0
 */
/**
 * Converts a value to vw;
 * @function rvw
 * @sinc 1.0.0
 */
/**
 * Convenience method to output a calc css property that adds 2 numbers.
 * @function calc-add
 * @sinc 1.0.0
 */
/**
 * Convenience method to output a calc css property that substracts 2 numbers.
 * @function calc-add
 * @sinc 1.0.0
 */
/**
 * Convenience method to output a calc css property that multiplies 2 numbers.
 * @function calc-add
 * @sinc 1.0.0
 */
/**
 * Convenience method to output a calc a relative vw value.
 * @function calc-rvw
 * @sinc 1.0.0
 */
/**
 * Converts a photoshop tracking value to letter-spacing value.
 * @function tracking
 * @sinc 1.0.0
 */
/**
 * Indicates whether the number is a valig length;
 * @function is-valid-length
 * @since 1.0.0
 */
/**
 * Removes unit from value.
 * @function strip-unit
 * @since 1.0.0
 */
/**
 * Replaces a string.
 * @function replace
 * @since 1.0.0
 */
/**
 * Parses rvw units.
 * @function replace
 * @since 1.0.0
 */
/**
 * Returns a transition duration by name.
 * @function transition-duration
 * @since 1.0.0
 */
/**
 * Returns a transition equation by name.
 * @function transition-equation
 * @since 1.0.0
 */
/**
 * @mixin flexbox
 * @since 1.0.0
 */
/**
 * @mixin inline-flex
 * @since 1.0.0
 */
/**
 * @mixin flex-direction
 * @since 1.0.0
 */
/**
 * @mixin flex-wrap
 * @since 1.0.0
 */
/**
 * @mixin flex-flow
 * @since 1.0.0
 */
/**
 * @mixin order
 * @since 1.0.0
 */
/**
 * @mixin flex-grow
 * @since 1.0.0
 */
/**
 * @mixin flex-shrink
 * @since 1.0.0
 */
/**
 * @mixin flex-basis
 * @since 1.0.0
 */
/**
 * @mixin flex
 * @since 1.0.0
 */
/**
 * @mixin justify-content
 * @since 1.0.0
 */
/**
 * @mixin align-items
 * @since 1.0.0
 */
/**
 * @mixin align-self
 * @since 1.0.0
 */
/**
 * @mixin align-content
 * @since 1.0.0
 */
/**
 * @mixin flex-box
 * @since 1.0.0
 */
/**
 * @mixin flex-box-inline
 * @since 1.0.0
 */
/**
 * @mixin flex-row
 * @since 1.0.0
 */
/**
 * @mixin flex-col
 * @since 1.0.0
 */
/**
 * @mixin mflex-set
 * @since 1.0.0
 */
/**
 * @function breakpoint-next
 * @since 1.0.0
 */
/**
 * @function breakpoint-min
 * @since 1.0.0
 */
/**
 * @function breakpoint-max
 * @since 1.0.0
 */
/**
 * @mixin media-breakpoint-up
 * @since 1.0.0
 */
/**
 * @mixin media-breakpoint-down
 * @since 1.0.0
 */
/**
 * @mixin media-breakpoint-between
 * @since 1.0.0
 */
/**
 * @mixin media-breakpoint-only
 * @since 1.0.0
 */
/**
 * @mixin placeholder
 * @since 1.0.0
 */
/**
 * @mixin selection
 * @since 1.0.0
 */
/**
 * Convenience nth-child mixin to improve loop readability.
 * @function nth-child
 * @sinc 1.0.0
 */
/**
 * Convenience nth-child mixin with content parameter.
 * @function nth-child
 * @sinc 1.0.0
 */
/**
 * Convenience nth-child mixin to improve loop readability.
 * @function nth-of-type
 * @sinc 1.0.0
 */
/**
 * Convenience nth-child mixin to improve loop readability.
 * @function nth-last-child
 * @sinc 1.0.0
 */
/**
 * Convenience nth-last-of-type mixin to improve loop readability.
 * @function nth-last-of-type
 * @sinc 1.0.0
 */
/**
 * Targets the last row of a sepcified amount of columns.
 * @mixin last-row
 * @since 1.0.0
 */
/**
 * Targets the last row of a sepcified amount of columns.
 * @mixin last-row-media
 * @since 1.0.0
 */
/**
 * Positions an element.
 * @mixin position
 * @since 1.0.0
 */
/**
 * Position an element with fixed type.
 * @mixin fixed
 * @since 1.0.0
 */
/**
 * Position an element with absolute type.
 * @mixin absolute
 * @since 1.0.0
 */
/**
 * Position an element with relative type.
 * @mixin relative
 * @since 1.0.0
 */
/**
 * Position an element with sticky type.
 * @mixin sticky
 * @since 1.0.0
 */
/**
 * Convenience mixin to position a element absolutely.
 * @mixin fill
 * @since 1.0.0
 */
/**
 * Sets the text antialias;
 * @mixin text-antialias
 * @since 1.0.0
 */
/**
 * Convenience mixin to support special writing direction.
 * @function text-dir
 * @sinc 1.0.0
 */
/**
 * @function text-dir-ttb
 * @sinc 1.0.0
 * @hidden
 */
/**
 * Convenience mixin to support special writing direction.
 * @function text-dir-btt
 * @sinc 1.0.0
 */
/**
 * Disables br.
 * @function no-br
 * @sinc 1.0.0
 */
/**
 * @function next-block-offset
 * @sinc 1.0.0
 */
/**
 * Initialize the common styles of a block.
 * @function block
 * @since 1.0.1
 */
.b-cta {
  position: relative;
  z-index: 50;
  margin-top: calc(30px + 60 * ((100vw - 375px) / 1545));
  margin-bottom: calc(30px + 60 * ((100vw - 375px) / 1545));
  padding-top: 0px;
  padding-bottom: 0px;
}
.b-cta.style-clear {
  margin-top: 0px;
  margin-bottom: 0px;
}
.b-cta.style-red, .b-cta.style-gray, .b-cta.style-green, .b-cta.style-brown, .b-cta.style-black, .b-cta.style-white {
  position: relative;
  z-index: 50;
  margin-top: 0px;
  margin-bottom: 0px;
  padding-top: calc(30px + 60 * ((100vw - 375px) / 1545));
  padding-bottom: calc(30px + 60 * ((100vw - 375px) / 1545));
}
.b-cta.style-red.style-clear, .b-cta.style-gray.style-clear, .b-cta.style-green.style-clear, .b-cta.style-brown.style-clear, .b-cta.style-black.style-clear, .b-cta.style-white.style-clear {
  padding-top: 0px;
  padding-bottom: 0px;
}
.b-cta:last-child {
  padding-top: 0vw;
  padding-bottom: 0vw;
}
.b-cta:last-child .container {
  position: relative;
  bottom: calc(-30px + -60 * ((100vw - 375px) / 1545));
}
.b-cta .container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -webkit-flex-direction: row;
  -moz-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: nowrap;
  -moz-flex-wrap: nowrap;
  -ms-flex-wrap: none;
  flex-wrap: nowrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  justify-content: flex-start;
}
@media (max-width: 767px) {
  .b-cta .container {
    -webkit-box-direction: normal;
    -webkit-box-orient: vertical;
    -webkit-flex-direction: column;
    -moz-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    -moz-align-items: flex-start;
    align-items: flex-start;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    justify-content: flex-start;
  }
}

.b-cta-body {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-direction: normal;
  -webkit-box-orient: vertical;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-self: stretch;
  -moz-align-self: stretch;
  -ms-flex-item-align: stretch;
  align-self: stretch;
  background: #003a46;
  color: #fff;
  padding: calc(30px + 30 * ((100vw - 375px) / 1545));
  width: 70%;
}
@media (max-width: 767px) {
  .b-cta-body {
    width: 100%;
  }
}

.b-cta-foot {
  position: relative;
  -webkit-align-self: stretch;
  -moz-align-self: stretch;
  -ms-flex-item-align: stretch;
  align-self: stretch;
  background: #003a46;
  color: #fff;
  overflow: hidden;
  padding: calc(30px + 30 * ((100vw - 375px) / 1545));
  width: 30%;
}
@media (max-width: 767px) {
  .b-cta-foot {
    display: none;
  }
}
.b-cta-foot .image {
  opacity: 0;
  transform: translateX(calc(45px + 15 * ((100vw - 375px) / 1545)));
  transition-property: opacity, transform;
  transition-duration: 1250ms;
  transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);
}
.ready .visible-on-screen .b-cta-foot .image {
  opacity: 1;
  transform: none;
}

.b-cta-content {
  color: #ffffff;
  font-size: calc(22px + 6 * ((100vw - 375px) / 1545));
  text-align: center;
}