/* Serenity fixes */
@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 300;
    src: url("/javax.faces.resource/fonts/OpenSans-Light.ttf.jsf") format('truetype');
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 400;
    src: url("/javax.faces.resource/fonts/OpenSans-Regular.ttf.jsf") format('truetype');
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 700;
    src: url("/javax.faces.resource/fonts/OpenSans-Bold.ttf.jsf") format('truetype');
    font-display: swap;
}

@font-face {
    font-family: 'Anonymous Pro';
    font-style: normal;
    font-weight: 400;
    src: url("/javax.faces.resource/fonts/AnonymousPro-Regular.ttf.jsf") format('truetype');
    font-display: swap;
}

/* Serenity has this definition fut somehow it works only if it is copied to here. */
body .md-inputfield .md-inputwrapper-focus ~ label,
body .md-inputfield .md-inputwrapper-filled ~ label {
    top: -20px;
    font-size: 12px;
    color: #607D8B;
}

.card h1:first-child {
    margin-top: 6px;
    margin-bottom: 16px;
}

/* Login page */

body {
    font-size: 16px;
}

img {
    width: 100%;
    max-width: 100%;
}

body .form-field > label.ui-outputlabel {
    font-size: 14px;
    margin-bottom: 0;
}

.login-body {
    /*background-image: url("");*/
}

.login-body .login-panel .login-panel-header img {
    width: auto;
}

/* Application */

body .ui-widget-content {
    background: transparent;
}

body .ui-confirm-dialog.ui-widget-content {
    background: #ffffff;
}

.details-column {
    width: 32px;
    text-align: center;
}

.form-vertical .form-field {
    margin: 0 0 10px;
}

.form-vertical.form-2col .form-field {
    width: 45%;
    display: inline-block;
    margin-right: 10px;
}

.form-vertical .form-field > label {
    color: #333;
    display: block;
    margin-bottom: 4px !important;
    font-size: 14px;
}

.form-vertical .form-field.checkbox-field > label {
    display: inline-block;
}

.form-buttons .ui-button {
    margin-right: 10px;
}

.form-buttons .ui-button:last-child {
    margin-right: 0;
}

.form-vertical .form-field > .ui-calendar,
.form-vertical .form-field > .yearweek-input {
    max-width: 140px;
    display: block;
}

.ui-fieldset {
    margin-bottom: 20px;
}

body .ui-fieldset .ui-fieldset-legend {
    padding-top: 0;
    padding-bottom: 0;
}

.card > h1 {
    margin-bottom: 6px;
}

.card > h3 {
    margin: 0 0 10px 0;
}

.card h4 {
    margin: 20px 0 10px 0;
}

.card h4:first-child {
    margin-top: 0;
}

.card h5 {
    margin: 20px 0 10px 0;
    font-size: 15px;
}

.card h5:first-child {
    margin-top: 0;
}

.hint {
    display: block;
    margin-bottom: 6px;
    font-size: 12px;
    color: #b5b5b5;
}

body .ui-datatable, body .ui-treetable {
    background: transparent;
}

.ui-datatable .ui-column-filter {
    width: 90%;
}

/* ------------------------------ */

body .panel-compact {
    margin-bottom: 6px;
    margin-right: 6px;
}

body .panel-compact > .ui-panel-titlebar {
    background-color: transparent;
    padding-top: 4px;
    padding-bottom: 4px;
}

body .panel-compact > .ui-panel-titlebar > .ui-panel-title {
    color: #607D8B;
    font-weight: bold;
}

body .panel-compact > .ui-panel-content {
    padding-top: 0;
}

.compact-details-row {
    display: flex;
    flex-wrap: wrap;
    margin: 8px 0;
}

.compact-details-row:last-child {
    margin-bottom: 0;
}

.compact-details-row:first-child {
    margin-top: 0;
}

.compact-details-row > div:not(:last-child) {
    margin-right: 20px;
}

.compact-details-row > div > label {
    margin-right: 4px;
    color: #b5b5b5;
}

