html {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    background-color: #383838;
    font-size: 14px;
    color: white;
    -webkit-font-smoothing: antialiased;
    overflow: hidden;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

div.app-body {
    display: none;
    height: 100%;
    width: 100%;
}

a, button, div, h1, h2, h3, input, span, p {
    font-family: 'Segoe UI', 'Lucida Grande', 'Ubuntu', 'Arial', sans-serif;
}

.page-wrapper {
    position: relative;
    height: 100%;
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    flex-direction: column;
}

header.logo-header {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    padding-left: 10px;
    padding-top: 10px;
    padding-right: 10px;
}

header.logo-header #logo-srg {
    height: 28px;
}

header.logo-header #logo-dimetis {
    width: 85px;
    height: 50px;
}

section {
    margin-top: 10px;
    margin-bottom: 10px;
}

footer {
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 10px;
}

footer .logos {
    height: 21px;
}

footer .logos > a {
    display: block;
    float: left;
    height: 21px;
}

footer .logos > a+a {
    margin-left: 12px;
}

footer .imprint-box {
    margin-right: 12px;
    line-height: 21px;
}

.login {
    display: block;
    padding: 20px;
}

.logo-container {
    max-width: 440px;
}

@media screen and (min-width: 520px) {
    .login {
        border: 1px solid rgba(0, 0, 0, 0.188);
        border-radius: 5px;
        background-color: rgba(0, 0, 0, 0.129);
        box-shadow: 1px 1px 6px 0px rgba(0, 0, 0, 0.6);
        width: 500px;
    }

    .logo-container {
        max-width: 460px;
    }
}

@media screen and (min-height: 730px),
       screen and (min-width: 860px) {
    header.logo-header {
        position: absolute;
        left: 0;
        top: 0;
        right: 0;

        padding-left: 20px;
        padding-top: 20px;
        padding-right: 20px;
    }

    header.logo-header #logo-srg {
        height: 60px;
    }

    header.logo-header #logo-dimetis {
        width: 170px;
        height: 100px;
    }

    section {
        margin: none;
    }

    footer {
        position: absolute;
        left: 0;
        bottom: 0;
        right: 0;

        padding-left: 20px;
        padding-bottom: 20px;
        padding-right: 20px;
    }

    footer .imprint-box {
        text-align: center;
        position: absolute;
        left: 50%;
        bottom: 20px;
        margin: -150px 0 0 -150px;
        width: 300px;
    }
}

section.login-form-wrapper,
.content {
    position: relative;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 10px;
}

body.default,
body.ard {
    background-image: url('../assets/background.jpg');

    @supports (background-image: url('../assets/background.webp')) {
        background-image: url('../assets/background.webp');
    }

    background-repeat: no-repeat;
    background-size: cover;
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
}

.link {
  cursor: pointer;
    color: #FFF;
    text-decoration: none;
}

.link:hover {
    text-decoration: underline;
}

.btn {
  height: 41px;
    position: relative;
    display: inline-block;
    padding: 4px 10px 4px;
    margin-bottom: 0;
    font-size: 15px;
    font-weight: 600;
    color: #333333;
    line-height: 18px;
    text-align: center;
    vertical-align: middle;
    background-color: #fafafa;
    cursor: pointer;
    -webkit-transition: background-color .5s ease;
    -moz-transition: background-color .5s ease;
    -o-transition: background-color .5s ease;
    -ms-transition: background-color .5s ease;
    transition: background-color .5s ease;
}

.btn-large {
    padding: 9px 14px;
    font-size: 15px;
    line-height: normal;
}

#cancel.btn {
    background-color: #754747;
}

.btn-primary {
    background-color: #E3000F;
    border: 1px solid rgba(0, 0, 0, 0.3);
    border-radius: 4px;
}

.btn-primary.enabled {
    background-color: #E3000F;
}

.btn-primary,
.btn-primary:hover {
    color: #ffffff;
}

.btn-primary.active {
    color: rgba(255, 255, 255, 0.75);
}

.btn-block {
    width: 100%;
    display: block;
}

.btn-group {
    display: flex;
    overflow: visible;
    gap: 5px;
}

.btn-group .btn {
    width: 50%;
}

.btn.success {
    border-color: #2b893c;
    background-color: #2b893c;
}

