/*
// Add your own theme-colors.
$theme-colors: (
    "primary": $primary,
    "secondary": $secondary,
    "light": $white-smoke-light
    //"highlight": $white,
);

$theme-colors: map-remove($theme-colors, "dark", "light");
*/
.container-xxl {
  max-width: 1590px;
  padding-right: 15px;
  padding-left: 15px;
  margin-left: auto;
  margin-right: auto;
}

/* new standard base font size */
/**
 * Helper function for downsize mixin.
 */
/**
 * Downsize a CSS property using the viewport to affect calc().
 *
 * @param {string} $property: The property to be affected.
 * @param {string|list} $min: The min value / values.
 * @param {string|list} $max: The max value / values.
 * @param {string} $viewport: The biggest viewport, which the property must be calculated. NOTE: we use media-breakpoint-down here!
 * @param {boolean} $default: True if the default property must be set, regardless of the viewport size.
 * @param {list} $min-limit: A list containing the min viewport and the min value.
 */
#footer {
  position: relative;
  z-index: 10;
}

.self-test {
  background-color: #fff;
  color: #133E8F;
  padding-bottom: 100px;
  position: relative;
  width: 100%;
  overflow-x: hidden;
}
.self-test a.big-link,
.self-test .big-link {
  color: #20B9D6;
  font-size: 20px;
  text-decoration: none;
  font-weight: 500;
  display: inline-block;
  text-align: center;
}
.self-test .container {
  background-color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 24px;
  width: 100%;
}
.self-test .container.container-start .headline {
  margin-top: 80px;
}
.self-test .container.container-start .content {
  margin-top: 16px;
}
.self-test .container.container-start .btn {
  margin-top: 48px;
}
.self-test .container .headline {
  color: #133E8F;
  font-size: 42px;
  line-height: 1;
  text-align: center;
  font-weight: 600;
}
.self-test .container .content {
  font-family: "Pangea", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #133E8F;
  font-size: 16px;
}
.self-test .container.container-result {
  justify-content: space-between;
}
.self-test .container.container-result .percent {
  font-size: 50px;
  color: #133E8F;
  min-height: 140px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  font-weight: 600;
}
.self-test .container.container-result .percent #arc {
  width: 200px;
}
.self-test .container.container-result .percent #result {
  position: absolute;
  text-align: center;
  margin-top: 24px;
}
.self-test .container.container-result .content {
  text-align: center;
  font-size: 18px;
  margin: 16px 0;
}
.self-test .container.container-result .btn {
  margin: 16px 0;
  min-width: 0;
}
.self-test .container.container-result .big-link {
  margin-bottom: 64px;
}
.self-test .container .btn {
  color: #fff;
  font-family: "Pangea", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-size: 20px;
  text-align: center;
  background-color: #20B9D6;
  padding: 20px 10px;
  min-width: 300px;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  white-space: initial;
}
.self-test .container .continue-wrapper {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 40px;
}
.self-test .container .prev-question {
  display: inline-block;
  text-align: center;
}
.self-test .container .btn-confirm {
  background-color: #133e8f;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 200px;
  padding: 10px;
  font-size: 14px;
  transition: bottom 200ms ease-in-out !important;
}
.self-test .container .btn-confirm[data-disabled=true] {
  cursor: default;
  background-color: #6f89ba;
}
@media screen and (max-width: 991.98px) {
  .self-test .container .btn-confirm.btn-sticky:not(.force-static) {
    position: fixed;
    bottom: 60px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
  }
  .self-test .container .btn-confirm.btn-sticky:not(.force-static)[data-disabled=true] {
    bottom: 0;
  }
}
.self-test .container .self-test-progress {
  width: 100%;
  margin-top: 16px;
}
.self-test .container .self-test-progress .self-test-progress-label {
  color: #6F6F6E;
  font-size: 11px;
}
.self-test .container .self-test-progress .self-test-progress-bar {
  position: relative;
  background-color: #D8D8D8;
  border-radius: 4px;
  width: 100%;
  height: 4px;
  margin: 8px 0;
}
.self-test .container .self-test-progress .self-test-progress-bar .self-test-progress-percent {
  position: absolute;
  content: " ";
  background-color: #133E8F;
  border-radius: 4px;
  width: 10%;
  height: 4px;
}
.self-test .container .question {
  text-align: center;
  display: flex;
  flex-direction: column;
  flex: 1;
  position: relative;
  width: 100%;
  font-weight: 600;
}
.self-test .container .question .question-label {
  color: #3F3F3D;
  font-size: 16px;
  font-family: "Pangea", "Helvetica Neue", Helvetica, Arial, sans-serif;
  margin-top: 40px;
}
.self-test .container .question .question-content {
  color: #133E8F;
  font-size: 20px;
  padding-top: 32px;
  min-height: 120px;
}
.self-test .container .question .question-answer {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  font-family: "Pangea", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  width: 100%;
  margin-bottom: 32px;
}
.self-test .container .question.question-result .question-answer {
  padding: 64px 0;
  justify-content: center;
  position: relative;
  bottom: 0;
}
.self-test .container .footer {
  height: 20px;
  color: #6F6F6E;
}
.self-test .container .footer a {
  color: #6F6F6E;
  font-size: 13px;
}

