:root {
    --color-primary: #41A36C;

    --color-green: #41A36C;
    --color-green-light: #67B88C;
    --color-yellow: #E8C547;
    --color-yellow-light: #F1D97A;
    --color-red: #D64550;
    --color-red-light: #E26A6F;
    --color-blue: #3A6EA5;
    --color-blue-light: #5B8CC0;
    --color-gray: #C9CBCF;
    --color-gray-light: #E4E5E7;

    --gap-0_5: 0.5rem;
    --gap-1: 1rem;
    --gap-2: 2rem;
}

body, .ui-widget {
    font-family: 'Open Sans', sans-serif !important;
}

body .ui-menu .active .ui-menuitem-text {
    font-weight: 700;
}

body {
    background: #f5fdf5;
    margin: 0 0.5rem;
}

h1 {
    margin-top: 32px;
    font-size: 22px;
}

a:link, a:visited {
    color: var(--color-green);
}

a:hover, a:active {
    color: var(--color-green-light);
}

/* Negative Margins des Grid-Layouts verursachen Scrolling Overflow */
.formgrid-container {
    overflow-x: hidden;
}

.ui-dataview .ui-dataview-content {
    overflow-x: hidden;
    background: transparent !important;
}

.ui-dataview .ui-paginator {
    background: transparent !important;
    border: 0 !important;
}

.ui-datascroller-content {
    border: 0 !important;
    padding: 0 !important;
}

/* Page Layout */
.default-layout-container {
    max-width: 1440px;
    margin: 20px auto;
}

.header, .footer {
    position: fixed;
    z-index: 1000;
    left: 0;
    width: 100%;
    transition: height 0.5s ease;
}

.header {
    top: 0;
    height: 150px;
    background-image: url("/jakarta.faces.resource/images/header-green.png.xhtml");
}

.mobile-menu .ui-tabmenuitem {
    border-bottom: none !important;
}

.content {
    padding: 150px 0 0 0; /* Platz für Header */
    height: 100%;
    overflow-y: auto;
    box-sizing: border-box;
}

@media (max-width: 992px) {
    .header {
        height: 80px;
    }
    .content {
        padding-top: 80px;
    }
}

@media (max-height: 450px) {
    .header {
        height: 48px;
    }
    .content {
        padding-top: 48px;
    }
}

@media (max-width: 992px) {
    .desktop-only {
        display: none !important;
    }
}

@media (min-width: 992px) {
    .mobile-only {
        display: none !important;
    }
}

/* menu */
.menu-container-left {
    padding: 0;
    position: absolute;
    bottom: 0;
    left: 0;
}

