@font-face {
  font-family: 'Maax';
  font-style: normal;
  font-weight: 100;
  src: url("https://dtxh53x5zi43j.cloudfront.net/fonts/maax/regular-205tf.woff2") format("woff2"), url("https://dtxh53x5zi43j.cloudfront.net/fonts/maax/regular-205tf.woff") format("woff");
}
@font-face {
  font-family: 'GT-Pressura';
  font-style: normal;
  src: url("https://dtxh53x5zi43j.cloudfront.net/fonts/gt-pressura/regular.woff2") format("woff2"), url("https://dtxh53x5zi43j.cloudfront.net/fonts/gt-pressura/regular.woff") format("woff");
}
@font-face {
  font-family: 'FontAwesome';
  src: url("/static/fonts/font-awesome/fontawesome-webfont.eot?v=4.7.0");
  src: url("/static/fonts/font-awesome/fontawesome-webfont.eot?#iefix&v=4.7.0") format("embedded-opentype"), url("/static/fonts/font-awesome/fontawesome-webfont.woff2?v=4.7.0") format("woff2"), url("/static/fonts/font-awesome/fontawesome-webfont.woff?v=4.7.0") format("woff"), url("/static/fonts/font-awesome/fontawesome-webfont.ttf?v=4.7.0") format("truetype"), url("/static/fonts/font-awesome/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'Maax-Bold';
  font-style: normal;
  src: url("https://assets.apostrophe.com/img/fonts/Maax+-+Bold-205TF.woff2") format("woff2"), url("https://assets.apostrophe.com/img/fonts/Maax+-+Bold-205TF.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: 'Maax-Light';
  font-style: normal;
  src: url("https://assets.apostrophe.com/img/fonts/Maax+-+Light-205TF.woff2") format("woff2"), url("https://assets.apostrophe.com/img/fonts/Maax+-+Light-205TF.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: 'Maax-Medium-Italic';
  font-style: normal;
  src: url("https://assets.apostrophe.com/img/fonts/Maax+-+Medium+Italic-205TF.woff2") format("woff2"), url("https://assets.apostrophe.com/img/fonts/Maax+-+Medium+Italic-205TF.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: 'Maax-Medium';
  font-style: normal;
  src: url("https://assets.apostrophe.com/img/fonts/Maax+-+Medium-205TF.woff2") format("woff2"), url("https://assets.apostrophe.com/img/fonts/Maax+-+Medium-205TF.woff") format("woff");
  font-display: swap;
}
.loading-overlay {
  visibility: hidden;
}

@-webkit-keyframes Loading {
  0% {
    background-position: 0% 22%;
  }
  50% {
    background-position: 100% 79%;
  }
  100% {
    background-position: 0% 22%;
  }
}
@-moz-keyframes Loading {
  0% {
    background-position: 0% 22%;
  }
  50% {
    background-position: 100% 79%;
  }
  100% {
    background-position: 0% 22%;
  }
}
@keyframes Loading {
  0% {
    background-position: 0% 22%;
  }
  50% {
    background-position: 100% 79%;
  }
  100% {
    background-position: 0% 22%;
  }
}
body {
  font-family: "Maax", Tahoma, Arial, Helvetica, sans-serif;
  font-style: normal;
  font-size: 1em;
  font-weight: 100;
  line-height: 1.375;
  color: #000000;
  margin: 0;
  background-color: #FFFEFA;
  -webkit-font-smoothing: antialiased;
}

body.busy {
  pointer-events: none;
  cursor: wait !important;
  opacity: .5;
  z-index: 2;
  overflow: hidden;
  position: relative;
}
body.busy .busy-loading-overlay {
  background-image: url("/static/img/apostrophe/icons/apostrophe_logo_loading.gif");
  background-position: center;
  background-repeat: no-repeat;
  position: fixed;
  height: 100vh;
  width: 100vw;
  z-index: 500;
}

body.noscroll {
  overflow: hidden;
}

body.busy-overlay {
  pointer-events: none;
  cursor: wait !important;
  opacity: .5;
  z-index: 2;
  overflow: hidden;
}

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

h1,
h2,
h3,
h4 {
  margin-top: 0;
  font-weight: normal;
}

h1 {
  font-size: 1.5rem;
  line-height: 1.33;
}
@media (min-width: 768px) {
  h1 {
    font-size: 2rem;
    line-height: 1.25;
  }
}

h2 {
  font-size: 1.25rem;
  line-height: 1.5;
}
@media (min-width: 768px) {
  h2 {
    line-height: 1.4;
  }
}

a {
  font-weight: 100;
  color: currentColor;
  cursor: pointer;
  cursor: hand;
}

.wrapper {
  width: calc(100% - 10vmin);
  margin: 0 auto;
  padding: 5vmin 0;
}

small {
  font-size: 0.875em;
}

code {
  background-color: #E3E3E3;
  margin-top: .375rem;
  white-space: pre-wrap;
}

button {
  display: inline-block;
  font-size: .875rem;
  padding: 20px 52px;
  color: white;
  background: #000000;
  border-radius: 31px;
  letter-spacing: .5px;
  font-weight: 100;
  border: none;
  clear: both;
  cursor: pointer;
  cursor: hand;
  transition: all .7s ease;
}
button.small {
  padding: 15px 30px;
}

button:hover {
  background: #8B8A87;
  transition: all .7s ease;
}

button:disabled {
  background: #d6d5d4;
  cursor: default;
}

.button {
  display: inline-block;
  font-size: .875rem;
  /*  Padding top/bottom 1px less because mysterious extra pixel. */
  padding: 19px 52px;
  color: white;
  background: #000000;
  border-radius: 31px;
  letter-spacing: .5px;
  font-weight: 100;
  border: none;
  text-decoration: none;
  transition: all .7s ease 0s;
  text-align: center;
}
.button.small {
  padding: 15px 30px;
}

.button:hover {
  background: #8B8A87;
  cursor: pointer;
  transition: all .7s ease 0s;
}

.button.disabled {
  background-color: #d6d5d4;
  cursor: default;
}

button.wide, a.button.wide, span.button.wide {
  width: 100%;
  border-radius: 0;
  text-align: center;
}

.cancel-icon {
  background-image: url("/static/img/apostrophe/icons/close.svg");
  height: 1rem;
  width: 1rem;
  background-position: center;
  background-repeat: no-repeat;
  cursor: pointer;
  cursor: hand;
}
.cancel-icon:hover {
  height: calc(1rem + 2px);
  width: calc(1rem + 2px);
}
@media (max-width: 480px) {
  .cancel-icon {
    height: 14px;
    width: 14px;
  }
}

.cta-plus {
  font-size: 0.875em;
  text-decoration: none;
  /* Have to use a seperate svg because can't change fill color in :before */
  /* Can fix this by trying to use a mask in the before, or by creating a */
  /* React component that replicates behavior */
}
.cta-plus:before {
  position: relative;
  top: 2px;
  padding-right: 10px;
  content: url("https://assets.apostrophe.com/img/apostrophe/icons/add.svg");
}
.cta-plus:hover {
  color: #8B8A87;
}
.cta-plus:hover:before {
  content: url("https://assets.apostrophe.com/img/apostrophe/icons/add-hover.svg");
}

.cta-back {
  font-size: 0.875em;
  text-decoration: none;
}
.cta-back:before {
  position: relative;
  top: -1px;
  padding-right: 10px;
  content: url("/static/img/apostrophe/icons/back-arrow.svg");
}
.cta-back:hover {
  color: #8B8A87;
}
.cta-back:hover:before {
  content: url("/static/img/apostrophe/icons/back-arrow-hover.svg");
}

.cta-next {
  font-size: 0.875em;
  text-decoration: none;
}
.cta-next:after {
  position: relative;
  top: -1px;
  padding-right: 10px;
  content: url("/static/img/apostrophe/icons/next-arrow.svg");
}
.cta-next:hover {
  color: #8B8A87;
}
.cta-next:hover:after {
  content: url("/static/img/apostrophe/icons/next-arrow-hover.svg");
}

input {
  border: none;
  border-radius: 0;
  background-color: transparent;
  font-size: 1rem;
  color: #8B8A87;
  line-height: 2.5em;
  position: relative;
  transition: all .2s ease;
  box-shadow: inset 0 -1px 0 0 #000000;
}
input:hover {
  cursor: pointer;
  cursor: hand;
}

input:not([type="checkbox"]) {
  -webkit-appearance: none;
}

label {
  color: #8B8A87;
  line-height: 1rem;
}
label:hover {
  cursor: pointer;
  cursor: hand;
}

select {
  -webkit-appearance: none;
  -webkit-border-radius: 0px;
  border-radius: none;
  background-color: transparent;
  font-size: 1rem;
  color: #8B8A87;
  border: none;
  border-bottom: 1px solid #000000;
  line-height: 2.5rem;
}
select:focus {
  border-bottom: 3px solid #000000;
}
select:hover {
  cursor: pointer;
  cursor: hand;
}

textarea {
  width: 100%;
  height: 5rem;
}
textarea::-webkit-scrollbar {
  display: none;
}

hr {
  border: none;
  height: 1px;
  color: currentColor;
  background-color: currentColor;
  border-color: currentColor;
}

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

.ReactModal__Body--open {
  overflow: hidden;
}
.ReactModal__Body--open #main-content {
  z-index: 1;
}

.ReactModal__Overlay {
  overflow: scroll;
}

#page {
  background-color: #F3F1F0;
}

.qr-code {
  height: 300px;
  width: 300px;
  margin: auto;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}

form {
  position: relative;
}
form .form-errors {
  margin-bottom: 0;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 66px;
  text-align: center;
}
form .form-errors p {
  color: red;
  font-size: 14px;
  margin-bottom: 4px;
}
form .form-errors p:last-child {
  margin-bottom: 0;
}
form .form-group .message {
  color: red;
  position: absolute;
  bottom: -18px;
}
form .form-group .message::after {
  display: none;
}
form .form-group .message ul {
  margin: 0;
  line-height: normal;
  list-style: none;
}
form .form-group .message ul li {
  line-height: normal;
  font-size: 12px;
}
form .form-group .message ul.errorList li {
  color: red;
}

.section-content {
  max-width: 768px;
}

.welcome .section-content {
  display: none;
}

.d-none {
  visibility: hidden;
  height: 0 !important;
}

.backup-method {
  max-width: 768px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 1.5rem;
}
.backup-method p {
  margin: 0;
  margin-right: 1.5rem;
}
.backup-method button {
  max-width: 350px;
}
.backup-method .backup-token-btn {
  width: 200px;
}

.backup-tokens {
  margin-bottom: 3rem;
}

input {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  border-bottom: solid 1px #000000 !important;
  width: 100% !important;
  height: 40px !important;
  margin: 0 !important;
  z-index: 200;
  box-shadow: none !important;
  padding: 0 !important;
  line-height: 2.5em !important;
}
input:focus {
  outline: none !important;
}

label {
  margin-bottom: 0 !important;
}

input:valid ~ label {
  font-size: 0.675rem;
  top: -12px;
  left: 0;
  position: absolute;
  transition: all .2s ease;
  z-index: 1;
  color: #000000;
}

.radio-container {
  position: relative;
}
.radio-container input[type="radio"] {
  -webkit-appearance: checkbox;
}
.radio-container label {
  display: none;
}
.radio-container ul {
  list-style-type: none;
  margin: 0;
}
.radio-container ul label {
  display: initial;
}
.radio-container ul li:last-child {
  display: none;
}
.radio-container ul li label {
  font-size: 1rem;
}

.method .radio-container ul, .setup .radio-container ul {
  margin-left: 30px;
}
.method .radio-container ul li, .setup .radio-container ul li {
  position: relative;
}
.method .radio-container ul li label input, .setup .radio-container ul li label input {
  position: absolute;
  left: -32px;
  height: 24px !important;
  width: 24px !important;
}

.setup .radio-container ul li:last-child {
  display: initial;
}
