/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

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

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

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

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

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

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

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

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

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

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

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/*#############################################################################
# FUNCTIONS
#############################################################################*/
/*#############################################################################
# MIXINS
#############################################################################*/
/* Example:
div.logo {
  background: image-url("logo.png") no-repeat;
  @include background-retina("logo2x.png", 100px, 25px);
}
*/
/*#############################################################################
# PLACEHOLDERS
#############################################################################*/
/*#############################################################################
# BASE
#############################################################################*/
html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

*, *:before, *:after {
  -webkit-box-sizing: inherit;
          box-sizing: inherit; }

html,
body {
  min-height: 100%;
  font-family: "Lato", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  overflow-x: hidden; }

body {
  background-color: #fff;
  color: #434448; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 900;
  margin: 0.5em 0;
  line-height: 1.4em; }

h1 {
  font-size: 1.875rem; }
  @media only screen and (min-width: 40.0625rem) {
    h1 {
      font-size: 2.375rem; } }

h2 {
  font-size: 1.625rem; }
  @media only screen and (min-width: 40.0625rem) {
    h2 {
      font-size: 2rem; } }

h3 {
  font-size: 1.375rem; }
  @media only screen and (min-width: 40.0625rem) {
    h3 {
      font-size: 1.75rem; } }

h4 {
  font-size: 1.125rem; }
  @media only screen and (min-width: 40.0625rem) {
    h4 {
      font-size: 1.375rem; } }

h5 {
  font-size: 1rem;
  text-transform: uppercase; }
  @media only screen and (min-width: 40.0625rem) {
    h5 {
      font-size: 1rem; } }

h6 {
  font-size: 1rem; }
  @media only screen and (min-width: 40.0625rem) {
    h6 {
      font-size: 1rem; } }

p {
  margin: 0 0 20px; }
  p.small {
    font-size: 0.875rem; }
  p.opacity {
    opacity: 0.5; }
  p.alert {
    color: #FF425E; }
  p.success {
    color: #45DFB0; }
  p.secondary {
    color: #AFB3C0; }
  p.centered {
    text-align: center; }

a {
  color: #4D4CFC;
  text-decoration: none;
  -moz-transition: color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s, background-color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s;
  -o-transition: color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s, background-color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s;
  -webkit-transition: color 0.3s cubic-bezier(0.7, 0, 0.175, 1), background-color 0.3s cubic-bezier(0.7, 0, 0.175, 1);
  -webkit-transition-delay: 0s, 0s;
  -webkit-transition: color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s, background-color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s;
  transition: color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s, background-color 0.3s cubic-bezier(0.7, 0, 0.175, 1) 0s; }
  a:hover {
    color: #2a29fb; }
  a.secondary {
    color: #AFB3C0; }
    a.secondary:hover {
      color: #848a9e;
      text-decoration: underline; }
  a.alert {
    color: #FF425E; }
    a.alert:hover {
      color: #f50024;
      text-decoration: underline; }
  a.underlined {
    text-decoration: underline; }

.text-secondary {
  color: #AFB3C0; }

.text-success {
  color: #45DFB0; }

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

hr {
  border: none;
  border-bottom: 1px solid #dadce2;
  margin: 30px 0; }
  hr.translucent {
    opacity: 0.5; }
  hr.big-push {
    margin: 60px 0; }

/*#############################################################################
# LAYOUT
#############################################################################*/
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr); }
  @media only screen and (min-width: 40.0625rem) {
    .grid {
      grid-column-gap: 40px; } }
  .grid .col.sm1 {
    grid-column: span 1; }
  .grid .col.sm2 {
    grid-column: span 2; }
  .grid .col.sm3 {
    grid-column: span 3; }
  .grid .col.sm4 {
    grid-column: span 4; }
  .grid .col.sm5 {
    grid-column: span 5; }
  .grid .col.sm6 {
    grid-column: span 6; }
  .grid .col.sm7 {
    grid-column: span 7; }
  .grid .col.sm8 {
    grid-column: span 8; }
  .grid .col.sm9 {
    grid-column: span 9; }
  .grid .col.sm10 {
    grid-column: span 10; }
  .grid .col.sm11 {
    grid-column: span 11; }
  .grid .col.sm12 {
    grid-column: span 12; }
  @media only screen and (min-width: 40.0625rem) {
    .grid .col.md1 {
      grid-column: span 1; }
    .grid .col.md2 {
      grid-column: span 2; }
    .grid .col.md3 {
      grid-column: span 3; }
    .grid .col.md4 {
      grid-column: span 4; }
    .grid .col.md5 {
      grid-column: span 5; }
    .grid .col.md6 {
      grid-column: span 6; }
    .grid .col.md7 {
      grid-column: span 7; }
    .grid .col.md8 {
      grid-column: span 8; }
    .grid .col.md9 {
      grid-column: span 9; }
    .grid .col.md10 {
      grid-column: span 10; }
    .grid .col.md11 {
      grid-column: span 11; }
    .grid .col.md12 {
      grid-column: span 12; } }
  @media only screen and (min-width: 53.75rem) {
    .grid .col.xm1 {
      grid-column: span 1; }
    .grid .col.xm2 {
      grid-column: span 2; }
    .grid .col.xm3 {
      grid-column: span 3; }
    .grid .col.xm4 {
      grid-column: span 4; }
    .grid .col.xm5 {
      grid-column: span 5; }
    .grid .col.xm6 {
      grid-column: span 6; }
    .grid .col.xm7 {
      grid-column: span 7; }
    .grid .col.xm8 {
      grid-column: span 8; }
    .grid .col.xm9 {
      grid-column: span 9; }
    .grid .col.xm10 {
      grid-column: span 10; }
    .grid .col.xm11 {
      grid-column: span 11; }
    .grid .col.xm12 {
      grid-column: span 12; } }
  @media only screen and (min-width: 64.0625rem) {
    .grid .col.lg1 {
      grid-column: span 1; }
    .grid .col.lg2 {
      grid-column: span 2; }
    .grid .col.lg3 {
      grid-column: span 3; }
    .grid .col.lg4 {
      grid-column: span 4; }
    .grid .col.lg5 {
      grid-column: span 5; }
    .grid .col.lg6 {
      grid-column: span 6; }
    .grid .col.lg7 {
      grid-column: span 7; }
    .grid .col.lg8 {
      grid-column: span 8; }
    .grid .col.lg9 {
      grid-column: span 9; }
    .grid .col.lg10 {
      grid-column: span 10; }
    .grid .col.lg11 {
      grid-column: span 11; }
    .grid .col.lg12 {
      grid-column: span 12; } }
  @media only screen and (min-width: 75rem) {
    .grid .col.xl1 {
      grid-column: span 1; }
    .grid .col.xl2 {
      grid-column: span 2; }
    .grid .col.xl3 {
      grid-column: span 3; }
    .grid .col.xl4 {
      grid-column: span 4; }
    .grid .col.xl5 {
      grid-column: span 5; }
    .grid .col.xl6 {
      grid-column: span 6; }
    .grid .col.xl7 {
      grid-column: span 7; }
    .grid .col.xl8 {
      grid-column: span 8; }
    .grid .col.xl9 {
      grid-column: span 9; }
    .grid .col.xl10 {
      grid-column: span 10; }
    .grid .col.xl11 {
      grid-column: span 11; }
    .grid .col.xl12 {
      grid-column: span 12; } }

.section-wrapper {
  padding: 80px 0; }
  .section-wrapper:last-child {
    padding: 80px 0 120px; }
  .section-wrapper.sides-push {
    background-color: #f7f8fb;
    margin: 40px 20px;
    border-radius: 10px; }
    @media only screen and (min-width: 64.0625rem) {
      .section-wrapper.sides-push {
        margin: 40px; } }
  .section-wrapper.negative {
    background-color: #282755;
    color: white; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 10px; }
  @media only screen and (min-width: 40.0625rem) {
    .container {
      padding: 0 20px; } }
  .container.centered {
    text-align: center; }
  .container .container {
    padding: 0; }

.content-box {
  margin-bottom: 120px; }
  .content-box:last-of-type {
    margin-bottom: 0; }
  @media only screen and (min-width: 40.0625rem) {
    .content-box {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-column-gap: 10%;
      justify-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      margin-bottom: 200px; }
      .content-box.reverse .content-box-col:nth-child(1) {
        grid-column: 2;
        grid-row: 1; }
      .content-box.reverse .content-box-col:nth-child(2) {
        grid-column: 1;
        grid-row: 1; } }
  @media only screen and (min-width: 53.75rem) {
    .content-box {
      grid-column-gap: 20%; } }

/*#############################################################################
# LAYOUT APP
#############################################################################*/
body#app {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100vh;
  overflow: auto; }
  body#app header.app-header {
    background-color: #fff; }
  body#app.steps section.app-body {
    background-color: #F4F4F5; }
    body#app.steps section.app-body div.step-main {
      background-color: #fff;
      overflow: auto;
      padding: 20px 20px 0;
      min-height: calc(100vh - 61px);
      position: relative; }
    body#app.steps section.app-body div.step-sidebar {
      display: none; }
      body#app.steps section.app-body div.step-sidebar::-webkit-scrollbar {
        display: none; }
    @media only screen and (min-width: 40.0625rem) {
      body#app.steps section.app-body div.step-main {
        padding: 20px 40px 0; } }
    @media only screen and (min-width: 53.75rem) {
      body#app.steps section.app-body {
        display: grid;
        grid-template-columns: 1fr 300px;
        height: calc(100vh - 70px); }
        body#app.steps section.app-body div.step-main {
          grid-column: 1;
          grid-row: 1;
          padding: 40px 60px 0;
          -webkit-box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.05);
          box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.05); }
        body#app.steps section.app-body div.step-sidebar {
          display: block;
          grid-column: 2;
          grid-row: 1;
          padding: 30px 30px 0; } }
    @media only screen and (min-width: 64.0625rem) {
      body#app.steps section.app-body {
        grid-template-columns: 1fr 400px; } }
  body#app.steps.sidebar-left section.app-body {
    grid-template-columns: 1fr; }
    body#app.steps.sidebar-left section.app-body div.step-main {
      grid-column: 1;
      grid-row: 1; }
    @media only screen and (min-width: 53.75rem) {
      body#app.steps.sidebar-left section.app-body {
        grid-template-columns: 300px 1fr; }
        body#app.steps.sidebar-left section.app-body div.step-main {
          grid-column: 2;
          grid-row: 1; }
        body#app.steps.sidebar-left section.app-body div.step-sidebar {
          grid-column: 1;
          grid-row: 1; } }
    @media only screen and (min-width: 64.0625rem) {
      body#app.steps.sidebar-left section.app-body {
        grid-template-columns: 400px 1fr; } }
  body#app.blocks section.app-body {
    background-color: #F4F4F5;
    display: grid;
    grid-template-columns: 1fr;
    height: calc(100vh - 70px); }
    body#app.blocks section.app-body div.block-main {
      grid-column: 1;
      grid-row: 1;
      background-color: #fff;
      overflow: auto;
      padding: 20px;
      position: relative; }
      body#app.blocks section.app-body div.block-main.centered-content .content-wrapper {
        margin: 0 auto;
        text-align: center; }
    @media only screen and (min-width: 53.75rem) {
      body#app.blocks section.app-body div.block-main {
        padding: 40px 60px; }
        body#app.blocks section.app-body div.block-main.centered-content .content-wrapper {
          width: 630px; } }
  body#app.progress-bar section.app-body {
    height: calc(100vh - 80px); }
  body#app.my-products section.app-body div.block-main {
    background-color: transparent; }
  body#app.my-account section.app-body div.step-main {
    padding-bottom: 60px; }
  @media only screen and (min-width: 53.75rem) {
    body#app {
      overflow: hidden; } }