.compact-details-row-vertical > div {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.compact-details-row.compact-details-row-vertical > div > label {
    margin-right: 0;
}

.audit-head {
    display: flex;
    align-items: center;
}

.audit-head h2 {
    margin: 0 20px 0 0;
    color: #455a64;
}

.layout-wrapper {
    position: relative;
}

.layout-sidebar .user-info {
    color: #9a9a9c;
    margin: 10px 10px 10px 21px;
}

.layout-sidebar .user-info .material-icons {
    font-size: 18px;
    margin-right: 4px;
    display: inline-block;
    position: relative;
    top: 3px;
    height: 20px;
}

/* APPLICATION */

.form-vertical .form-field > .other-person {
    display: flex;
}

.form-vertical .form-field > .other-person input:nth-child(1) {
    width: 30%;
}

.form-vertical .form-field > .other-person input:nth-child(2) {
    margin-left: 10px;
    flex-grow: 1;
}

.form-vertical .form-field > .compliance-input {
    display: flex;
}

.form-vertical .form-field > .compliance-input *:nth-child(1) {
    width: 30%;
    align-self: flex-start;
}

.form-vertical .form-field > .compliance-input *:nth-child(2) {
    margin-left: 50px;
    flex-grow: 1;
}

.claim-nav {
    margin-left: auto; /* pull it to the right edge */
}

.claim-nav .text {
    margin: 0 10px 0 10px;
}

.form-checkbox-info {
    float: right;
    font-size: 90%;
    opacity: 0.8;
}

#form\:claimsTable .ui-datatable-tablewrapper {
    max-height: 700px; /* limit height of the claims table */
}

#operationsTabs\:adjustmentForm .ui-g-6 {
    padding: 0 2em 0 0;
}

#operationsTabs\:adjustmentForm .max-amount {
    font-size: 80%;
    color: #8fb577;
    font-weight: bold;
    float: right;
}

.click-to-edit {
    font-style: italic;
}

* {
    font-family: 'Open Sans', sans-serif !important;
}

.fa {
    font: normal normal normal 16px/1 FontAwesome !important;
}

.fa:hover {
    text-decoration: none !important;
}

body.ls-striped-bg {
    /*background-image: url("/javax.faces.resource/images/background_overlay.png.jsf"), url("/javax.faces.resource/images/background.png.jsf");*/
    /*background-repeat: repeat;*/
    background-color: #f5f5f5;
}

header {
    background-color: #000 !important;
    /*color: #6d6d6c !important;*/
}

.logo-container {
    display: flex;
    align-items: center;
    height: 60px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.logo {
    width: 56px;
    height: 56px;
    background-image: url("/javax.faces.resource/images/logo.png.jsf");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center left;
    margin-left: 20px;
    display: block;
}

@media (min-width: 1000px) {
    .logo-container {
        height: 80px;
    }

    .logo {
        margin-left: 4vw;
        margin-right: 25px;
        /*height: 45px;*/
    }
}

.layout-topbar {
    background-color: #000 !important;
    color: #f6c917 !important;
    height: 60px;
    box-shadow: 0 3px 7px rgba(0, 0, 0, .05);
    position: relative;
    display: flex;
    width: 100%;
}

@media (min-width: 768px) {
    .layout-topbar {
        height: 80px;
    }
}

.layout-topbar .topbar-info-wrapper .menu-item,
.layout-topbar .topbar-info-wrapper .user-info {
    display: table-cell;
    position: relative;
    height: 60px;
    max-width: 180px;
    padding: 24px 15px 0;
    text-align: center;
    vertical-align: middle;
    line-height: 1;
    border-bottom: 3px solid transparent;
    color: #6d6d6c;
    font-size: 14px;
}

@media (min-width: 1000px) {
    .layout-topbar .topbar-info-wrapper .menu-item,
    .layout-topbar .topbar-info-wrapper .user-info {
        color: #b3b3b2;
    }
}

.layout-topbar.is-admin {
    display: flex;
}

.layout-topbar .topbar-info-wrapper {
    display: flex;
}

.layout-topbar .topbar-info-wrapper--right {
    flex-direction: column;
    display: flex;
    text-transform: lowercase;
}

@media (min-width: 1000px) {
    .layout-topbar .topbar-info-wrapper {
        display: unset;
    }

    .layout-topbar .topbar-info-wrapper--right {
        flex-direction: row;
        float: none !important;
        margin-left: auto;
        margin-right: 4vw;
        height: 80px;
        display: flex;
        align-items: center;
    }

    .layout-topbar .topbar-info-wrapper .menu-item:first-child {
        padding-left: 0;
    }

    .layout-topbar .topbar-info-wrapper--right .menu-item:last-child {
        padding-right: 0;
    }
}

.header__logo__container {
    display: flex;
    align-items: center;
    float: left;
    height: 60px
}

@media (min-width: 768px) {
    .header__logo__container {
        display: flex;
        align-items: center;
        float: left;
        height: 80px
    }
}

@media (min-width: 1000px) {
    .layout-topbar .topbar-info-wrapper .menu-item,
    .layout-topbar .topbar-info-wrapper .user-info {
        padding: 0 15px;
        font-size: 14px;
        height: auto;
    }
}

@media (min-width: 1255px) {
    .layout-topbar .topbar-info-wrapper .menu-item,
    .layout-topbar .topbar-info-wrapper .user-info {
        font-size: 14px;
    }

    .layout-topbar .topbar-info-wrapper {
        /*display: flex;*/
    }
}

.layout-topbar .topbar-info-wrapper .menu-item:hover {
    color: #b3b3b2;
}

.layout-topbar .topbar-info-wrapper .menu-item.active {
    color: black;
    border-bottom: 3px solid transparent !important;
}

@media (min-width: 1000px) {
    .layout-topbar .topbar-info-wrapper .menu-item.active {
        color: #fff;
    }

    .layout-topbar .topbar-info-wrapper .menu-item:hover {
        color: #ffffff;
    }
}

.layout-topbar .topbar-info-wrapper {
    flex-shrink: 0;
    float: left;
}

.layout-topbar a {
    color: #666;
    transition: all 0.3s ease-in-out;
}

iframe {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    z-index: 30;
}

.iframe__container {
    display: flex;
    align-items: center;
    min-height: calc(100vh - 80px);
    height: 100%;
    /*padding-bottom: 60px;*/
    position: relative;
}

.login-body .layout-topbar {
    justify-content: center;
    box-shadow: rgba(0, 0, 0, 0.16) 0 3px 6px, rgba(0, 0, 0, 0.23) 0 3px 6px;
}

.login-body .login-panel {
    display: flex;
    justify-content: center;
    min-height: calc(100vh - 60px);
    /*background-image: url("/javax.faces.resource/images/login.jpg.jsf");*/
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right top;
    /*padding-bottom: 80px;*/
    width: 100%;
}

@media (min-width: 768px) {
    .login-body .login-panel {
        min-height: calc(100vh - 80px);
    }
}

.login-body .login-panel .login-panel-content {
    display: flex;
    justify-content: center;
    max-width: 320px;
    margin: 100px 30px 0;
}

/*@media (min-width: 1200px) {*/
/*    .login-body .login-panel .login-panel-content {*/
/*        transform: translateX(-300px);*/
/*    }*/
/*}*/

/*@media (min-width: 1450px) {*/
/*    .login-body .login-panel .login-panel-content {*/
/*        transform: translateX(-450px);*/
/*    }*/
/*}*/

#key {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.loginForm {
    border-radius: 0;
    height: auto;
    /*background-color: rgba(0, 0, 0, 0.25);*/
    width: 320px;
}

