/* this is the lightest grey that meets AA contrast standards */
/* Normalization */
html {
  box-sizing: border-box; }

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

* {
  margin: 0;
  padding: 0; }

input[type="text"],
input[type="number"],
select,
textarea {
  font-size: 14px; }

body {
  background: white;
  margin: 0; }

i {
  vertical-align: -webkit-baseline-middle;
  vertical-align: middle; }

main {
  background: #fff; }
  main:focus {
    outline: none; }

.row.is-flex {
  display: flex;
  flex-wrap: wrap; }

.row.is-flex > [class*='col-'] {
  display: flex;
  flex-direction: column; }

@font-face {
  font-family: 'Roboto';
  font-weight: 300;
  font-style: normal;
  src: url("../fonts/Roboto-Light.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 300;
  font-style: italic;
  src: url("../fonts/Roboto-LightItalic.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/Roboto-Regular.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 400;
  font-style: italic;
  src: url("../fonts/Roboto-Italic.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 500;
  font-style: normal;
  src: url("../fonts/Roboto-Medium.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 500;
  font-style: italic;
  src: url("../fonts/Roboto-MediumItalic.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 700;
  font-style: normal;
  src: url("../fonts/Roboto-Bold.ttf"); }

@font-face {
  font-family: 'Roboto';
  font-weight: 700;
  font-style: italic;
  src: url("../fonts/Roboto-BoldItalic.ttf"); }

html {
  font-size: 62.5% !important; }

:root {
  font-size: 62.5%; }

body {
  font-family: "Roboto", "Helvetica-Neue", sans-serif;
  font-size: 1.6rem; }

h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0;
  margin-bottom: 1.6rem;
  line-height: 1.6; }

h1 {
  font-size: 5.3rem;
  font-weight: 400;
  line-height: 1.2; }

h2 {
  font-size: 3.6rem;
  font-weight: 400;
  line-height: 1.2; }

h3 {
  font-size: 2.8rem;
  font-weight: 400; }

h4 {
  font-size: 2rem;
  font-weight: 700; }

p {
  margin-bottom: 1.5rem;
  line-height: 1.6;
  color: #4a4a4a; }
  p.intro {
    font-size: 1.8rem; }

caption,
p.disclaimer {
  font-size: 1.2rem; }

caption {
  padding-bottom: 5px;
  color: #4a4a4a; }

a {
  color: #01568d;
  text-decoration: none; }
  a.hover, a:hover {
    color: #01568d;
    text-decoration: underline; }
  a.active, a:active {
    color: #2075ac;
    text-decoration: underline; }
  a.visited, a:visited {
    color: #2075ac; }

.btn, .fn-primary {
  border-radius: 18px;
  padding: 0 1.6rem;
  line-height: 33px;
  height: 36px;
  background: white;
  margin-right: 0.8em;
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: uppercase;
  outline: none; }
  .btn.active, .active.fn-primary, .btn.hover, .hover.fn-primary, .btn:active, .fn-primary:active, .btn:hover, .fn-primary:hover {
    outline: none;
    box-shadow: none; }
  .btn.focus, .focus.fn-primary, .btn:focus, .fn-primary:focus {
    outline: none;
    color: #fff;
    box-shadow: none;
    box-shadow: 0 0 3px #4a4a4a, 0 0 7px #e1e1e1 !important; }

button[aria-disabled="true"], button[disabled] {
  background: white;
  color: #d8d8d8;
  border: 1px solid #d8d8d8;
  pointer-events: none; }

.fn-inverse,
.fn-primary,
.fn-secondary {
  min-width: 120px; }
  .fn-inverse i,
  .fn-primary i,
  .fn-secondary i {
    font-size: 2.4rem;
    vertical-align: middle;
    vertical-align: -webkit-baseline-middle; }

.fn-primary {
  border: 2px solid #18477e;
  color: #18477e; }
  .fn-primary.hover, .fn-primary:hover {
    background: #18477e;
    border-color: #18477e;
    color: white;
    box-shadow: none; }
  .fn-primary.active, .fn-primary:active {
    outline: none !important;
    background: #0c233e !important;
    border-color: #0c233e !important;
    color: white; }
  .fn-primary.focus, .fn-primary:focus {
    outline: none;
    background: #18477e;
    border-color: #18477e;
    color: white; }

.btn-group > .btn, .btn-group > .fn-primary,
.btn-group > .fn-primary {
  margin-right: 0; }

.form-control,
input[type='text'],
input[type='password'],
textarea {
  font-size: 1.6rem;
  background: #fafafa;
  border-color: #b7b7b7;
  box-shadow: none; }
  .form-control::-webkit-input-placeholder,
  input[type='text']::-webkit-input-placeholder,
  input[type='password']::-webkit-input-placeholder,
  textarea::-webkit-input-placeholder {
    color: #d8d8d8; }
  .form-control:-moz-placeholder, .form-control::-moz-placeholder,
  input[type='text']:-moz-placeholder,
  input[type='text']::-moz-placeholder,
  input[type='password']:-moz-placeholder,
  input[type='password']::-moz-placeholder,
  textarea:-moz-placeholder,
  textarea::-moz-placeholder {
    color: #d8d8d8;
    opacity: 1; }
  .form-control:-ms-input-placeholder,
  input[type='text']:-ms-input-placeholder,
  input[type='password']:-ms-input-placeholder,
  textarea:-ms-input-placeholder {
    color: #d8d8d8; }

.form-control[disabled],
input[disabled],
textarea[disabled] {
  background: white;
  border-color: #d8d8d8;
  color: #d8d8d8; }
  .form-control[disabled] label,
  input[disabled] label,
  textarea[disabled] label {
    color: #d8d8d8; }

.form-control-focus {
  border-color: #1071bc !important; }

.form-control-error {
  border-color: #cb4027 !important; }

textarea {
  color: #4a4a4a;
  font-weight: 500; }

input[type='text'],
input[type='password'] {
  color: black;
  font-weight: 500; }

.form-group {
  margin: 3rem 0; }
  .form-group .control-label {
    font-weight: 700;
    font-size: 1.4rem;
    margin-bottom: 5px;
    text-transform: uppercase;
    display: block;
    padding-left: 12px; }
    .form-group .control-label .required {
      font-weight: 700;
      color: #cb4027;
      text-transform: none;
      font-size: 16px; }
      .form-group .control-label .required:before {
        content: '*'; }
    .form-group .control-label .help-text {
      color: #4a4a4a;
      padding-left: 5px;
      font-weight: 700; }
  .form-group .help-block {
    font-size: 1.2rem; }
  .form-group.has-error .control-label {
    color: #cb4027; }
  .form-group.has-error .form-control {
    border-color: #cb4027; }

.help-text {
  color: #777777;
  font-size: 1.2rem;
  text-transform: normal; }
  .help-text.has-error {
    color: #cb4027; }

.msgBlock {
  min-height: 36px;
  text-align: center;
  width: 100%; }
  .msgBlock.error {
    color: #cb4027;
    display: inline-block; }
    .msgBlock.error:before {
      content: url("../images/icon-error.svg");
      width: 30px; }
  .msgBlock.success {
    color: #008740; }
    .msgBlock.success:before {
      content: url("../images/icon-check-circle-green.svg");
      width: 24px; }
  .msgBlock.error, .msgBlock.success {
    margin: 2rem auto;
    font-weight: 700; }
    .msgBlock.error:before, .msgBlock.success:before {
      display: inline-block;
      vertical-align: middle;
      transform: scale(0.6); }
  .msgBlock.error-list {
    text-align: left;
    margin: 2rem auto;
    width: 90%; }
    .msgBlock.error-list ul {
      list-style: none; }
      .msgBlock.error-list ul li {
        padding-left: 32px;
        padding-top: 5px; }
    .msgBlock.error-list.error::before, .msgBlock.error-list.succes::before {
      position: absolute; }

.forgotPasswordPage,
.loginPage,
.logoutConfPage,
.newPasswordPage {
  background: white; }
  .forgotPasswordPage .fn-primary,
  .loginPage .fn-primary,
  .logoutConfPage .fn-primary,
  .newPasswordPage .fn-primary {
    margin: 2em 0;
    min-width: 50%; }

header {
  padding: 3rem 0 0;
  text-align: center; }
  header .branding {
    width: 176px;
margin: 0 auto 3rem; }
  header h1 {
    margin: 1.5rem 0; }

.FNForm {
  padding: 0 0 3rem; }
  .FNForm .forgot-password-link {
    text-align: center;
    line-height: 4.2rem; }

.newUserForm {
  background: #fafafa;
  padding: 2em 0;
  text-align: center; }

.form-submit {
  text-align: center; }

.password-reqs {
  padding-bottom: 18px;
  font-weight: 500;
  text-align: center; }
  .password-reqs .list-requirements {
    list-style: none;
    font-weight: 400;
    font-size: 14px; }
    .password-reqs .list-requirements li {
      text-align: left;
      float: left; }
      .password-reqs .list-requirements li:before {
        content: '\2022 ';
        padding-right: 6px; }
      .password-reqs .list-requirements li.isValid {
        color: #008740 !important;
        font-weight: 500; }
        .password-reqs .list-requirements li.isValid:before {
          content: '\2713 ';
          padding-right: 6px; }

fieldset div:first-of-type {
  margin-top: 0; }

.nowrap {
  white-space: nowrap; }

.forgotPasswordPage .msgBlock,
.loginPage .msgBlock,
.newPasswordPage .msgBlock {
  display: none; }

.toc > li {
  font-weight: 500;
  margin-bottom: 10px; }

.toc li > ul {
  margin-left: 15px;
  font-weight: 400; }

/* XS */
@media only screen and (min-width: 320px) {
  h1 {
    font-size: 3.6rem; }
  h2 {
    font-size: 3.2rem; }
  .password-reqs {
    width: 90%;
    margin: 0 auto; }
    .password-reqs .list-requirements li {
      width: 100%; } }

/* SM */
@media only screen and (min-width: 768px) {
  h1 {
    font-size: 5.3rem; }
  h2 {
    font-size: 3.6rem; }
  .password-reqs {
    width: 100%; }
    .password-reqs .list-requirements li {
      width: 50%; } }

.FNProgressBar {
  width: 80vw;
  max-width: 450px;
  margin: 60px auto; }
  .FNProgressBar .progress {
    padding: 2px;
    height: 48px;
    background: rgba(0, 0, 0, 0.25);
    border-radius: 6px;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25), 0 1px rgba(255, 255, 255, 0.08); }
  .FNProgressBar .progress-bar {
    width: 100%;
    background-color: #f2b01e;
    height: 44px;
    border-radius: 4px;
    background-image: repeating-linear-gradient(-45deg, #999, #999 15px, #aaa 15px, #aaa 30px);
    -webkit-animation: progress 2s linear infinite;
    -moz-animation: progress 2s linear infinite;
    -ms-animation: progress 2s linear infinite;
    animation: progress 2s linear infinite;
    background-size: 162% 100%; }

@-webkit-keyframes progress {
  0% {
    background-position: 0 0; }
  100% {
    background-position: 42px 0; } }

@-moz-keyframes progress {
  0% {
    background-position: 0 0; }
  100% {
    background-position: 42px 0; } }

@-ms-keyframes progress {
  0% {
    background-position: 0 0; }
  100% {
    background-position: 42px 0; } }

@keyframes progress {
  0% {
    background-position: 0 0; }
  100% {
    background-position: 42px 0; } }
    
.sign-in-ok-btn {
  padding-top: 10px;
  text-align: center;
}
.sign-in-ok-btn .btn {
  align-items: center;
  background-color: transparent;
  border: none;
  border-radius: 100px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.15);
  cursor: pointer;
  display: -ms-inline-flexbox;
  font-family: "font-medium", "Omnes-ATT-W02-Medium";
  font-size: 1.9rem;
  height: 46px;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 450px;
  min-width: 90px;
  position: relative;
  text-align: center;
  vertical-align: middle;
  overflow: hidden;
  white-space: nowrap;
  color: #ffffff;
  background: #078cc5;
  border-color: #078cc5;
  background: linear-gradient(to bottom, #078cc5 0, #0574ac 50%, #0574ac 100%);
  width: 0px;
}
@media only screen and (max-width: 700px) {
	.sign-in-ok-btn .btn {
	      width:100%
	}
}
    