
.container,
.container-fluid {
  margin-right: auto;
  margin-left: auto;
}
.container-fluid {
  padding-right: 2rem;
  padding-left: 2rem;
}
.row {
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -0.5rem;
  margin-left: -0.5rem;
}
.row.reverse {
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.col.reverse {
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}
.col-xs,
.col-xs-1,
.col-xs-10,
.col-xs-11,
.col-xs-12,
.col-xs-2,
.col-xs-3,
.col-xs-4,
.col-xs-5,
.col-xs-6,
.col-xs-7,
.col-xs-8,
.col-xs-9,
.col-xs-offset-0,
.col-xs-offset-1,
.col-xs-offset-10,
.col-xs-offset-11,
.col-xs-offset-12,
.col-xs-offset-2,
.col-xs-offset-3,
.col-xs-offset-4,
.col-xs-offset-5,
.col-xs-offset-6,
.col-xs-offset-7,
.col-xs-offset-8,
.col-xs-offset-9 {
  box-sizing: border-box;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  padding-right: 0.5rem;
  padding-left: 0.5rem;
}
.col-xs {
  -ms-flex-positive: 1;
  flex-grow: 1;
  -ms-flex-preferred-size: 0;
  flex-basis: 0;
  max-width: 100%;
}
.col-xs-1 {
  -ms-flex-preferred-size: 8.33333333%;
  flex-basis: 8.33333333%;
  max-width: 8.33333333%;
}
.col-xs-2 {
  -ms-flex-preferred-size: 16.66666667%;
  flex-basis: 16.66666667%;
  max-width: 16.66666667%;
}
.col-xs-3 {
  -ms-flex-preferred-size: 25%;
  flex-basis: 25%;
  max-width: 25%;
}
.col-xs-4 {
  -ms-flex-preferred-size: 33.33333333%;
  flex-basis: 33.33333333%;
  max-width: 33.33333333%;
}
.col-xs-5 {
  -ms-flex-preferred-size: 41.66666667%;
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}
.col-xs-6 {
  -ms-flex-preferred-size: 50%;
  flex-basis: 50%;
  max-width: 50%;
}
.col-xs-7 {
  -ms-flex-preferred-size: 58.33333333%;
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}
.col-xs-8 {
  -ms-flex-preferred-size: 66.66666667%;
  flex-basis: 66.66666667%;
  max-width: 66.66666667%;
}
.col-xs-9 {
  -ms-flex-preferred-size: 75%;
  flex-basis: 75%;
  max-width: 75%;
}
.col-xs-10 {
  -ms-flex-preferred-size: 83.33333333%;
  flex-basis: 83.33333333%;
  max-width: 83.33333333%;
}
.col-xs-11 {
  -ms-flex-preferred-size: 91.66666667%;
  flex-basis: 91.66666667%;
  max-width: 91.66666667%;
}
.col-xs-12 {
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
  max-width: 100%;
}
.col-xs-offset-0 {
  margin-left: 0;
}
.col-xs-offset-1 {
  margin-left: 8.33333333%;
}
.col-xs-offset-2 {
  margin-left: 16.66666667%;
}
.col-xs-offset-3 {
  margin-left: 25%;
}
.col-xs-offset-4 {
  margin-left: 33.33333333%;
}
.col-xs-offset-5 {
  margin-left: 41.66666667%;
}
.col-xs-offset-6 {
  margin-left: 50%;
}
.col-xs-offset-7 {
  margin-left: 58.33333333%;
}
.col-xs-offset-8 {
  margin-left: 66.66666667%;
}
.col-xs-offset-9 {
  margin-left: 75%;
}
.col-xs-offset-10 {
  margin-left: 83.33333333%;
}
.col-xs-offset-11 {
  margin-left: 91.66666667%;
}
.start-xs {
  -ms-flex-pack: start;
  justify-content: flex-start;
  text-align: start;
}
.center-xs {
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
}
.end-xs {
  -ms-flex-pack: end;
  justify-content: flex-end;
  text-align: end;
}
.top-xs {
  -ms-flex-align: start;
  align-items: flex-start;
}
.middle-xs {
  -ms-flex-align: center;
  align-items: center;
}
.bottom-xs {
  -ms-flex-align: end;
  align-items: flex-end;
}
.around-xs {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}
.between-xs {
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.first-xs {
  -ms-flex-order: -1;
  order: -1;
}
.last-xs {
  -ms-flex-order: 1;
  order: 1;
}
@media only screen and (min-width: 48em) {
.container {
    width: 49rem;
}
.col-sm,
  .col-sm-1,
  .col-sm-10,
  .col-sm-11,
  .col-sm-12,
  .col-sm-2,
  .col-sm-3,
  .col-sm-4,
  .col-sm-5,
  .col-sm-6,
  .col-sm-7,
  .col-sm-8,
  .col-sm-9,
  .col-sm-offset-0,
  .col-sm-offset-1,
  .col-sm-offset-10,
  .col-sm-offset-11,
  .col-sm-offset-12,
  .col-sm-offset-2,
  .col-sm-offset-3,
  .col-sm-offset-4,
  .col-sm-offset-5,
  .col-sm-offset-6,
  .col-sm-offset-7,
  .col-sm-offset-8,
  .col-sm-offset-9 {
    box-sizing: border-box;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
}
.col-sm {
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
}
.col-sm-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
}
.col-sm-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
}
.col-sm-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
}
.col-sm-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
}
.col-sm-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
}
.col-sm-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
}
.col-sm-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
}
.col-sm-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
}
.col-sm-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
}
.col-sm-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
}
.col-sm-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
}
.col-sm-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
}
.col-sm-offset-0 {
    margin-left: 0;
}
.col-sm-offset-1 {
    margin-left: 8.33333333%;
}
.col-sm-offset-2 {
    margin-left: 16.66666667%;
}
.col-sm-offset-3 {
    margin-left: 25%;
}
.col-sm-offset-4 {
    margin-left: 33.33333333%;
}
.col-sm-offset-5 {
    margin-left: 41.66666667%;
}
.col-sm-offset-6 {
    margin-left: 50%;
}
.col-sm-offset-7 {
    margin-left: 58.33333333%;
}
.col-sm-offset-8 {
    margin-left: 66.66666667%;
}
.col-sm-offset-9 {
    margin-left: 75%;
}
.col-sm-offset-10 {
    margin-left: 83.33333333%;
}
.col-sm-offset-11 {
    margin-left: 91.66666667%;
}
.start-sm {
    -ms-flex-pack: start;
    justify-content: flex-start;
    text-align: start;
}
.center-sm {
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
}
.end-sm {
    -ms-flex-pack: end;
    justify-content: flex-end;
    text-align: end;
}
.top-sm {
    -ms-flex-align: start;
    align-items: flex-start;
}
.middle-sm {
    -ms-flex-align: center;
    align-items: center;
}
.bottom-sm {
    -ms-flex-align: end;
    align-items: flex-end;
}
.around-sm {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}
.between-sm {
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.first-sm {
    -ms-flex-order: -1;
    order: -1;
}
.last-sm {
    -ms-flex-order: 1;
    order: 1;
}
}
@media only screen and (min-width: 64em) {
.container {
    width: 65rem;
}
.col-md,
  .col-md-1,
  .col-md-10,
  .col-md-11,
  .col-md-12,
  .col-md-2,
  .col-md-3,
  .col-md-4,
  .col-md-5,
  .col-md-6,
  .col-md-7,
  .col-md-8,
  .col-md-9,
  .col-md-offset-0,
  .col-md-offset-1,
  .col-md-offset-10,
  .col-md-offset-11,
  .col-md-offset-12,
  .col-md-offset-2,
  .col-md-offset-3,
  .col-md-offset-4,
  .col-md-offset-5,
  .col-md-offset-6,
  .col-md-offset-7,
  .col-md-offset-8,
  .col-md-offset-9 {
    box-sizing: border-box;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
}
.col-md {
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
}
.col-md-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
}
.col-md-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
}
.col-md-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
}
.col-md-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
}
.col-md-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
}
.col-md-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
}
.col-md-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
}
.col-md-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
}
.col-md-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
}
.col-md-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
}
.col-md-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
}
.col-md-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
}
.col-md-offset-0 {
    margin-left: 0;
}
.col-md-offset-1 {
    margin-left: 8.33333333%;
}
.col-md-offset-2 {
    margin-left: 16.66666667%;
}
.col-md-offset-3 {
    margin-left: 25%;
}
.col-md-offset-4 {
    margin-left: 33.33333333%;
}
.col-md-offset-5 {
    margin-left: 41.66666667%;
}
.col-md-offset-6 {
    margin-left: 50%;
}
.col-md-offset-7 {
    margin-left: 58.33333333%;
}
.col-md-offset-8 {
    margin-left: 66.66666667%;
}
.col-md-offset-9 {
    margin-left: 75%;
}
.col-md-offset-10 {
    margin-left: 83.33333333%;
}
.col-md-offset-11 {
    margin-left: 91.66666667%;
}
.start-md {
    -ms-flex-pack: start;
    justify-content: flex-start;
    text-align: start;
}
.center-md {
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
}
.end-md {
    -ms-flex-pack: end;
    justify-content: flex-end;
    text-align: end;
}
.top-md {
    -ms-flex-align: start;
    align-items: flex-start;
}
.middle-md {
    -ms-flex-align: center;
    align-items: center;
}
.bottom-md {
    -ms-flex-align: end;
    align-items: flex-end;
}
.around-md {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}
.between-md {
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.first-md {
    -ms-flex-order: -1;
    order: -1;
}
.last-md {
    -ms-flex-order: 1;
    order: 1;
}
}
@media only screen and (min-width: 75em) {
.container {
    width: 76rem;
}
.col-lg,
  .col-lg-1,
  .col-lg-10,
  .col-lg-11,
  .col-lg-12,
  .col-lg-2,
  .col-lg-3,
  .col-lg-4,
  .col-lg-5,
  .col-lg-6,
  .col-lg-7,
  .col-lg-8,
  .col-lg-9,
  .col-lg-offset-0,
  .col-lg-offset-1,
  .col-lg-offset-10,
  .col-lg-offset-11,
  .col-lg-offset-12,
  .col-lg-offset-2,
  .col-lg-offset-3,
  .col-lg-offset-4,
  .col-lg-offset-5,
  .col-lg-offset-6,
  .col-lg-offset-7,
  .col-lg-offset-8,
  .col-lg-offset-9 {
    box-sizing: border-box;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
}
.col-lg {
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
}
.col-lg-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
}
.col-lg-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
}
.col-lg-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
}
.col-lg-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
}
.col-lg-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
}
.col-lg-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
}
.col-lg-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
}
.col-lg-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
}
.col-lg-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
}
.col-lg-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
}
.col-lg-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
}
.col-lg-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
}
.col-lg-offset-0 {
    margin-left: 0;
}
.col-lg-offset-1 {
    margin-left: 8.33333333%;
}
.col-lg-offset-2 {
    margin-left: 16.66666667%;
}
.col-lg-offset-3 {
    margin-left: 25%;
}
.col-lg-offset-4 {
    margin-left: 33.33333333%;
}
.col-lg-offset-5 {
    margin-left: 41.66666667%;
}
.col-lg-offset-6 {
    margin-left: 50%;
}
.col-lg-offset-7 {
    margin-left: 58.33333333%;
}
.col-lg-offset-8 {
    margin-left: 66.66666667%;
}
.col-lg-offset-9 {
    margin-left: 75%;
}
.col-lg-offset-10 {
    margin-left: 83.33333333%;
}
.col-lg-offset-11 {
    margin-left: 91.66666667%;
}
.start-lg {
    -ms-flex-pack: start;
    justify-content: flex-start;
    text-align: start;
}
.center-lg {
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
}
.end-lg {
    -ms-flex-pack: end;
    justify-content: flex-end;
    text-align: end;
}
.top-lg {
    -ms-flex-align: start;
    align-items: flex-start;
}
.middle-lg {
    -ms-flex-align: center;
    align-items: center;
}
.bottom-lg {
    -ms-flex-align: end;
    align-items: flex-end;
}
.around-lg {
    -ms-flex-pack: distribute;
    justify-content: space-around;
}
.between-lg {
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.first-lg {
    -ms-flex-order: -1;
    order: -1;
}
.last-lg {
    -ms-flex-order: 1;
    order: 1;
}
}
.m-a-0 {
  margin: 0rem 0rem !important;
}
.m-t-0 {
  margin-top: 0rem !important;
}
.m-r-0 {
  margin-right: 0rem !important;
}
.m-b-0 {
  margin-bottom: 0rem !important;
}
.m-l-0 {
  margin-left: 0rem !important;
}
.m-x-0 {
  margin-right: 0rem !important;
  margin-left: 0rem !important;
}
.m-y-0 {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
}
.m-a-1 {
  margin: 1rem 1rem !important;
}
.m-t-1 {
  margin-top: 1rem !important;
}
.m-r-1 {
  margin-right: 1rem !important;
}
.m-b-1 {
  margin-bottom: 1rem !important;
}
.m-l-1 {
  margin-left: 1rem !important;
}
.m-x-1 {
  margin-right: 1rem !important;
  margin-left: 1rem !important;
}
.m-y-1 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}
.m-a-2 {
  margin: 2rem 2rem !important;
}
.m-t-2 {
  margin-top: 2rem !important;
}
.m-r-2 {
  margin-right: 2rem !important;
}
.m-b-2 {
  margin-bottom: 2rem !important;
}
.m-l-2 {
  margin-left: 2rem !important;
}
.m-x-2 {
  margin-right: 2rem !important;
  margin-left: 2rem !important;
}
.m-y-2 {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}
.m-a-3 {
  margin: 3rem 3rem !important;
}
.m-t-3 {
  margin-top: 3rem !important;
}
.m-r-3 {
  margin-right: 3rem !important;
}
.m-b-3 {
  margin-bottom: 3rem !important;
}
.m-l-3 {
  margin-left: 3rem !important;
}
.m-x-3 {
  margin-right: 3rem !important;
  margin-left: 3rem !important;
}
.m-y-3 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}
.m-a-4 {
  margin: 4rem 4rem !important;
}
.m-t-4 {
  margin-top: 4rem !important;
}
.m-r-4 {
  margin-right: 4rem !important;
}
.m-b-4 {
  margin-bottom: 4rem !important;
}
.m-l-4 {
  margin-left: 4rem !important;
}
.m-x-4 {
  margin-right: 4rem !important;
  margin-left: 4rem !important;
}
.m-y-4 {
  margin-top: 4rem !important;
  margin-bottom: 4rem !important;
}
.m-a-5 {
  margin: 5rem 5rem !important;
}
.m-t-5 {
  margin-top: 5rem !important;
}
.m-r-5 {
  margin-right: 5rem !important;
}
.m-b-5 {
  margin-bottom: 5rem !important;
}
.m-l-5 {
  margin-left: 5rem !important;
}
.m-x-5 {
  margin-right: 5rem !important;
  margin-left: 5rem !important;
}
.m-y-5 {
  margin-top: 5rem !important;
  margin-bottom: 5rem !important;
}
.p-a-0 {
  padding: 0rem 0rem !important;
}
.p-t-0 {
  padding-top: 0rem !important;
}
.p-r-0 {
  padding-right: 0rem !important;
}
.p-b-0 {
  padding-bottom: 0rem !important;
}
.p-l-0 {
  padding-left: 0rem !important;
}
.p-x-0 {
  padding-right: 0rem !important;
  padding-left: 0rem !important;
}
.p-y-0 {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
}
.p-a-1 {
  padding: 1rem 1rem !important;
}
.p-t-1 {
  padding-top: 1rem !important;
}
.p-r-1 {
  padding-right: 1rem !important;
}
.p-b-1 {
  padding-bottom: 1rem !important;
}
.p-l-1 {
  padding-left: 1rem !important;
}
.p-x-1 {
  padding-right: 1rem !important;
  padding-left: 1rem !important;
}
.p-y-1 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}
.p-a-2 {
  padding: 2rem 2rem !important;
}
.p-t-2 {
  padding-top: 2rem !important;
}
.p-r-2 {
  padding-right: 2rem !important;
}
.p-b-2 {
  padding-bottom: 2rem !important;
}
.p-l-2 {
  padding-left: 2rem !important;
}
.p-x-2 {
  padding-right: 2rem !important;
  padding-left: 2rem !important;
}
.p-y-2 {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}
.p-a-3 {
  padding: 3rem 3rem !important;
}
.p-t-3 {
  padding-top: 3rem !important;
}
.p-r-3 {
  padding-right: 3rem !important;
}
.p-b-3 {
  padding-bottom: 3rem !important;
}
.p-l-3 {
  padding-left: 3rem !important;
}
.p-x-3 {
  padding-right: 3rem !important;
  padding-left: 3rem !important;
}
.p-y-3 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}
.p-a-4 {
  padding: 4rem 4rem !important;
}
.p-t-4 {
  padding-top: 4rem !important;
}
.p-r-4 {
  padding-right: 4rem !important;
}
.p-b-4 {
  padding-bottom: 4rem !important;
}
.p-l-4 {
  padding-left: 4rem !important;
}
.p-x-4 {
  padding-right: 4rem !important;
  padding-left: 4rem !important;
}
.p-y-4 {
  padding-top: 4rem !important;
  padding-bottom: 4rem !important;
}
.p-a-5 {
  padding: 5rem 5rem !important;
}
.p-t-5 {
  padding-top: 5rem !important;
}
.p-r-5 {
  padding-right: 5rem !important;
}
.p-b-5 {
  padding-bottom: 5rem !important;
}
.p-l-5 {
  padding-left: 5rem !important;
}
.p-x-5 {
  padding-right: 5rem !important;
  padding-left: 5rem !important;
}
.p-y-5 {
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}

