.my-alert {
  padding: 15px 15px 15px 1px;
  margin-bottom: 20px;
  border: 1px solid transparent;
  border-radius: 4px;
}

.my-alert-danger {
  color: #A94442;
  background-color: #EFEFEF;
  border-color: #EDEDED;
}

.my-alert-success {
  color: #3c763d;
  background-color: #EFEFEF;
  border-color: #EDEDED;
}


/*  Added 1/06/2021 - loading animation  */
.test-loader {
  border: 16px solid #f3f3f3; /* Light grey */
  border-top: 16px solid #3498db; /* Blue */
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: spin 2s linear infinite;
}

.loader-spin {
    border: 8px solid #f3f3f3;
    border-top: 8px solid #3498db;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    animation: spin 1s linear infinite;
    /*  This fixes the fixed-width block element.  */
    margin: 0 auto;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* ============================================
   CSP-Compliant Inline Style Replacements
   ============================================ */

/* Body backgrounds */
.body-bg-blue {
  background-color: #093670;
}

.body-bg-auth0-blue {
  background-color: RGB(9,54,112);
}

/* Text alignment */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.td-center {
    text-align: center;
}

.td-left {
    text-align: left;
}

.td-right {
    text-align: right;
}

/* Container and layout classes */
.full-width-container {
  width: 100%;
  align-items: center;
}

.main-container {
  margin: 0 auto;
  display: table;
}

.main-table {
  text-align: left;
  border: 0;
  padding: 0;
  width: 100%;
  font-family: Verdana, Arial;
  font-size: 12px;
}

.inner-table-480 {
  padding: 0;
  width: 480px;
}

.inner-table-640 {
  padding: 0;
  width: 640px;
}

.inner-table-320 {
  padding: 0;
  width: 320px;
}

.inner-table-320-tall {
  padding: 0;
  width: 320px;
  height: 480px;
}

.section-wrapper {
    width: 100%;
}

.section-wrapper-full {
  width: 100%;
  height: 100%;
}

.section-wrapper-bg {
  width: 100%;
  padding: 0;
  background-color: #ffffff;
}

/* Card/panel with white background and rounded corners */
.white-panel-rounded {
  background-color: white;
  border-radius: 10px;
}

/* Logo area */
.logo-cell {
  padding: 0;
  height: 60px;
}

/* Padding classes */
.padding-cell-standard {
  padding: 15px 15px 15px 15px;
  min-height: 100px;
}

.padding-cell-small {
  padding: 10px 13px 10px 13px;
}

.padding-cell-form {
  padding: 5px 5px 5px 5px;
  width: 100%;
}

.padding-cell-section {
  padding: 15px 15px 15px 15px;
  min-height: 50px;
  height: 50px;
}

.padding-cell-header {
  padding: 20px 10px 20px;
}

.padding-cell-button {
  padding: 20px 13px 20px 13px;
}

.padding-cell-link {
  height: 40px;
  padding-right: 20px;
}

.padding-cell-footer {
  padding-top: 20px;
  padding-bottom: 20px;
}

.padding-cell-hidden {
  padding-top: 20px;
  padding-bottom: 20px;
  min-height: 10px;
}

.padding-cell-site-label {
  padding: 5px 20px 5px 20px;
  min-height: 30px;
}

.padding-cell-input {
  padding: 2px 2px 2px 10px;
}

.padding-cell-auth0 {
  padding: 0 24px 2px 24px;
  width: 100%;
}

.padding-cell-error {
  padding: 2px 40px 2px 40px;
  min-height: 40px;
}

/* Table styling */
.table-centered-full {
  text-align: center;
  border-collapse: collapse;
  width: 100%;
}

.table-full-width {
  width: 100%;
}

/* Headings */
.form-heading {
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  color: #555555;
}

.form-text-gray {
  margin: 0;
  font-size: 14px;
  font-weight: 400;
  color: #555555;
}

/* Noscript warning */
.noscript-warning {
  text-align: center;
}

/* Hidden divs for loading spinners */
.div-submitting-hidden {
  visibility: hidden;
  height: 0;
  padding-top: 10px;
  padding-bottom: 10px;
}

.div-submitting-hidden-small {
  visibility: hidden;
  height: 0;
  padding-top: 10px;
  padding-bottom: 5px;
}

/* Hidden content area */
.hidden-area {
  display: none;
  width: 0;
  height: 0;
  border-color: transparent;
  border-style: none;
  background-color: transparent;
}

/* Auth0 two-factor page styles */
.auth0-center-panel {
  background-color: white;
  width: 400px;
  height: 550px;
  min-height: 550px;
}

.auth0-table {
  text-align: center;
  width: 100%;
  height: 100%;
}

.auth0-header {
  height: 160px;
}

.auth0-header-cell {
  padding-top: 35px;
}

.auth0-message-row {
  height: 80px;
}

.auth0-message-cell {
  padding-top: 20px;
}

.auth0-input-row {
  height: 120px;
  text-align: center;
}

.auth0-button-row {
  height: 80px;
}

.auth0-error-row {
  height: 100px;
}

/* Width classes for table cells */
.w-33 {
  width: 33%;
}

.w-34 {
  width: 34%;
}

.w-100 {
  width: 100%;
}

.padding-zero {
  padding: 0;
}

.padding-cell-footer-large {
  padding-top: 20px;
  padding-bottom: 50px;
}

.cta-table-fixed {
  height: 45px;
  margin: 0 auto;
  table-layout: fixed;
  width: 280px;
  border-style: none;
}

/* Confirmation/status pages */
.section-wrapper-bordered {
  width: 100%;
  padding: 0;
  border-collapse: collapse;
  background-color: #fff;
  border: solid 1px #ededed;
}

.success-message {
  margin: 0;
  font-size: 18px;
  font-weight: 400;
  color: green;
}

.error-message-large {
  margin: 0;
  font-size: 18px;
  font-weight: 400;
  color: red;
}

.button-area-cell {
  padding-top: 20px;
  padding-bottom: 40px;
  border-bottom: 1px solid #ededed;
}

.footer-table {
  border-collapse: collapse;
  border-top: dotted 1px #e1e1e1;
  color: #a5a5a5;
  width: 100%;
  border-style: none;
}

.footer-text {
  font-weight: 300;
}

/* Additional classes for confirmation pages */
.inner-table-40p {
  padding: 0;
  width: 40%;
  min-width: 320px;
}

.padding-cell-success {
  padding: 40px 10px 10px 10px;
}

.success-text-medium {
  font-size: 16px;
  font-weight: 400;
}

.padding-cell-button-large {
  padding-top: 20px;
  padding-bottom: 40px;
}

.button-wrapper {
  padding: 15px 15px 15px 15px;
}

/* Centering classes for Default.aspx */
.center-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  width: 100%;
}

.centered-panel {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.main-content-wrapper {
  display: table;
  width: 100%;
  height: 100vh;
  table-layout: fixed;
}

.main-content-cell {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}

.login-panel {
  margin: 0 auto;
  text-align: center;
}

.form-container {
  display: inline-block;
  text-align: center;
}

/* column numbers for table cells */


/* bold font for labels */
.label-bold {
    font-weight: bold;
}

/* margin top for spacing */
.top-margin-10 {
    margin-top: 10vh;
}

/* CSP-compliant validator message classes (replaces inline styles from asp:RequiredFieldValidator) */
.validator-msg-hidden {
    display: none;
}

.validator-msg-visible {
    display: block;
}