.btn[disabled] {
    background-image: none;
    filter: none;
    background-color: #87575a;
}

.btn[disabled]:hover {
    background-image: none;
    filter: none;
}

.btn[disabled] .spinner {
    display: block;
}

.login h2 {
    color: #fff;
    letter-spacing: 1px;
}

.spinner {
    position: absolute;
    top: 7px;
    left: 5px;
    height: 25px;
}

.spinner:not(.auto) {
    display: none;
}

.method-selection-list {
    margin-bottom: 5px;
}

.method-selection-list > span {
    border: 1px solid black;
    border-radius: 4px;
    display: block;
    padding: 10px;
    background-color: rgba(0, 0, 0, 0.15);
    box-shadow: 0px 0px 3px 0px #0000006b;
    cursor: pointer;
}

.method-selection-list > span:hover {
    box-shadow: 3px 3px 3px 0px #0000006b;
    background-color: #33768f;
}

.method-selection-list > span:not(:last-child) {
    margin-bottom: 5px;
}

.k-dropdown-wrap .k-input {
    padding: 0;
    line-height: 20px;
}

.k-input {
    line-height: 20px;
    padding: 10px;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(0, 0, 0, 0.3);
}

.k-input[type="text"],
.k-input[type="password"] {
    width: 100%;
    margin-bottom: 10px;
    font-size: 13px;
    height: 41px;
    color: #FFF;
}

.k-input[type="text"]::placeholder,
.k-input[type="password"]::placeholder {
    color: #AAA;
}

.k-input[type="text"]:focus,
.k-input[type="password"]:focus,
.k-input[type="checkbox"]:focus,
.btn:focus {
    outline: 1px solid #6060b5;
}

.k-rounded-md {
    border-radius: 4px;
}

.k-checkbox {
    display: inline-block;
    height: 17px;
    width: 17px;
    margin: 0;
    padding: 0;
    outline: 0;
    line-height: initial;
    border-width: 1px;
    border-style: solid;
    border-color: rgba(0, 0, 0, 0.3);
    background-color: rgba(0, 0, 0, 0.3);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    flex: none;
    position: relative;
    cursor: pointer;
    vertical-align: middle;
    -webkit-appearance: none;
}

.k-checkbox:checked,.k-checkbox.k-checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='var%28--kendo-color-on-primary, white%29' stroke-linecap='square' stroke-linejoin='square' stroke-width='2' d='M3,8 l3,3 l7-7'/%3e%3c/svg%3e")
}

.k-checkbox:indeterminate,.k-checkbox.k-indeterminate {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23464646' stroke-linecap='square' stroke-linejoin='square' stroke-width='2' d='M4,8 h8'/%3e%3c/svg%3e")
}

.k-checkbox:focus {
  outline: 1px solid #6060b5;
}

.k-checkbox-label {
  color: #FFF;
}

.k-checkbox+.k-checkbox-label {
    display: inline-block;
    position: relative;
    padding-left: 6px;
    cursor: pointer;
    border-style: solid;
    border-width: 0
}

.k-progressbar {
  border-color: #282828;
  color: #E3E3E3;
  background-color: #282828;
  --kendo-progressbar-value: 0;
  border-width: 0px;
  border-style: solid;
  box-sizing: border-box;
  outline: 0;
  line-height: 1;
  display: inline-grid;
  vertical-align: middle;
  position: relative;
  overflow: hidden;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}

.k-progressbar-horizontal {
  width: 100%;
  height: 24px;
  grid-template-columns: 1fr;
  grid-template-rows: 100%;
}

.k-progressbar-horizontal .k-progress-status-wrap {
  flex-direction: row;
}

.k-progress-status-wrap.k-progress-end {
  justify-content: flex-end;
  padding-left: 5px;
  padding-right: 5px;
}

.k-progress-status-wrap {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  grid-column: 1/-1;
  grid-row: 1/-1;
}

.k-progressbar *, .k-progressbar *::before, .k-progressbar *::after {
  box-sizing: border-box;
}