@media (min-width: 992px) {
  .self-test .container {
    position: relative;
  }
  .self-test .container .headline {
    font-size: 60px;
  }
  .self-test .container .content {
    text-align: center;
    font-size: 20px;
    max-width: 770px;
  }
  .self-test .container .self-test-progress {
    max-width: 335px;
    margin-top: 32px;
    margin-bottom: 16px;
  }
  .self-test .container .question {
    max-width: 770px;
    justify-content: space-evenly;
  }
  .self-test .container .question .question-label {
    font-size: 16px;
  }
  .self-test .container .question .question-content {
    font-size: 30px;
    padding-bottom: 0;
  }
  .self-test .container .footer {
    margin-top: 32px;
  }
  .self-test .container.container-start .content {
    margin-top: 48px;
  }
  .self-test .container.container-start .btn {
    margin-top: 80px;
  }
  .self-test .container.container-result .content {
    font-size: 20px;
  }
  .self-test .container.container-result .btn {
    padding: 24px 36px;
  }
  .self-test .container.container-result .big-link {
    margin-top: 16px;
    margin-bottom: 80px;
  }
}
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .self-test .container.container-result .percent #result {
    left: 0;
    right: 0;
    bottom: 0;
  }
  .self-test .container .question.question-result {
    padding-bottom: 16px;
  }
  .self-test .container .footer {
    margin-top: 450px;
  }
}
@supports (-moz-appearance: none) {
  .self-test .container.container-result .percent #result {
    margin-top: 40px;
  }
  .self-test :focus {
    outline: none;
  }
  .self-test ::-moz-focus-inner {
    border: 0;
  }
}
.self-test .answer-btn {
  position: relative;
  min-height: 68px;
  width: 100%;
  padding: 16px;
  padding-left: 48px;
  display: flex;
  align-items: center;
  margin: 8px 0;
  max-width: 335px;
}
.self-test .answer-btn .answer-btn-background {
  cursor: pointer;
  border-radius: 4px;
}
.self-test .answer-btn .answer-btn-hide {
  box-sizing: border-box;
  padding: 0;
  position: absolute;
  left: 0;
  z-index: -1;
  width: 16px;
  height: 20px;
  opacity: 0;
  overflow: visible;
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
.self-test .answer-btn .answer-btn-label {
  position: relative;
  margin-bottom: 0;
  vertical-align: top;
  color: #133E8F;
  line-height: 1.2;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 100%;
  font-size: 20px;
  text-align: left;
  pointer-events: none;
}
.self-test .answer-btn .answer-btn-label::before {
  content: "";
  display: block;
  position: absolute;
  box-sizing: border-box;
  left: -30.4px;
  width: 20px;
  height: 20px;
  pointer-events: none;
  background-color: #fff;
  border: #C6C6C6 solid 2px;
}
.self-test .answer-btn .answer-btn-label::after {
  content: "";
  display: block;
  position: absolute;
  box-sizing: border-box;
  left: -30.4px;
  width: 20px;
  height: 20px;
  background: no-repeat 50%/50% 50%;
}
.self-test .answer-btn .answer-btn-background:hover ~ .answer-btn-label,
.self-test .answer-btn .answer-btn-hide:hover ~ .answer-btn-label,
.self-test .answer-btn .answer-btn-hide:checked ~ .answer-btn-label {
  color: #fff;
}
.self-test .answer-btn .answer-btn-background:hover ~ .answer-btn-label::before,
.self-test .answer-btn .answer-btn-hide:hover ~ .answer-btn-label::before,
.self-test .answer-btn .answer-btn-hide:checked ~ .answer-btn-label::before {
  color: #fff;
  border-color: #fff;
  background-color: #20B9D6;
  transition: background ease 0.5s;
}
.self-test .answer-btn .answer-btn-hide:checked ~ .answer-btn-label::after {
  background-image: url("../icons-svg/checkbox-tick.svg");
}
.self-test .answer-btn .answer-btn-background {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #EFEFEF;
}
.self-test .answer-btn .answer-btn-background:hover,
.self-test .answer-btn .answer-btn-hide:hover ~ .answer-btn-background,
.self-test .answer-btn .answer-btn-hide:checked ~ .answer-btn-background {
  background: #20B9D6;
  transition: background ease 0.5s;
}
.self-test .answer-btn .answer-btn-hide[type=radio] ~ .answer-btn-label::before {
  border-radius: 100%;
}
.self-test .answer-btn .answer-btn-hide[type=radio]:checked ~ .answer-btn-label::after {
  background-image: url("../icons-svg/radio-circle.svg");
}

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .self-test .answer-btn .answer-btn-label::before {
    top: 9.6px;
  }
  .self-test .answer-btn .answer-btn-label::after {
    top: 9.6px;
  }
}
