/* martian-mono-300 - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 300;
  src: url('../font/martian-mono-v6-latin_latin-ext-300.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* martian-mono-regular - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 400;
  src: url('../font/martian-mono-v6-latin_latin-ext-regular.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* martian-mono-500 - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 500;
  src: url('../font/martian-mono-v6-latin_latin-ext-500.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* martian-mono-600 - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 600;
  src: url('../font/martian-mono-v6-latin_latin-ext-600.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* martian-mono-700 - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 700;
  src: url('../font/martian-mono-v6-latin_latin-ext-700.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* martian-mono-800 - latin_latin-ext */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Martian Mono';
  font-style: normal;
  font-weight: 800;
  src: url('../font/martian-mono-v6-latin_latin-ext-800.woff2') format('woff2');
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
.row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 100%;
  max-width: 63.66249312rem;
  margin-left: auto;
  margin-right: auto;
  padding: 0 1.92162322rem;
}
.row .row {
  padding-left: 0;
  padding-right: 0;
}
.row .row .col {
  padding-left: 0;
  padding-right: 0;
}
.row .row .col:first-child {
  padding-top: 0;
}
.col {
  flex-basis: 100%;
  padding: 0.8567405rem 1.12147331rem;
}
.colSpan {
  margin-top: 0;
  padding: 0;
}
/* XSmall Size Devices, Phones */
@media only screen and (min-width: 320px) {
  .xs1 {
    flex-basis: 8.33333333%;
  }
  .xs2 {
    flex-basis: 16.66666667%;
  }
  .xs3 {
    flex-basis: 25%;
  }
  .xs4 {
    flex-basis: 33.33333333%;
  }
  .xs5 {
    flex-basis: 41.66666667%;
  }
  .xs6 {
    flex-basis: 50%;
  }
  .xs7 {
    flex-basis: 58.33333333%;
  }
  .xs8 {
    flex-basis: 66.66666667%;
  }
  .xs9 {
    flex-basis: 75%;
  }
  .xs10 {
    flex-basis: 83.33333333%;
  }
  .xs11 {
    flex-basis: 91.66666667%;
  }
  .xs12 {
    flex-basis: 100%;
  }
}
/* Small Size Devices, Phones */
@media only screen and (min-width: 425px) {
  .sm1 {
    flex-basis: 8.33333333%;
  }
  .sm2 {
    flex-basis: 16.66666667%;
  }
  .sm3 {
    flex-basis: 25%;
  }
  .sm4 {
    flex-basis: 33.33333333%;
  }
  .sm5 {
    flex-basis: 41.66666667%;
  }
  .sm6 {
    flex-basis: 50%;
  }
  .sm7 {
    flex-basis: 58.33333333%;
  }
  .sm8 {
    flex-basis: 66.66666667%;
  }
  .sm9 {
    flex-basis: 75%;
  }
  .sm10 {
    flex-basis: 83.33333333%;
  }
  .sm11 {
    flex-basis: 91.66666667%;
  }
  .sm12 {
    flex-basis: 100%;
  }
}
/* Middle Size Devices, Tablets */
@media only screen and (min-width: 768px) {
  .md1 {
    flex-basis: 8.33333333%;
  }
  .md2 {
    flex-basis: 16.66666667%;
  }
  .md3 {
    flex-basis: 25%;
  }
  .md4 {
    flex-basis: 33.33333333%;
  }
  .md5 {
    flex-basis: 41.66666667%;
  }
  .md6 {
    flex-basis: 50%;
  }
  .md7 {
    flex-basis: 58.33333333%;
  }
  .md8 {
    flex-basis: 66.66666667%;
  }
  .md9 {
    flex-basis: 75%;
  }
  .md10 {
    flex-basis: 83.33333333%;
  }
  .md11 {
    flex-basis: 91.66666667%;
  }
  .md12 {
    flex-basis: 100%;
  }
}
/* Large Devices, Wide Screens */
@media only screen and (min-width: 1024px) {
  .lg1 {
    flex-basis: 8.33333333%;
  }
  .lg2 {
    flex-basis: 16.66666667%;
  }
  .lg3 {
    flex-basis: 25%;
  }
  .lg4 {
    flex-basis: 33.33333333%;
  }
  .lg5 {
    flex-basis: 41.66666667%;
  }
  .lg6 {
    flex-basis: 50%;
  }
  .lg7 {
    flex-basis: 58.33333333%;
  }
  .lg8 {
    flex-basis: 66.66666667%;
  }
  .lg9 {
    flex-basis: 75%;
  }
  .lg10 {
    flex-basis: 83.33333333%;
  }
  .lg11 {
    flex-basis: 91.66666667%;
  }
  .lg12 {
    flex-basis: 100%;
  }
}
/* Extra Large Devices, Wide Screens */
@media only screen and (min-width: 1440px) {
  .xl1 {
    flex-basis: 8.33333333%;
  }
  .xl2 {
    flex-basis: 16.66666667%;
  }
  .xl3 {
    flex-basis: 25%;
  }
  .xl4 {
    flex-basis: 33.33333333%;
  }
  .xl5 {
    flex-basis: 41.66666667%;
  }
  .xl6 {
    flex-basis: 50%;
  }
  .xl7 {
    flex-basis: 58.33333333%;
  }
  .xl8 {
    flex-basis: 66.66666667%;
  }
  .xl9 {
    flex-basis: 75%;
  }
  .xl10 {
    flex-basis: 83.33333333%;
  }
  .xl11 {
    flex-basis: 91.66666667%;
  }
  .xl12 {
    flex-basis: 100%;
  }
}
.noGrow {
  flex-basis: initial;
}
@media only screen and (max-width: 768px) {
  .row {
    padding: 0 0.8567405rem;
  }
  .col {
    padding: 0.8567405rem 0.6545rem;
  }
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 0.8567405rem 0;
  color: #000000;
}
h1 {
  font-size: 3.35385723rem;
}
h2 {
  font-size: 2.79488102rem;
}
h3 {
  font-size: 2.32906752rem;
}
h4 {
  font-size: 1.9408896rem;
}
h5 {
  font-size: 1.617408rem;
}
h6 {
  font-size: 1.34784rem;
}
p {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  line-height: 1.6;
  margin: 0 0 0.8567405rem 0;
  color: #000000;
}
.textSmall {
  font-size: 0.936rem;
}
.textMuted {
  color: #949494;
}
.textUppercase {
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.label {
  font-size: 0.936rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #828282;
  margin-bottom: 0.6545rem;
}
a {
  color: #000000;
  text-decoration: underline;
  cursor: pointer;
}
a:hover {
  color: #828282;
}
.btn {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  padding: 0.6545rem 1.12147331rem;
  border: 2px solid #000000;
  border-radius: 1.92162322rem;
  cursor: pointer;
  display: inline-block;
  text-decoration: none;
  transition: all 0.15s ease;
  appearance: none;
  white-space: nowrap;
  color: #000000;
}
.btn:first-child {
  margin-left: 0;
}
.btnOutline {
  background-color: transparent;
  color: #000000;
}
.btnOutline:hover {
  background-color: #000000;
  color: #fff;
}
.btnDefault {
  background-color: #a6a6a6;
  border-color: #a6a6a6;
  color: #000000;
}
.btnDefault:hover {
  background-color: #8c8c8c;
  border-color: #8c8c8c;
  color: #000000;
}
.btnPrimary {
  background-color: #000000;
  border-color: #000000;
  color: #fff;
}
.btnPrimary:hover {
  background-color: #333333;
  border-color: #333333;
  color: #fff;
}
.btnSuccess {
  background-color: #75ff9e;
  border-color: #75ff9e;
  color: #000000;
}
.btnSuccess:hover {
  background-color: #42ff7a;
  border-color: #42ff7a;
  color: #000000;
}
.btnError {
  background-color: #ff8a8a;
  border-color: #ff8a8a;
  color: #000000;
}
.btnError:hover {
  background-color: #ff5757;
  border-color: #ff5757;
  color: #000000;
}
.btnWarning {
  background-color: #fff175;
  border-color: #fff175;
  color: #000000;
}
.btnWarning:hover {
  background-color: #ffec42;
  border-color: #ffec42;
  color: #000000;
}
.btnInfo {
  background-color: #75eeff;
  border-color: #75eeff;
  color: #000000;
}
.btnInfo:hover {
  background-color: #42e8ff;
  border-color: #42e8ff;
  color: #000000;
}
.btnSm {
  font-size: 0.78rem;
  padding: 0.5rem 0.8567405rem;
}
.btnXs {
  font-size: 0.65rem;
  padding: 0.5rem 0.6545rem;
}
.btnGroup {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8567405rem;
  align-items: center;
}
.btnGroup .formInput {
  width: auto;
}
.btnGroupFixed {
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 0.6545rem;
}
.tag {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  padding: 0.5rem 0.6545rem;
  color: #000000;
  display: inline-block;
  text-decoration: none;
  margin-left: 0.5rem;
  margin-top: 0.5rem;
}
.tag:first-child {
  margin-left: 0;
}
.tag a {
  color: inherit;
  text-decoration: none;
}
.tag:hover,
.tag:visited {
  color: #000000;
  text-decoration: none;
}
.tagDefault {
  background-color: #a6a6a6;
  color: #000000;
}
.tagPrimary {
  background-color: #000000;
  color: #fff;
}
.tagSuccess {
  background-color: #75ff9e;
  color: #000000;
}
.tagError {
  background-color: #ff8a8a;
  color: #000000;
}
.tagWarning {
  background-color: #fff175;
  color: #000000;
}
.tagInfo {
  background-color: #75eeff;
  color: #000000;
}
.tagAccent {
  background-color: #e8ff75;
  color: #000000;
}
.tagGroup {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
}
.pageTitle {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.rowHeader {
  background-color: #fff;
}
.headerTop {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.headerLogo {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 2.79488102rem;
  font-weight: 700;
  color: #000000;
  text-decoration: none;
  margin: 0;
}
.headerLogo:hover,
.headerLogo:visited {
  color: #000000;
  text-decoration: none;
}
.headerMeta {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  color: #949494;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.6545rem 1.46800857rem;
  margin-top: 0.8567405rem;
  background-color: #f5f5f5;
  border-radius: 1.12147331rem;
}
.headerMetaUser {
  font-weight: 700;
  color: #000000;
}
.headerMetaSep {
  color: #b8b8b8;
  margin: 0 0.5rem;
}
.headerMetaUnselect {
  color: #949494;
  text-decoration: none;
}
.headerMetaUnselect:hover {
  color: #000000;
}
.headerNav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6545rem;
  margin-top: 0.8567405rem;
  padding-top: 0.6545rem;
}
.headerNav:empty {
  display: none;
}
.menuToggle {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 1.46800857rem;
  height: 1.12147331rem;
  box-sizing: content-box;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 1.12147331rem;
}
.menuToggle span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #000000;
  transition: all 0.3s ease;
}
@media only screen and (max-width: 425px) {
  .headerLogo {
    font-size: 1.9408896rem;
  }
}
.jumbotron {
  background-color: #f5f5f5;
  padding: 1.46800857rem 1.92162322rem 2.51540479rem 1.92162322rem;
  border-radius: 1.46800857rem;
}
.jumbotronTags {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.6545rem;
  margin-bottom: 1.12147331rem;
  padding-bottom: 1.12147331rem;
  text-transform: uppercase;
}
.jumbotronTitle {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.9408896rem;
  font-weight: 700;
  line-height: 1.15;
  color: #000000;
  margin-bottom: 1.12147331rem;
}
.jumbotronText {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  line-height: 1.6;
  color: #000000;
  margin-bottom: 1.46800857rem;
  max-width: 80%;
}
.jumbotronActions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8567405rem;
}
.jumbotronLayer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 1.46800857rem 1.92162322rem 2.51540479rem 1.92162322rem;
  opacity: 0;
  transition: opacity 1s ease;
  pointer-events: none;
}
.jumbotronLayerActive {
  position: relative;
  opacity: 1;
  pointer-events: auto;
  z-index: 1;
}
.jumbotronNav {
  position: absolute;
  bottom: 0.8567405rem;
  right: 1.12147331rem;
  display: flex;
  gap: 0.5rem;
  z-index: 2;
}
.jumbotronNavBtn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 2.79488102rem;
  line-height: 1;
  color: #707070;
  opacity: 0.3;
  padding: 0 0.5rem;
  transition: opacity 0.2s ease;
}
.jumbotronNavBtn:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 768px) {
  .jumbotronTitle {
    font-size: 1.617408rem;
  }
  .jumbotronText {
    max-width: 100%;
  }
}
@media only screen and (max-width: 425px) {
  .jumbotronTitle {
    font-size: 1.34784rem;
  }
  .jumbotronTags {
    justify-content: flex-start;
  }
}
.card {
  background-color: #f5f5f5;
  padding: 2.51540479rem 1.46800857rem;
  border-radius: 1.46800857rem;
  height: 100%;
}
.card form {
  margin-top: 1.92162322rem;
}
.card h2 {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.617408rem;
  font-weight: 700;
  line-height: 1.2;
  color: #000000;
  margin-bottom: 0.8567405rem;
}
.card h2 a {
  color: #000000;
  text-decoration: none;
}
.card h2 a:hover {
  color: #828282;
}
.card p {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  line-height: 1.6;
  color: #000000;
  margin-bottom: 0.8567405rem;
}
.cardLabel {
  display: block;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #000000;
  margin-bottom: 0.8567405rem;
}
.cardTitle {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.617408rem;
  font-weight: 700;
  line-height: 1.2;
  color: #000000;
  margin-bottom: 0.8567405rem;
}
.cardText {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  line-height: 1.6;
  color: #000000;
}
.cardSpecimen {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
}
.specimenChars {
  font-size: 0.936rem;
  line-height: 1.4;
  margin-bottom: 1.12147331rem;
  word-break: break-all;
}
.specimenAlphabet {
  font-size: 0.936rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 1.12147331rem;
  word-break: break-all;
}
.statBox {
  background-color: #fff;
  padding: 1.12147331rem;
  margin-top: 1.12147331rem;
  border-radius: 0.8567405rem;
}
.statNumber {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 2.32906752rem;
  font-weight: 700;
  line-height: 1;
  color: #000000;
  margin-bottom: 0.6545rem;
}
.statText {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  line-height: 1.4;
  color: #000000;
}
@media only screen and (max-width: 425px) {
  .cardTitle {
    font-size: 1.34784rem;
  }
  .statNumber {
    font-size: 1.9408896rem;
  }
}
.table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
}
.table th,
.table td {
  padding: 0.8567405rem 1.12147331rem;
  text-align: left;
  border-bottom: 1px solid #c9c9c9;
}
.table th {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  background-color: #f5f5f5;
}
.table th.fixedMiddle,
.table td.fixedMiddle {
  width: 20%;
  white-space: nowrap;
}
.table th.fixedSmall,
.table td.fixedSmall {
  width: 10%;
  white-space: nowrap;
}
.table th.fixedZero,
.table td.fixedZero {
  width: 1%;
  white-space: nowrap;
}
.table tbody tr:hover {
  background-color: #f5f5f5;
}
.tableStriped tbody tr:nth-child(odd) {
  background-color: #f5f5f5;
}
.tableStriped tbody tr:hover {
  background-color: #c9c9c9;
}
.tableBordered th,
.tableBordered td {
  border: 1px solid #c9c9c9;
}
.tableCompact th,
.tableCompact td {
  padding: 0.6545rem 0.8567405rem;
  font-size: 0.78rem;
}
.tableResponsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.tableHeaderDefault th {
  background-color: #a6a6a6;
}
.tableHeaderPrimary th {
  background-color: #000000;
  color: #fff;
}
.tableHeaderSuccess th {
  background-color: #75ff9e;
}
.tableHeaderError th {
  background-color: #ff8a8a;
}
.tableHeaderWarning th {
  background-color: #fff175;
}
.tableHeaderInfo th {
  background-color: #75eeff;
}
@media only screen and (max-width: 425px) {
  .table th,
  .table td {
    padding: 0.6545rem 0.8567405rem;
    font-size: 0.78rem;
  }
}
.pagination {
  display: flex;
  align-items: center;
  gap: 0.6545rem;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.1232rem;
  margin-top: 1.12147331rem;
}
.paginationItem {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1.92162322rem;
  height: 1.92162322rem;
  padding: 0 0.6545rem;
  background-color: #f5f5f5;
  color: #949494;
  text-decoration: none;
  border-radius: 0.6545rem;
  transition: background-color 0.2s ease, color 0.2s ease;
  cursor: pointer;
  border: none;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.1232rem;
}
.paginationItem:hover {
  background-color: #c9c9c9;
  color: #000000;
}
.paginationItem.active {
  background-color: #e8ff75;
  color: #000000;
  font-weight: 700;
}
.paginationItem.disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}
.paginationFirst,
.paginationLast {
  font-weight: 700;
}
.paginationPrev,
.paginationNext {
  font-weight: 400;
}
.paginationCompact {
  gap: 0.5rem;
}
.paginationCompact .paginationItem {
  min-width: 1.46800857rem;
  height: 1.46800857rem;
  font-size: 0.936rem;
  border-radius: 0.5rem;
}
.paginationCenter {
  justify-content: center;
}
.paginationRight {
  justify-content: flex-end;
}
.form {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
}
.formGroup {
  margin-top: 1.46800857rem;
}
.formGroup:first-child {
  margin-top: 0;
}
.formLabel {
  display: block;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.6545rem;
  color: #000000;
}
.formInput,
.formSelect,
.formTextarea {
  width: 100%;
  padding: 0.8567405rem 1.12147331rem;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  color: #000000;
  background-color: #fff;
  border: 1px solid #c9c9c9;
  border-radius: 0.6545rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.formInput:focus,
.formSelect:focus,
.formTextarea:focus {
  outline: none;
  border-color: #a6a6a6;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1);
}
.formInput::placeholder,
.formSelect::placeholder,
.formTextarea::placeholder {
  color: #b8b8b8;
}
.formInput:disabled,
.formSelect:disabled,
.formTextarea:disabled {
  background-color: #f5f5f5;
  color: #a6a6a6;
  cursor: not-allowed;
}
.formTextarea {
  min-height: 9.66732049rem;
  resize: vertical;
}
.formInputSm {
  padding: 0.6545rem 0.8567405rem;
  font-size: 0.78rem;
}
.formSearch {
  display: contents;
}
.formSelect {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.8567405rem center;
  padding-right: 2.51540479rem;
  cursor: pointer;
}
.formHint {
  display: block;
  font-size: 0.78rem;
  color: #a6a6a6;
  margin-top: 0.5rem;
}
.formError {
  color: #ff8a8a;
}
.formInputError {
  border-color: #ff8a8a;
}
.formInputError:focus {
  box-shadow: 0 0 0 2px rgba(255, 138, 138, 0.2);
}
.formCheck {
  display: flex;
  align-items: center;
  gap: 0.6545rem;
  margin-bottom: 0.6545rem;
  cursor: pointer;
}
.formCheckInput {
  width: 1.12147331rem;
  height: 1.12147331rem;
  margin: 0;
  cursor: pointer;
  accent-color: #000000;
}
.formCheckLabel {
  font-size: 0.936rem;
  color: #000000;
  cursor: pointer;
}
.formInline {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.8567405rem;
}
.formInline .formGroup {
  margin-top: 0;
  flex: 1;
  min-width: 150px;
}
.formInline .formGroupAuto {
  flex: none;
}
.formActions {
  display: flex;
  gap: 0.8567405rem;
  margin-top: 1.46800857rem;
}
.formCompact .formInput,
.formCompact .formSelect,
.formCompact .formTextarea {
  padding: 0.6545rem 0.8567405rem;
  font-size: 0.78rem;
}
.formCompact .formLabel {
  font-size: 0.65rem;
  margin-bottom: 0.5rem;
}
.formCompact .formGroup {
  margin-top: 1.12147331rem;
}
.formHighlight .formLabel {
  display: inline-block;
  background-color: #e8ff75;
  padding: 0.5rem 0.6545rem;
  margin-bottom: 0.6545rem;
  border-radius: 0.5rem;
}
@media only screen and (max-width: 425px) {
  .formInline {
    flex-direction: column;
    align-items: stretch;
  }
  .formInline .formGroup {
    width: 100%;
  }
}
.alert {
  position: relative;
  padding: 1.12147331rem 2.51540479rem 1.12147331rem 1.12147331rem;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  border-radius: 0.8567405rem;
  margin-bottom: 1.12147331rem;
  animation: alertFadeIn 0.3s ease;
}
@keyframes alertFadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.alert.alertClosing {
  animation: alertFadeOut 0.3s ease forwards;
}
@keyframes alertFadeOut {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-10px);
  }
}
.alertClose {
  position: absolute;
  top: 0.8567405rem;
  right: 0.8567405rem;
  width: 1.46800857rem;
  height: 1.46800857rem;
  background: transparent;
  border: none;
  font-size: 1.34784rem;
  line-height: 1;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.alertClose:hover {
  opacity: 1;
}
.alertTitle {
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.6545rem;
}
.alertText {
  line-height: 1.5;
}
.alertDefault {
  background-color: #dbdbdb;
  border-left: 4px solid #a6a6a6;
  color: #000000;
}
.alertDefault .alertClose {
  color: #000000;
}
.alertPrimary {
  background-color: rgba(0, 0, 0, 0.1);
  border-left: 4px solid #000000;
  color: #000000;
}
.alertPrimary .alertClose {
  color: #000000;
}
.alertSuccess {
  background-color: rgba(117, 255, 158, 0.4);
  border-left: 4px solid #75ff9e;
  color: #000000;
}
.alertSuccess .alertClose {
  color: #000000;
}
.alertError {
  background-color: rgba(255, 138, 138, 0.4);
  border-left: 4px solid #ff8a8a;
  color: #000000;
}
.alertError .alertClose {
  color: #000000;
}
.alertWarning {
  background-color: rgba(255, 241, 117, 0.5);
  border-left: 4px solid #fff175;
  color: #000000;
}
.alertWarning .alertClose {
  color: #000000;
}
.alertInfo {
  background-color: rgba(117, 238, 255, 0.4);
  border-left: 4px solid #75eeff;
  color: #000000;
}
.alertInfo .alertClose {
  color: #000000;
}
.callout {
  padding: 1.12147331rem;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  border-radius: 0.8567405rem;
  margin-bottom: 1.12147331rem;
  border-left: 4px solid;
}
.calloutTitle {
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.6545rem;
}
.calloutText {
  line-height: 1.5;
}
.calloutDefault {
  background-color: #dbdbdb;
  border-left-color: #a6a6a6;
  color: #000000;
}
.calloutPrimary {
  background-color: rgba(0, 0, 0, 0.1);
  border-left-color: #000000;
  color: #000000;
}
.calloutSuccess {
  background-color: rgba(117, 255, 158, 0.4);
  border-left-color: #75ff9e;
  color: #000000;
}
.calloutError {
  background-color: rgba(255, 138, 138, 0.4);
  border-left-color: #ff8a8a;
  color: #000000;
}
.calloutWarning {
  background-color: rgba(255, 241, 117, 0.5);
  border-left-color: #fff175;
  color: #000000;
}
.calloutInfo {
  background-color: rgba(117, 238, 255, 0.4);
  border-left-color: #75eeff;
  color: #000000;
}
.rowFooter {
  background-color: #fff;
  margin-top: 1.46800857rem;
}
.footerText {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  color: #000000;
  margin-bottom: 0.6545rem;
}
.footerLink {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 0.936rem;
  color: #949494;
  text-decoration: none;
}
.footerLink:hover {
  color: #000000;
  text-decoration: underline;
}
.footerSep {
  color: #b8b8b8;
  margin: 0 0.5rem;
}
.copyLink {
  background: none;
  border: none;
  cursor: pointer;
  color: #a6a6a6;
  font-size: 0.936rem;
  padding: 0;
  transition: opacity 100ms ease;
}
.copyLink:hover {
  color: #000000;
}
.topMenu {
  display: flex;
  align-items: center;
  gap: 0.6545rem;
  font-size: 0.78rem;
}
.topMenuLink {
  color: #949494;
  text-decoration: none;
}
.topMenuLink:hover {
  color: #000000;
}
.topMenuActive {
  color: #000000;
  font-weight: 700;
}
.topMenuSep {
  color: #b8b8b8;
}
.mobileMenu {
  position: fixed;
  top: 0;
  right: -21.6832839rem;
  width: 21.6832839rem;
  height: 100vh;
  background-color: #fff;
  z-index: 1000;
  transition: right 0.3s ease;
  overflow-y: auto;
  padding: 1.46800857rem;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05), 0 2px 4px rgba(0, 0, 0, 0.24);
}
.mobileMenu.active {
  right: 0;
}
.mobileMenuHeader {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.46800857rem;
  padding-bottom: 0.8567405rem;
  border-bottom: 1px solid #c9c9c9;
}
.mobileMenuLogo {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.617408rem;
  font-weight: 700;
  color: #000000;
}
.mobileMenuClose {
  background: transparent;
  border: none;
  font-size: 2.32906752rem;
  cursor: pointer;
  padding: 0.8567405rem;
  color: #000000;
  line-height: 1;
}
.mobileMenuClose:hover {
  color: #949494;
}
.mobileMenuNav {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.8567405rem;
}
.mobileMenuItem {
  margin: 0;
}
.mobileMenuLink {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.34784rem;
  color: #000000;
  text-decoration: none;
  display: block;
  padding: 0.6545rem 0;
}
.mobileMenuLink:hover {
  color: #949494;
}
.mobileMenuLabel {
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
  font-size: 1.34784rem;
  font-weight: 700;
  color: #000000;
  display: block;
  padding: 0.6545rem 0;
  cursor: pointer;
}
.mobileMenuSub {
  list-style: none;
  padding: 0;
  padding-left: 1.12147331rem;
  margin: 0;
  display: none;
  flex-direction: column;
  gap: 0.6545rem;
}
.mobileMenuOpen > .mobileMenuSub {
  display: flex;
}
.mobileMenuSub .mobileMenuLink {
  font-size: 1.1232rem;
}
@media only screen and (max-width: 425px) {
  .mobileMenu {
    width: 100%;
    right: -100%;
  }
}
.menuOverlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}
.menuOverlay.active {
  opacity: 1;
  visibility: visible;
}
.goTop {
  position: fixed;
  bottom: 1.46800857rem;
  right: calc(50% - 63.66249312rem / 2 + 1.92162322rem + 1.12147331rem);
  width: 2.51540479rem;
  height: 2.51540479rem;
  background-color: #000000;
  color: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 1.1232rem;
  z-index: 900;
  transition: opacity 0.3s ease;
  opacity: 0.7;
}
.goTop i {
  transform: rotate(-45deg);
}
.goTop:hover {
  opacity: 1;
}
.goTop.active {
  display: flex;
}
@media only screen and (max-width: 63.66249312rem) {
  .goTop {
    right: 1.92162322rem;
  }
}
body#homePage .jumbotron {
  position: relative;
  overflow: hidden;
  padding: 0;
}
body#loginPage {
  background-color: #f5f5f5;
}
.login {
  margin-top: 5.64191869rem;
}
.bgLayer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease;
}
.bgLayerActive {
  opacity: 1;
}
body#endPage pre {
  white-space: pre-wrap;
  word-break: break-word;
}
body#fatalErrorPage pre {
  white-space: pre-wrap;
  word-break: break-word;
}
body#roleRightPage table {
  margin-top: 0;
}
body#roleRightPage table tbody {
  display: none;
}
body#roleRightPage table tbody tr:first-child th {
  background-color: rgba(0, 0, 0, 0.1);
}
body#roleRightPage table thead tr.roleHeader {
  border: 1px solid #c9c9c9;
  cursor: pointer;
}
body#roleRightPage table thead tr.roleHeader th {
  background-color: #f5f5f5;
}
body#roleRightPage table thead tr.roleHeader th .accordionIcon {
  float: right;
  font-size: 1.9408896rem;
  color: #a6a6a6;
}
body#roleRightPage table thead tr.roleHeader th .accordionIcon:hover {
  color: #828282;
}
body#roleRightPage table thead tr.roleHeader th .selectAll,
body#roleRightPage table thead tr.roleHeader th .selectNone,
body#roleRightPage table thead tr.roleHeader th .selectReverse {
  display: none;
}
body#roleRightPage table:not(:first-of-type) {
  margin-top: 1.46800857rem;
}
body#userRolePage table tbody td div.revokeConfirm {
  display: none;
}
* {
  box-sizing: border-box;
}
html {
  margin: 0;
  font-size: 1.12147331rem;
  font-family: 'Martian Mono', 'SF Mono', 'Roboto Mono', 'Fira Code', monospace;
}
body {
  margin: 0;
  padding-bottom: 5.64191869rem;
  color: #707070;
  background-color: #fff;
}
.clear:after {
  content: " ";
  display: table;
  clear: both;
}
.hidden {
  display: none;
}
.section {
  display: block;
  width: 100%;
  margin: 0;
}
.section:first-child {
  margin-top: 0;
}
main {
  padding: 1.46800857rem 0;
}
.find {
  background-color: rgba(255, 241, 117, 0.5);
  padding: 1px 2px;
}
.contentRow {
  margin-top: 0.8567405rem;
}
.siteMessage .row .col:first-child {
  margin-top: 1.12147331rem;
}
.wasmLoader {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  font-size: 1.9408896rem;
  color: #a6a6a6;
}
table tr td.right,
table tr th.right {
  text-align: right;
}
table tr td.center,
table tr th.center {
  text-align: center;
}