.k-progressbar .k-selected {
  border-color: var(--kendo-color-primary-active, #5297dc);
  color: var(--kendo-color-on-primary, white);
  background-color: var(--kendo-color-primary, #0066cc);
}

.k-progressbar-horizontal > .k-progressbar-value {
  width: calc(var(--kendo-progressbar-value, 0)*1%);
  flex-direction: row;
}

.k-progressbar > .k-progressbar-value {
  border-width: 0;
  border-style: solid;
  display: flex;
  overflow: hidden;
  grid-column: 1/-1;
  grid-row: 1/-1;
}

.k-progressbar *, .k-progressbar ::before, .k-progressbar ::after {
  box-sizing: border-box;
}

.overlay {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.7);
    display:none;
}

.overlay:target {
    visibility: visible;
    opacity: 1;
}

.remember-me-container {
    display: flex;
    position: relative;
    width: 100%;
    height: 31px;
    line-height: 31px;
    text-align: left;
    margin-bottom: 10px;
    align-items: center;
}

.popup {
    margin: 300px auto;
    padding: 20px;
    background: #545454;
    width: 30%;
    border-width: 1px;
    border-style: solid;
    border-color: #888;
    position: relative;
}

.popup h2 {
    margin-top: 0;
    margin-left:15px;
    color: #FFF;
}

.popup .close {
    position: absolute;
    top: 0px;
    right: 15px;
    font-size: 30px;
    font-weight: bold;
    text-decoration: none;
    color: #FFF;
    margin-top: 0px;
}

.popup .content {
    max-height: 90%;
    overflow: auto;
}

.header  {
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0px;
    height: 35px;
    background: #1A1A1A;
    padding: 5px;
}

ul, li {
    margin:0;
    padding:0;
    list-style-type:none;
}

#pwd_info {
    text-align:left;
    margin-top:15px;
    padding:15px;
    background: rgba(0, 0, 0, 0.55);
    border: 1px solid #000000;
    border-radius: 4px;
}

#pwd_info h4 {
    margin:0 0 10px 0;
    padding:0;
    font-weight:normal;
}

.invalid {
    padding-left: 15px;
    line-height: 24px;
    color: #be5138;
}

.invalid:before {
    position:absolute;
    margin-left: -15px;
    content: "\f00d";
    font-family: "Font Awesome 5 Free";
    color: #be5138;
    font-variant: normal;
    font-weight: 900;
}

.valid {
    padding-left:15px;
    line-height:24px;
    color:#2b893c;
}

.valid:before {
    position:absolute;
    margin-left: -15px;
    content: "\f00c";
    font-family: "Font Awesome 5 Free";
    color: #2b893c;
    font-variant: normal;
    font-weight: 900;
}

.realperson-challenge {
    color: white;
}

.login-divider {
  display: flex;
  align-items: center;
  text-align: center;
  height: 30px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.login-divider::before,
.login-divider::after {
  content: '';
  flex: 1;
  border-top: 1px solid #C1C1C1;
}

.login-divider:not(:empty)::before {
  margin-right: .25em;
}

.login-divider:not(:empty)::after {
  margin-left: .25em;
}

.btn.microsoft {
  display: flex;
  height: 41px;
  gap: 12px;
  background-color: #FFFFFF;
  border: 1px solid #8c8c8c;
  align-items: center;
  justify-content: center;
  font-family: 'Segoe UI', 'Lucida Grande', 'Ubuntu', 'Arial', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: #5e5e5e;
  text-decoration: none;
}

.btn.microsoft span {
  display: inline-block;
  line-height: 19px;
  height: 19px;
}

.k-fx-end .k-fx-next,
.k-fx-end .k-fx-current {
    -webkit-transition: all 500ms ease-out;
    -moz-transition: all 500ms ease-out;
    -ms-transition: all 500ms ease-out;
    -o-transition: all 500ms ease-out;
    transition: all 500ms ease-out;
}

/* A custom swap effect. */
/* The initial position of the next element. */
.k-fx-swap.k-fx-start .k-fx-next {
    -webkit-transform: translatex(15%);
    -moz-transform: translatex(15%);
    -ms-transform: translatex(15%);
    transform: translatex(15%);
}

/* The initial position of the current element. */
.k-fx-swap.k-fx-end .k-fx-current {
    opacity: 0;
    -webkit-transform: scale(0.9);
    -moz-transform: scale(0.9);
    transform: scale(0.9);
}