.loginForm h2 {
    margin-top: 0;
    margin-bottom: 24px;
    font-weight: 900;
    color: black;
    text-align: center;
    font-size: 23px;
}

@media (min-width: 576px) {
    .loginForm h2 {
        font-size: 46px;
    }
}

.loginForm .ui-inputfield {
    border: 1px solid #98989B;
}

label.loginLabel {
    font-weight: 400 !important;
    font-size: 16px;
    color: black;
}

.ui-button.loginButton {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 20px;
    width: 100%;
    overflow: hidden;
    background: #f6c917;
    color: white;
    font-size: 16px;
    margin-top: 16px;
    transition: all 0.3s ease;
    border: 1px solid #98989B;
    border-radius: 3px;
}

.loginButton .ui-button-text {
    color: black !important;
}

.ui-button.loginButton--mt50 {
    margin-top: 50px;
}

.ui-button.loginButton:hover, .ui-button.loginButton:focus {
    background: #f6c917;
    color: white;
}

button.ui-button.ui-state-disabled:hover, button.ui-button.ui-state-disabled.ui-state-hover {
    background: #f6c917;
    color: white;
}

#linkPanel {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: rgba(0, 0, 0, 0.8);
    opacity: 1;
    visibility: visible;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hintModal {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 75vw;
    background: white;
    padding: 30px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
    z-index: 2000;
    height: auto;
    overflow: auto;
    max-height: 90vh;
    box-sizing: border-box;
}

@media (max-width: 400px) {
    .hintModal {
       max-width: none;
    }

    .hintModal h2 {
        font-size: 24px;
    }

    .hintModal h3 {
        font-size: 18px;
    }

    .hintModal .btn {
        white-space: normal;
    }
}

.loginInput {
    color: #000;
    outline: none !important;
    box-shadow: none;
    font-size: 18px;
    padding: 4px 8px !important;
}

/* HAMBURGER */