.menu-container-center {
    padding: 0;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.menu-container-right {
    padding: 0;
    position: absolute;
    bottom: 0;
    right: 0;
}

.main-menu .ui-menubar {
    background: transparent !important; /* Hintergrund entfernen */
    border: none !important; /* Rand entfernen */
}

/* Main Menu > Menubar */
.main-menu .ui-menuitem-link.ui-state-hover {
    background: rgba(255, 255, 255, 0.2) !important; /* Hintergrund entfernen */
}

.main-menu .ui-menuitem-icon,
.main-menu .ui-menuitem-text,
.main-menu .ui-menuitem-link .ui-icon {
    color: white !important;
}

/* Main Menu > Submenu */
.main-menu .ui-menu-child .ui-menuitem-icon,
.main-menu .ui-menu-child .ui-menuitem-text,
.main-menu .ui-menu-child .ui-menuitem-link .ui-icon {
    color: var(--text-color-secondary) !important;
}

.main-menu .ui-menu-child .ui-menuitem-link:hover {
    background: var(--primary-50) !important;
}

.dropdown-menu.ui-menu {
    width: 16em !important;
}

.sidebar-menu {
    border: 0 !important;
}

.sidebar-submenu-item {
    padding-left: 40px !important;
}

.sidebar-divider {
    margin-top: 2em !important;
    margin-bottom: 1em !important;
}

.sidebar-menu .ui-menuitem-link:hover {
    background: var(--primary-50) !important;
}

.main-menu-title {
    color: white !important;
    font-weight: bold !important;
    margin-bottom: 8px;
    text-align: center;
}


.menu-container-right .ui-button {
    color: white !important;
}

.footer .ui-button {
    color: white !important;
}

/* Wide-box Layout */
.wide-box-content-container {
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
    background-color: #ffffff;
    border-top: 0;
    border-bottom: 0;
    border-left: 1px solid #666;
    border-right: 1px solid #666;
    padding: var(--gap-2) var(--gap-1) 8rem;
    box-sizing: border-box;
}

.wide-box-content {
    padding: 0;
    height: 100%;
    overflow-y: auto;
    box-sizing: border-box;
}

/* Global growl */
.system-exception-message {
    display: inline-block !important;
    padding-top: 10px !important;
    font-size: 12px !important;
}

.section {
    font-size: 16px !important;
    font-weight: bold;
    margin-top: 18px;
    margin-bottom: 10px;
    color: #666;
}

.input-message {
    font-size: 12px !important;
    display: block !important;
    margin-top: 4px;
}

.input-message.help {
    color: #666;
}

.input-message.error {
    color: var(--color-red);
}

/* Messages (e.g. Info) */
.message-bar-container {
    position: relative;
    width: 100%;
    background-color: #d9f0e0; /* Pendant in Gelb: #FFF5D9; */
    border: 1px solid #666;
    border-radius: 16px;
    padding: var(--gap-1);
    box-sizing: border-box;
    margin-bottom: var(--gap-1);
    color: #666;
}

.message-bar-container .message-bar-close-button {
    position: absolute;
    top: var(--gap-0_5);
    right: var(--gap-0_5);
}

.message-bar-container .message-bar-got-it-button {
    text-align: right;
}

.message-bar-container .ui-button {
}

.message-bar-container .ui-icon {
    color: #666;
}

.message-bar-content {
    h1 {
        font-size: 22px;
    }
    ol li {
        padding: 10px 10px 0 10px;
    }
}

/* Input validation errors */
.ui-message-error {
    margin-left: 0 !important;
    border-left-width: 0 !important;
    background-color: transparent !important;
}

.ui-message-error-detail {
    margin-left: 0 !important;
}

/* dataview */
.ui-dataview-header {
    border-width: 0 !important;
    background-color: inherit !important;
    padding: var(--gap-1) 0 var(--gap-1) 0 !important;
}

/* toolbar */
.ui-toolbar {
    border-width: 0 !important;
    background-color: inherit !important;
    padding: var(--gap-1) 0 var(--gap-1) 0 !important;
}

/* card */
.ui-card {
    border: 1px solid #dee2e6; /* grauer Rand */
    box-shadow: none !important;
}

/* list-item */
.clickable-div { /* Klickbares Div mit Hover-Effekt */
    cursor: pointer;
    transition: background-color 0.3s ease-in-out;
}

.clickable-div:hover {
    border-radius: 8px;
    background-color: #f8fbf9; /* picked from primefaces button hover */
}

.clickable-div a { /* Entfernt den Link-Stil */
    text-decoration: none !important;
    color: inherit !important;
    display: block; /* Sorgt dafür, dass der Link den ganzen div-Bereich einnimmt */
    width: 100%;
    height: 100%;
}

.hoverable-div:hover {
    border-radius: 8px;
    background-color: #f8fbf9; /* picked from primefaces button hover */
}

.login-box-container {
    margin: var(--gap-2) var(--gap-1);
    display: flex;
    justify-content: center
}

.login-box {
    width: 100%; /* Für kleine Bildschirme */
    max-width: 400px;
}

.form-container {
    width: 100%; /* Für kleine Bildschirme */
    /*max-width: 800px;*/
}

div.vis-item {
    font-size: 12px;
    height: 24px;
}
div.vis-minor.vis-saturday {
    background: #fffbf4;
}
div.vis-minor.vis-sunday {
    background: #faeeda;
}

/* challenge timeline */

.events-group {
    font-style: italic;
}

div.timeline_event {
    background: var(--color-blue-light) none !important;
    border-color: var(--color-blue) !important;
}
div.timeline_ready {
    background: var(--color-gray-light) none !important;
    border-color: var(--color-gray) !important;
}
div.timeline_open {
    background: var(--color-yellow-light) none !important;
    border-color: var(--color-yellow) !important;
}
div.timeline_completed {
    background: var(--color-green-light) none !important;
    border-color: var(--color-green) !important;
}
div.timeline_partially_completed {
    background: #FFCFA0 none !important;
    border-color: #FFCFA0 !important;
}
div.timeline_failed {
    background: var(--color-red-light) none !important;
    border-color: var(--color-red) !important;
}
div.timeline_rescued_by_joker {
    background: #FFFFFF none !important;
    border-color: var(--color-green) !important;
}
div.timeline_canceled {
    background: #FFFFFF none !important;
    border-color: #FF6384 !important;
}

/* overview */

.taskinstance-canceled .listItemTitle{
    text-decoration: line-through;
}

/* Abstand zwischen Buttons */
.button-group > *:not(:last-child) {
    margin-right: 10px;
}

.listItemTitle {
}

.listItemInfo {
    font-size: 12px;
    color: gray;
}

.icon-edit {
    color: var(--color-primary);
}

/* workaround for https://github.com/primefaces/primefaces/issues/9412 */
html body .ui-chkbox {
    display: inline-flex;
    align-items: center;
    width: auto;
    height: auto;
}

.overview-active-challenges .ui-dataview-header {
    display: none;
}

/* state badge */
span.state-badge {
    display: inline-block;
    text-transform: uppercase;
    font-weight: bold;
    border-radius: 3px;
    padding: 3px 7px;
}

/* challenge-phase */
span.challenge-phase-draft {
    background-color: var(--color-gray-light);
    color: #FFF;
    font-size: 16px;
}

span.challenge-phase-ready {
    background-color: var(--color-gray-light);
    color: #FFF;
    font-size: 16px;
}

span.challenge-phase-active {
    background-color: var(--color-yellow-light);
    color: #FFF;
    font-size: 16px;
}

span.challenge-phase-successful {
    background-color: var(--color-green-light);
    color: #FFF;
    font-size: 16px;
}

span.challenge-phase-failed {
    background-color: var(--color-red);
    color: #FFF;
    font-size: 16px;
}

span.challenge-phase-canceled {
    border: solid 1px var(--color-red);
    background-color: #FFF;
    color: var(--color-red);
    font-size: 16px;
}

/* taskinstance-state */
span.task-instance-state-ready {
    background-color: #C9CBCF;
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-rescued-by-joker {
    background-color: var(--color-green);
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-open {
    background-color: var(--color-yellow);
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-completed {
    background-color: var(--color-green);
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-partially-completed {
    background-color: #FFCFA0;
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-failed {
    background-color: var(--color-red);
    color: #FFF;
    font-size: 16px;
}
span.task-instance-state-cancelled {
    background-color: var(--color-red);
    color: #FFF;
    font-size: 16px;
}

/* ChallengeDraftEdit */

@media (max-width: 1024px) {
    .challengetaskdraft-table .ui-datatable-tablewrapper {
        font-size: 12px;
    }
}

/* Colored Amount View */
.colored-amount-negative {
    color: var(--color-red);
}