/* Functions & Mixins */
/* ==== Containers & Responsive Mixins ==== */
/* Defines convenience mixins for common breakpoint targets.
these are small, medium, mediumlarge, and large. These variables should be defined prior to use.
*/
/* Universal breakpoints */
.about {
  background-color: #3b3c43;
  position: relative;
  margin-top: 1.25rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }
  .about + .setpay-diagram {
    margin-top: 0; }
  @media screen and (min-width: 48rem) {
    .about {
      margin-top: 2.5rem; } }
  @media screen and (min-width: 64rem) {
    .about {
      margin-top: 3.75rem;
      background-image: var(--largeBkgImage);
      background-repeat: no-repeat;
      background-size: cover;
      background-position: left center; } }
  .about__container {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    max-width: 100%;
    margin: 0 auto;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    width: 82.5rem;
    padding-top: 1.75rem;
    padding-bottom: 1.75rem; }
    @media (min-width: 768px) {
      .about__container {
        padding-left: 2.5rem;
        padding-right: 2.5rem; } }
    @media (min-width: 1280px) {
      .about__container {
        padding-left: 5rem;
        padding-right: 5rem; } }
    @media (min-width: 768px) {
      .about__container {
        width: 85rem; } }
    @media (min-width: 1280px) {
      .about__container {
        width: 90rem; } }
    @media screen and (min-width: 64rem) {
      .about__container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr; } }
  .about__video {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 1.5rem;
    position: relative;
    z-index: 2; }
    .about__video::after {
      content: '';
      position: absolute;
      top: 0;
      left: -1.25rem;
      width: calc(100% + 2.5rem);
      height: calc(100% + 1.75rem);
      background-image: var(--smallBkgImage);
      background-repeat: no-repeat;
      background-size: 200%;
      background-position: 50% -29vw; }
    @media screen and (min-width: 48rem) {
      .about__video::after {
        top: 0;
        left: -2.5rem;
        width: calc(100% + 5rem); } }
    @media screen and (min-width: 64rem) {
      .about__video {
        margin-top: 0;
        padding: 2.5rem 0;
        grid-column: 1/2;
        grid-row: 1/2; }
        .about__video::after {
          content: none; } }
    .about__video .video-embed {
      position: relative;
      z-index: 2; }
  .about__content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    z-index: 2; }
    @media screen and (min-width: 64rem) {
      .about__content {
        grid-column: 2/3;
        grid-row: 1/2;
        padding: 2.5rem;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center; } }
  .about__body {
    color: #f7f7f7;
    font-size: 16px;
    font-size: 1rem;
    margin: 0; }
    .about__body + .about__body {
      margin-top: 1rem; }
      @media screen and (min-width: 64rem) {
        .about__body + .about__body {
          margin-top: 1.5rem; } }
  .about__heading {
    font-size: 32px;
    font-size: 2rem;
    font-weight: normal;
    color: #f7f7f7;
    margin: 0 0 1rem; }
    @media screen and (min-width: 48rem) {
      .about__heading {
        font-size: 48px;
        font-size: 3rem; } }
    @media screen and (min-width: 64rem) {
      .about__heading {
        margin: 0 0 1.5rem; } }