.layout-topbar .topbar-info-wrapper.topbar-admin {
    display: flex;
    flex-direction: column;
    position: fixed;
    left: 0;
    top: 60px;
    height: 100%;
    background-color: #fff;
    transition: transform 0.3s ease;
    transform: translateX(-100%);
    width: 250px;
    padding: 0 40px 40px;
    z-index: 31;
    box-shadow: 0 6px 10px rgba(0, 0, 0, 0.22);
    float: left;
}

@media (min-width: 768px) {
    .layout-topbar .topbar-info-wrapper.topbar-admin {
        top: 80px;
    }
}

.layout-topbar .topbar-info-wrapper.topbar-admin.is-active {
    transform: translate(0, 0);
}

.layout-topbar .topbar-info-wrapper.topbar-admin .menu-item {
    /*    margin-right: 0;*/
    /*    padding: 12px 0 12px 0;*/
    /*    border-bottom: 1px solid white !important;*/
    font-size: 15px;
    text-transform: lowercase;
}

.layout-topbar .topbar-info-wrapper .topbar-info-wrapper--right .menu-item {
    font-size: 12px;
    text-transform: unset;
}

@media (min-width: 1000px) and (max-width: 1200px) {
    .layout-topbar .topbar-info-wrapper.topbar-admin .menu-item {
        font-size: 14px;
    }

    .layout-topbar .topbar-info-wrapper .topbar-info-wrapper--right .menu-item {
        font-size: 12px;
        padding: 0 10px;
    }
}

/*.layout-topbar .topbar-info-wrapper.topbar-admin .user-info {*/
/*    padding: 12px 0 12px 0;*/
/*}*/

/*.layout-topbar .topbar-info-wrapper.topbar-admin .menu-item.active {*/
/*    color: #f6c917;*/
/*}*/

.layout-topbar .topbar-info-wrapper.topbar-admin .logoutBtn {
    margin: 12px 0;
    background: #f6c917;
}

#menuToggle {
    position: relative;
    z-index: 2;
    width: 36px;
    height: 36px;
    cursor: pointer;
    display: block;
    float: left;
    margin: 19px 0 5px 15px;
    color: #fff;
}

@media (min-width: 768px) {
    #menuToggle {
        margin: 29px 0 15px 25px;
    }
}

.topbar-info-wrapper.topbar-user {
    font-size: 12px;
    align-items: center;
}

@media (min-width: 1000px) {
    .layout-topbar .topbar-info-wrapper.topbar-admin,
    .layout-topbar .topbar-info-wrapper.topbar-admin.is-active {
        display: flex;
        flex-direction: row;
        position: relative;
        padding: 0;
        transform: none;
        background-color: transparent;
        left: auto;
        top: auto;
        width: auto;
        box-shadow: none;
        align-items: center;
        height: 100%;
        flex-grow: 1;
    }

    /*.layout-topbar .topbar-info-wrapper.topbar-admin .menu-item {*/
    /*margin-right: 44px;*/
    /*padding: 0;*/
    /*border-bottom: 2px solid transparent !important;*/
    /*font-size: 14px;*/
    /*color: white;*/
    /*}*/
    /*.layout-topbar .topbar-info-wrapper.topbar-admin .menu-item:hover {*/
    /*    color: #f6c917;*/
    /*}*/
    /*.layout-topbar .topbar-info-wrapper.topbar-admin .menu-item.active {*/
    /*    border-bottom: 2px solid #f6c917 !important;*/
    /*    color: white;*/
    /*}*/
    .layout-topbar .topbar-info-wrapper.topbar-admin .logoutBtn {
        margin: 0;
    }

    .layout-topbar .topbar-info-wrapper.topbar-user {
        font-size: 14px;
        align-items: center;
        float: right;
    }

    #menuToggle {
        display: none;
    }
}

#menuToggle span {
    display: block;
    width: 29px;
    height: 2px;
    margin-bottom: 5px;
    position: relative;

    background: #ffffff;
    border-radius: 3px;

    z-index: 1;

    transform-origin: 4px 0;

    transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1.0),
    background 0.5s cubic-bezier(0.77, 0.2, 0.05, 1.0),
    opacity 0.55s ease;
}

#menuToggle span:first-child {
    transform-origin: 0 0;
}

#menuToggle span:nth-last-child(2) {
    transform-origin: 0 100%;
}

#menuToggle span:last-child {
    margin-bottom: 0;
}

#menuToggle.is-active > span {
    opacity: 1;
    transform: rotate(45deg) translate(2px, -5px);
    background: #ffffff;
}

