﻿@font-face {
  font-family: 'radikal-light';
  src: url("../assets/fonts/radikal-light.otf") format("otf"), url("../assets/fonts/radikal-light.ttf") format("truetype");
}
@font-face {
  font-family: 'radikal-medium';
  src: url("../assets/fonts/radikal-medium.otf") format("otf"), url("../assets/fonts/radikal-medium.ttf") format("truetype");
}
html,
body {
  height: 100%;
}
body {
  background: #f7f9fa;
  font-family: 'radikal-light', Arial, Helvetica, sans-serif;
  position: relative;
  display: flex;
  flex-direction: column;
}
.main-container {
  flex: 1 0 auto;
}
a {
  color: #e73539;
}
a:hover {
  color: #B01e22;
  text-decoration: none;
}
strong {
  font-weight: 400;
  font-family: 'radikal-medium', sans-serif;
}
.align-center {
  text-align: center;
  display: block;
}
.panel {
  border: none;
  border-radius: 0;
  max-width: 460px;
  margin: 40px auto 0;
}
.panel .panel-body {
  padding: 0 80px 10px;
}
@media screen and (max-width: 768px) {
  .panel .panel-body {
    padding: 0 20px 20px;
  }
}
.panel .icon {
  width: 100px;
  height: 80px;
  display: block;
  margin: -45px auto 20px;
  background-image: url(../assets/leona_password_illustration.png);
  background-repeat: no-repeat;
  background-position: 0 -80px;
  background-size: cover;
}
.panel .icon.with-eyes-close {
  background-position: 0 1px;
}
@media screen and (max-width: 768px) {
  .panel .icon {
    width: 70px;
    height: 57px;
    background-position: 0 -57px;
  }
  .panel .icon.with-eyes-close {
    background-position: 0 1px;
  }
}
.panel .intro {
  text-align: center;
  font-family: 'radikal-light', sans-serif;
  color: #001e46;
  font-size: 16px;
  line-height: 20px;
  margin-bottom: 20px;
}
.panel .intro-title {
  margin-bottom: 10px;
  display: block;
  font-family: 'radikal-medium', sans-serif;
}
.panel .panel-form {
  padding-top: 20px;
}
.panel .form-group {
  margin-bottom: 25px;
}
.panel .solo-group {
  text-align: center;
  margin-top: 30px;
}
.panel .form-control {
  border: none;
  border-bottom: 1px solid #b2b2b2;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  font-size: 16px;
  color: #303030;
}
.panel .form-control::-webkit-input-placeholder {
  color: #b2b2b2;
}
.panel .form-control:-moz-placeholder {
  color: #b2b2b2;
}
.panel .form-control::-moz-placeholder {
  color: #b2b2b2;
}
.panel .form-control:-ms-input-placeholder {
  color: #b2b2b2;
}
.panel .password-lk {
  margin-top: 5px;
  font-family: 'radikal-medium', sans-serif;
  color: #e73539;
  font-size: 10px;
  line-height: 12px;
}
.panel label {
  font-family: 'radikal-medium', sans-serif;
  font-weight: 400;
}
.alert {
  border: none;
  border-radius: 0;
  max-width: 460px;
  margin: 0 auto;
}
.alert ul {
  padding: 0;
  margin: 5px 0;
}
.alert ul li {
  list-style: none;
  margin: 2px 0;
}
.bottom-panel {
  max-width: 460px;
  margin: 0 auto;
  text-align: center;
  margin: 15px auto;
  font-family: 'radikal-light', sans-serif;
  color: #7d7d7d;
  font-size: 16px;
  line-height: 20px;
}
.password-input-wrapper {
  position: relative;
}
.password-viewer-trigger {
  position: absolute;
  right: 0;
  top: 10px;
  width: 15px;
  height: 15px;
  border: none;
  padding: 0;
  cursor: pointer;
  background-color: #7d7d7d;
  -webkit-mask: url("../assets/icon-password_show.svg") no-repeat 50% 50%;
  mask: url("../assets/icon-password_show") no-repeat 50% 50%;
}
.password-viewer-trigger:focus {
  outline: none;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .password-viewer-trigger {
    background-color: transparent;
    background-image: url("../assets/icon-password_show.svg");
    background-repeat: no-repeat;
  }
}
@supports (-ms-ime-align:auto) {
  .password-viewer-trigger {
    background-color: transparent !important;
    background-image: url("../assets/icon-password_show.svg");
    background-repeat: no-repeat;
    mask-image: none;
  }
}
.password-viewer-trigger.active {
  background-color: #e73539;
  -webkit-mask: url("../assets/icon-password_show.svg") no-repeat 50% 50%;
  mask: url("../assets/icon-password_show") no-repeat 50% 50%;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .password-viewer-trigger.active {
    background-color: transparent;
    background-image: url("../assets/icon-password_show.svg");
    background-repeat: no-repeat;
  }
}
@supports (-ms-ime-align:auto) {
  .password-viewer-trigger.active {
    background-color: transparent !important;
    background-image: url("../assets/icon-password_show.svg");
    background-repeat: no-repeat;
    mask-image: none;
  }
}
.password-viewer-trigger.active.triggered {
  background-color: #e73539;
  -webkit-mask: url("../assets/icon-password_hide.svg") no-repeat 50% 50%;
  mask: url("../assets/icon-password_hide") no-repeat 50% 50%;
  top: 9px;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .password-viewer-trigger.active.triggered {
    background-color: transparent;
    background-image: url("../assets/icon-password_hide.svg");
    background-repeat: no-repeat;
  }
}
@supports (-ms-ime-align:auto) {
  .password-viewer-trigger.active.triggered {
    background-color: transparent !important;
    background-image: url("../assets/icon-password_hide.svg");
    background-repeat: no-repeat;
    mask-image: none;
  }
}
.form-pins {
  display: flex;
  margin: 0 -5px 10px -5px;
  justify-content: space-between;
  align-items: center;
}
.form-pins .form-pin {
  letter-spacing: 0.22em;
  padding: 0 10px;
  text-align: left;
}
.form-pins .form-pin[maxlength="5"] {
  width: 82px;
}
.form-pins .form-pin[maxlength="4"] {
  width: 70px;
}
.form-pins .form-pin[maxlength="2"] {
  width: 45px;
}
.form-pins .form-pin.align-right {
  text-align: right;
}
.punkt {
  margin: 0 5px;
  font-weight: bold;
  font-size: 24px;
  line-height: 1;
  position: relative;
  bottom: 7px;
}
.invalid-field {
  border-bottom: 1px solid #a94442 !important;
}
.invalid-checkbox {
  border: 1px solid #a94442 !important;
}
.checkbox-container {
  display: flex;
  position: relative;
}
.checkbox-container input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
.checkbox-container .fake-checkbox {
  width: 20px;
  height: 20px;
  border: 1px solid #b2b2b2;
  margin-right: 10px;
  flex-shrink: 0;
}
.checkbox-container input:checked ~ .fake-checkbox:after {
  content: "";
  background-image: url(../assets/checked.svg);
  background-repeat: no-repeat;
  width: 14px;
  height: 14px;
  position: absolute;
  left: 3px;
  top: 2px;
}
.checkbox-container span {
  font-family: 'radikal-light', sans-serif;
}
.btn {
  color: #ffffff;
  font-family: 'radikal-medium', Arial, Helvetica, sans-serif;
  font-size: 14px;
  line-height: 17px;
  font-weight: 500;
  justify-content: center;
  border-width: 2px;
  border-style: solid;
  border-radius: 0;
  display: flex;
  align-items: center;
  cursor: pointer;
  min-width: 140px;
  padding: 12px;
  margin: auto;
}
.btn.btn-primary {
  color: #e73539;
  background-color: transparent;
  border-color: #e73539;
}
.btn.btn-primary:hover {
  color: #ffffff;
  background-color: #e73539;
  border-color: #e73539;
}
.btn.btn-primary:focus {
  color: #ffffff;
  background-color: #B01e22;
  border-color: #B01e22;
}
.solo-group a.btn {
  display: inline;
}
.page-header {
  border-bottom: none;
  text-align: center;
  margin: 0;
  padding: 0;
}
.page-header h1 {
  margin: 130px 0;
}
.page-header h1 img {
  width: 200px;
}
@media screen and (max-width: 768px) {
  .page-header h1 {
    margin: 30px 0 80px;
  }
  .page-header h1 img {
    width: 150px;
  }
}
footer {
  flex-shrink: 0;
  margin: 30px;
  display: flex;
  justify-content: flex-end;
}
footer ul {
  display: flex;
  padding: 0;
  margin: 0;
  justify-content: flex-end;
}
footer ul li {
  padding: 0;
  margin: 0 20px 0 0;
  list-style: none;
}
footer ul li a {
  font-family: 'radikal-medium', sans-serif;
  color: #001e46;
  font-size: 10px;
  line-height: 12px;
}
@media screen and (max-width: 768px) {
  footer {
    margin: 0 0 15px;
  }
}
/* clientside password strength indicator */
#password-strength-status {
  padding: 5px 10px;
  color: #FFFFFF;
  border-radius: 4px;
  margin-top: 5px;
}
.medium-pass {
  background-color: #ff9800;
  max-width: 350px;
}
.weak-pass {
  background-color: #E73539;
  max-width: 350px;
}
.strong-pass {
  background-color: #4CAF50;
  max-width: 350px;
}
.navbar-brand > .icon-banner {
  position: relative;
  top: -2px;
  display: inline;
}
.logged-out iframe {
  display: none;
  width: 0;
  height: 0;
}
.page-consent .client-logo {
  float: left;
}
.page-consent .client-logo img {
  width: 80px;
  height: 80px;
}
.page-consent .consent-buttons {
  margin-top: 25px;
}
.page-consent .consent-form .consent-scopecheck {
  display: inline-block;
  margin-right: 5px;
}
.page-consent .consent-form .consent-description {
  margin-left: 25px;
}
.page-consent .consent-form .consent-description label {
  font-weight: normal;
}
.page-consent .consent-form .consent-remember {
  padding-left: 16px;
}
.grants .page-header {
  margin-bottom: 10px;
}
.grants .grant {
  margin-top: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid lightgray;
}
.grants .grant img {
  width: 100px;
  height: 100px;
}
.grants .grant .clientname {
  font-size: 140%;
  font-weight: bold;
}
.grants .grant .granttype {
  font-size: 120%;
  font-weight: bold;
}
.grants .grant .created {
  font-size: 120%;
  font-weight: bold;
}
.grants .grant .expires {
  font-size: 120%;
  font-weight: bold;
}
.grants .grant li {
  list-style-type: none;
  display: inline;
}
.grants .grant li:after {
  content: ', ';
}
.grants .grant li:last-child:after {
  content: '';
}
.language-switcher {
  position: absolute;
  right: 30px;
  top: 30px;
}
@media screen and (max-width: 768px) {
  .language-switcher {
    position: static;
    display: flex;
    justify-content: flex-end;
    padding: 15px 15px 0 0;
  }
}
.culture-trigger {
  background-color: transparent;
  border: none;
  font-size: 16px;
  margin-right: 5px;
}
.culture-trigger.selected-culture {
  font-weight: bold;
}