/*#############################################################################
# BUTTONS
#############################################################################*/
.button {
  display: inline-block;
  background-color: #4D4CFC;
  color: #fff;
  font-weight: 900;
  padding: 10px 20px;
  margin: 0 10px 10px 0;
  border-radius: 4px; }
  .button:hover {
    background-color: #0504de;
    color: white;
    text-decoration: none; }
  .button.secondary {
    background-color: #AFB3C0;
    color: #ffffff; }
    .button.secondary:hover {
      background-color: #848a9e;
      color: #fff;
      text-decoration: none; }
  .button.success {
    background-color: #45DFB0;
    color: #ffffff; }
    .button.success:hover {
      background-color: #20b889;
      color: #fff;
      text-decoration: none; }
  .button.alert {
    background-color: #FF425E;
    color: #ffffff; }
    .button.alert:hover {
      background-color: #f50024;
      color: #fff;
      text-decoration: none; }
  .button.warning {
    background-color: #FFFF00;
    color: #434448; }
    .button.warning:hover {
      background-color: #b3b300;
      color: #fff;
      text-decoration: none; }
  .button.outline {
    background: transparent;
    color: #4D4CFC;
    -webkit-box-shadow: 0 0 0 2px #4D4CFC inset;
    box-shadow: 0 0 0 2px #4D4CFC inset; }
    .button.outline:hover {
      background: rgba(77, 76, 252, 0.1);
      color: #0504de;
      -webkit-box-shadow: 0 0 0 2px #0504de inset;
      box-shadow: 0 0 0 2px #0504de inset; }
    .button.outline.secondary {
      background: transparent;
      color: #AFB3C0;
      -webkit-box-shadow: 0 0 0 2px #AFB3C0 inset;
      box-shadow: 0 0 0 2px #AFB3C0 inset; }
      .button.outline.secondary:hover {
        background: rgba(175, 179, 192, 0.1);
        color: #848a9e;
        -webkit-box-shadow: 0 0 0 2px #848a9e inset;
        box-shadow: 0 0 0 2px #848a9e inset; }
    .button.outline.success {
      background: transparent;
      color: #45DFB0;
      -webkit-box-shadow: 0 0 0 2px #45DFB0 inset;
      box-shadow: 0 0 0 2px #45DFB0 inset; }
      .button.outline.success:hover {
        background: rgba(69, 223, 176, 0.1);
        color: #20b889;
        -webkit-box-shadow: 0 0 0 2px #20b889 inset;
        box-shadow: 0 0 0 2px #20b889 inset; }
    .button.outline.alert {
      background: transparent;
      color: #FF425E;
      -webkit-box-shadow: 0 0 0 2px #FF425E inset;
      box-shadow: 0 0 0 2px #FF425E inset; }
      .button.outline.alert:hover {
        background: rgba(255, 66, 94, 0.1);
        color: #f50024;
        -webkit-box-shadow: 0 0 0 2px #f50024 inset;
        box-shadow: 0 0 0 2px #f50024 inset; }
    .button.outline.warning {
      background: transparent;
      color: #FFFF00;
      -webkit-box-shadow: 0 0 0 2px #FFFF00 inset;
      box-shadow: 0 0 0 2px #FFFF00 inset; }
      .button.outline.warning:hover {
        background: rgba(255, 255, 0, 0.1);
        color: #b3b300;
        -webkit-box-shadow: 0 0 0 2px #b3b300 inset;
        box-shadow: 0 0 0 2px #b3b300 inset; }
  .button.small {
    font-size: 0.875rem;
    padding: 5px 10px; }
  .button.is-disabled {
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.3; }

/*#############################################################################
# FORMS AND INPUTS
#############################################################################*/
.input-group {
  margin: 0 0 30px; }
  .input-group > label {
    display: block;
    font-weight: 900;
    line-height: 1.5rem;
    margin-bottom: 10px; }
  .input-group .input-wrapper {
    margin-bottom: 10px; }

.input-wrapper {
  margin: 0 0 30px;
  position: relative;
  /* Remove the stupid outer glow in Webkit */
  /* Labels
  -----------------------------------------------*/
  /* Text Inputs
  -----------------------------------------------*/
  /* Button Controls
  -----------------------------------------------*/
  /* Textarea
  -----------------------------------------------*/
  /* Selects
  -----------------------------------------------*/
  /* Placeholder
  -----------------------------------------------*/ }
  .input-wrapper.no-margin {
    margin: 0; }
  .input-wrapper input {
    width: 100%; }
  .input-wrapper input,
  .input-wrapper label,
  .input-wrapper select,
  .input-wrapper button,
  .input-wrapper textarea {
    margin: 0;
    border: 0;
    padding: 0;
    display: inline-block;
    vertical-align: middle;
    white-space: normal;
    line-height: 1;
    font-size: 1rem;
    font-family: 'Lato', "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif; }
  .input-wrapper input:focus,
  .input-wrapper textarea:focus,
  .input-wrapper select:focus {
    outline: 0; }
  .input-wrapper label {
    font-weight: 900;
    line-height: 1.5rem;
    margin-bottom: 10px; }
  .input-wrapper .general-input-styles, .input-wrapper input[type=date],
  .input-wrapper input[type=datetime],
  .input-wrapper input[type=datetime-local],
  .input-wrapper input[type=email],
  .input-wrapper input[type=month],
  .input-wrapper input[type=number],
  .input-wrapper input[type=password],
  .input-wrapper input[type=range],
  .input-wrapper input[type=search],
  .input-wrapper input[type=tel],
  .input-wrapper input[type=text],
  .input-wrapper input[type=time],
  .input-wrapper input[type=url],
  .input-wrapper input[type=week], .input-wrapper textarea, .input-wrapper select {
    display: block;
    background-color: #ffffff;
    border: 1px solid #D7D9E2;
    color: #434448;
    font-weight: 400;
    margin: 0;
    padding: 12px 18px;
    min-height: 46px;
    width: 100%;
    border-radius: 4px; }
    .input-wrapper .general-input-styles:focus, .input-wrapper input[type=date]:focus,
    .input-wrapper input[type=datetime]:focus,
    .input-wrapper input[type=datetime-local]:focus,
    .input-wrapper input[type=email]:focus,
    .input-wrapper input[type=month]:focus,
    .input-wrapper input[type=number]:focus,
    .input-wrapper input[type=password]:focus,
    .input-wrapper input[type=range]:focus,
    .input-wrapper input[type=search]:focus,
    .input-wrapper input[type=tel]:focus,
    .input-wrapper input[type=text]:focus,
    .input-wrapper input[type=time]:focus,
    .input-wrapper input[type=url]:focus,
    .input-wrapper input[type=week]:focus, .input-wrapper textarea:focus, .input-wrapper select:focus {
      border-color: #4D4CFC;
      -webkit-box-shadow: 0 0 0 3px rgba(77, 76, 252, 0.15) inset;
      box-shadow: 0 0 0 3px rgba(77, 76, 252, 0.15) inset; }
    .input-wrapper .general-input-styles:disabled, .input-wrapper input[type=date]:disabled,
    .input-wrapper input[type=datetime]:disabled,
    .input-wrapper input[type=datetime-local]:disabled,
    .input-wrapper input[type=email]:disabled,
    .input-wrapper input[type=month]:disabled,
    .input-wrapper input[type=number]:disabled,
    .input-wrapper input[type=password]:disabled,
    .input-wrapper input[type=range]:disabled,
    .input-wrapper input[type=search]:disabled,
    .input-wrapper input[type=tel]:disabled,
    .input-wrapper input[type=text]:disabled,
    .input-wrapper input[type=time]:disabled,
    .input-wrapper input[type=url]:disabled,
    .input-wrapper input[type=week]:disabled, .input-wrapper textarea:disabled, .input-wrapper select:disabled {
      background-color: #F4F4F4;
      border-color: #E9EAEA;
      color: #B6B8BD; }
  .input-wrapper input[type=checkbox],
  .input-wrapper input[type=radio] {
    width: 15px;
    height: 15px; }
  .input-wrapper textarea {
    /* Move the label to the top */
    vertical-align: top;
    /* Turn off scroll bars in IE unless needed */
    overflow: auto; }
  .input-wrapper select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 30px; }
  .input-wrapper ::-webkit-input-placeholder {
    /* Chrome/Opera/Safari */
    color: #AFB3C0; }
  .input-wrapper ::-moz-placeholder {
    /* Firefox 19+ */
    color: #AFB3C0; }
  .input-wrapper :-ms-input-placeholder {
    /* IE 10+ */
    color: #AFB3C0; }
  .input-wrapper :-moz-placeholder {
    /* Firefox 18- */
    color: #AFB3C0; }
  .input-wrapper .select-wrapper {
    position: relative; }
    .input-wrapper .select-wrapper::after {
      display: block;
      content: "";
      border-style: solid;
      border-width: 5px 5px 0 5px;
      border-color: #D7D9E2 transparent transparent transparent;
      width: 0;
      height: 0;
      position: absolute;
      top: 50%;
      right: 13px;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
  .input-wrapper.has-addon {
    display: grid;
    grid-template-rows: auto 1fr; }
    .input-wrapper.has-addon .input-addon {
      background: #D7D9E2;
      line-height: 46px;
      height: 46px;
      padding: 0 18px; }
    .input-wrapper.has-addon label {
      grid-column: 1/3;
      grid-row: 1; }
    .input-wrapper.has-addon.preppend {
      grid-template-columns: auto 1fr; }
      .input-wrapper.has-addon.preppend .input-addon {
        grid-column: 1;
        grid-row: 2;
        border-top-left-radius: 4px;
        border-bottom-left-radius: 4px; }
      .input-wrapper.has-addon.preppend input,
      .input-wrapper.has-addon.preppend textarea,
      .input-wrapper.has-addon.preppend select {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0; }
    .input-wrapper.has-addon.append {
      grid-template-columns: 1fr auto; }
      .input-wrapper.has-addon.append .input-addon {
        grid-column: 2;
        grid-row: 2;
        border-top-right-radius: 4px;
        border-bottom-right-radius: 4px; }
      .input-wrapper.has-addon.append input,
      .input-wrapper.has-addon.append textarea,
      .input-wrapper.has-addon.append select {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0; }
    .input-wrapper.has-addon input:focus + .input-addon,
    .input-wrapper.has-addon textarea:focus + .input-addon,
    .input-wrapper.has-addon select:focus + .input-addon {
      background: #4D4CFC;
      color: #fff; }
  .input-wrapper.has-error .error-input-styles, .input-wrapper.has-error input[type=date],
  .input-wrapper.has-error input[type=datetime],
  .input-wrapper.has-error input[type=datetime-local],
  .input-wrapper.has-error input[type=email],
  .input-wrapper.has-error input[type=month],
  .input-wrapper.has-error input[type=number],
  .input-wrapper.has-error input[type=password],
  .input-wrapper.has-error input[type=range],
  .input-wrapper.has-error input[type=search],
  .input-wrapper.has-error input[type=tel],
  .input-wrapper.has-error input[type=text],
  .input-wrapper.has-error input[type=time],
  .input-wrapper.has-error input[type=url],
  .input-wrapper.has-error input[type=week],
  .input-wrapper.has-error textarea,
  .input-wrapper.has-error select {
    background-color: #fff4f6;
    border-color: #FF425E;
    color: #FF425E; }
    .input-wrapper.has-error .error-input-styles:focus, .input-wrapper.has-error input[type=date]:focus,
    .input-wrapper.has-error input[type=datetime]:focus,
    .input-wrapper.has-error input[type=datetime-local]:focus,
    .input-wrapper.has-error input[type=email]:focus,
    .input-wrapper.has-error input[type=month]:focus,
    .input-wrapper.has-error input[type=number]:focus,
    .input-wrapper.has-error input[type=password]:focus,
    .input-wrapper.has-error input[type=range]:focus,
    .input-wrapper.has-error input[type=search]:focus,
    .input-wrapper.has-error input[type=tel]:focus,
    .input-wrapper.has-error input[type=text]:focus,
    .input-wrapper.has-error input[type=time]:focus,
    .input-wrapper.has-error input[type=url]:focus,
    .input-wrapper.has-error input[type=week]:focus,
    .input-wrapper.has-error textarea:focus,
    .input-wrapper.has-error select:focus {
      border-color: #FF425E;
      -webkit-box-shadow: 0 0 0 3px rgba(255, 66, 94, 0.15) inset;
      box-shadow: 0 0 0 3px rgba(255, 66, 94, 0.15) inset; }
  .input-wrapper.has-error .input-addon {
    background-color: #FF425E;
    color: #fff; }
  .input-wrapper.has-error input:focus + .input-addon,
  .input-wrapper.has-error textarea:focus + .input-addon,
  .input-wrapper.has-error select:focus + .input-addon {
    background: #FF425E; }
  .input-wrapper.has-error .select-wrapper::after {
    border-color: #FF425E transparent transparent transparent; }
  .input-wrapper.has-error span.error-msg {
    display: block;
    grid-column: 1 / span 2;
    font-size: 0.875rem;
    color: #FF425E; }
  .input-wrapper.radio input {
    position: absolute;
    opacity: 0; }
    .input-wrapper.radio input + label {
      cursor: pointer;
      font-weight: 400;
      padding: 0;
      margin: 0;
      position: relative; }
      .input-wrapper.radio input + label::before {
        content: '';
        display: inline-block;
        background: #fff;
        border: 1px solid #D7D9E2;
        margin-right: 10px;
        vertical-align: text-top;
        width: 20px;
        height: 20px;
        border-radius: 100%; }
    .input-wrapper.radio input:hover + label::before {
      background: #F7F8FB; }
    .input-wrapper.radio input:focus + label::before {
      -webkit-box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset;
      box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset; }
    .input-wrapper.radio input:checked + label::before {
      border-color: #4D4CFC;
      -webkit-box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset;
      box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset; }
    .input-wrapper.radio input:disabled + label {
      color: #b8b8b8;
      cursor: auto; }
      .input-wrapper.radio input:disabled + label::before {
        -webkit-box-shadow: none;
                box-shadow: none;
        background: #ddd; }
    .input-wrapper.radio input:checked + label::after {
      content: '';
      background: #4D4CFC;
      width: 8px;
      height: 8px;
      position: absolute;
      left: 6px;
      top: 50%;
      border-radius: 100%;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
  .input-wrapper.checkbox input {
    position: absolute;
    opacity: 0; }
    .input-wrapper.checkbox input + label {
      cursor: pointer;
      font-weight: 400;
      padding: 0;
      margin: 0;
      position: relative; }
      .input-wrapper.checkbox input + label::before {
        content: '';
        display: inline-block;
        background: #fff;
        border: 1px solid #D7D9E2;
        margin-right: 10px;
        vertical-align: text-top;
        width: 20px;
        height: 20px;
        border-radius: 3px; }
    .input-wrapper.checkbox input:hover + label::before {
      background: #F7F8FB; }
    .input-wrapper.checkbox input:focus + label::before {
      -webkit-box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset;
      box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset; }
    .input-wrapper.checkbox input:checked + label::before {
      border-color: #4D4CFC;
      -webkit-box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset;
      box-shadow: 0 0 0 2px rgba(77, 76, 252, 0.15) inset; }
    .input-wrapper.checkbox input:disabled + label {
      color: #b8b8b8;
      cursor: auto; }
      .input-wrapper.checkbox input:disabled + label::before {
        -webkit-box-shadow: none;
                box-shadow: none;
        background: #ddd; }
    .input-wrapper.checkbox input:checked + label::after {
      content: '';
      position: absolute;
      left: 5px;
      top: 11px;
      background: #4D4CFC;
      width: 2px;
      height: 2px;
      -webkit-box-shadow: 2px 0 0 #4D4CFC, 4px 0 0 #4D4CFC, 4px -2px 0 #4D4CFC, 4px -4px 0 #4D4CFC, 4px -6px 0 #4D4CFC, 4px -8px 0 #4D4CFC;
      box-shadow: 2px 0 0 #4D4CFC, 4px 0 0 #4D4CFC, 4px -2px 0 #4D4CFC, 4px -4px 0 #4D4CFC, 4px -6px 0 #4D4CFC, 4px -8px 0 #4D4CFC;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
  .input-wrapper.small {
    margin-bottom: 20px; }
    .input-wrapper.small input,
    .input-wrapper.small label,
    .input-wrapper.small select,
    .input-wrapper.small button,
    .input-wrapper.small textarea {
      font-size: 0.875rem; }
    .input-wrapper.small label {
      margin-bottom: 5px; }
    .input-wrapper.small input[type=date],
    .input-wrapper.small input[type=datetime],
    .input-wrapper.small input[type=datetime-local],
    .input-wrapper.small input[type=email],
    .input-wrapper.small input[type=month],
    .input-wrapper.small input[type=number],
    .input-wrapper.small input[type=password],
    .input-wrapper.small input[type=range],
    .input-wrapper.small input[type=search],
    .input-wrapper.small input[type=tel],
    .input-wrapper.small input[type=text],
    .input-wrapper.small input[type=time],
    .input-wrapper.small input[type=url],
    .input-wrapper.small input[type=week],
    .input-wrapper.small select {
      padding: 0 14px;
      min-height: 36px; }
    .input-wrapper.small.has-addon .input-addon {
      height: 36px;
      line-height: 36px; }

/*#############################################################################
# MODALS
#############################################################################*/
.modal-wrapper {
  background: rgba(67, 68, 72, 0.9);
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3; }

.modal-box {
  background: #fff;
  width: calc(100vw - 20px);
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 4px;
  -webkit-box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.05);
  box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.05);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }
  @media only screen and (min-width: 40.0625rem) {
    .modal-box.large {
      width: 640px; } }
  @media only screen and (min-width: 40.0625rem) {
    .modal-box.extra-large {
      width: 860px; } }
  @media only screen and (min-width: 40.0625rem) {
    .modal-box.small {
      width: 440px; } }
  .modal-box.centered {
    text-align: center; }
  .modal-box header {
    border-bottom: 2px solid #F5F5F7;
    padding: 10px 60px 10px 10px;
    position: relative; }
    .modal-box header .modal-title {
      margin: 0;
      padding-right: 50px; }
    .modal-box header .close-modal {
      color: #AFB3C0;
      font-size: 1.875rem;
      font-weight: 900;
      position: absolute;
      top: 50%;
      right: 20px;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
      @media only screen and (min-width: 40.0625rem) {
        .modal-box header .close-modal {
          right: 40px; } }
    .modal-box header .modal-header-action {
      position: absolute;
      top: 50%;
      right: 20px;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
      @media only screen and (min-width: 40.0625rem) {
        .modal-box header .modal-header-action {
          right: 30px; } }
    .modal-box header.has-icon {
      padding: 20px 90px; }
      .modal-box header.has-icon img.icon {
        position: absolute;
        top: 50%;
        left: 30px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%); }
  .modal-box .modal-body {
    padding: 20px 10px; }
    .modal-box .modal-body > :last-child {
      margin-bottom: 0; }
    .modal-box .modal-body.secondary {
      background-color: #fafafb; }
    .modal-box .modal-body .modal-body-title {
      margin: 0 0 20px 0; }
  .modal-box .modal-email {
    padding: 0 10px 10px; }
    .modal-box .modal-email .email-to,
    .modal-box .modal-email .email-subject {
      display: grid;
      grid-template-columns: auto 1fr;
      grid-column-gap: 8px;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      border-bottom: 2px solid #E9EAEA;
      padding: 12px 0; }
      .modal-box .modal-email .email-to .label,
      .modal-box .modal-email .email-subject .label {
        grid-column: 1;
        grid-row: 1;
        color: #AFB3C0;
        font-weight: 900; }
      .modal-box .modal-email .email-to .emails,
      .modal-box .modal-email .email-to .subject,
      .modal-box .modal-email .email-subject .emails,
      .modal-box .modal-email .email-subject .subject {
        grid-column: 2;
        grid-row: 1;
        color: #434448; }
      .modal-box .modal-email .email-to .email,
      .modal-box .modal-email .email-subject .email {
        display: inline-block;
        background-color: #E4E4FF;
        padding: 3px 5px;
        border-radius: 4px; }
      .modal-box .modal-email .email-to .subject,
      .modal-box .modal-email .email-subject .subject {
        border: none; }
        .modal-box .modal-email .email-to .subject:focus,
        .modal-box .modal-email .email-subject .subject:focus {
          outline: 0; }
    .modal-box .modal-email textarea.email-body {
      border: none;
      width: 100%;
      height: 250px;
      padding: 15px 0 0;
      resize: none; }
      .modal-box .modal-email textarea.email-body:focus {
        outline: 0; }
  .modal-box .modal-warning {
    background-color: #FFFFAB;
    border-bottom: 2px solid #F5F5F7;
    padding: 4px 0; }
    .modal-box .modal-warning p {
      font-size: 0.875rem;
      margin: 0; }
  .modal-box footer {
    border-top: 2px solid #F5F5F7;
    padding: 10px;
    *zoom: 1; }
    .modal-box footer:after {
      content: "";
      display: table;
      clear: both; }
    .modal-box footer .button {
      margin: 0; }
      .modal-box footer .button.left {
        float: left; }
      .modal-box footer .button.right {
        float: right; }
  @media only screen and (min-width: 40.0625rem) {
    .modal-box {
      width: 580px; }
      .modal-box header {
        padding: 20px 90px 20px 40px; }
      .modal-box .modal-body {
        padding: 30px 40px; }
      .modal-box .modal-email {
        padding: 0 20px 20px; }
      .modal-box footer {
        padding: 20px 40px; } }

/*#############################################################################
# STEPS
#############################################################################*/
.panel {
  font-size: 0.8125rem;
  margin: 30px 0;
  padding: 10px 20px;
  position: relative;
  border-radius: 6px; }
  .panel.has-icon {
    padding-left: 60px; }
    .panel.has-icon img.icon {
      position: absolute;
      left: 20px;
      top: 50%;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
  .panel :last-child {
    margin: 0; }
  .panel.success {
    background-color: #86eacc; }
  .panel.warning {
    background-color: #FFFFAB; }
  .panel.primary-dark {
    background-color: #282755;
    color: white; }

/*#############################################################################
# PROGRESS BAR
#############################################################################*/
div.progress-bar {
  background-color: #F9F9FB;
  border: 1px solid #E9EAEA;
  height: 12px;
  width: 100%;
  margin: 0 0 20px;
  border-radius: 6px; }
  div.progress-bar .progress {
    background-color: #4D4CFC;
    height: 10px;
    border-radius: 5px; }
  div.progress-bar.alert .progress {
    background-color: #FF425E; }

/*#############################################################################
# TOOLTIPS
#############################################################################*/
.has-tooltip {
  position: relative; }
  .has-tooltip::before {
    content: "";
    display: none;
    border-style: solid;
    width: 0;
    height: 0;
    position: absolute;
    z-index: 999; }
  .has-tooltip::after {
    content: attr(data-tooltip);
    display: none;
    background: #434448;
    color: #fff;
    font-size: 0.875rem;
    font-weight: 400;
    padding: 8px 12px;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    max-width: 300px;
    position: absolute;
    z-index: 999;
    border-radius: 3px; }
  .has-tooltip[data-tooltip-position="top"]::before {
    border-width: 5px 5px 0 5px;
    border-color: #434448 transparent transparent transparent;
    top: 0;
    right: auto;
    bottom: auto;
    left: 50%;
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%); }
  .has-tooltip[data-tooltip-position="top"]::after {
    top: -5px;
    right: auto;
    bottom: auto;
    left: 50%;
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%); }
  .has-tooltip[data-tooltip-position="right"]::before {
    border-width: 5px 5px 5px 0;
    border-color: transparent #434448 transparent transparent;
    top: 50%;
    right: 0;
    bottom: auto;
    left: auto;
    -webkit-transform: translate(100%, -50%);
    transform: translate(100%, -50%); }
  .has-tooltip[data-tooltip-position="right"]::after {
    top: 50%;
    right: -5px;
    bottom: auto;
    left: auto;
    -webkit-transform: translate(100%, -50%);
    transform: translate(100%, -50%); }
  .has-tooltip[data-tooltip-position="bottom"]::before {
    border-width: 0 5px 5px 5px;
    border-color: transparent transparent #434448 transparent;
    top: auto;
    right: auto;
    bottom: 0;
    left: 50%;
    -webkit-transform: translate(-50%, 100%);
    transform: translate(-50%, 100%); }
  .has-tooltip[data-tooltip-position="bottom"]::after {
    top: auto;
    right: auto;
    bottom: -5px;
    left: 50%;
    -webkit-transform: translate(-50%, 100%);
    transform: translate(-50%, 100%); }
  .has-tooltip[data-tooltip-position="left"]::before {
    border-width: 5px 0 5px 5px;
    border-color: transparent transparent transparent #434448;
    top: 50%;
    right: auto;
    bottom: auto;
    left: 0;
    -webkit-transform: translate(-100%, -50%);
    transform: translate(-100%, -50%); }
  .has-tooltip[data-tooltip-position="left"]::after {
    top: 50%;
    right: auto;
    bottom: auto;
    left: -5px;
    -webkit-transform: translate(-100%, -50%);
    transform: translate(-100%, -50%); }
  .has-tooltip:hover::before {
    display: block; }
  .has-tooltip:hover::after {
    display: block; }

/*#############################################################################
# RESPONSIVE VIDEO
#############################################################################*/
.video-container {
  position: relative;
  padding-bottom: 56.25%;
  /*16:9*/
  padding-top: 30px;
  height: 0;
  overflow: hidden; }
  .video-container iframe,
  .video-container object,
  .video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

/*#############################################################################
# BLOCKS
#############################################################################*/
.block-title {
  margin-top: 0; }
  .block-title br {
    display: none; }
  .block-title.margin {
    margin: 0 0 50px; }
  @media only screen and (min-width: 53.75rem) {
    .block-title br {
      display: block; } }

.blocks-wrapper .block-step {
  border-bottom: 1px solid #dadce2;
  margin-bottom: 20px;
  padding-bottom: 20px;
  max-width: 300px; }
  .blocks-wrapper .block-step:last-child {
    border: none;
    margin: 0;
    padding: 0; }
  .blocks-wrapper .block-step .block-step-number {
    margin: 0; }
  .blocks-wrapper .block-step .block-step-title {
    margin: 0; }
  .blocks-wrapper .block-step .block-step-description {
    margin: 0 0 10px; }
  .blocks-wrapper .block-step .progress-bar {
    margin: 0 0 10px; }
  .blocks-wrapper .block-step a.button {
    margin: 0; }
  .blocks-wrapper .block-step.disabled > * {
    opacity: 0.3; }
  .blocks-wrapper .block-step.completed {
    position: relative; }
    .blocks-wrapper .block-step.completed::after {
      display: block;
      content: "";
      background: url(/images/interface/icons/check-green-circle-large.svg) no-repeat 0 0;
      width: 32px;
      height: 32px;
      position: absolute;
      top: 50%;
      right: 0;
      -webkit-transform: translate(60px, -50%);
      transform: translate(60px, -50%); }

.block-main .card {
  max-width: 340px;
  float: right;
  clear: both; }

body#app.bg-application-incomplete .block-main {
  background: url(/images/interface/block-bg-application-incomplete.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-application-incomplete .block-main {
      background-image: url(/images/interface/block-bg-application-incomplete@2x.jpg);
      background-size: 733px 713px; } }
body#app.bg-application-complete .block-main {
  background: url(/images/interface/block-bg-application-complete.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-application-complete .block-main {
      background-image: url(/images/interface/block-bg-application-complete@2x.jpg);
      background-size: 662px 711px; } }
body#app.bg-document-revision .block-main {
  background: url(/images/interface/block-bg-application-complete.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-document-revision .block-main {
      background-image: url(/images/interface/block-bg-application-complete@2x.jpg);
      background-size: 662px 711px; } }
body#app.bg-credit-options .block-main {
  background: url(/images/interface/block-bg-credit-options.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-credit-options .block-main {
      background-image: url(/images/interface/block-bg-credit-options@2x.jpg);
      background-size: 733px 714px; } }
body#app.bg-application-rejected .block-main {
  background: url(/images/interface/block-bg-credit-options.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-application-rejected .block-main {
      background-image: url(/images/interface/block-bg-credit-options@2x.jpg);
      background-size: 733px 714px; } }
body#app.bg-document-signature .block-main {
  background: url(/images/interface/block-bg-credit-options.jpg) no-repeat right bottom; }
  @media only screen and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min--moz-device-pixel-ratio: 1.3), only screen and (min-device-pixel-ratio: 1.3), only screen and (min-resolution: 1.3dppx) {
    body#app.bg-document-signature .block-main {
      background-image: url(/images/interface/block-bg-credit-options@2x.jpg);
      background-size: 733px 714px; } }

/*#############################################################################
# CARDS
#############################################################################*/
.card {
  background-color: #fff;
  border: 1px solid #E9EAEA;
  margin: 0 0 30px 0;
  -webkit-box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.05);
  box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.05); }
  .card .card-header {
    padding: 30px 30px 0;
    *zoom: 1; }
    .card .card-header:after {
      content: "";
      display: table;
      clear: both; }
    .card .card-header .card-title {
      margin: 0;
      float: left; }
    .card .card-header .card-icon {
      float: right; }
  .card .card-body {
    padding: 30px; }
    .card .card-body > :last-child {
      margin-bottom: 0; }
  .card.credit-option {
    cursor: pointer;
    border: none;
    overflow: hidden;
    position: relative;
    border-radius: 4px; }
    .card.credit-option .card-body {
      padding: 20px 30px; }
      .card.credit-option .card-body h5 {
        font-size: 0.875rem;
        margin: 0; }
      .card.credit-option .card-body h6.credit-option-amount {
        font-size: 1.625rem;
        margin: 0; }
      .card.credit-option .card-body p.option-info-line {
        color: #AFB3C0;
        font-size: 0.875rem;
        margin: 0; }
        .card.credit-option .card-body p.option-info-line span {
          display: inline-block;
          padding-right: 12px;
          margin-right: 3px;
          position: relative; }
          .card.credit-option .card-body p.option-info-line span::after {
            content: "";
            display: block;
            background-color: #dadce2;
            width: 5px;
            height: 5px;
            position: absolute;
            top: 50%;
            right: 0;
            border-radius: 100%;
            -webkit-transform: translateY(-50%);
            transform: translateY(-50%); }
          .card.credit-option .card-body p.option-info-line span:last-child {
            padding: 0;
            margin: 0; }
            .card.credit-option .card-body p.option-info-line span:last-child::after {
              display: none; }
    .card.credit-option::before {
      content: "";
      display: block;
      background-color: #dadce2;
      height: 100%;
      width: 7px;
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0; }
    .card.credit-option:hover {
      -webkit-box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.1);
      box-shadow: -10px 10px 20px 0 rgba(0, 0, 0, 0.1); }
      .card.credit-option:hover::before {
        background-color: #AFB3C0; }
    .card.credit-option.selected {
      width: 370px;
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
      -webkit-box-shadow: -20px 10px 20px 0 rgba(0, 0, 0, 0.15);
      box-shadow: -20px 10px 20px 0 rgba(0, 0, 0, 0.15); }
      .card.credit-option.selected .card-body {
        padding-right: 60px; }
      .card.credit-option.selected::before {
        background-color: #4D4CFC; }
      .card.credit-option.selected:hover {
        -webkit-box-shadow: -20px 10px 20px 0 rgba(0, 0, 0, 0.2);
        box-shadow: -20px 10px 20px 0 rgba(0, 0, 0, 0.2); }
        .card.credit-option.selected:hover::before {
          background-color: #0504de; }

/*#############################################################################
# GENERAL CONTENT ELEMENTS
#############################################################################*/
a.navigate-back {
  display: inline-block;
  background: url(/images/interface/icons/arrow-left.svg) no-repeat 0 50%;
  padding-left: 20px;
  margin: 0 0 20px; }

.step-title {
  margin: 0 0 50px; }

.step-actions {
  margin-top: 60px;
  *zoom: 1; }
  .step-actions:after {
    content: "";
    display: table;
    clear: both; }
  .step-actions .actions-wrapper {
    background: #fff;
    border-top: 1px solid #D7D9E2;
    padding: 20px 0;
    *zoom: 1; }
    .step-actions .actions-wrapper:after {
      content: "";
      display: table;
      clear: both; }
  .step-actions.is-sticky {
    height: 75px; }
    .step-actions.is-sticky .actions-wrapper {
      padding: 15px;
      width: 100vw;
      position: fixed;
      left: 0;
      bottom: 0;
      right: auto;
      z-index: 1; }
      @media only screen and (min-width: 40.0625rem) {
        .step-actions.is-sticky .actions-wrapper {
          padding: 15px 60px;
          width: calc(100vw - 400px); } }
  .step-actions .button {
    margin: 0; }
    .step-actions .button.left {
      float: left; }
    .step-actions .button.right {
      float: right; }

body.sidebar-left .step-actions.is-sticky .actions-wrapper {
  left: auto;
  right: 0; }

.icon-msg-box {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-column-gap: 20px; }
  .icon-msg-box img.icon {
    -ms-flex-item-align: center;
        align-self: center;
    display: block;
    margin: 0; }
  .icon-msg-box .msg {
    -ms-flex-item-align: center;
        align-self: center; }
  .icon-msg-box p {
    margin: 0 0 5px 0; }

a.add-shareholder {
  line-height: 22px; }
  a.add-shareholder img.icon {
    margin: 0 5px -5px 0; }

ul.people {
  margin: 0;
  padding: 0;
  list-style: none; }
  ul.people li.person {
    border-bottom: 1px solid #D7D9E2;
    margin-bottom: 20px;
    padding-bottom: 20px; }
    ul.people li.person .person-info > span {
      display: block; }
    ul.people li.person .person-info .name {
      font-weight: 900; }
  ul.people.compact li.person {
    border-bottom: none;
    margin-bottom: 15px;
    padding-bottom: 0; }

ul.documents {
  margin: 0;
  padding: 0;
  list-style: none; }
  ul.documents li.document {
    display: grid;
    grid-template-columns: 1fr 110px;
    border-bottom: 1px solid #D7D9E2;
    margin-bottom: 20px;
    padding-bottom: 20px; }
    ul.documents li.document:last-child {
      border: none; }
    ul.documents li.document .main-info {
      grid-column: 1;
      grid-row: 1; }
    ul.documents li.document .status-icon {
      grid-column: 2;
      grid-row: 1;
      justify-self: center;
      -ms-flex-item-align: center;
          align-self: center; }
    ul.documents li.document .title {
      margin: 0 0 10px 0; }
    ul.documents li.document p.description,
    ul.documents li.document p.alert {
      max-width: 490px;
      margin: 0; }

.list-item-actions {
  margin-top: 15px; }
  .list-item-actions .item-action {
    display: inline-block;
    color: #AFB3C0;
    font-size: 0.875rem;
    margin-right: 12px;
    padding-right: 17px;
    position: relative; }
    .list-item-actions .item-action:hover {
      text-decoration: underline; }
    .list-item-actions .item-action img.icon {
      margin: 0 2px 0 0; }
    .list-item-actions .item-action::after {
      content: "";
      display: block;
      background-color: #dadce2;
      width: 5px;
      height: 5px;
      position: absolute;
      top: 50%;
      right: 0;
      border-radius: 100%;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
    .list-item-actions .item-action:last-child {
      margin: 0;
      padding: 0; }
      .list-item-actions .item-action:last-child::after {
        display: none; }
    .list-item-actions .item-action.modify img.icon {
      margin-bottom: -1px; }
    .list-item-actions .item-action.review img.icon {
      margin-bottom: -2px; }
    .list-item-actions .item-action.delete img.icon {
      margin-bottom: -1px; }
    .list-item-actions .item-action.download {
      color: #4D4CFC; }
    .list-item-actions .item-action.example img.icon {
      margin-bottom: -2px; }
  .list-item-actions .button {
    margin-bottom: 0; }

.shareholder-type-switch {
  margin-bottom: 20px;
  *zoom: 1; }
  .shareholder-type-switch:after {
    content: "";
    display: table;
    clear: both; }
  .shareholder-type-switch a.button {
    margin: 0;
    float: left;
    border-radius: 0; }
    .shareholder-type-switch a.button:first-child {
      border-top-left-radius: 4px;
      border-bottom-left-radius: 4px; }
    .shareholder-type-switch a.button:last-child {
      border-top-right-radius: 4px;
      border-bottom-right-radius: 4px; }

.revision-needed {
  background-color: #FFFFE5;
  padding: 30px;
  margin-bottom: 60px; }
  .revision-needed > h3 {
    margin: 0; }
  .revision-needed ul.documents li:last-child {
    margin-bottom: 0;
    padding-bottom: 0; }

ul.checklist {
  margin: 0;
  padding: 0;
  list-style: none; }
  ul.checklist li {
    background: url(/images/interface/icons/check-purple.svg) no-repeat 0 50%;
    padding-left: 20px; }

.summary-block {
  border-bottom: 1px solid #D7D9E2;
  margin-bottom: 30px;
  padding-bottom: 30px; }
  .summary-block:nth-last-of-type(2) {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0; }
  .summary-block h4.summary-title {
    margin: 0 0 25px; }
    .summary-block h4.summary-title a {
      font-size: 0.875rem; }
  .summary-block p.credit-amount {
    font-size: 1.625rem; }
  .summary-block footer {
    border-top: 2px solid #dadce2;
    margin-top: 25px;
    padding-top: 15px; }
    .summary-block footer p {
      margin: 0; }
  .summary-block.dotted {
    background-color: #f6f7f8;
    border: 2px dashed #AFB3C0;
    padding: 20px;
    border-radius: 4px; }

.credit-option-main-info .label-title {
  font-weight: 900; }
.credit-option-main-info .label-info {
  color: #AFB3C0; }

.credit-simulation-panel h6 {
  font-size: 0.875rem;
  font-weight: 400;
  opacity: 0.5;
  margin: 0; }
.credit-simulation-panel p {
  font-size: 1rem;
  font-weight: 900;
  margin: 0; }

.credit-simulation-table .table-header .table-row {
  border-top: 2px solid #AFB3C0;
  border-bottom: 2px solid #AFB3C0; }
  .credit-simulation-table .table-header .table-row .table-cell {
    color: #434448;
    font-size: 0.9375rem;
    font-weight: 900;
    padding: 20px 15px; }
.credit-simulation-table .table-footer .table-row {
  border-bottom: none; }
  .credit-simulation-table .table-footer .table-row .table-cell {
    color: #434448;
    font-size: 0.9375rem;
    font-weight: 900; }
.credit-simulation-table .table-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-bottom: 1px solid #dadce2; }
  .credit-simulation-table .table-row .table-cell {
    color: #AFB3C0;
    font-size: 0.8125rem;
    padding: 15px;
    text-align: center; }
    .credit-simulation-table .table-row .table-cell:first-child {
      text-align: left; }
    .credit-simulation-table .table-row .table-cell:last-child {
      text-align: right; }
.credit-simulation-table .installment-num {
  display: inline-block;
  background-color: #f3f4f6;
  color: #434448;
  font-weight: 900;
  padding: 1px 6px;
  border-radius: 4px; }
.credit-simulation-table .payment-total {
  color: #434448;
  font-weight: 900; }

.signatures .person-signatures {
  border-bottom: 1px solid #D7D9E2;
  margin-bottom: 30px;
  padding-bottom: 30px; }
  .signatures .person-signatures:last-child {
    border-bottom: none; }
  .signatures .person-signatures h4 {
    margin: 0; }
  .signatures .person-signatures p {
    margin: 0; }
  .signatures .person-signatures ul.documents-to-sign {
    margin: 15px 0 0;
    padding: 0;
    list-style: none; }
    .signatures .person-signatures ul.documents-to-sign li.document {
      background: url(/images/interface/icons/signature-pending.svg) no-repeat 0 50%;
      padding-left: 42px;
      margin-bottom: 8px; }
      .signatures .person-signatures ul.documents-to-sign li.document h6 {
        margin: 0; }
      .signatures .person-signatures ul.documents-to-sign li.document p.signature-status {
        color: #AFB3C0;
        font-size: 0.75rem;
        font-weight: 900;
        margin: 0; }
      .signatures .person-signatures ul.documents-to-sign li.document.signed {
        background-image: url(/images/interface/icons/check-green-circle-large.svg); }
  .signatures .person-signatures a.button {
    float: right; }

ul.signatures-doc-samples {
  list-style: none;
  padding: 0;
  margin: 0; }
  ul.signatures-doc-samples li a {
    font-size: 0.875rem; }

h4.signature-steps-title {
  margin: 0 0 50px; }

ul.signature-steps {
  list-style: none;
  padding: 0;
  margin: 0; }
  ul.signature-steps li {
    font-size: 1rem;
    font-weight: 900;
    line-height: 26px;
    position: relative;
    padding-top: 40px;
    padding-left: 40px; }
    ul.signature-steps li span.small {
      display: block;
      color: #AFB3C0;
      font-size: 0.875rem;
      font-weight: 400; }
    ul.signature-steps li::after {
      content: "";
      display: block;
      background: url(/images/interface/icons/signature-step-default.svg) no-repeat 50% 50%;
      background-size: 24px 24px;
      width: 26px;
      height: 26px;
      position: absolute;
      left: 0;
      bottom: 0;
      z-index: 2; }
    ul.signature-steps li::before {
      content: "";
      display: block;
      background-color: #AFB3C0;
      height: 45px;
      width: 2px;
      position: absolute;
      left: 12px;
      bottom: 24px;
      z-index: 1; }
    ul.signature-steps li:first-child {
      padding-top: 0; }
      ul.signature-steps li:first-child::before {
        display: none; }
    ul.signature-steps li.active::before {
      background-color: #4D4CFC; }
    ul.signature-steps li.active::after {
      background: url(/images/interface/icons/signature-step-active.svg) no-repeat 50% 50%; }
    ul.signature-steps li.completed::before {
      background-color: #4D4CFC; }
    ul.signature-steps li.completed::after {
      background: url(/images/interface/icons/signature-step-completed.svg) no-repeat 50% 50%; }

p.code-validation-instruction strong {
  white-space: nowrap; }

.validation-code-inputs .input-wrapper {
  display: inline-block;
  max-width: 70px;
  margin: 0;
  margin-right: 5px; }
  .validation-code-inputs .input-wrapper:last-child {
    margin: 0; }
  .validation-code-inputs .input-wrapper input[type=text] {
    font-size: 36px;
    font-weight: 900;
    text-align: center; }

.report-checkbox {
  position: absolute;
  right: 0;
  top: 0; }

.animate-rotation {
  -webkit-animation: spin 4s linear infinite;
  animation: spin 4s linear infinite; }
@-webkit-keyframes spin {
  100% {
    -webkit-transform: rotate(360deg); } }
@keyframes spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
.signature-box-wrapper {
  width: 100%;
  height: 190px;
  border: 2px solid #dadce2;
  border-radius: 4px; }

/*#############################################################################
# HEADER
#############################################################################*/
header.app-header {
  border-bottom: 1px solid #E9EAEA;
  display: grid;
  grid-template-columns: 180px 1fr minmax(180px, auto);
  grid-template-rows: 50px; }
  .progress-bar header.app-header {
    grid-template-rows: 50px 10px; }
  header.app-header h1.sempli-logo {
    grid-column: 1;
    grid-row: 1;
    width: 130px;
    margin: 0;
    border-right: 1px solid #E9EAEA; }
    header.app-header h1.sempli-logo a {
      display: block;
      background: url(/images/interface/sempli-logo.svg) no-repeat 50% 50%;
      background-size: 87px 22px;
      height: 0;
      width: 130px;
      padding-top: 50px;
      margin: 0;
      overflow: hidden; }
  header.app-header .header-step-title {
    grid-column: 2;
    grid-row: 1;
    height: 50px;
    padding: 0 20px 0 32px;
    *zoom: 1; }
    header.app-header .header-step-title:after {
      content: "";
      display: table;
      clear: both; }
    header.app-header .header-step-title > * {
      height: 50px;
      line-height: 50px;
      margin: 0;
      float: left; }
    header.app-header .header-step-title h2.header-block-name {
      color: #434448;
      font-size: 18px;
      font-weight: 400; }
    header.app-header .header-step-title h3.header-step-name {
      color: #AFB3C0;
      font-size: 16px;
      font-weight: 400;
      margin-left: 15px;
      padding-left: 20px;
      position: relative; }
      header.app-header .header-step-title h3.header-step-name::before {
        content: "";
        display: block;
        background-color: #AFB3C0;
        width: 5px;
        height: 5px;
        position: absolute;
        top: 50%;
        left: 0;
        border-radius: 100%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%); }
  header.app-header .header-save-progress {
    grid-column: 3;
    grid-row: 1;
    height: 50px;
    padding: 0 20px; }
    header.app-header .header-save-progress a.save-progress {
      display: block;
      height: 50px;
      line-height: 50px;
      margin: 0;
      position: relative; }
      header.app-header .header-save-progress a.save-progress span.tooltip {
        display: none;
        background: #4D4CFC;
        color: #fff;
        font-size: 0.875rem;
        line-height: 20px;
        width: 320px;
        padding: 10px 20px;
        position: absolute;
        right: 0;
        border-radius: 6px;
        -webkit-transform: translateY(-10px);
        transform: translateY(-10px);
        -webkit-box-shadow: -2px 4px 10px 0 rgba(0, 0, 0, 0.1);
        box-shadow: -2px 4px 10px 0 rgba(0, 0, 0, 0.1); }
        header.app-header .header-save-progress a.save-progress span.tooltip::before {
          content: "";
          display: block;
          width: 0;
          height: 0;
          border-style: solid;
          border-width: 0 10px 10px 10px;
          border-color: transparent transparent #4D4CFC transparent;
          position: absolute;
          top: 0;
          right: 60px;
          -webkit-transform: translateY(-100%);
          transform: translateY(-100%); }
      header.app-header .header-save-progress a.save-progress:hover span.tooltip, header.app-header .header-save-progress a.save-progress.tooltip-active span.tooltip {
        display: block; }
  header.app-header .header-nav {
    grid-column: 2;
    grid-row: 1;
    height: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center; }
    header.app-header .header-nav a.nav-link {
      display: block;
      color: #AFB3C0;
      font-weight: 900;
      height: 50px;
      line-height: 50px;
      margin-right: 35px; }
      header.app-header .header-nav a.nav-link:last-child {
        margin-right: 0; }
      header.app-header .header-nav a.nav-link:hover {
        color: #434448; }
      header.app-header .header-nav a.nav-link.active {
        color: #434448;
        border-bottom: 2px solid #434448; }
  header.app-header .header-account {
    grid-column: 3;
    grid-row: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    height: 50px;
    padding: 0 20px; }
    header.app-header .header-account img.profile-photo {
      display: block;
      width: 34px;
      height: 34px;
      border-radius: 100%; }
  header.app-header .progress-bar {
    grid-column: 1/4;
    grid-row: 2;
    border: none;
    border-top: 1px solid #E9EAEA;
    height: 10px;
    margin: 0;
    border-radius: 0; }
    header.app-header .progress-bar .progress {
      height: 9px;
      border-radius: 0;
      border-top-right-radius: 4.5px;
      border-bottom-right-radius: 4.5px; }
  @media only screen and (min-width: 40.0625rem) {
    header.app-header {
      grid-template-rows: 70px; }
      .progress-bar header.app-header {
        grid-template-rows: 70px 10px; }
      header.app-header h1.sempli-logo {
        width: 180px; }
        header.app-header h1.sempli-logo a {
          background-size: 119px 30px;
          width: 180px;
          padding-top: 70px; }
      header.app-header .header-step-title {
        height: 70px; }
        header.app-header .header-step-title > * {
          height: 70px;
          line-height: 70px; }
      header.app-header .header-save-progress {
        height: 70px; }
        header.app-header .header-save-progress a.save-progress {
          height: 70px;
          line-height: 70px; }
      header.app-header .header-nav {
        height: 70px; }
        header.app-header .header-nav a.nav-link {
          height: 70px;
          line-height: 70px; }
      header.app-header .header-account {
        height: 70px; } }
  header.app-header.payment {
    grid-template-columns: 1fr; }
    header.app-header.payment h1.sempli-logo {
      border-right: none;
      margin: 0 auto; }

/*#############################################################################
# MY ACCOUNT
#############################################################################*/
body#app.my-account section.app-body {
  grid-template-columns: 260px 1fr !important; }

nav.account a {
  display: block;
  color: #434448;
  font-size: 0.875rem;
  margin: 0 0 20px; }
  nav.account a.active {
    font-weight: 900; }

header.transaction-history {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 2fr 1fr;
  grid-column-gap: 30px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid #dadce2;
  padding: 10px 0; }
  header.transaction-history .history-header {
    font-size: 0.75rem;
    font-weight: 900; }
    header.transaction-history .history-header.last {
      text-align: right;
      padding-right: 12px; }

ul.transaction-history {
  list-style: none;
  margin: 0;
  padding: 0; }
  ul.transaction-history li {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 2fr 1fr;
    grid-column-gap: 30px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 1px solid #dadce2;
    padding: 10px 0; }
    ul.transaction-history li:last-child {
      border-bottom: none; }
    ul.transaction-history li .history-box span {
      display: block; }
      ul.transaction-history li .history-box span.installment {
        color: #AFB3C0;
        font-size: 0.75rem; }
      ul.transaction-history li .history-box span.credit-id {
        font-size: 0.875rem; }
      ul.transaction-history li .history-box span.date {
        font-size: 0.75rem; }
      ul.transaction-history li .history-box span.time {
        font-size: 0.75rem; }
      ul.transaction-history li .history-box span.amount {
        font-size: 0.75rem;
        font-weight: 900; }
      ul.transaction-history li .history-box span.paid-by {
        font-size: 0.75rem; }
      ul.transaction-history li .history-box span.status {
        display: inline-block;
        color: #fff;
        font-size: 0.75rem;
        font-weight: 900;
        text-align: right;
        padding: 3px 12px;
        border-radius: 20px; }
        ul.transaction-history li .history-box span.status.approved {
          background-color: #45DFB0; }
        ul.transaction-history li .history-box span.status.rejected {
          background-color: #FF425E; }
    ul.transaction-history li .history-box.last {
      text-align: right; }

header.team-members {
  display: grid;
  grid-template-columns: 2fr 2fr 1fr 1fr;
  grid-column-gap: 30px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid #dadce2;
  padding: 10px 0; }
  header.team-members .team-header {
    font-size: 0.75rem;
    font-weight: 900; }
    header.team-members .team-header.last {
      text-align: right; }

ul.team-members {
  list-style: none;
  margin: 0;
  padding: 0; }
  ul.team-members li {
    display: grid;
    grid-template-columns: 2fr 2fr 1fr 1fr;
    grid-column-gap: 30px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 1px solid #dadce2;
    padding: 10px 0; }
    ul.team-members li:last-child {
      border-bottom: none; }
    ul.team-members li .team-box span {
      display: block; }
      ul.team-members li .team-box span.name {
        font-size: 0.875rem;
        font-weight: 900; }
      ul.team-members li .team-box span.permissions {
        font-size: 0.75rem; }
      ul.team-members li .team-box span.alarms {
        font-size: 0.75rem; }
      ul.team-members li .team-box span.actions {
        font-size: 0.75rem; }
    ul.team-members li .team-box.last {
      text-align: right; }

.modal-box .permission-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column-gap: 30px; }
  .modal-box .permission-wrapper .permission-box {
    border: 1px solid #dadce2;
    padding: 15px;
    border-radius: 4px; }

/*#############################################################################
# MY PRODUCTS
#############################################################################*/
.my-products-base-box, .my-products-list-wrapper .product-box, .product-details-wrapper .product-details-box {
  background-color: #fff;
  padding: 20px 30px;
  border-radius: 4px;
  -webkit-box-shadow: -2px 2px 6px 0 rgba(0, 0, 0, 0.05);
  box-shadow: -2px 2px 6px 0 rgba(0, 0, 0, 0.05); }

.my-products-list-wrapper {
  max-width: 1000px;
  margin: 0 auto; }
  .my-products-list-wrapper .product-box {
    display: grid;
    grid-template-columns: repeat(4, 1fr) 120px;
    justify-items: center;
    margin: 0 0 20px; }
    .my-products-list-wrapper .product-box:last-child {
      margin: 0; }
    .my-products-list-wrapper .product-box .product-box-column {
      padding: 0 20px; }
      .my-products-list-wrapper .product-box .product-box-column:first-child {
        padding-left: 0; }
      .my-products-list-wrapper .product-box .product-box-column:last-child {
        padding-right: 0; }
    .my-products-list-wrapper .product-box .credit-id {
      justify-self: start; }
    .my-products-list-wrapper .product-box .product-box-title {
      color: #AFB3C0;
      font-size: 0.625rem;
      text-transform: uppercase;
      margin: 0 0 10px; }
    .my-products-list-wrapper .product-box .product-box-content {
      font-size: 0.875rem;
      margin: 0; }
    .my-products-list-wrapper .product-box .product-box-credit-amount {
      font-size: 1.25rem;
      margin: 0; }
    .my-products-list-wrapper .product-box .progress-bar {
      min-width: 120px;
      margin-top: 18px; }
    .my-products-list-wrapper .product-box .product-box-payment-status {
      font-size: 0.75rem;
      font-weight: 900;
      margin: 0; }
    .my-products-list-wrapper .product-box a.product-box-action {
      display: block;
      opacity: 0;
      font-size: 0.75rem;
      text-align: center;
      margin: 0 0 12px; }
      .my-products-list-wrapper .product-box a.product-box-action:last-child {
        margin: 0; }
    .my-products-list-wrapper .product-box:hover {
      -webkit-box-shadow: -6px 6px 10px 0 rgba(0, 0, 0, 0.075);
      box-shadow: -6px 6px 10px 0 rgba(0, 0, 0, 0.075); }
      .my-products-list-wrapper .product-box:hover a.product-box-action {
        opacity: 1; }

header.product-details {
  margin: 0 0 40px; }
  header.product-details .product-details-id {
    color: #AFB3C0;
    font-size: 0.875rem;
    text-transform: uppercase;
    margin: 0; }
  header.product-details .product-details-amount {
    font-size: 1.75rem;
    margin: 0 0 30px; }
  header.product-details .secondary-product-info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap; }
    header.product-details .secondary-product-info .product-info-box {
      margin-right: 70px; }
    header.product-details .secondary-product-info .product-info-title {
      color: #AFB3C0;
      font-size: 0.75rem;
      text-transform: uppercase;
      margin: 0; }
    header.product-details .secondary-product-info .product-info-value {
      font-size: 0.875rem;
      font-weight: 900;
      margin: 0; }

.product-details-wrapper {
  display: grid;
  grid-template-columns: 1fr 360px;
  grid-column-gap: 30px;
  margin: 0 0 40px; }
  .product-details-wrapper:last-child {
    margin: 0; }
  .product-details-wrapper .product-details-box {
    min-height: 500px;
    padding: 0; }
    .product-details-wrapper .product-details-box header.product-details-header {
      padding: 20px 20px 0;
      border-bottom: 1px solid #dadce2; }
      .product-details-wrapper .product-details-box header.product-details-header nav {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
            -ms-flex-flow: row wrap;
                flex-flow: row wrap;
        -webkit-box-pack: space-evenly;
            -ms-flex-pack: space-evenly;
                justify-content: space-evenly; }
        .product-details-wrapper .product-details-box header.product-details-header nav a {
          color: #AFB3C0;
          font-size: 0.875rem;
          padding: 0 5px 15px; }
          .product-details-wrapper .product-details-box header.product-details-header nav a.active {
            border-bottom: 2px solid #4D4CFC;
            color: #4D4CFC;
            font-weight: 900; }
          .product-details-wrapper .product-details-box header.product-details-header nav a:hover {
            color: #767d93; }
    .product-details-wrapper .product-details-box .box-content {
      padding: 30px; }
      .product-details-wrapper .product-details-box .box-content .col:first-child {
        padding: 0 30px 0 20px; }
      .product-details-wrapper .product-details-box .box-content .col:last-child {
        padding: 0 20px 0 30px; }
    .product-details-wrapper .product-details-box footer.product-details-footer {
      border-top: 1px solid #dadce2;
      padding: 20px 60px;
      border-bottom-left-radius: 4px;
      border-bottom-right-radius: 4px; }
      .product-details-wrapper .product-details-box footer.product-details-footer a {
        display: inline-block;
        font-size: 0.875rem;
        font-weight: 900; }
  .product-details-wrapper h5.payments-table-title {
    font-size: 0.875rem;
    margin: 0 0 20px; }
  .product-details-wrapper header.payment-details-header {
    margin-bottom: 20px;
    *zoom: 1; }
    .product-details-wrapper header.payment-details-header:after {
      content: "";
      display: table;
      clear: both; }
    .product-details-wrapper header.payment-details-header h6 {
      font-size: 0.875rem;
      margin: 0;
      float: left; }
    .product-details-wrapper header.payment-details-header p {
      color: #AFB3C0;
      font-size: 0.875rem;
      font-weight: 900;
      margin: 0;
      float: right; }
  .product-details-wrapper a.next-installment-pay {
    display: block;
    text-align: center;
    margin: 30px 0; }
  .product-details-wrapper p.next-installment-text {
    font-size: 0.75rem;
    margin: 0; }
  .product-details-wrapper footer.next-installment {
    border-top: 1px solid #dadce2;
    margin-top: 15px;
    padding-top: 15px; }
    .product-details-wrapper footer.next-installment p {
      font-size: 0.75rem;
      margin: 0; }
      .product-details-wrapper footer.next-installment p a {
        font-weight: bold; }
  .product-details-wrapper p.payment-simulator {
    font-size: 0.875rem;
    margin: 20px 0 0;
    padding: 0 20px; }

ul.payments-table {
  border-bottom: 1px solid #dadce2;
  list-style: none;
  margin: 0 0 15px;
  padding: 0 0 15px; }
  ul.payments-table li {
    margin: 0 0 10px;
    padding-left: 15px;
    position: relative;
    *zoom: 1; }
    ul.payments-table li:after {
      content: "";
      display: table;
      clear: both; }
    ul.payments-table li:last-child {
      margin: 0; }
    ul.payments-table li::before {
      content: "";
      display: block;
      background-color: #4D4CFC;
      width: 5px;
      height: 5px;
      position: absolute;
      top: 50%;
      left: 0;
      border-radius: 10px;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
  ul.payments-table.no-decoration li {
    padding-left: 0; }
    ul.payments-table.no-decoration li::before {
      display: none; }

ul.payments-history {
  list-style: none;
  margin: 0;
  padding: 0; }
  ul.payments-history li {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-column-gap: 30px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 1px solid #dadce2;
    padding: 10px 0; }
    ul.payments-history li:last-child {
      border-bottom: none; }
    ul.payments-history li .history-box span {
      display: block; }
      ul.payments-history li .history-box span.installment {
        color: #AFB3C0;
        font-size: 0.75rem; }
      ul.payments-history li .history-box span.date {
        font-size: 0.875rem; }
      ul.payments-history li .history-box span.amount {
        font-size: 0.875rem;
        font-weight: 900;
        text-align: right; }
        ul.payments-history li .history-box span.amount.penalty {
          color: #FF425E;
          font-size: 0.75rem;
          font-weight: 400; }
    ul.payments-history li .history-box.left {
      justify-self: start; }
    ul.payments-history li .history-box.right {
      justify-self: end; }

ul.statements-history {
  list-style: none;
  margin: 0;
  padding: 0; }
  ul.statements-history li {
    display: grid;
    grid-template-columns: 24px 1fr 1fr;
    grid-column-gap: 15px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 1px solid #dadce2;
    padding: 10px 0; }
    ul.statements-history li:last-child {
      border-bottom: none; }
    ul.statements-history li img.icon {
      display: block;
      width: 100%; }
    ul.statements-history li .history-box span {
      display: block; }
      ul.statements-history li .history-box span.statement {
        color: #AFB3C0;
        font-size: 0.75rem; }
      ul.statements-history li .history-box span.date {
        font-size: 0.875rem; }
      ul.statements-history li .history-box span.actions {
        font-size: 0.875rem;
        font-weight: 900;
        text-align: right; }
    ul.statements-history li .history-box.left {
      justify-self: start; }
    ul.statements-history li .history-box.right {
      justify-self: end; }

ul.documents-history {
  list-style: none;
  margin: 0;
  padding: 0; }
  ul.documents-history li {
    display: grid;
    grid-template-columns: 24px 1fr 1fr;
    grid-column-gap: 15px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 1px solid #dadce2;
    padding: 10px 0; }
    ul.documents-history li:last-child {
      border-bottom: none; }
    ul.documents-history li img.icon {
      display: block;
      width: 100%; }
    ul.documents-history li .history-box span {
      display: block; }
      ul.documents-history li .history-box span.document {
        font-size: 0.875rem; }
      ul.documents-history li .history-box span.file-size {
        color: #AFB3C0;
        font-size: 0.75rem; }
      ul.documents-history li .history-box span.actions {
        font-size: 0.875rem;
        font-weight: 900;
        text-align: right; }
    ul.documents-history li .history-box.left {
      justify-self: start; }
    ul.documents-history li .history-box.right {
      justify-self: end; }

span.payments-table-item-title {
  font-size: 0.75rem;
  font-weight: 900;
  float: left; }

span.payments-table-item-value {
  font-size: 0.75rem;
  float: right; }

.payments-table-totals {
  *zoom: 1; }
  .payments-table-totals:after {
    content: "";
    display: table;
    clear: both; }
  .payments-table-totals span.item-title {
    font-size: 0.8125rem; }
  .payments-table-totals span.item-value {
    font-size: 0.8125rem;
    font-weight: 900; }
  .payments-table-totals.large span {
    font-size: 0.875rem; }

p.payment-simulation-result {
  font-size: 0.875rem;
  margin-top: 30px; }

/*#############################################################################
# SIGNATURES SPECIFIC STYLES
#############################################################################*/
body.signatures header.app-header {
  grid-template-columns: 1fr; }
  body.signatures header.app-header h1.sempli-logo {
    border-right: none; }