#menuToggle.is-active > span:nth-child(2) {
    opacity: 0;
    transform: rotate(0deg) scale(0.2, 0.2);
}

#menuToggle.is-active > span:nth-child(3) {
    transform: rotate(-45deg) translate(0, 2px);
}

/* GROWL */

div.ui-growl {
    padding: 0 0 0 0;
    max-width: 80%;
    min-width: 120px;
    position: fixed;
    left: auto !important;
    right: 5%;
    opacity: .95;
    font-size: 12px;
    text-align: center;
    font-weight: 500;
    z-index: 9999 !important;
}

.btn-logout {
    float: right;
    background-color: #f6c917;
    color: #fff !important;
    margin-top: 10px;
    margin-right: 12px;
    display: flex;
    align-items: center;
    font-size: 17px;
    transition: background-color 0.3s ease-in-out;
    border-radius: 3px;
    padding: 8px 12px 8px 42px;
    background-image: url("/javax.faces.resource/images/icon-logout.svg.jsf");
    background-position: left 10px center;
    background-repeat: no-repeat;
    background-size: 24px 24px;
}

.btn-logout:hover {
    background-color: rgba(246, 201, 23, 0.9);
}

@media (min-width: 768px) {
    .btn-logout {
        background-position: left 20px center;
        padding: 11px 20px 10px 50px;
        margin-top: 19px;
        margin-right: 25px;
    }
}

.btn-logout:hover {
    color: #ffffff;
}

.btn-info {
    background: #f6c917 !important;
    border-radius: 0;
}

.btn-info:hover {
    background: #f6c917 !important;
    border: 1px solid #f6c917 !important;
}

button.ui-button.btn-lg.btn-blue {
    background: #f6c917 !important;
    border: 1px solid #f6c917 !important;
    border-radius: 0;
}

button.ui-button.btn-blue .ui-button-text {
    color: #ffffff !important;
}

button.ui-button.btn-blue:hover {
    background: #f6c917 !important;
    border: 1px solid #f6c917 !important;
}

/* FILEUPLOAD */
div.ui-fileupload {
    box-shadow: none;
}

div.ui-fileupload .ui-fileupload-buttonbar {
    /*border: 1px solid #c8c8c8;*/
    /*background-color: #f4f4f4;*/
    /*color: #333;*/
    /*padding: .571em 1em .571em 1em;*/
    border: none;
    background-color: transparent;
    color: #333;
    padding: .571em 0;
}

div.ui-fileupload .ui-fileupload-buttonbar span.ui-fileupload-choose {
    padding: 4px 12px;
    display: inline-block;
    margin-bottom: 0;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.74857143;
    text-align: center;
    white-space: normal;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    user-select: none;
    border: 1px solid #ddd;
    border-radius: 3px;
    background: #ddd none;
    box-shadow: none;
    text-shadow: none !important;
    transition: background-color .2s;
    overflow: hidden;
}

div.ui-fileupload .ui-fileupload-buttonbar span.ui-fileupload-choose:hover,
div.ui-fileupload .ui-fileupload-buttonbar span.ui-fileupload-choose:hover,
div.ui-fileupload .ui-fileupload-buttonbar span.ui-fileupload-choose:focus {
    background-color: #e7e7e7 !important;
}

div.ui-fileupload .ui-fileupload-buttonbar span.ui-fileupload-choose .ui-button-text {
    color: #444 !important;
}

div.ui-fileupload .ui-fileupload-buttonbar span.ui-icon-plusthick {
    width: auto;
    top: 9px;
    height: 30px;
}

div.ui-fileupload .ui-fileupload-buttonbar span.ui-icon-plusthick::before {
    color: #444 !important;
}

div.ui-fileupload.fileupload-265 .ui-fileupload-buttonbar span.ui-fileupload-choose {
    width: 265px;
}

div.ui-fileupload .ui-fileupload-buttonbar {
    padding-top: 0;
}

.ui-fileupload-content {
    border: 0;
}

.ui-fileupload-row {
    display: flex !important;
    align-items: center;
    flex-wrap: wrap;
}

.ui-fileupload-row .ui-fileupload-preview {
    padding-left: 0;
}

.ui-fileupload-row .ui-fileupload-progress {
    padding: 0 10px;
}

.ui-fileupload-row .ui-fileupload-progress .ui-progressbar {
    top: 0;
    width: 160px;
}

.ui-fileupload-row > div:nth-child(2) {
    flex-shrink: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 160px
}

.ui-fileupload-row > div:nth-child(3) {
    flex-shrink: 0;
}