/**
 * Responsive mixin. The media breakpoints are as defined
 * in the twitter bootstrap framework:
 *
 * - phone
 * - tablet-portrait
 * - tablet-landscape-desktop
 * - large-desktop
 *
 * Additional parameters for tagetting retina and non-retina
 * devices
 *
 * - retina
 * - non-retina
 *
 * Moreover, a specific value in px can be passed which is
 * used to generate a max-width media query.
 */
h1 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
h2 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
h3 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
h4 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
h5 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
h6 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
}
.text-cf-heading h1 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.text-cf-heading h2 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.text-cf-heading h3 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.text-cf-heading h4 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.text-cf-heading h5 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.text-cf-heading h6 {
  font-family: "Playfair Display", serif;
  color: #2c2b3c;
  text-transform: capitalize;
  margin-top: 3rem;
}
.contain-image {
  object-fit: contain;
  height: 100%;
  width: 100%;
  border-radius: 30px;
}
.cover-image {
  object-fit: cover;
  height: 100%;
  width: 100%;
  border-radius: 30px;
}
.phone {
  position: relative;
}
.phone .notch-container {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100px;
}
.phone .notch-container .notch {
  width: 20vh;
  height: 4.25vh;
  margin: 0 auto;
  background-color: #111;
  border-bottom-left-radius: 2.334vh;
  border-bottom-right-radius: 2.334vh;
}
.phone img {
  display: block;
  border: 1.334vh solid #111;
  border-radius: 4.5vh;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.icon {
  width: 16px;
  height: 16px;
}
p {
  line-height: 1.6;
  -webkit-margin-after: 1.5em;
          margin-block-end: 1.5em;
}
.font-large {
  font-size: 120%;
}
h1.special {
  font-size: 2.8em;
}
.h0 {
  color: #131221;
  font-family: "Playfair Display", serif;
  font-weight: normal;
  font-size: 400%;
}
.h0.project-heading {
    margin-top: 0.2em;
    display: inline-block;
}
a {
  text-decoration: none;
}
a:hover {
    text-decoration: underline;
}
ul {
  margin: 0;
  padding: 0;
}
ul li {
    list-style: none;
}
.italic {
  font-style: italic;
}
.scroll-it {
  height: 100vh;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}
.drop-shadow {
  box-shadow: 1px 1px 41px #eee;
}
.no-shadow {
  box-shadow: none;
}
.rotate90 {
  transform: rotate(90deg);
}
.text-modern-serif {
  font-family: "Bodoni Moda", serif;
  text-decoration: none;
  font-weight: 300;
  line-height: 1;
  font-size: 0.9rem;
}
.text-modern {
  text-decoration: none;
  font-weight: 300;
  line-height: 1.3;
  font-size: 1rem;
}
.text-modern-special {
  font-family: "Helvetica Neue LT Pro", sans-serif;
  text-decoration: none;
  font-style: italic;
  font-weight: 800;
  line-height: 1;
}
.text-number {
  font-family: "Inconsolata", monospace;
  text-decoration: none;
}
.text-cf {
  font-family: "Oswald", sans-serif;
  text-decoration: none;
}
.text-hf {
  font-family: "Playfair Display", serif;
  text-decoration: none;
}
.text-ns {
  font-family: "Nunito Sans", sans-serif;
  text-decoration: none;
}
.font-size-80 {
  font-size: 80%;
}
.text-yt-live {
  color: #ff0200;
}
.text-white {
  color: #FFFFFF;
}
.text-white a {
    color: #FFFFFF;
    text-decoration: underline;
}
.text-lighter {
  color: #d9d6ff;
}
.text-light {
  color: #b2b0d4;
}
.text-darker {
  color: #1d1b31;
}
.text-mid-color {
  color: #100963;
}
.text-darkest {
  color: #131221;
}
.font-weight-bold {
  font-weight: bold;
}
.font-weight-lighter {
  font-weight: lighter;
}
.text-center {
  text-align: center;
}
.justify-content-center {
  -ms-flex-pack: center;
      justify-content: center;
}
.text-right {
  text-align: right;
}
.text-left {
  text-align: left;
}
.hide {
  display: none !important;
}
.show {
  display: block !important;
}
.flex-end {
  -ms-flex-pack: end;
      justify-content: flex-end;
}
.show-flex {
  display: -ms-flexbox !important;
  display: flex !important;
}
.height-100-vh {
  height: 100vh;
}
.height-100 {
  height: 100%;
}
.float-r {
  float: right;
}
.w-100 {
  width: 100%;
}
.w-90 {
  width: 90%;
}
.w-85 {
  width: 85% !important;
}
.w-75 {
  width: 75% !important;
}
.w-65 {
  width: 65% !important;
}
.all-caps {
  text-transform: uppercase;
}
.subtitle {
  font-weight: bold;
  font-size: 90%;
  text-transform: uppercase;
}
@media (max-width: 767px) {
.p-sm-x-4 {
    padding: 0 4rem;
}
}
@media (max-width: 480px) {
.p-xs-x-0 {
    padding: 0 0 !important;
}
}
@media (max-width: 767px) {
.m-sm-x-2 {
    margin: 0 2rem 0 2rem !important;
}
}
@media (max-width: 767px) {
.m-sm-x {
    margin: -6px !important;
}
}
@media (max-width: 480px) {
.m-xs-t-2 {
    margin-top: 3rem;
    margin-left: 0rem !important;
}
}
.bg-white {
  background-color: #fff;
}
.bg-dark {
  background-color: #2c2b3c;
}
.bg-darkest {
  background-color: #131221;
}
.bg-lighter {
  background-color: #d9d6ff;
}
.bg-portify-grey {
  background-color: #EAF1F5;
}
.border-radius-30 {
  border-radius: 30px;
}
.border-b {
  border-bottom: 1px solid #b2b0d4;
}
.border-l {
  border-left: 1px solid #b2b0d4;
}
.border-r {
  border-right: 1px solid #b2b0d4;
}
.border-t {
  border-top: 1px solid #b2b0d4;
}
.position-absolute {
  position: absolute;
}
.position-relative {
  position: relative;
}
.ext {
  /* Safari */
  transition-duration: 0.4s;
  color: #1d1b31;
  padding: 3px 30px;
  background: #d9d6ff;
  border: 1px solid #2c2b3c;
  font-size: 80%;
  display: inline-block;
}
.ext:hover {
  background-color: #1d1b31;
  /* Green */
  color: white;
  transform: skewX(-20deg);
}
.margin-auto {
  width: 0 auto;
}
blockquote {
  border-left: 6px solid #d9d6ff;
  padding-left: 1.2em;
  margin: 0;
  line-height: 2.1em;
  border-top-left-radius: 0px;
  border-bottom-left-radius: 0px;
  padding-bottom: 0em;
}
.section hr {
  height: 1px !important;
  background-color: #d9d6ff;
  border: none;
}
.hide-on-mobile {
  display: block;
}
@media (max-width: 480px) {
.hide-on-mobile {
      display: none;
}
}
.show-on-mobile {
  display: none;
}
@media (max-width: 480px) {
.show-on-mobile {
      display: block;
}
}

/* ==========================================================================
   Normalize.scss settings
   ========================================================================== */
/**
 * Includes legacy browser support IE6/7
 *
 * Set to false if you want to drop support for IE6 and IE7
 */
/* Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 * 3. Corrects text resizing oddly in IE 6/7 when body `font-size` is set using
 *  `em` units.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevents modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active, a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Addresses styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * 1. Remove border when inside `a` element in IE 8/9/10.
 * 2. Improves image quality when scaled in IE 7.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 * Correct font family set oddly in IE 6, Safari 4/5, and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *  Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 * 4. Improves appearance and consistency in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *  and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *  `input` and others.
 * 4. Removes inner spacing in IE 7 without affecting normal text inputs.
 *  Known issue: inner spacing remains in IE 6.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 *  Known issue: excess padding remains in IE 6.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 * 3. Corrects text not wrapping in Firefox 3.
 * 4. Corrects alignment displayed oddly in IE 6/7.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
body,
html {
  background-color: #f3f8ff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body,
html {
  font-family: "Nunito Sans", sans-serif;
  color: #1d1b31;
}
.card {
  border-radius: 50px;
}
.section-2 {
  background: #fff;
}
#_section_2_img,
.section-2-content {
  opacity: 0;
  transform: translateY(100px);
}
#about .email {
  display: none;
}
#home .box {
  margin-top: 9%;
}
#home .prevent-select, #home p {
  -webkit-user-select: none;
  /* Safari */
  -ms-user-select: none;
  /* IE 10 and IE 11 */
  user-select: none;
  /* Standard syntax */
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -moz-user-select: none;
}
#home .animated-text h1 {
  margin: -12px 0;
  padding: 0;
  font-weight: 300;
  line-height: 1.3;
  font-size: clamp(32px, 8vw, 110px);
  font-family: "Bodoni Moda", serif;
}
@media (max-width: 1362px) {
#home .animated-text h1 {
      font-size: clamp(32px, 6vw, 110px);
}
}
#home .animated-text h2 {
  margin: 0;
  padding: 10px 0 38px 0;
  line-height: 1.3;
  font-size: clamp(28px, 5vw, 38px);
  margin-left: 20px;
  font-weight: 200;
}
@media (max-width: 1362px) {
#home .animated-text h2 {
      font-size: clamp(28px, 3vw, 38px);
}
}
@media (max-width: 767px) {
#home h1 {
    font-size: 1.3rem;
}
}
@media (max-width: 480px) {
#home .logo-large svg {
    width: 100px;
}
#home .box {
    margin: 8% 1rem 0 0rem !important;
    padding-left: 25px !important;
}
#home .animated-text {
    margin-top: 70px;
}
#home .animated-text h2 {
    font-size: 1.6em;
    margin-left: 0;
    margin-bottom: 12px;
    font-weight: normal;
}
#home .animated-text h1 {
    font-size: 3em;
}
#home .arrow-link {
    margin-left: 0;
}
#home .arrow-link svg {
      display: none;
}
}
.home {
  opacity: 0;
  transform: translateY(50px);
  -webkit-transform: translateY(50px);
  -moz-transform: translateY(50px);
}
.timeline {
  opacity: 0;
  transform: translateY(50px);
  -webkit-transform: translateY(50px);
  -moz-transform: translateY(50px);
}
.about {
  opacity: 0;
  transform: translateY(50px);
  -webkit-transform: translateY(50px);
  -moz-transform: translateY(50px);
}
.about .img-box {
    height: 80vh;
}
@media (max-width: 480px) {
.about,
  .menu-page,
  .timeline {
    background: #fff;
    width: 100% !important;
}
}
.menu-page-links {
  display: inline-block;
  margin-top: 20%;
}
.menu-page-links a {
    text-decoration: none;
}
@media (max-width: 480px) {
.menu-page-links {
      margin-top: 20vh;
}
}
.contact-links.contact-on-project-item {
  text-align: center;
  width: 100%;
  display: block;
  position: fixed;
  bottom: 0;
  opacity: 0;
  z-index: 9999;
}
.contact-links.contact-on-project-item > .copyright,
  .contact-links.contact-on-project-item > .email {
    display: none;
}
.contact-links.contact-on-project-item ul .copyright,
  .contact-links.contact-on-project-item ul .email {
    display: inline-block !important;
    color: #1d1b31;
}
.contact-links > a {
  font-size: 150%;
  display: inline-block;
}
.contact-links li {
  display: inline-block;
  color: #b2b0d4;
  padding: 6px 0;
}
.contact-links li a {
    display: inline-block;
    color: #1d1b31;
}
.contact-links li a:hover {
      color: #131221;
}
.youtube img.design-principle-img {
  width: 80%;
  margin-top: 10px;
  margin-left: auto;
}
.copyright-container {
  position: fixed;
  bottom: 10px;
  right: 35px;
  z-index: 9;
}
.contact-icons {
  position: fixed;
  top: 24px;
  right: 35px;
  z-index: 9;
}
@media (max-width: 480px) {
.contact-icons a {
      display: inline-block;
}
}
.contact-icons a:hover svg {
    fill: #131221;
}
.contact-icons svg {
    height: 16px;
    width: 16px;
    display: list-item;
    padding: 6px 30%;
    fill: #1d1b31;
}
.contact-on-menu {
  margin-top: 10%;
}
.arrow-container {
  display: -ms-flexbox;
  display: flex;
  position: fixed;
  right: 0;
  top: 15vh;
  z-index: 2;
}
.page-nav,
.page-nav .nav-item {
  width: 55px;
}
.page-nav span,
  .page-nav .nav-item span {
    display: inline-block;
}
.page-nav .nav-arrow-indicator,
  .page-nav .nav-item .nav-arrow-indicator {
    height: 177px;
    margin-bottom: 30px;
}
.page-nav .project-page-no,
  .page-nav .nav-item .project-page-no {
    padding: 20px 10px 35px;
    width: 10px;
}
.page-nav .next-link,
  .page-nav .project-nav-name,
  .page-nav .nav-item .next-link,
  .page-nav .nav-item .project-nav-name {
    transform: rotate(90deg);
    padding: 2%;
}
.page-nav svg,
  .page-nav .nav-item svg {
    height: 190px;
}
.nav-num {
  padding: 5px 30px 10px;
}
._page-no {
  display: inline-block;
}
.home-link-mobile {
  display: none;
}
@media (max-width: 480px) {
.home-link-mobile {
      display: inline-block;
      position: fixed;
      text-decoration: none;
      top: 8px;
      font-size: 1.3rem;
      z-index: 3;
      left: 50%;
      margin-left: -20px;
}
.home-link-mobile svg {
        width: 24px;
}
}
.top-bar-mobile {
  display: none;
}
@media (max-width: 480px) {
.top-bar-mobile {
      display: block;
      height: 50px;
      width: 100%;
      background: #fff;
      position: fixed;
      z-index: 2;
}
}
.menu-container {
  margin-left: 100px;
}
@media (max-width: 480px) {
.menu-container {
      margin-left: 20%;
}
}
.all-projects-link {
  top: -16px;
  display: inline-block;
  position: absolute;
  padding: 38%;
}
#side-menu {
  height: 100vh;
  width: 64px;
  position: fixed;
  top: 0;
  z-index: 2;
}
#side-menu .icon-menu {
    display: block;
    position: relative;
    top: calc(50vh - 50px);
    cursor: pointer;
    left: 50%;
    margin-left: -15%;
}
#side-menu .home-link {
    position: absolute;
    top: 24px;
    left: 50%;
    margin-left: -25%;
}
@media (max-width: 480px) {
#side-menu {
      height: 80px;
      width: 50px;
      position: fixed;
      top: 0;
      z-index: 2;
}
#side-menu .icon-menu {
        top: 9px;
        left: 10px;
        margin-left: 0;
        display: inline-block;
}
#side-menu .icon-menu .icon-menu-container.close {
          position: absolute;
          top: -30px;
          left: 10px;
}
#side-menu .home-link {
        display: none !important;
}
}
div#project-item.full-page {
  padding-left: 0;
  width: 100%;
}
#project-item {
  margin-left: 0;
}
#project-item .section-1, #project-item .section-2, #project-item .section {
    width: 80vw;
    margin: 0 auto;
    padding-bottom: 4em;
}
@media (max-width: 480px) {
#project-item .section-1, #project-item .section-2, #project-item .section {
        padding: 0;
        margin-right: 0;
        margin-bottom: 45px;
        width: 100vw;
}
}
@media (max-width: 480px) {
#project-item .section .h0 {
      margin-top: 30px;
      font-size: 300%;
}
}
@media (max-width: 480px) {
#project-item .box {
      margin: 3rem 2rem 0 2rem !important;
}
#project-item .box .project-heading {
        margin-bottom: -50px;
        margin-top: 30px;
        font-size: 300%;
}
}
#_section_2_img {
  opacity: 0;
}
.decko-main-img {
  overflow: hidden;
  border: 31px solid #FFEB3B;
}
#tinySquare {
  height: 5px;
  width: 5px;
  background: #2c2b3c;
  position: absolute;
  left: 50%;
  top: 0;
  margin-left: -3px;
  border-radius: 50%;
  transition: all 0s;
}
.full-page {
  width: calc(100% - 64px + 1px);
  height: 100vh;
  padding-left: calc(64px + 1px);
  position: absolute;
  top: 0;
  z-index: 1;
  left: 0;
}
@media (max-width: 767px) {
.full-page {
      margin-left: 0;
      padding-left: 0;
}
}
.boxy-mcBoxBucket {
  border-radius: 50px;
  border-top-right-radius: 0;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background-color: rgba(255, 255, 255, 0.865);
}
.project-item-right-image {
  opacity: 0;
}
.img-caption-text {
  width: 100%;
  text-align: center;
  padding: 0;
  margin: 0;
  font-size: 0.7rem;
  opacity: 0.8;
}
.img-caption-text a {
    color: white;
}
.sidebar-img-box {
  height: 100vh;
  overflow: hidden;
}
.sidebar-img-box img {
    width: 100%;
}
@media (max-width: 480px) {
.sidebar-img-box {
      position: relative;
      width: 100%;
      text-align: center;
      margin: 2.6%;
}
}
#about .arrow-link {
  margin-left: 2.6em;
}
#about .arrow-link p {
    background: #fff !important;
}
.arrow-link {
  text-decoration: none;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: start;
  justify-content: flex-start;
  text-transform: uppercase;
  margin-left: 42px;
}
.arrow-link svg {
    transition: transform 0.5s ease;
    transform: translate3d(-60%, 1px, 0);
}
.arrow-link svg.hide-pointer {
      margin-right: -5em;
}
.arrow-link svg.hide-pointer #Line-2 {
        display: none;
}
.arrow-link p, .arrow-link span {
    color: #1d1b31;
    padding: 6px 8px;
    white-space: nowrap;
    position: relative;
    z-index: 1;
    font-size: 90%;
    background: rgba(255, 255, 255, 0.58);
    border-radius: 0px;
    backdrop-filter: blur(5.1px);
    -webkit-backdrop-filter: blur(5.1px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    top: 3px;
}
.arrow-link:hover {
    color: #2c2b3c;
}
.arrow-link:hover p, .arrow-link:hover span {
      color: #2c2b3c;
}
.arrow-link:hover svg {
      transform: translate3d(-30%, 1px, 0);
}
.pagination-big {
  font-size: 6rem;
  position: fixed;
  bottom: 0;
  width: 300px;
  z-index: 2;
  margin-bottom: -16px;
  margin-left: -6px;
}
@media (max-width: 480px) {
.pagination-big {
      padding-left: 30px !important;
      font-size: 2.5rem;
      padding-bottom: 1px !important;
}
}
.img-box {
  overflow: hidden;
  display: -ms-inline-grid;
  display: inline-grid;
}
.img-box img {
    width: 100%;
}
.affix-container {
  width: 100%;
}
@media (max-width: 767px) {
.affix-container {
      position: relative !important;
}
}
.affix {
  width: 38.93%;
}
.vue-affix.affix {
  top: 10px !important;
}
.card.bg-dark h3 {
  color: white;
}
.horizontal-timeline-container {
  position: relative;
  white-space: nowrap;
  overflow: hidden;
}
.horizontal-timeline-line {
  position: absolute;
  top: 3%;
  left: 0;
  height: 1px;
  background-color: #ffffff;
  width: 0%;
  z-index: 0;
}
@media (max-width: 480px) {
.horizontal-timeline-line {
      display: none;
}
}
.horizontal-timeline {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: row;
      flex-direction: row;
  position: relative;
}
@media (max-width: 480px) {
.horizontal-timeline {
      -ms-flex-direction: column;
          flex-direction: column;
}
}
.horizontal-timeline-item {
  position: relative;
  text-align: left;
  width: 100%;
  z-index: 1;
}
.timeline-dot {
  height: 10px;
  width: 10px;
  background-color: #ffffff;
  border-radius: 50%;
  display: inline-block;
  margin-bottom: 10px;
  /* Hidden initially */
}
@media (max-width: 480px) {
.timeline-dot {
      visibility: hidden;
}
}
.timeline-text {
  color: white;
  text-wrap: balance;
  opacity: 0;
  /* Hidden initially */
}
.timeline-text h4 {
  font-size: 16px;
  color: white;
  font-weight: bold;
  margin: 0px 0px 10px;
  text-wrap: wrap;
  padding-right: 40%;
}
.timeline-text p {
  font-size: 14px;
  margin: 0;
}
.timeline-page-image img {
  width: 70%;
  border: 36px solid #ffffff;
  margin: 10% 5%;
}
@media (max-width: 480px) {
.timeline-page-image img {
      display: none;
}
}
.timeline-item {
  padding: 1px 2em 1em;
  position: relative;
  opacity: 0;
  border-left: 1px solid #f3f8ff;
}
.timeline-item::before {
    content: attr(date-is);
    position: absolute;
    left: -6rem;
    top: 2em;
    display: block;
    font-weight: 700;
    font-size: 0.785rem;
    width: 5rem;
    text-align: right;
    color: #2c2b3c;
    letter-spacing: 0.8px;
}
@media (max-width: 480px) {
.timeline-item::before {
        left: 2rem;
        top: 0;
        text-align: left;
}
}
.timeline-item::after {
    width: 5px;
    height: 5px;
    display: block;
    top: 2em;
    position: absolute;
    left: -4px;
    border-radius: 10px;
    content: '';
    border: 1px solid #b2b0d4;
    background: #b2b0d4;
}
@media (max-width: 480px) {
.timeline-item::after {
        display: none;
}
}
.timeline-item:last-child {
    border-image: linear-gradient(to bottom, #f3f8ff 60%, rgba(243, 248, 255, 0)) 1 100%;
}
.timeline-item:first-child {
    border-image: linear-gradient(to top, #f3f8ff 60%, rgba(243, 248, 255, 0)) 1 100%;
}
#nprogress .bar {
  background: #131221 !important;
}
.spinner {
  display: none !important;
}
#nprogress .peg {
  box-shadow: 0 0 10px #000, 0 0 5px #000 !important;
}
img.design-principle-img {
  padding: 2em 0;
  width: 20%;
  margin-top: 100px;
  margin-left: 10px;
}
img.user-research-example-img {
  max-width: 100%;
}
img.user-research-flow-img {
  max-width: 100%;
}
img.portify-screenshot-showcase-img {
  width: 100%;
  margin: 0 auto;
  display: block;
}
@media (max-width: 480px) {
img.sketch-storybook-img {
    width: 100%;
}
}
@media (max-width: 480px) {
img.atomic-img {
    width: 100%;
}
}
.design-system-svg-container > svg {
  width: 100%;
  height: 100%;
}
@media (max-width: 480px) {
.sidebar {
    padding-top: 0;
    margin-top: 0 !important;
    padding-left: 0 !important;
}
}
@media (max-width: 480px) {
.sidebar .subtitle {
    padding-top: 0 !important;
}
}
.section-right-content {
  padding-top: 4rem;
  padding-bottom: 4rem;
  margin-top: 4rem;
  margin-bottom: 4rem;
  margin-right: 4rem;
  margin-left: 2rem;
}
@media (max-width: 480px) {
.section-right-content {
      padding: 4rem;
      margin: 0;
}
}
.section-left-content {
  padding-top: 4rem;
  padding-bottom: 4rem;
  margin-top: 4rem;
  margin-bottom: 4rem;
  margin-right: 4rem;
  margin-left: 4rem;
}
@media (max-width: 480px) {
.section-left-content {
      padding: 4rem;
      margin: 0;
}
}
@media (max-width: 480px) {
.home-main-content {
    font-size: 100%;
    padding-right: 10%;
}
}
@media (max-width: 480px) {
.contact-icons {
    right: 5%;
    top: 11px;
}
}
.video-container {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  height: 0;
}
.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Global Stylesheet (e.g., styles.css) */
/* Ensure the medium-zoom overlay is above other elements */
.medium-zoom-overlay {
  z-index: 9999 !important;
}

/* Ensure the zoomed image is above the overlay */
.medium-zoom-image--opened {
  z-index: 10000 !important;
}

/* ==========================================================================
   Normalize.scss settings
   ========================================================================== */
/**
 * Includes legacy browser support IE6/7
 *
 * Set to false if you want to drop support for IE6 and IE7
 */
/* Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 * 3. Corrects text resizing oddly in IE 6/7 when body `font-size` is set using
 *  `em` units.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevents modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active, a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Addresses styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * 1. Remove border when inside `a` element in IE 8/9/10.
 * 2. Improves image quality when scaled in IE 7.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 * Correct font family set oddly in IE 6, Safari 4/5, and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *  Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 * 4. Improves appearance and consistency in all browsers.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *  and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *  `input` and others.
 * 4. Removes inner spacing in IE 7 without affecting normal text inputs.
 *  Known issue: inner spacing remains in IE 6.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 *  Known issue: excess padding remains in IE 6.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 * 3. Corrects text not wrapping in Firefox 3.
 * 4. Corrects alignment displayed oddly in IE 6/7.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
.icon-menu-container {
  display: -ms-flexbox;
  display: flex;
}
.icon-menu-container .bar1,
  .icon-menu-container .bar2,
  .icon-menu-container .bar3 {
    width: 1px;
    height: 50px;
    background-color: #131221;
    margin: 6px 3px;
    transition: 0.4s;
}
@media (max-width: 480px) {
.icon-menu-container .bar1,
      .icon-menu-container .bar2,
      .icon-menu-container .bar3 {
        height: 20px;
}
}
.icon-menu-container.close .bar1 {
    transform: rotate(45deg) translate(8px, 13px) !important;
    height: 12px;
}
.icon-menu-container.close .bar2 {
    transform: rotate(-90deg) translate(-10px, 0px);
    height: 30px;
}
.icon-menu-container.close .bar3 {
    transform: rotate(-45deg) translate(-29px, 4px) !important;
    height: 12px;
}
.icon-menu-container.close:hover .bar1,
  .icon-menu-container.close:hover .bar2,
  .icon-menu-container.close:hover .bar3 {
    margin: 6px 3px;
}
.icon-menu-container.close:hover .bar2 {
    transform: rotate(-90deg) translate(-6px, 4px);
    transform-style: preserve-3d;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    height: 38px;
}
.icon-menu-container:hover .bar2 {
    transform: scale(1.1);
    transform-style: preserve-3d;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    /* transition: all 0.4s linear; */
}
.icon-menu-container:hover .bar1,
  .icon-menu-container:hover .bar3 {
    transform: scale(0.9);
    transform-style: preserve-3d;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
.animated-box-1 {
  height: 100%;
  width: 100%;
  position: absolute;
  z-index: 0;
  transition: all 2s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.unicorn-text {
  background-image: linear-gradient(to right, #008686, #00b7db, #c039c5, #4a50c2, #009e9e);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  background-size: 300%;
  background-position: -100%;
  animation: colourfulText 10s infinite alternate-reverse;
}
@keyframes colourfulText {
to {
    background-position: 100%;
}
}
.big-button {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  z-index: 9;
}
@media (max-width: 480px) {
.big-button .arrow-wrapper {
      margin-left: 10% !important;
}
}
@media (max-width: 767px) {
.big-button {
      margin-right: -3rem;
}
.big-button.project-page {
        width: 100% !important;
        margin-right: 0;
}
.big-button h1 {
        font-size: 1.2rem;
}
}
.big-button:hover .animated-box-1 {
    transform: scale(1.1, 1.1);
    box-shadow: 0px 0 144px rgba(178, 176, 214, 0.47);
}
@media (max-width: 480px) {
.big-button:hover .animated-box-1 {
        transform: scale(1, 1);
}
}
.big-button:hover .animated-box-1::after {
      opacity: 1;
}
.big-button.project-page .animated-box-1 {
    box-shadow: 11px 0 14px rgba(0, 0, 0, 0.04);
}
.fade-out {
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
  -moz-transition: opacity 0.3s ease-in-out;
  -webkit-transition: opacity 0.3s ease-in-out;
}
.fade-in {
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
  -moz-transition: opacity 0.3s ease-in-out;
  -webkit-transition: opacity 0.3s ease-in-out;
}
.arrow-container a {
  text-decoration: none;
  transition: all 3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.arrow-container a:hover span {
    transition: all 3s cubic-bezier(0.165, 0.84, 0.44, 1);
    color: #131221;
}
.arrow-container .page-nav .page-nav-item {
  height: 25%;
}
.arrow-container .page-nav .page-nav-item.active span {
    color: #131221;
}
.pulseText {
  transition: all 3s cubic-bezier(0.165, 0.84, 0.44, 1);
  color: #131221;
}
#arrow-1-svg-stroke path:first-child {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: offsetAnim 2s linear forwards;
  animation-delay: 2s;
}
#arrow-1-svg-stroke #Line-2 {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: offsetAnim 10s linear forwards;
}
.page-nav #arrow-1-svg-stroke path:first-child {
  animation-delay: 0s;
}
#vikku_s path {
  fill-opacity: 0;
  fill: #fff;
  stroke-dasharray: 400;
  stroke-dashoffset: 400;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
  animation-iteration-count: 1;
  animation-name: offsetAnim, fillInAnime;
  animation-duration: 2s, 1s;
  animation-delay: 2s, 3.5s;
}
@keyframes offsetAnim {
to {
    stroke-dashoffset: 0;
    transition: 2s linear;
}
}
@keyframes fillInAnime {
from {
    fill-opacity: 0;
}
to {
    fill-opacity: 1;
}
}
#vikku_s {
  transform: rotateY(0deg);
  transition: all 2s linear;
  transform-origin: 50% 0;
}
.home-link:hover #vikku_s {
  animation: rotationAnime 2s infinite linear;
}
@keyframes rotationAnime {
from {
    transform: rotateY(0deg);
}
to {
    transform: rotateY(359deg);
}
}
a .fancy-link {
  color: #1d1b31;
  background-image: linear-gradient(0deg, rgba(178, 176, 212, 0.09) 0%, #f3f8ff 100%);
  background-repeat: no-repeat;
  background-size: 100% 0;
  background-position: 0 88%;
  transition: background-size 0.25s ease-in;
}
a .fancy-link:hover {
    background-size: 100% 88%;
    color: #131221;
}
.fli {
  color: #1d1b31;
  background-image: linear-gradient(0deg, #b2b0d4 0%, #f3f8ff 100%);
  background-repeat: no-repeat;
  background-size: 100% 30%;
  background-position: 0 88%;
  transition: background-size 0.25s ease-in;
  text-decoration: none;
}
.fli:hover {
    background-size: 100% 88%;
    color: #131221;
    text-decoration: none;
}

/* credit: https://codepen.io/peeke/pen/BjxXZa*/
.attention {
  position: absolute;
  transform: translateX(-50%) translateY(-50%);
  width: 130px;
  height: 130px;
}
.attention.featured-project {
    left: 47%;
    bottom: -14.5%;
    opacity: 0.30;
}
.attention:before {
    content: '';
    position: relative;
    display: block;
    width: 300%;
    height: 300%;
    box-sizing: border-box;
    margin-left: -96%;
    margin-top: -96%;
    border-radius: 100%;
    border: 1px solid #131221;
    animation: pulse-ring 6.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}
.attention:after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    border: 4px solid #b2b0d4;
    border-radius: 100%;
    animation: pulse-dot 6.25s cubic-bezier(0.455, 0.03, 0.515, 0.955) -0.4s infinite;
}
@keyframes pulse-ring {
0% {
    transform: scale(0.33);
}
80%, 100% {
    opacity: 0;
}
}
@keyframes pulse-dot {
0% {
    transform: scale(0.8);
}
50% {
    transform: scale(1);
}
100% {
    transform: scale(0.8);
}
}
.all-projects-link circle {
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.all-projects-link circle#Rectangle-1 {
    transform: translate(1px, 1px);
}
.all-projects-link circle#Rectangle-2 {
    transform: translate(-1px, 1px);
}
.all-projects-link circle#Rectangle-3 {
    transform: translate(1px, -1px);
}
.all-projects-link circle#Rectangle-4 {
    transform: translate(-1px, -1px);
}
.all-projects-link:hover circle#Rectangle-1, .all-projects-link:active circle#Rectangle-1 {
  transform: translate(0, 0);
}
.all-projects-link:hover circle#Rectangle-2, .all-projects-link:active circle#Rectangle-2 {
  transform: translate(0, 0);
}
.all-projects-link:hover circle#Rectangle-3, .all-projects-link:active circle#Rectangle-3 {
  transform: translate(0, 0);
}
.all-projects-link:hover circle#Rectangle-4, .all-projects-link:active circle#Rectangle-4 {
  transform: translate(0, 0);
}
#parallax-container {
  position: relative;
  height: 110vh;
  padding-bottom: 100px;
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
}
#parallax-container h1 {
    font-size: 1.5rem;
}
@media (min-width: 1200px) {
#parallax-container h1 {
      font-size: 2;
}
}
@media (max-width: 979px) {
#parallax-container h1 {
      font-size: 1.2rem;
}
}
.grid-item-img {
  overflow: hidden;
  z-index: 1;
}
.grid-item-4 {
  left: 20%;
  top: 10vh;
}
@media (max-width: 767px) {
.grid-item-4 {
      left: 18%;
      top: 30%;
}
}
.grid-item-1 {
  left: 60%;
  top: 10vh;
}
@media (max-width: 767px) {
.grid-item-1 {
      left: 18%;
      top: 90%;
}
}
.grid-item-2 {
  left: 10%;
  top: 70vh;
}
@media (max-width: 767px) {
.grid-item-2 {
      left: 18%;
      top: 150%;
}
}
.grid-item-3 {
  left: 60%;
  top: 70vh;
}
@media (max-width: 767px) {
.grid-item-3 {
      left: 18%;
      top: 220%;
}
}
.grid-item-4-img {
  width: 400px;
}
.grid-item-4-bg,
.grid-item-4-img-container {
  height: 18rem;
  width: 16rem;
}
.grid-item-4-bg {
  z-index: 0;
  left: 0;
  top: 0;
  margin-left: 30px;
  margin-top: 30px;
}
.grid-item-4-label {
  width: 140px;
  text-align: right;
  left: -11rem;
  top: 8rem;
}
@media (max-width: 767px) {
.grid-item-4-label {
      left: 7rem;
      top: -11rem;
}
}
.grid-item-1-img {
  width: 400px;
}
.grid-item-1-bg,
.grid-item-1-img-container {
  height: 20rem;
  width: 16rem;
}
.grid-item-1-bg {
  z-index: 0;
  left: 0;
  top: 0;
  margin-left: 30px;
  margin-top: 30px;
}
.grid-item-1-label {
  width: 140px;
  text-align: right;
  left: -11rem;
  top: 8rem;
}
@media (max-width: 767px) {
.grid-item-1-label {
      left: 7rem;
      top: -11rem;
}
}
.grid-item-2-img {
  width: 400px;
}
.grid-item-2-bg,
.grid-item-2-img-container {
  height: 20rem;
  width: 16rem;
}
.grid-item-2-bg {
  z-index: 0;
  margin-left: 30px;
  margin-top: -30px;
}
.grid-item-2-label {
  width: 90px;
  text-align: left;
  left: 3rem;
  top: -10rem;
}
@media (min-width: 1200px) {
.grid-item-2-label {
      left: 19rem;
      top: 3rem;
}
}
.grid-item-3-img {
  width: 400px;
}
.grid-item-3-img-container img {
  margin-top: -24px;
}
.grid-item-3-bg,
.grid-item-3-img-container {
  height: 13rem;
  width: 21rem;
}
@media (max-width: 767px) {
.grid-item-3-bg,
    .grid-item-3-img-container {
      width: 18rem;
}
}
.grid-item-3-bg {
  z-index: 0;
  margin-left: -30px;
  margin-top: -30px;
}
.grid-item-3-label {
  width: 90px;
  text-align: left;
  left: 24rem;
  top: 4rem;
}
@media (max-width: 767px) {
.grid-item-3-label {
      left: 4rem;
      top: -13rem;
}
}
.img-hover-effect {
  background: #fff;
}
.img-hover-effect img {
    width: 100%;
}
.img-hover-effect .img-caption {
    padding: 3em;
}
.img-hover-effect img {
    transform: translate3d(0, -30px, 0);
    transition: opacity 0.35s, transform 0.35s;
}
.img-hover-effect:hover {
    background: #2c2b3c;
}
.img-hover-effect:hover img {
      opacity: 0.2;
      transform: translate3d(0, 0, 0);
}
.img-hover-effect:hover .img-caption .arrow .line {
      opacity: 1;
      transform: scale(1);
}
.img-hover-effect:hover .img-caption .arrow-bar2 {
      transform: rotate(45deg) translate(15px, 14px) scale(-1);
      -webkit-transition: rotate(45deg) translate(15px, 14px) scale(-1);
}
.img-hover-effect:hover .img-caption .arrow-bar3 {
      transform: rotate(135deg) translate(-8px, 6px) scale(1);
      -webkit-transition: rotate(135deg) translate(-8px, 6px) scale(1);
}
.img-hover-effect .arrow {
    width: 180px;
    margin: 50px auto;
    height: 180px;
    position: absolute;
    top: 0;
    left: 50%;
}
.img-hover-effect .arrow-tip {
    position: absolute;
    bottom: -54px;
}
.img-hover-effect .line {
    margin-top: 14px;
    width: 1px;
    background: #fff;
    height: 180px;
    float: left;
    transform: scale(0);
    transform-origin: 0 0;
    transition: opacity 0.35s, transform 0.35s;
}
.img-hover-effect .box {
    width: auto;
    height: 400px;
    margin: 4em 20px;
    border: 1px dashed;
    position: relative;
}
.img-hover-effect .arrow-bar2 {
    transform: rotate(45deg) translate(15px, 14px) scale(0);
    transform-origin: 0 0;
}
.img-hover-effect .arrow-bar3 {
    transform: rotate(135deg) translate(-8px, 6px) scale(0);
    transform-origin: 0 0;
}
.img-hover-effect .arrow-bar2,
  .img-hover-effect .arrow-bar3 {
    width: 1px;
    height: 30px;
    background-color: #fff;
    transition: 0.4s;
    -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
}
.grid-item-3-img-container .line {
  height: 80px;
}
.grid-item-3-img-container .arrow-tip {
  bottom: 46px;
}
.grid-item-1-bg,
.grid-item-2-bg,
.grid-item-3-bg,
.grid-item-4-bg {
  left: 0;
  top: 0;
  transition: all 0.5s ease;
}
.grid-item-1:hover .grid-item-1-bg {
  height: 21rem;
  width: 16rem;
  left: 2rem;
  top: -1rem;
}
.grid-item-2:hover .grid-item-2-bg {
  height: 21rem;
  width: 16rem;
  left: -2rem;
  top: -1rem;
}
.grid-item-2-bg {
  transform: translate(40px);
  left: -3rem;
  top: 1rem;
}
.grid-item-3:hover .grid-item-3-bg {
  height: 18rem;
  width: 20rem;
  top: -1rem;
  left: -1rem;
}
.grid-item-4:hover .grid-item-4-bg {
  height: 18rem;
  width: 20rem;
  top: -1rem;
  left: -1rem;
}
/* Make clicks pass-through */
#nprogress {
  pointer-events: none;
}
#nprogress .bar {
  background: #29d;

  position: fixed;
  z-index: 1031;
  top: 0;
  left: 0;

  width: 100%;
  height: 2px;
}

/* Fancy blur effect */
#nprogress .peg {
  display: block;
  position: absolute;
  right: 0px;
  width: 100px;
  height: 100%;
  box-shadow: 0 0 10px #29d, 0 0 5px #29d;
  opacity: 1.0;
  transform: rotate(3deg) translate(0px, -4px);
}

/* Remove these to get rid of the spinner */
#nprogress .spinner {
  display: block;
  position: fixed;
  z-index: 1031;
  top: 15px;
  right: 15px;
}
#nprogress .spinner-icon {
  width: 18px;
  height: 18px;
  box-sizing: border-box;

  border: solid 2px transparent;
  border-top-color: #29d;
  border-left-color: #29d;
  border-radius: 50%;
  animation: nprogress-spinner 400ms linear infinite;
}
.nprogress-custom-parent {
  overflow: hidden;
  position: relative;
}
.nprogress-custom-parent #nprogress .spinner,
.nprogress-custom-parent #nprogress .bar {
  position: absolute;
}
@keyframes nprogress-spinner {
0%   { transform: rotate(0deg);
}
100% { transform: rotate(360deg);
}
}