.ui-fileupload-row > div:nth-child(5) {
    padding-right: 0;
}

.text__content {
    min-height: calc(100vh - 60px);
    background-color: #fff;
}

.text__content__header {
    padding: 15px 0;
    border-bottom: 1px solid #e5e5e5;
    max-width: 800px;
    margin: auto;
    width: 100%;
}

.text__content__title {
    font-weight: 700;
}

.text__content__body {
    max-width: 800px;
    margin: auto auto 100px;
    width: 100%;
    padding: 15px 0;
}

.text__content__body h5 {
    font-weight: 700;
    margin-top: 40px;
    margin-bottom: 10px;
    line-height: 20px;
    font-size: 18px;
}

.text__content__body h6 {
    font-weight: 400;
    margin-top: 5px;
    margin-bottom: 0;
    line-height: 20px;
    font-size: 16px;
}

.text-success {
    color: #f6c917;
}


/* Primefaces Calendar */
.ui-datepicker, .ui-datepicker th, .ui-datepicker .ui-datepicker-header {
    background-color: #f6c917 !important;
    background-image: none !important;
    border: none !important;
}

/* COOKIE ALERT */

.cookiealert {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    margin: 0 !important;
    z-index: 999;
    opacity: 0;
    border-radius: 0;
    transform: translateY(100%);
    transition: all 500ms ease-out;
    color: #666;
    background: #fff;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 15px 20px;
}

.cookiealert.show {
    display: flex !important;
    opacity: 1;
    transform: translateY(0%);
    transition-delay: 1000ms;
}

.cookiealert a {
    text-decoration: underline;
}

.cookiealert .acceptcookies {
    margin: 10px;
    vertical-align: baseline;
    color: white;
    flex-shrink: 0;
}

@media (min-width: 800px) {
    .cookiealert {
        flex-direction: row;
    }

    .cookiealert .acceptcookies {
        margin: 10px 10px 10px 30px;
    }
}

.layout-footer {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 1rem;
    border-top: 1px solid #E6EAEA;
    background-color: #fff;
    text-align: center;
}

.layout-footer .menu-item {
    padding: 12px 0 12px 0;
    border-bottom: 1px solid white !important;
    font-size: 14px;
    margin-right: 25px;
    border-bottom: 2px solid transparent !important;
    color: #202121;
    font-weight: 300;
}

.layout-footer .menu-item:hover {
    opacity: 0.75;
}

h1 {
    font-weight: 300;
}

/*.layout-content {*/
/*    min-height: calc(100vh - 60px);*/
/*}*/

/*@media (min-width: 768px) {*/
/*    .layout-content {*/
/*        min-height: calc(100vh - 80px);*/
/*    }*/
/*}*/

.branding {
    flex-shrink: 0;
    width: 220px;
    background-repeat: no-repeat;
    background-position: center center;
    display: none;
    position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    top: 50%;
    filter: grayscale(1);
    height: 40px;
    background-size: contain;
}

@media (min-width: 768px) {
    .branding {
        height: 45px;
        display: block;
    }
}

.ui-datatable thead th,
.ui-datatable tfoot td {
    text-align: left !important;
}

.ui-button .ui-button-text {
    color: #333;
}

button.btn-primary, .btn-primary {
    background-color: #f6c917 !important;
    border: 1px solid #f6c917 !important;
    font-size: 16px;
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1);
}

body .btn-primary:hover,
body button.ui-button.btn-primary:hover, button.ui-button.btn-primary.ui-state-hover,
body button.ui-button.btn-primary:focus, button.ui-button.btn-primary.ui-state-focus {
    background-color: #e3b80e !important;
    border: 1px solid #e3b80e !important;
}

.btn-primary .ui-button-text {
    color: #ffffff;
}

button.ui-button, button.btn-secondary, .btn-secondary {
    padding: 4px 12px;
    display: inline-block;
    margin-bottom: 0;
    font-size: 14px;
    font-weight: normal;
    line-height: 1.74857143;
    text-align: center;
    white-space: normal;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    user-select: none;
    border: 1px solid #ddd;
    border-radius: 3px;
    background: #ddd none;
    box-shadow: none;
    text-shadow: none !important;
    color: #444;
    transition: background-color .2s;
    overflow: hidden;
}

.btn-secondary:hover {
    background-color: #e7e7e7;
}

.btn, button.ui-button {
    font-size: 16px;
}

.ui-widget .ui-widget {
    font-size: 16px;
}

label {
    font-weight: normal;
}

.ui-inputfield {
    font-size: 16px;
    padding: 6px 8px !important;
}

div.ui-selectonemenu, div.ui-fluid div.ui-selectonemenu, div.ui-selectcheckboxmenu, div.ui-fluid div.ui-selectcheckboxmenu {
    height: 41px;
    background-color: #fff;
}

div.ui-selectonemenu * {
    color: #333;
}

.ui-selectonemenu .ui-selectonemenu-trigger .ui-icon {
    top: 4px !important;
}

.ui-selectonemenu-panel {
    background: white !important;
}

.filter-area {
    background: linear-gradient(180deg, #f6c917 25%, #f6c917 100%);
}

.headline-area {
    /*background-color: #f6c917;*/
}

.headline-area h1,
.filter-area h1 {
    font-weight: bold;
    font-size: 30px;
    word-break: break-all;
}

.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default {
    color: #333;
}

.ui-datatable .ui-widget-header {
    background: transparent;
}

body .ui-datatable tbody > tr > td > a, body .ui-treetable tbody > tr > td > a {
    /*color: #f6c917*/
    color: #000
}

.content-area {
    padding-top: 20px;
}

body .ui-datatable th[role="columnheader"].ui-state-default, body .ui-treetable th[role="columnheader"].ui-state-default {
    border-top: 0;
    border-bottom: 2px solid #333;
    border-left: 1px solid #fff;;
    border-right: 1px solid #fff;;
}

body .ui-datatable tbody > tr.ui-widget-content, body .ui-treetable tbody > tr.ui-widget-content {
    border: 0;
}

.ui-datatable tbody.ui-datatable-data {
    border: 0;
}

body .ui-datatable.collapsed table tbody td {
    padding: 4px 10px;
}

body .ui-datatable table tbody td {
    padding: 16px 10px;
}

body .ui-datatable table tbody td span {
    font-size: 14px;
}


@media (min-width: 1400px) {
    .container {
        width: 1310px;
    }
}

.input-search {
    width: 100%;
    padding-right: 40px !important;
    background-image: url("/javax.faces.resource/images/search.svg.jsf");
    background-repeat: no-repeat;
    background-position: right 8px center;
}

.headline-search {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

body .ui-dialog.ui-widget-content,
body .ui-dialog {
    padding: 0;
    border-radius: 0;
    background: white;
}

body .ui-dialog.ui-widget-content .ui-dialog-titlebar,
body .ui-dialog .ui-dialog-titlebar {
    background-color: #f6c917 !important;
}

body .ui-dialog .ui-dialog-titlebar .ui-dialog-title {
    color: #ffffff !important;
    font-weight: 500;
}

.mailList:not(:empty) {
    margin-top: 16px;
    border-top: 1px solid #f6c917;
    padding: 16px 0;
}

.ui-button-text-icon-left .ui-button-text {
    color: #ffffff;
}

.addUser.ui-button-text-icon-left .ui-button-text {
    color: #333;
}

div.ui-chkbox .ui-chkbox-box {
    cursor: pointer;
    font-size: 14px;
}

div.ui-chkbox span.ui-icon-check {
    position: relative;
    right: 3px;
    bottom: 4px;
}

.ui-icon-add {
    background-position: -16px -128px;
}

.not-started-dot::before {
    content: '';
    height: 16px;
    width: 16px;
    display: inline-block;
    border: 1px solid #000000;
    margin-left: 5px;
    margin-top: 5px;
    border-radius: 3px;
    position: absolute;
}

.open-dot::before {
    content: '';
    position: absolute;
    height: 16px;
    width: 16px;
    display: inline-block;
    background-color: #fc0;
    background-image: url("/javax.faces.resource/images/spinner.svg.jsf");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 16px 16px;
    margin-left: 5px;
    margin-top: 5px;
    border-radius: 3px;
}

.red-dot {
    height: 25px;
    width: 25px;
    display: inline-block;
    background-image: url("/javax.faces.resource/images/icon-red.svg.jsf");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 16px 16px;
}

.green-dot {
    height: 25px;
    width: 25px;
    display: inline-block;
    background-image: url("/javax.faces.resource/images/icon-green.svg.jsf");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 16px 16px;
}

.training-status label {
    padding-left: 28px;
    white-space: nowrap;
}

.ui-datatable thead th, .ui-datatable tbody td, .ui-datatable tfoot td, .ui-datatable tfoot th {
    border-left: 0 !important;
    border-right: 0 !important;
}

@media (max-width: 670px) {
    .training-grid {
        display: flex;
        flex-direction: column;
    }
}

@media (min-width: 40.063em) and (max-width: 670px) {
    .ui-grid-column.ui-md-3 {
        width: 100%;
    }
}

@media (min-width: 671px) and (max-width: 1000px) {
    .ui-grid-column.ui-md-3 {
        width: 50%;
    }
}

@media (min-width: 1001px) and (max-width: 1400px) {
    .ui-grid-column.ui-md-3 {
        width: 33%;
    }
}

@media (min-width: 1401px) {
    .ui-datagrid .ui-datagrid-column.ui-md-3 {
        width: 25%;
    }
}

.card {
    height: 290px;
    width: 290px;
    border-radius: 6px;
    background-color: #fff;
    box-shadow: 0 0.2rem 2.5rem 0 rgba(0, 0, 0, 0.1);
    transition: box-shadow .3s, transform .3s;
    position: relative;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    margin-bottom: 40px;
}

.card:hover {
    box-shadow: 0 0.2rem 4rem 0 rgba(0, 0, 0, 0.15);
    transform: translate3d(0, -1rem, 0);
}

.card .progress__icon {
    width: 32px;
    height: 32px;
    right: -13px;
    top: -13px;
    border-radius: 50%;
    position: absolute;
    z-index: 2;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

.card .progress__icon.not_started {
    display: none;
}

.card .progress__icon.started {
    background-color: #fc0;
    background-image: url("/javax.faces.resource/images/spinner.svg.jsf");
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 2px 1px -1px rgba(0, 0, 0, 0.12);
}

.card .progress__icon.finished {
    background-image: url("/javax.faces.resource/images/icon-green.svg.jsf");
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 2px 1px -1px rgba(0, 0, 0, 0.12);
}

.card .card__image {
    height: 148px;
    width: 100%;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat;
}

.card .card__content {
    height: auto;
    flex: 1 1 auto;
    padding: 0 16px 16px 16px;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.card .card__lastrow {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.card .card__marker {
    color: black;
}

.card .card__highlight {
    width: 40px;
    height: 3px;
    background-color: #f6c917;
    margin-top: 20px;
    margin-bottom: 12px;
    margin-left: 16px;
}

.card .card__title {
    margin-top: 0;
    margin-bottom: 0 !important;
    font-weight: 700;
    color: black;
    font-size: 18px;
    cursor: pointer;
    line-height: 1.3 !important;
}

.card .card__signin {
    background-image: url("/javax.faces.resource/images/icon-arrow-right.svg.jsf");
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 16px;
    right: 16px;
    height: 26px;
    width: 26px;
    align-self: flex-end;
    cursor: pointer;
}

.training__image {
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
}

@media (min-width: 641px) {
    .training__description {
        margin-left: 2vw;
    }
}

.richtlinie__text {
    font-weight: bold;
    padding-left: 16px;
}

.start-button {
    cursor: pointer;
    color: black;
    padding-left: 28px;
    position: relative;
    display: inline-block;
}

.start-button::before {
    content: '';
    position: absolute;
    height: 21px;
    width: 21px;
    background-image: url("/javax.faces.resource/images/play.svg.jsf");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.start-button:hover, .start-button:active, .start-button:focus {
    color: black;
}

.back-button {
    cursor: pointer;
    color: black;
    padding-left: 24px;
    position: relative;
}

.back-button:hover, .back-button:active, .back-button:focus {
    color: black;
}

.back-button::before {
    content: '';
    position: absolute;
    height: 21px;
    width: 21px;
    background-image: url("/javax.faces.resource/images/arrow-back.svg.jsf");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.back-button.admin {
    margin-top: 40px;
    display: inline-block;
    margin-left: -6px;
}

.headline__main {
    margin-top: 83px;
}

body .ui-paginator .ui-paginator-page.ui-state-active {
    background: #ffcc00;
    border-color: #ffcc00;
}

body .ui-paginator .ui-paginator-page, body .ui-paginator .ui-paginator-pages, body .ui-paginator .ui-paginator-current, body .ui-paginator select, body .ui-paginator .ui-paginator-first, body .ui-paginator .ui-paginator-prev, body .ui-paginator .ui-paginator-last, body .ui-paginator .ui-paginator-next {
    background: transparent;
}

.layout-wrapper.is-admin .layout-content {
    margin-bottom: 80px;
}

body .ui-widget a.ui-link {
    color: #000000;
}

@media (max-width: 767px) {
    body .no-mobile {
        display: none !important;
    }
}

@media (min-width: 768px) {
    body .only-mobile {
        display: none !important;
    }
}

.hidden_panel {
    display: none;
    visibility: hidden;
}
