:root {
    --HeaderColor: #ffffff;
    --HeaderBgColor: #558DF5;
    --HeaderColorMobile: #ffffff;
    --HeaderBgColorMobile: #558DF5;
    --HeaderHeight: 60px;
    --HeaderHeightMobile: 60px;
    --ContentBorderTop: 20px;
    --ContentBorderTopMobile: 15px;
    --ContentBorderHor: 20px;
    --ContentBorderHorMobile: 10px;
    --MobileMenuButtonWidth: 50px;
    --DesktopLimitedWorkspaceWidth: 1080px;
    --NavigationBgColor: #ffffff;
    --NavigationWidth: 300px;
    --NavigationWidthMobile: 85vw;
    --NavigationGroupHeightDefault: 40px;
    --NavigationGroupHeightMobile: 45px;
    --NavigationGroupColor: #8e8e93;
    --NavigationGroupBgColor: #efeff4;
    --NavigationGroupBgColorLevel2: #f8f8f8;
    --NavigationGroupBgColorHover: #eaeaf0;
    --NavigationGroupFontSize: 16px;
    --NavigationButtonHeightDefault: 40px;
    --NavigationButtonHeightMobile: 55px;
    --NavigationButtonColor: #000000;
    --NavigationButtonBgColor: #ffffff;
    --NavigationButtonBgColorHover: #fafafc;
    --NavigationButtonBgColorActive: #e6eefe;
    --NavigationButtonFontSize: 16px;
    --NavigationLineColor: #C8C7CC;
    --NavigationLineColorLight: #DDDDDD;
    --Color: #000000;
    --ColorLight: #343436;
    --ColorMain: #4b4b4d;
    --ColorHover: #f1f1f6;
    --ColorInfo: #558DF5;
    --ColorWarning: #FF8800;
    --ColorError: #f44336;
    --ColorDisabled: #C8C7CC;
    --ColorActiveItem: #d4eaf4;
    --BgColor: #ffffff;
    --FrmAreaBorderColor: #dddddd;
    --FrmLineColorDesktop: #C8C7CC;
    --FrmLineColorMobile: #C8C7CC;
    --FrmHeaderColor: #000000;
    --FrmHeaderBgColor: #88aff8;
    --FrmHeaderColorMobile: #8E8E93;
    --FrmHeaderBgColorMobile: #EFEFF4;
    --FrmHeaderHeight: 28px;
    --FrmHeaderHeightMobile: 42px;
    --FrmLabelColor: #000000;
    --FrmLabelColorMobile: #787878;
    --FrmLabelBgColor: #88aff8;
    --FrmValueColor: #000000;
    --FrmValueBgColor: #f6f6fb;
    --StvUnmodifiedBgColor: #f6f6fb;
    --StvRequestedAddedBgColor: #4caf50;
    --StvRequestedModifiedBgColor: #f08404;
    --StvRequestedColor: #ffffff;
    --BackgroundDefault: #ffffff;
    --BackgroundLight: #f6f6fb;
    --ControlBgColor: #ffffff;
    --ControlBgColorDisabled: #ffffff;
    --ControlBorderColor: #558DF5;
    --ControlBorderColorDisabled: #C8C7CC;
    --ControlBgColorMobile: #f7faff;
    --ControlBgColorMobileDisabled: #fbfbfb;
    --ControlBorderColorMobile: #d7e4fd;
    --ControlBorderColorMobileDisabled: #C8C7CC;
    --DisabledButtonColor: #ffffff;
    --DisabledButtonBgColor: #C8C7CC;
    --LightButtonColor: #558DF5;
    --LightButtonBgColor: #ffffff;
    --PrimaryButtonColor: #ffffff;
    --PrimaryButtonBgColor: #558DF5;
    --GreenButtonColor: #ffffff;
    --GreenButtonBgColor: #6fbd85;
    --RedButtonColor: #ffffff;
    --RedButtonBgColor: #ee6b64;
    --PanelBgColor: #efeff4;
    --LoginColor: #558DF5;
    --TableBgColor: #ffffff;
    --TableHeaderColor: #000000;
    --TableHeaderBgColor: #88aff8;
    --TableCellColor: #000000;
    --TableCellBgColor: #f6f6fb;
    --CellHeadBgColor: #88aff8;
    --CellLabelBgColor: #88aff8;
    --CellContentBgColor: #f6f6fb;
    --CellContentBgColorHover: #e4e4e9;
    --FontFamily: 'Lato', Arial, sans-serif;
    --FontSizeXS: 9px;
    --FontSizeS: 13px;
    --FontSizeM: 15px;
    --FontSizeL: 16px;
    --FontSizeXL: 17pt;
    --FontSizeXXL: 20px;
    --FontSizeTbl: 10pt;
    --OpacityDarkColor: rgba(0, 0, 0, 0.4);
    /* Material-Design (zunaechst nur fuer Landing Page)*/
    --MaterialDesignListItemBackgroundColor: #ffffff;
    --MaterialDesignListItemBackgroundColorHover: #fafafc;
    --MaterialDesignListItemBorderColor: #efeff4;
    --MaterialDesignListItemColor: #535355;
    --MaterialDesignListItemColorActionRequired: #FF4D4D;
    --MaterialDesignExtendedFloatingActionButtonBackgroundColor: #558DF5;
    --MaterialDesignExtendedFloatingActionButtonColor: #ffffff;
    --MaterialDesignExtendedFloatingActionButtonBoxShadowColor: #787878;
    --MaterialDesignFontSizeS: 12px;
    --MaterialDesignFontSizeM: 14px;
    --MaterialDesignFontSizeL: 16px;
    --MaterialDesignFontSizeXL: 20px;
    --FlyInButtonPanelBgColor: #f8f8f8;
    --FlyInButtonPanelBorderColor: #8E8E93;
}

/* lato-regular - latin */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Lato';
    font-style: normal;
    font-weight: 400;
    src: url('../../fonts/lato-v24-latin-regular.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
    url('../../fonts/lato-v24-latin-regular.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}
/* lato-700 - latin */
@font-face {
    font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Lato';
    font-style: normal;
    font-weight: 700;
    src: url('../../fonts/lato-v24-latin-700.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
    url('../../fonts/lato-v24-latin-700.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

/*------------------------------------*\
  #Allgemein
\*------------------------------------*/

body {
    font-size: var(--FontSizeM);
    font-weight: normal;
    margin: 0px;
    margin-left: 0px;
    margin-top: 0px;
    margin-right: 0px;
    margin-bottom: 0px;
    color: var(--Color);
    font-family: var(--FontFamily);
    position: static;
    background-color: var(--BgColor);
}

td, div, input, button, textarea, select, th {
    font-family: var(--FontFamily);
    font-size: var(--FontSizeM);
}

@media screen and (max-width: 600px) {
    body.mobile-gray-background {
        background-color: var(--PanelBgColor);
    }
}

/*------------------------------------*\
  #ViewportHeightIndicator
\*------------------------------------*/

#ViewportHeightIndicator {
    display: block;
    position: fixed;
    padding: 0;
    margin: 0;
    left: -30px;
    bottom: 0;
    width: 30px;
    height: 10px;
    background-color: blue;
    z-index: 9999;
}

#NavigationBar1_pdfFrame {
    width: 100%;
    height: 100%;
    border: 0;
}

/*------------------------------------*\
  #ContentPanel
\*------------------------------------*/

#NavigationBar1_ContentPanel {
    position: absolute;
    display: block;
    left: calc(var(--NavigationWidth) + var(--ContentBorderHor));
    top: calc(var(--HeaderHeight) + var(--ContentBorderTop));
    width: calc(100vw - var(--NavigationWidth) - (2 * (var(--ContentBorderHor))));
    height: calc(100vh - var(--HeaderHeight) - var(--ContentBorderTop));
    margin: 0;
    overflow: visible;
}

#NavigationBar1_ContentWrapper {
    width: calc(100vw - var(--NavigationWidth) - (2 * (var(--ContentBorderHor))));
}

@media screen and (max-width: 600px) {

    #NavigationBar1_ContentPanel {
        left: var(--ContentBorderHorMobile);
        top: calc(var(--HeaderHeightMobile) + var(--ContentBorderTopMobile));
        width: calc(100vw - (2 * (var(--ContentBorderHorMobile))));
        height: calc(100vh - var(--HeaderHeightMobile) - var(--ContentBorderTopMobile));
        overflow: auto;
    }

    body.mobileready #NavigationBar1_ContentPanel {
        overflow-x: hidden;
        overflow-y: auto;
    }

    body.mobileready.mobileform #NavigationBar1_ContentPanel {
        left: 0;
        width: 100vw;
        top: var(--HeaderHeightMobile);
        height: calc(100vh - var(--HeaderHeightMobile));
    }

    #NavigationBar1_ContentWrapper {
        width: calc(100vw - (2 * (var(--ContentBorderHorMobile))));
    }

    body.mobileready.mobileform #NavigationBar1_ContentWrapper {
        width: 100vw;
    }
}

/*------------------------------------*\
  #mbox & popupok
\*------------------------------------*/

#msgboxwrapper {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--OpacityDarkColor);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0.3s, opacity 0.3s linear;
}

    #msgboxwrapper.active {
        visibility: visible;
        opacity: 1;
    }

#msgboxinner {
    padding: 20px;
    background-color: white;
    border-radius: 5px;
    display: inline-block;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 50%;
    opacity: 1;
    position: relative;
    text-align: center;
    height: auto;
    margin: -20% 0 0 0;
}

#NavigationBar1_msgboxlabel {
    display: inline-block;
    text-align: justify;
    cursor: default;
}

#NavigationBar1_msgboxbtnok {
    display: inline-block;
    margin: 20px 0 0 0;
    min-width: 80px;
}

#NavigationBar1_msgboxbtncancel {
    display: none;
    margin: 20px 0 0 15px;
    min-width: 80px;
}

#msgboxwrapper.confirm #NavigationBar1_msgboxbtncancel {
    display: inline-block;
}

@media screen and (max-width: 600px) {
    #msgboxinner {
        max-width: 75%;
    }
}

#popupokwrapper {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--OpacityDarkColor);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0.3s, opacity 0.3s linear;
    padding: 0px;
    margin: 0;
}

    #popupokwrapper.active {
        visibility: visible;
        opacity: 1;
    }

#popupokinner {
    padding: 15px;
    margin: 0;
    background-color: white;
    border-radius: 5px;
    display: inline-block;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 90%;
    opacity: 1;
    position: relative;
    text-align: center;
    margin: -20% 0 0 0;
}

    #popupokinner div {
        width: 200px;
        height: 200px;
        background-image: url('popupok.svg');
    }

/*------------------------------------*\
  #Fullscreen
\*------------------------------------*/

#fullscreenwrapper {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    background-color: #ffffff;
    z-index: 9950;
}

    #fullscreenwrapper.active {
        display: grid;
    }

#fullscreencontent {
    margin: 32px 8px 8px 8px;
    display: block;
    position: relative;
    background-color: #ffffff;
    overflow-x: hidden;
    overflow-y: auto;
}

#fullscreenbutton {
    display: block;
    position: absolute;
    top: 8px;
    right: 8px;
    width: 16px;
    height: 16px;
    background-image: url('btn-fullscreenclose.svg');
    background-size: cover;
    cursor: pointer;
}

/*------------------------------------*\
  #Header
\*------------------------------------*/

#MspHeader,
#MspHeader * {
    box-sizing: border-box;
}

#MspHeader {
    position: fixed;
    display: none;
    left: 0;
    top: 0;
    width: 100vw;
    height: var(--HeaderHeight);
    z-index: 2001;
    background-color: var(--HeaderBgColor);
    -webkit-backface-visibility: hidden;
}

body:not(.login) #MspHeader {
    display: block;
}

#HdrWrapper {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    color: var(--HeaderColor);
}

#HdrTitle {
    position: absolute;
    left: var(--MobileMenuButtonWidth);
    top: 20px;
    width: calc(100% - var(--MobileMenuButtonWidth));
    max-width: calc(var(--DesktopLimitedWorkspaceWidth) - var(--ContentBorderHor) - var(--MobileMenuButtonWidth));
    height: 26px;
    text-align: center;
    vertical-align: middle;
    font-size: var(--FontSizeXXL);
    line-height: 20px;    
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

#HdrLine {
    display: block;
    position: absolute;
    bottom: 0px;
    width: 100%;
    height: 1px;
    background-color: #DDDDDD;
}

@media (max-width: 600px) {
    #MspHeader {
        display: block;
        height: var(--HeaderHeightMobile);
    }

    #HdrTitle {
        display: block;
        width: calc(100% - (2 * var(--MobileMenuButtonWidth)));
    }

}

/*------------------------------------*\
  #Login
\*------------------------------------*/

#LoginBackground {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    background-size: cover;
    background-image: url('startbackground.jpg');
}

#LoginCenterWrapper {
    position: absolute;
    display: flex;
    justify-content: center;
    width: 100vw;
    top: calc(var(--HeaderHeight) + 120px);
}

#LoginWrapper {
    display: block;
    width: 350px;
    max-width: calc(100vw - 20px);
}

#LoginHeader {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 0 40px 0;
}

#LoginHeaderImage {
    width: 200px;
    height: 54px;
    content: url('startlogo.png');
}

#LoginHeaderText {
    display: block;
    margin: 5px 0 0 0;
    color: #4a4a49;
}

#LoginInfoWrapper {
    display: flex;
    margin: 0 0 30px 0;
    padding: 10px;
    background-color: rgba(255, 255, 255, 0.4);
    border: solid 1px var(--ColorError);
    border-radius: 5px;
}

#LoginInfoText {
    display: inline-flex;
    margin: 0 5px 0 5px;
    align-items: center;
}

    #LoginInfoText span {
        text-align: justify;
        color: var(--ColorError);
    }

#LoginDataWrapper {
    margin: 0 55px 0 55px;
}

.LoginDataText {
    position: relative;
    width: 100%;
    margin: 0 0 20px 0;
    border-bottom: 1px solid var(--LoginColor);
    text-align: center;
}

    .LoginDataText input {
        border: 0;
        box-shadow: none;
        outline: none;
        text-align: center;
        background-color: transparent;
        color: var(--LoginColor);
    }

        .LoginDataText input:-webkit-autofill,
        .LoginDataText input:-webkit-autofill:hover,
        .LoginDataText input:-webkit-autofill:focus {
            border: 0;
            -webkit-text-fill-color: var(--LoginColor);
            -webkit-box-shadow: 0 0 0px 1000px transparent inset;
            transition: background-color 5000s ease-in-out 0s;
        }

    .LoginDataText ::-webkit-input-placeholder {
        color: #8E8E93;
    }

    .LoginDataText ::-moz-placeholder {
        color: #8E8E93;
    }

    .LoginDataText :-ms-input-placeholder {
        color: #8E8E93;
    }

    .LoginDataText ::placeholder {
        color: #8E8E93;
    }

div.ViewPassword {
    display: flex;
    position: absolute;
    align-items: center;
    bottom: 0px;
    right: 2px;
    width: 26px;
    height: 100%;
}

    div.ViewPassword button {
        display: block;
        width: 26px;
        height: 16px;
        border: none;
        background-color: transparent;
        background-image: url('pwd-eye-slash.svg');
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        margin: 0;
        padding: 0;
        cursor: pointer;
    }

        div.ViewPassword button:focus {
            outline: none;
        }

    div.ViewPassword.PwdVisible button {
        background-image: url('pwd-eye.svg');
    }

#LoginButtonWrapper {
    margin: 50px 65px 0 65px;
    text-align: center;
}

.LoginButton {
    width: 100%;
    height: 34px;
    line-height: 22px;
    margin: 0 0 20px 0;
    border: 1px solid var(--PrimaryButtonBgColor);
    border-radius: 17px;
    cursor: pointer;
    background-color: var(--PrimaryButtonBgColor);
    color: var(--PrimaryButtonColor);
}

    .LoginButton:focus {
        outline: none;
    }

#LoginLng {
    margin: 25px 0 0 0;
    border: 0;
    text-align: center;
}

#LoginLngBackground {
    display: inline-block;
    padding: 3px 8px 3px 8px;
    background-color: transparent;
}

#LoginLngOptions {
    display: block;
    padding: 0;
    margin: 0;
}

.LoginLngLanguage {
    display: inline-block;
    width: 36px;
    height: 24px;
    margin-right: 10px;
}

    .LoginLngLanguage img {
        width: 36px;
        height: 24px;
        cursor: pointer;
    }

    .LoginLngLanguage.selected {
        padding: 4px;
        border: 2px solid var(--LoginColor);
    }

    .LoginLngLanguage:last-child {
        margin-right: 0px;
    }

@media screen and (max-width: 600px) {

    #LoginBackground {
        display: none;
    }

    #LoginWrapper {
        top: calc(var(--HeaderHeight) + 40px);
    }

    #LoginLngBackground {
        background-color: #f6f6fb;
    }
}

/*------------------------------------*\
  Navigation
\*------------------------------------*/

/* ueberblendet den uebrigen Content, wenn das Navigation-Menue im mobilen Modus offen ist */
.navigation-menu-content-overlay {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--OpacityDarkColor);
    z-index: 9000;
}

.navigation-menu-wrapper,
.navigation-menu-wrapper * {
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.navigation-menu-wrapper {
    display: block;
    position: fixed;
    top: var(--HeaderHeight);
    left: 0;
    width: var(--NavigationWidth);
    height: calc(100vh - var(--HeaderHeight));
    background-color: var(--NavigationBgColor);
    border-right: solid 1px var(--NavigationLineColorLight);
    z-index: 100;
}

.navigation-menu {
    display: block;
    width: 100%;
    height: calc(100vh - var(--HeaderHeight) - 42px);
    overflow-x: hidden;
    overflow-y: auto;
}

.navigation-menu ul {
    width: 100%;
    margin: 0;
    padding: 0;
}

.navigation-menu li {
    display: block;
    margin: 0;
    padding: 0;
}

.navigation-menu input[type=checkbox] {
    display: none;
}

.navigation-menu label::after {
    content: '';
    width: 18px;
    height: 18px;
    background-image: url('btn-frmheaderopen-mobile.svg');
    background-position: center;
    background-size: contain;
}

.navigation-menu input[type=checkbox]:checked ~ label::after {
    background-image: url('btn-frmheaderclose-mobile.svg');
}

.navigation-menu input[type=checkbox] ~ ul {
    display: none;
}

.navigation-menu input[type=checkbox]:checked ~ ul {
    display: block;
}

.navigation-menu a,
.navigation-menu label {
    height: var(--NavigationGroupHeightDefault);
    position: relative;
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    padding-left: 10px;
    padding-right: 10px;
    text-align: left;
    font-family: var(--FontFamily);
    border-bottom: solid 1px var(--NavigationLineColor);
}

.navigation-menu a {
    font-size: var(--NavigationButtonFontSize);
    background-color: var(--NavigationButtonBgColor);
    color: var(--NavigationButtonColor);
    text-decoration: none;
}

.navigation-menu a.active {
    background-color: var(--NavigationButtonBgColorActive);
}

.navigation-menu a.external::after,
.navigation-menu a.logout::after {
    content: '';
    background-size: contain;
    background-position: center;
}

.navigation-menu a.external::after {
    width: 18px;
    height: 18px;
    background-image: url('btn-next-mobile.svg');
}

.navigation-menu a.logout::after {
    width: 24px;
    height: 24px;
    background-image: url('nav-abmelden.svg');
}

.navigation-menu label {
    font-size: var(--NavigationGroupFontSize);
    color: var(--NavigationGroupColor);
    text-transform: uppercase;
    background-color: var(--NavigationGroupBgColor);
    cursor: pointer;
}

.navigation-menu ul ul label {
    background-color: var(--NavigationGroupBgColorLevel2);
}

@media (hover: hover) {
    .navigation-menu label:hover {
        background-color: var(--NavigationGroupBgColorHover);
    }

    .navigation-menu a:hover {
        background-color: var(--NavigationButtonBgColorHover);
    }
}

.navigation-versioninfo-wrapper {
    display: block;
    position: fixed;
    left: 0;
    bottom: 0;
    width: calc(var(--NavigationWidth) - 1px);
    height: 42px;
    margin: 0;
    padding: 0;
    background-color: var(--NavigationBgColor);
}

.navigation-versioninfo-wrapper.withborder {
    border-top: solid 1px var(--NavigationLineColorLight);
}

.navigation-versioninfo-wrapper div {
    display: block;
    margin: 5px 10px 5px 10px;
    padding: 0;
    color: #a6a5ad;
    font-size: var(--FontSizeXS);
}

@media screen and (max-width: 600px) {

    body.mobilemenu .navigation-menu-content-overlay {
        display: block;
    }

    .navigation-menu-wrapper {
        left: auto;
        right: -100vw;
        top: 0;
        width: var(--NavigationWidthMobile);
        height: 100vh;
        padding-top: var(--HeaderHeightMobile);
        visibility: hidden;
        opacity: 0;
        transition: all 0.2s, visibility 0.2s, opacity 0.2s linear;
        border-right: none;
        z-index: 9100;
    }

    body.mobilemenu .navigation-menu-wrapper {
        right: 0;
        visibility: visible;
        opacity: 1;
    }

    .navigation-menu {
        border-top: solid 1px var(--NavigationLineColor);
    }

    @supports (-webkit-touch-callout: none) {
        /* CSS specific to iOS devices */
        /* auf iPhone sind sonst die beiden untersten Eintraege nicht sichtbar */
        .navigation-menu {
            padding-bottom: calc(2 * var(--NavigationButtonHeightMobile));
        }
    }

        .navigation-menu a,
        .navigation-menu label {
            height: var(--NavigationGroupHeightMobile);
        }

    .navigation-versioninfo-wrapper {
        left: auto;
        width: var(--NavigationWidthMobile);
        right: -100vw;
        visibility: hidden;
        opacity: 0;
        transition: all 0.2s, visibility 0.2s, opacity 0.2s linear;
    }

    body.mobilemenu .navigation-versioninfo-wrapper {
        right: 0;
        visibility: visible;
        opacity: 1;
    }
}

/*------------------------------------*\
  Landing Page -- User Info
\*------------------------------------*/
.user-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 16px;
    padding-bottom: 24px;
}

.user-info-name {
    color: #558DF5;
    font-size: var(--MaterialDesignFontSizeXL);
    font-weight: bold;
}

.user-info-orga {
    color: #535355;
    font-size: var(--MaterialDesignFontSizeM);
    max-width: calc(100% - 32px);
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.user-avatar {
    position: relative;
    color: #ffffff;
    background-color: #c51915;
    opacity: 1;
    display: inline-block;
    font-size: var(--MaterialDesignFontSizeXL);
    font-weight: bold;
    vertical-align: middle;
    text-align: center;
    width: 56px;
    height: 56px;
    line-height: 56px;
    border-radius: 50%;
    margin-bottom: 16px;
}

.user-avatar[data-user-initials]:before {
    content: attr(data-user-initials);
}

    .user-avatar:after {
        content: '';
        /* 'wiederholt' das background-image aus `user-avatar`, damit dies *vor* den Initialen steht */
        background-image: inherit;
        position: absolute;
        z-index: 1;
        /* etwas groesser, weil es sonst einen unschoenen Rand vom farbigen Hintergrund des Fallbacks gibt */
        top: -1px;
        left: -1px;
        width: 58px;
        height: 58px;
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
        border-radius: 50%;
    }

.color00 { background-color: #c51915; }
.color01 { background-color: #ca4218; }
.color02 { background-color: #ec6d20; }
.color03 { background-color: #fe8a27; }
.color04 { background-color: #9aca28; }
.color05 { background-color: #c8b654; }
.color06 { background-color: #c79b38; }
.color07 { background-color: #ca7620; }
.color08 { background-color: #86b042; }
.color09 { background-color: #53a527; }
.color0A { background-color: #67981b; }
.color0B { background-color: #13864b; }
.color0C { background-color: #21aa66; }
.color0D { background-color: #66b393; }
.color0E { background-color: #1897a6; }
.color0F { background-color: #70b3b9; }
.color10 { background-color: #3cb7e3; }
.color11 { background-color: #1a9acb; }
.color12 { background-color: #1993e8; }
.color13 { background-color: #1789cf; }
.color14 { background-color: #8266ca; }
.color15 { background-color: #754cb2; }
.color16 { background-color: #6568c9; }
.color17 { background-color: #1b57b7; }
.color18 { background-color: #a969ca; }
.color19 { background-color: #983bca; }
.color1A { background-color: #9d45b6; }
.color1B { background-color: #fd464b; }
.color1C { background-color: #a39497; }
.color1D { background-color: #a37c81; }
.color1E { background-color: #c35e7e; }
.color1F { background-color: #e62564; }

/*------------------------------------*\
  Landing Page -- List
\*------------------------------------*/
ul.md-list {
    box-sizing: border-box;
    padding: 8px 0 64px 0; /* padding-bottom groesser, damit der Extended Floating Action Button nicht dauerhaft das unterste Element verdecken kann */
    list-style: none;
}

.md-list-item {
    display: grid;
    grid-template-columns: 1fr 72px 48px;
    grid-template-rows: 72px;
    grid-template-areas: "headline trailing-supporting-text trailing-icon";
    align-items: center;
    background-color: var(--MaterialDesignListItemBackgroundColor);
    border-top: 1px solid var(--MaterialDesignListItemBorderColor);
}

.md-list-item:hover {
    background-color: var(--MaterialDesignListItemBackgroundColorHover);
}

.md-list-item.md-list-item-link {
    cursor: pointer;
    text-decoration: none;
}

.md-list-item >* {
    margin: 0;
    padding: 0;
    display: grid;
}

.md-list-headline-column {
    grid-area: headline;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding-left: 16px;
}

.md-list-trailing-supporting-text-column {
    grid-area: trailing-supporting-text;
    padding-right: 16px;
    text-align: right;
}

.md-list-trailing-icon-column {
    grid-area: trailing-icon;
    padding-right: 24px;
}

.md-list-trailing-icon-column >* {
    background-position: center;
    background-repeat: no-repeat;
    background-size: 18px;
    height: 24px;
}

.md-list-item-link .md-list-trailing-icon-column>* {
    background-image: url('btn-next-mobile.svg');
}

.md-list-item-accordion .md-list-trailing-icon-column>* {
    cursor: pointer;
    background-image: url('btn-frmheaderclose-mobile.svg');
}

input.WrpHeaderBtnOpenClose:checked ~ .md-list-item-accordion .md-list-trailing-icon-column>* {
    transform: rotate(180deg);
}

.md-list-accordion-item {
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--MaterialDesignListItemBackgroundColor);
    height: 48px;
    padding-left: 16px;
    padding-right: 24px;
}

.md-list-accordion-item>* {
    margin: 0;
    padding: 0 16px 0 0;
}

.md-list-accordion-item>a {
    text-decoration-line: none;
}

input.WrpHeaderBtnOpenClose:checked ~ .md-list-accordion-item {
    display: none;
}

.md-list-headline,
.md-list-supporting-text,
.md-list-trailing-supporting-text-column {
    color:	var(--MaterialDesignListItemColor);
}

.md-list-item.action-required .md-list-headline,
.md-list-item.action-required .md-list-supporting-text,
.md-list-item.action-required .md-list-trailing-supporting-text-column {
    color: var(--MaterialDesignListItemColorActionRequired);
}

.md-list-headline,
.md-list-trailing-supporting-text-column {
    font-size: var(--MaterialDesignFontSizeL);
    font-weight: bold;
}

.md-list-headline,
.md-list-supporting-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.md-list-headline {
    margin-bottom: 4px;
}

.md-list-supporting-text {
    margin-top: 4px;
    font-size: var(--MaterialDesignFontSizeM);
}

.md-extended-floating-action-button {
    cursor: pointer;
    box-sizing: border-box;
    position: fixed;
    display: flex;
    align-items: center;
    right: 16px;
    bottom: 16px;
    min-width: 80px;
    height: 56px;
    padding: 16px;
    border-radius: 16px;
    background-color: var(--MaterialDesignExtendedFloatingActionButtonBackgroundColor);
    color: var(--MaterialDesignExtendedFloatingActionButtonColor);
    font-size: var(--MaterialDesignFontSizeL);
    font-weight: bold;
    text-decoration: none;
    box-shadow: 1px 3px 3px var(--MaterialDesignExtendedFloatingActionButtonBoxShadowColor);
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}

.md-extended-floating-action-button img {
    height: 24px;
    padding-right: 16px;
}

/*------------------------------------*\
  Landing Page -- Desktop
\*------------------------------------*/
@media screen and (min-width: 601px) {
    .md-list-item {
        grid-template-rows: 80px;
        border-top: initial;
    }
    
    /* Der ExtendedFloatingActionButton soll beim Desktop rechtsbuendig mit den ListItems ausgerichtet sein */
    .md-extended-floating-action-button {
        right: unset;
    }

    .md-extended-floating-action-button-desktop-positioner-outer {
        position: relative;
    }
    
    .md-extended-floating-action-button-desktop-positioner-inner {
        position: absolute;
        right: 0;
        display: flex;
        flex-direction: row-reverse;
    }
    
    /* Die ListItems sollen beim Desktop nur so lange im rechten Bereich zentriert werden, bis der "Arbeitsbereich" 1080px breit ist*/
    .landing-page-desktop-wrapper-outer {
        max-width: calc(min(100vw, var(--DesktopLimitedWorkspaceWidth)) - var(--NavigationWidth) - (2 * (var(--ContentBorderHor))));
    }
    
    .landing-page-desktop-wrapper-inner {
        margin-left: auto;
        margin-right: auto;
        max-width: 480px;
    }
}

/*------------------------------------*\
  #ad-form
\*------------------------------------*/

.ad-form-area {
    display: grid;
    grid-template-columns: minmax(min-content, min-content) 1fr;
    grid-gap: 0.1em;
    max-width: calc(var(--DesktopLimitedWorkspaceWidth) - var(--NavigationWidth));
    margin: 0 0 25px 0;
}

    .ad-form-area.WrpFrmWide {
        max-width: none; /* 800px; */
    }

    .ad-form-area.WrpFrmClosed {
        height: var(--FrmHeaderHeight);
        overflow: hidden;
    }

.ad-form-floating-button-panel {
    box-sizing: border-box;
    position: fixed;
    z-index: 9100;
    display: flex;
    justify-content: end;
    align-items: end;
    bottom: 0px;
    width: calc(100vw - var(--NavigationWidth) - (2 * var(--ContentBorderHor)));
    max-width: calc(var(--DesktopLimitedWorkspaceWidth) - var(--NavigationWidth));
    height: 80px;
}

.ad-form-fly-in-button-panel {
    box-sizing: border-box;
    position: fixed;
    padding: 10px 10px 10px 10px;
    display: flex;
    align-items: center;
    justify-content: end;
    bottom: -80px;
    width: calc(100vw - var(--NavigationWidth) - (2 * var(--ContentBorderHor)));
    max-width: calc(var(--DesktopLimitedWorkspaceWidth) - var(--NavigationWidth));
    height: 80px;
    visibility: hidden;
    opacity: 0;
    transition: all 0.2s, visibility 0.2s, opacity 0.2s linear;
}

    .ad-form-fly-in-button-panel.active {
        bottom: 0px;
        opacity: 1;
        visibility: visible;
    }

    .ad-form-fly-in-button-panel > input[type=submit] {
        z-index: 9100;
    }

.ad-form-fly-in-button-panel__bg {
    position: absolute;
    display: block;
    left: calc(-1 * var(--ContentBorderHor));
    width: calc(100% + var(--ContentBorderHor));
    height: 100%;
    background-color: var(--FlyInButtonPanelBgColor);
    border-top: 1px solid var(--FlyInButtonPanelBorderColor);
}

@media screen and (max-width: 600px) {
    .ad-form-fly-in-button-panel {
        width: calc(100vw - (2 * (var(--ContentBorderHorMobile))));
    }

    .ad-form-fly-in-button-panel__bg {
        left: 0;
        width: 100%;
    }
}

.ad-form-dark-overlay {
    display: flex;
    position: fixed;
    position: absolute;
    bottom: 0;
    left: calc(-1 * (var(--NavigationWidth) + var(--ContentBorderHor)));
    width: 100vw;
    height: 100vh;
    background-color: var(--OpacityDarkColor);
    opacity: 0;
    visibility: hidden;
    transition: visibility 0.3s, opacity 0.2s linear;
    z-index: 9200;
}

    .ad-form-dark-overlay.active {
        visibility: visible;
        opacity: 1;
    }

@media screen and (max-width: 600px) {
    .ad-form-dark-overlay {
        left: 0;
    }
}

.ad-form-button-panel-space-area {
    display: block;
    height: 60px;
    margin: 0;
}

.ad-form-button-area {
    display: block;
    max-width: calc(var(--DesktopLimitedWorkspaceWidth) - var(--NavigationWidth));
    padding: 20px 0 0 0;
    border-top: 1px solid var(--FrmLabelBgColor);
}

.ad-form-row {
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
}

    /* if row with separator is not the last item in area it has border bottom */
    .ad-form-row.ad-form--separate:not(.ad-form-area > *:last-child),
    .ad-form-row.ad-form--separate-desktop:not(.ad-form-area > *:last-child) {
        border-bottom: 1px solid var(--FrmLineColorDesktop);
    }

.ad-form-row--header-row {
    display: flex;
    white-space: nowrap;
    color: var(--FrmHeaderColor);
    background-color: var(--FrmHeaderBgColor);
    padding: 2px 5px 2px 5px;
    height: var(--FrmHeaderHeight);
    margin: 0 0 5px 0;
    font-weight: bold;
}

    .ad-form-row--header-row span {
        display: inline-block;
        height: var(--FrmHeaderHeight);
        line-height: var(--FrmHeaderHeight);
        vertical-align: middle;
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;
    }

    .ad-form-row--header-row.OnlyMobile {
        display: none;
    }

div.WrpHeaderBtnContainer {
    display: inline-block;
    height: var(--FrmHeaderHeight);
    overflow-y: hidden;
}

    div.WrpHeaderBtnContainer.OnlyMobile {
        display: none;
    }

label.WrpHeaderBtnOpenClose,
div.WrpHeaderBtnOpenClose {
    display: inline-flex;
    width: 16px;
    height: 16px;
    border-top: 3px solid var(--FrmHeaderBgColor);
    border-left: none;
    border-right: 10px solid var(--FrmHeaderBgColor);
    border-bottom: none;
    background-image: url('btn-frmheaderclose.svg');
    background-size: cover;
    cursor: pointer;
}

input.WrpHeaderBtnOpenClose:checked ~ .WrpFrmHeadButtons label.WrpHeaderBtnOpenClose,
.ad-form-area.WrpFrmClosed div.WrpHeaderBtnOpenClose {
    background-image: url('btn-frmheaderopen.svg');
}

label.WrpHeaderBtnMaximize,
div.WrpHeaderBtnMaximize {
    display: inline-flex;
    width: 12px;
    height: 12px;
    border-top: 2px solid var(--FrmHeaderBgColor);
    border-left: none;
    border-right: 10px solid var(--FrmHeaderBgColor);
    border-bottom: 2px solid var(--FrmHeaderBgColor);
    background-image: url('btn-frmheadermaximize.svg');
    background-size: cover;
    cursor: pointer;
}

/* Ein-/Ausklappen & Maximieren mit "pure" HTML/CSS */
/* Die <input>-Elemente werden nur über ihre <label>-Elemente geklickt und speichern den Zustand über das Post-Back hinaus. */
input.WrpHeaderBtnMaximize,
input.WrpHeaderBtnOpenClose {
    display: none;
}

/* Der Inhalt wird verborgen, falls WrpHeaderBtnOpenClose aktiviert ist */
input.WrpHeaderBtnOpenClose:checked ~ .ad-form-area-content {
    display: none;
}

/* Der Inhalt wird maximiert, falls WrpHeaderBtnMaximize aktiviert ist */
input.WrpHeaderBtnMaximize:checked ~ .ad-form-area-content {
    position: fixed;
    display: block;
    width: calc(100% - 16px);
    height: calc(100% - 16px);
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: white;
    z-index: 9950;
    padding: 24px 8px 8px 8px;
}

/* Das jeweilige <label> zum Schließen der maximierten Ansicht wird oben rechts positioniert, falls WrpHeaderBtnMaximize aktiviert ist */
input.WrpHeaderBtnMaximize:checked ~ .WrpFrmHeadButtons label.WrpHeaderBtnMaximize {
    position: fixed;
    top: 8px;
    right: 8px;
    width: 16px;
    height: 16px;
    border: 0px;
    background-image: url(btn-fullscreenclose.svg);
    background-size: cover;
    cursor: pointer;
    z-index: 9951;
}

@media screen and (min-width: 601px) {
    label.WrpHeaderBtnOpenClose.OnlyMobile,
    div.WrpHeaderBtnOpenClose.OnlyMobile {
        display: none;
    }

    label.WrpHeaderBtnMaximize.OnlyMobile,
    div.WrpHeaderBtnMaximize.OnlyMobile {
        display: none;
    }
}

.ad-form-row--container-row {
    display: block;
}

.ad-form-row--info-row {
    display: block;
    padding: 2px 0 2px 0;
    margin: 0 0 5px 0;
}

.ad-form-row--caption-row {
    display: block;
    padding: 15px 0 2px 0;
    margin: 0 0 5px 0;
    color: var(--ColorInfo);
}

.ad-form-row--control-row {
    display: block;
    padding: 2px 0 2px 0;
    margin: 0 0 5px 0;
}

.ad-form-row--control-row > * {
    display: inline-block;    
}

.ad-form-row--table-row {
    display: block;
}

.ad-form-row--space-row {
    display: block;
    height: 25px;
    margin: 0;
}

.ad-form-row--line-row {
    display: block;
    height: 20px;
    margin: 0 0 20px 0;
    border-bottom: 1px solid var(--FrmLabelBgColor);
}

.ad-form-cell {
    display: block;
    position: relative;
}

    /* if cell with separator is not the last item in area it has border bottom */
    .ad-form-cell.ad-form--separate:not(.ad-form-area > *:last-child),
    .ad-form-cell.ad-form--separate-desktop:not(.ad-form-area > *:last-child) {
        border-bottom: 1px solid var(--FrmLineColorDesktop);
    }

.ad-form-cell--label-cell {
    /* currently no modifications */
}

.ad-form-cell__label {
    white-space: nowrap;
    color: var(--FrmLabelColor);
    background-color: var(--FrmLabelBgColor);
    padding: 2px 5px 2px 5px;
    margin: 0 5px 6px 0px;
    min-width: 130px;
}

.ad-form-cell--value-cell {
    min-height: 19px;
    color: var(--FrmValueColor);
    background-color: var(--FrmValueBgColor);
    margin: 0 0 5px 0;
    padding: 2px 5px 2px 5px;
}

.ad-form-cell--control-cell {
    margin: 0 0 5px 0;
}

.WrpFrmControlFill {
    width: 100%;
}

div.WrpFrmControlFill.CtlSelect {
    width: calc(100% - 2px);
}

div.WrpFrmErrInfo {
    display: none;
    position: relative;
    color: var(--ColorError);
    width: 100%;
    margin: 3px 0 0 0;
    font-size: var(--FontSizeS);
}

    div.WrpFrmErrInfo.active {
        display: block;
    }

.ad-form-area .ad-space-top,
.ad-form-row .ad-space-top {
    padding-top: 20px;
}

.ad-form-area .ad-space-bottom,
.ad-form-row .ad-space-bottom {
    padding-bottom: 20px;
}

@media screen and (max-width: 600px) {

    .ad-form-area {
        display: grid;
        grid-template-columns: 1fr;
        width: 100vw;
        max-width: 100vw;
        background-color: #ffffff;
        margin-bottom: 0;
    }

        .ad-form-area.ad-form--separate,
        .ad-form-area.ad-form--separate-mobile {
            border-bottom: 1px solid var(--FrmLineColorMobile);
        }

        .ad-form-area.WrpFrmClosed {
            height: calc(var(--FrmHeaderHeightMobile) + 4px);
            overflow: hidden;
        }

    .ad-form-floating-button-panel {
        width: 100vw;
    }

    .ad-form-fly-in-button-panel {
        width: 100vw;
    }

    .ad-form-button-panel-space-area {
        height: 80px;
    }

        .ad-form-row {
            grid-column: 1;
            width: 100vw;
            max-width: 100vw;
        }

            /* if row with separator is not the last item in area it has border bottom */
            .ad-form-row.ad-form--separate:not(.ad-form-area > *:last-child),
            .ad-form-row.ad-form--separate-mobile:not(.ad-form-area > *:last-child) {
                border-bottom: 1px solid var(--FrmLineColorMobile);
            }

    .ad-form-button-area {
        display: block;
        max-width: none;
        margin: 0;
        padding: 20px var(--ContentBorderHorMobile) 0 var(--ContentBorderHorMobile);
        border-top: 1px solid var(--FrmLineColorMobile);
    }

    .ad-form-row--header-row,
    .ad-form-row--header-row.OnlyMobile {
        display: table;
        color: var(--FrmHeaderColorMobile);
        background-color: var(--FrmHeaderBgColorMobile);
        font-weight: normal;
        margin: 0;
        padding: 2px var(--ContentBorderHorMobile) 2px var(--ContentBorderHorMobile);
        height: var(--FrmHeaderHeightMobile);
        font-size: var(--FontSizeS);
        border-top: 1px solid var(--FrmLineColorMobile);
        border-bottom: 1px solid var(--FrmLineColorMobile);
    }

    /* The header of the first visible area has no border-top */
    .ad-content-wrapper > .ad-form-area:not(.WrpFrmInvisible) > .ad-form-row--header-row {
        border-top: none;
    }

    /* The header of the following areas of the first visible area have a border-top */
    .ad-content-wrapper > .ad-form-area:not(.WrpFrmInvisible) ~ .ad-form-area > .ad-form-row--header-row {
        border-top: 1px solid var(--FrmLineColorMobile);
    }

        .ad-form-row--header-row.WrpFrmHeadButtons,
        .ad-form-row--header-row.WrpFrmHeadButtons.OnlyMobile {
            height: calc(var(--FrmHeaderHeightMobile) + 4px);
        }

        .ad-form-row--header-row > span {
            display: table-cell;
            vertical-align: bottom;
            text-transform: uppercase;
        }

    div.WrpHeaderBtnContainer {
        display: flex;
        position: absolute;
        justify-content: center;
        left: 0;
        top: 1px;
        width: calc(100% - (2 * var(--ContentBorderHorMobile)));
        height: 22px;
    }

    label.WrpHeaderBtnOpenClose,
    div.WrpHeaderBtnOpenClose {
        display: block;
        width: 16px;
        height: 16px;
        border-top: 2px solid var(--FrmHeaderBgColorMobile);
        border-left: 10px solid var(--FrmHeaderBgColorMobile);
        border-right: 10px solid var(--FrmHeaderBgColorMobile);
        border-bottom: none;
        background-image: url('btn-frmheaderclose-mobile.svg');
        background-size: cover;
        cursor: pointer;
    }

    input.WrpHeaderBtnOpenClose:checked ~ .WrpFrmHeadButtons label.WrpHeaderBtnOpenClose,
    .ad-form-area.WrpFrmClosed div.WrpHeaderBtnOpenClose {
        background-image: url('btn-frmheaderopen-mobile.svg');
    }

    label.WrpHeaderBtnMaximize,
    div.WrpHeaderBtnMaximize {
        display: block;
        width: 12px;
        height: 12px;
        border-top: 4px solid var(--FrmHeaderBgColorMobile);
        border-left: 10px solid var(--FrmHeaderBgColorMobile);
        border-right: 10px solid var(--FrmHeaderBgColorMobile);
        border-bottom: none;
        background-image: url('btn-frmheadermaximize-mobile.svg');
        background-size: cover;
        cursor: pointer;
    }

    .ad-form-row--container-row {
        margin: 0;
        padding: 0;
    }

    .ad-form-row--info-row {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    .ad-form-row--caption-row {
        margin: 0;
        padding: 15px var(--ContentBorderHorMobile) 2px var(--ContentBorderHorMobile);
    }

    .ad-form-row--table-row {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    .ad-form-row--line-row {
        margin: 0;
        border-bottom: 1px solid var(--FrmLineColorMobile);
    }

    .ad-form-row--control-row {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    .ad-form-cell {
        margin: 0;
        background-color: inherit;
    }

        /* if cell with separator is not the last item in area it has border bottom */
        .ad-form-cell.ad-form--separate:not(.ad-form-area > *:last-child),
        .ad-form-cell.ad-form--separate-mobile:not(.ad-form-area > *:last-child) {
            border-bottom: 1px solid var(--FrmLineColorMobile);
        }

    .ad-form-cell--label-cell {
        /* currently no modifications */
    }

    .ad-form-cell__label {        
        font-size: var(--FontSizeS);
        background-color: inherit;
        color: var(--FrmLabelColorMobile);
        padding: 2px var(--ContentBorderHorMobile) 2px var(--ContentBorderHorMobile);
    }

    .ad-form-cell--value-cell {
        padding: 2px var(--ContentBorderHorMobile) 4px var(--ContentBorderHorMobile);
    }

    .ad-form-cell--control-cell {
        padding: 2px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

}

.ad-form-area div.WrpFrmNoBorderTop {
    border-top: none;
}

div.WrpFrmInvisible {
    display: none;
}

.ad-form--nowrap {
    display: inline-block;
    white-space: nowrap
}

.ad-label-toggle-container {
    display: grid;
    grid-template-columns: 1fr auto;
    padding-bottom: 8px;
}

.ad-label-toggle-control-container {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-row-gap: 10px;
    padding-bottom: 8px;
}


/*------------------------------------*\
  #MessageSection
\*------------------------------------*/

div.MessageSection {
    display: block;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin: 0;
}

    div.MessageSection ul {
        margin: 5px 0 5px 0;
        padding: 0 0 0 20px;
    }

        div.MessageSection ul > li {
            list-style: none;
            padding-bottom: 5px;
        }

            div.MessageSection ul > li > span,
            div.MessageSection ul > li > div > span {
                display: block;
                font-size: var(--FontSizeM);
            }

            div.MessageSection ul > li:before {
                content: '';
                position: absolute;
                margin-top: 6px;
                margin-left: -16px;
                width: 6px;
                height: 6px;
            }

            div.MessageSection ul > li.warning {
                color: var(--ColorWarning);
            }

                div.MessageSection ul > li.warning:before {
                    background-color: var(--ColorWarning);
                }

            div.MessageSection ul > li.error {
                color: var(--ColorError);
            }

                div.MessageSection ul > li.error:before {
                    background-color: var(--ColorError);
                }

            div.MessageSection ul > li.infolink {
                color: var(--PrimaryButtonBgColor);
            }

                div.MessageSection ul > li.infolink:before {
                    background-color: var(--PrimaryButtonBgColor);
                }

/*------------------------------------*\
  #Fixed-Sortable-Tables
\*------------------------------------*/

div.FiSoTblView {
    position: relative;
    background-color: var(--TableBgColor);
}

    div.FiSoTblView table {
        border-spacing: 0;
        empty-cells: show;
        border: none;
        border-collapse: separate;
        background-color: var(--TableBgColor);
        margin: 0 0 4px 0;
    }

        div.FiSoTblView table th {
            padding: 2px 5px 2px 5px;
            font-weight: bold;
            font-size: var(--FontSizeM);
            text-align: left;
            white-space: nowrap;
            color: var(--TableHeaderColor);
            background-color: var(--TableHeaderBgColor);
            border-right: 5px solid var(--TableBgColor);
            border-bottom: 5px solid var(--TableBgColor);
            -webkit-user-select: none;
            -khtml-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none;
        }

            div.FiSoTblView table th:last-child {
                border-right: none;
            }

            div.FiSoTblView table th.sortable {
                cursor: pointer;
            }

            div.FiSoTblView table th.sortasc:after {
                display: inline-block;
                position: relative;
                top: -2px;
                right: 0;
                padding-left: 5px;
                content: '▲';
                font-size: 10px;
            }

            div.FiSoTblView table th.sortdesc:after {
                display: inline-block;
                position: relative;
                top: -2px;
                padding-left: 5px;
                content: '▼';
                font-size: 10px;
            }

        div.FiSoTblView table td {
            padding: 2px 5px 2px 5px;
            font-weight: normal;
            font-size: var(--FontSizeM);
            text-align: left;
            white-space: nowrap;
            color: var(--TableCellColor);
            background-color: var(--TableCellBgColor);
            border-right: 5px solid var(--TableBgColor);
            border-bottom: 5px solid var(--TableBgColor);
        }

            div.FiSoTblView table td:last-child {
                border-right: none;
            }

        div.FiSoTblView table tr:last-child td {
            border-bottom: none;
        }

div.FiSoTblScroll {
    position: relative;
    left: 0;
    top: 0;
    width: 100%;
    overflow: auto;
}

div.FiSoTblOverlay {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: var(--TableBgColor);
}

div.FiSoTblFixed {
    position: absolute;
    left: 0;
    top: 0;
    overflow: hidden;
}

@media screen and (max-width: 600px) {

    div.FiSoTblView table th {
        border-right: 2px solid var(--TableBgColor);
        border-bottom: 2px solid var(--TableBgColor);
    }

        div.FiSoTblView table th:last-child {
            border-right: none;
        }

    div.FiSoTblView table td {
        border-right: 2px solid var(--TableBgColor);
        border-bottom: 2px solid var(--TableBgColor);
    }

        div.FiSoTblView table td:last-child {
            border-right: none;
        }

    div.FiSoTblView table tr:last-child td {
        border-bottom: none;
    }
}

/*------------------------------------*\
  #Bookingview
\*------------------------------------*/

div.bookingview {
    display: grid;
    grid-gap: 5px;
    background-color: var(--TableBgColor);
}

div.bookingview--cols3 {
    grid-template-columns: auto auto auto auto auto auto;
}

div.bookingview--cols4 {
    grid-template-columns: 34px auto auto auto 34px auto auto auto;
}

div.bookingview--selection {
    padding-top: 25px;
}

div.bookingview__header {
    display: inline-block;
    font-size: var(--FontSizeM);
    font-weight: bold;
    line-height: 22px;
    text-align: center;
    vertical-align: middle;
    color: var(--TableHeaderColor);
    background-color: var(--TableHeaderBgColor);
    padding: 2px;
}

div.bookingview--cols3 div.bookingview__header {
    grid-column: auto / span 3;
}

div.bookingview--cols4 div.bookingview__header {
    grid-column: auto / span 4;
}

div.bookingview__subheader {
    display: inline-block;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: center;
    vertical-align: middle;
    color: var(--TableHeaderColor);
    background-color: var(--TableHeaderBgColor);
    padding: 2px;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

div.bookingview__value {
    display: inline-block;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: center;
    vertical-align: middle;
    color: var(--TableCellColor);
    background-color: var(--TableCellBgColor);
    padding: 2px;
}

div.bookingview__value--selected {
    background-color: #e3e3ee;
}

div.bookingview__value--new {
    background-color: var(--GreenButtonBgColor);
    color: var(--GreenButtonColor);
}

div.bookingview__value--del {
    background-color: var(--RedButtonBgColor);
    color: var(--RedButtonColor);
}

div.bookingview__rowvalue {
    display: inline-block;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: left;
    vertical-align: middle;
    color: var(--TableCellColor);
    background-color: var(--TableCellBgColor);
    padding: 2px 2px 2px 6px;
}

div.bookingview--cols3 div.bookingview__rowvalue {
    grid-column: 1 / span 6;
}

div.bookingview--cols4 div.bookingview__rowvalue {
    grid-column: 1 / span 8;
}

div.bookingview__rowvalue--preview {
    display: inline-block;
    grid-column: 1 / span 6;
}

div.bookingview__rowvalue--info {
    text-align: center;
    color: var(--ColorInfo);
}

div.bookingview__rowvalue--legend {
    margin: 10px 0 10px 0;
    font-size: var(--FontSizeS);
    line-height: 14px;
    color: var(--ColorInfo);
}

div.bookingview__rowvalue--change {
    padding-left: 12px;
}

div.bookingview__rowvalue--selected {
    background-color: #e3e3ee;
}

div.bookingview__rowvalue--new {
    background-color: var(--GreenButtonBgColor);
    color: var(--GreenButtonColor);
}

@media screen and (max-width: 600px) {

    div.bookingview {
        grid-gap: 2px;
    }

    div.bookingview--selection {
        padding-top: 15px;
    }
}

/*------------------------------------*\
  #Bookingedit
\*------------------------------------*/

div.bookingedit {
    display: grid;
    grid-template-columns: auto auto minmax(auto, 86px) auto;
    grid-template-columns: auto 1fr;
    grid-gap: 5px;
    padding: 25px 0 25px 0;
}

div.bookingedit__rowheader {
    display: inline-block;
    align-self: center;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: left;
    vertical-align: middle;
    color: var(--TableHeaderColor);
    background-color: var(--TableHeaderBgColor);
    padding: 2px 5px 2px 5px;
}

div.bookingedit__value {
    display: block;
    align-self: center;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: left;
    vertical-align: middle;
    padding: 2px;
}

div.bookingedit__control {
    display: block;
    align-self: center;
    font-size: var(--FontSizeM);
    font-weight: normal;
    line-height: 22px;
    text-align: left;
    vertical-align: middle;
    padding: 0;
}

    div.bookingedit__control div.CtlSelect {
        width: calc(100% - 2px);
    }

        div.bookingedit__control div.CtlSelect select {
            width: calc(100% - 2px);
        }

div.bookingedit__value div.CtlRadio {
    display: inline-block;
    padding: 0 10px 0 0;
}


@media screen and (max-width: 600px) {

    div.bookingedit {
        grid-template-columns: auto 1fr;
        grid-gap: 5px;
        padding: 15px 0 15px 0;
    }

    div.bookingedit__value div.CtlRadio {
        display: inline-block;
        padding: 0 10px 0 0;
    }
}


/*------------------------------------*\
  #tabselection
\*------------------------------------*/

div.tabselection {
    display: grid;
    grid-gap: 2px;
    grid-template-columns: auto auto auto 1fr;
    margin: 0 0 10px 0;
}

div.tabselection__btn {
    display: inline-block;
    user-select: none;
    padding: 3px 10px 3px 10px;
    background-color: var(--PrimaryButtonBgColor);
    color: var(--PrimaryButtonColor);
}

div.tabselection__btn--selected {
    border-bottom: 4px #3652c0 solid;
}

div.tabcontent {
    display: none;
}

div.tabcontent--selected {
    display: block;
}


/*------------------------------------*\
  #Grid
\*------------------------------------*/

.griditem100 {
    display: inline-block;
    width: 100%;
}

.gridspan-2 {
    grid-column: auto / span 2;
}

.gridspan-4 {
    grid-column: auto / span 4;
}

.gridspan-1m2 {
    grid-column: auto / span 1;
}

.gridspan-2m4 {
    grid-column: auto / span 2;
}

.gridspan-2mh {
    grid-column: auto / span 2;
}

@media screen and (max-width: 600px) {

    .gridspan-1m2 {
        grid-column: auto / span 2;
    }

    .gridspan-2m4 {
        grid-column: auto / span 4;
    }

    .gridspan-2mh {
        display: none;
    }
}


/*
    Workflow
*/



div.WrpWfNextEntscheider {
    margin: 60px 0 0 0;
}


/* 
    Tbl-Werte 
*/

.CSSTblHeadB {
    font-weight: bold;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellHeadBgColor);
}

.CSSTblHead {
    font-weight: normal;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellHeadBgColor);
}

.CSSTblCellGray {
    font-weight: normal;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellContentBgColor);
}

.CSSTblCellWhite {
    font-weight: normal;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: #ffffff;
}

/* PageMain-Werte */
.CSSpageMain {
    font-size: var(--FontSizeM);
    margin: 0px;
    color: #000000;
    position: static;
    background-color: #ffffff;
}

A.CSSpageMain:link {
    color: #5076e6;
}

A.CSSpageMain:visited {
    color: #5076e6;
}

A.CSSpageMain:hover {
    color: #5076e6;
}

A.CSSpageMainActiveLink:link {
    font-weight: bold;
    color: #f08f00;
}

A.CSSpageMainActiveLink:visited {
    font-weight: bold;
    color: #f08f00;
}

A.CSSpageMainActiveLink:hover {
    font-weight: bold;
    color: #f08f00;
}

/*
 Page: Vertreter
*/

.InfoHeader {
    display: block;
    background-color: var(--CellHeadBgColor);
    width: 600px;
    font-size: var(--FontSizeM);
    font-weight: bold;
    margin-bottom: 10px;
    padding-left: 5px;
    padding-top: 2px;
    padding-bottom: 2px;
    padding-right: 5px;
}

table.VertreterList tr th {
    background-color: var(--CellHeadBgColor);
    font-size: var(--FontSizeTbl);
    border-right: 5px solid white;
    text-align: left;
    padding-left: 5px;
    padding-right: 10px;
    padding-top: 2px;
    padding-bottom: 2px;
    border-bottom: 5px solid white;
}

table.VertreterList tr td {
    font-size: var(--FontSizeTbl);
    border-right: 5px solid white;
    border-top: 2px solid white;
}

    table.VertreterList tr td.KeyText {
        background-color: var(--CellHeadBgColor);
        font-size: var(--FontSizeTbl);
        /*border-right:2px solid white;
	border-top:2px solid white;*/
        padding-left: 5px;
        padding-right: 10px;
    }

hr.Vertretung {
    background-color: var(--CellHeadBgColor);
    color: var(--CellHeadBgColor);
    width: 600px;
    height: 1px;
    margin-bottom: 10px;
}

.VertreterContent {
    display: block;
    margin-bottom: 10px;
}

    .VertreterContent td.Info {
        background-color: var(--CellHeadBgColor);
        width: 80px;
        padding-left: 5px;
        padding-right: 5px;
        border-right: solid 5px white;
    }

        .VertreterContent td.Info input {
            margin-right: 5px;
        }

    .VertreterContent .CalendarPos {
        margin-left: 95px;
    }

table.VertreterStd {
    font-size: var(--FontSizeTbl);
    margin-bottom: 10px;
}

    table.VertreterStd td.Tage {
        border-right: solid 5px white;
        /*background-color:#ececec;*/
    }

        table.VertreterStd td.Tage input {
            width: 50px;
            text-align: center;
        }

    table.VertreterStd td.LabelMore {
        border-left: solid 5px white;
        border-right: solid 5px white;
    }

table.VertreterZeit {
    font-size: var(--FontSizeTbl);
}

    table.VertreterZeit td.VonDatum input {
        width: 80px;
        text-align: center;
        margin-right: 3px;
    }

    table.VertreterZeit td.BisDatum input {
        width: 80px;
        text-align: center;
        margin-right: 3px;
    }

    table.VertreterZeit td.LabelBis {
        border-left: solid 5px white;
        border-right: solid 5px white;
    }

    table.VertreterZeit td.Vertreter {
        border-left: solid 15px white;
    }

/*
	Antrag
*/

.AntragText {
    display: block;
    width: 405px;
    height: 50px;
    overflow: auto;
    background-color: var(--CellContentBgColor);
    font-size: var(--FontSizeM);
    padding-left: 3px;
    padding-right: 3px;
}


/*

Antraege

*/
.Request td, .Request input, .Request td, .Request th {
    font-size: var(--FontSizeTbl);
}

.Request .Head {
    margin-bottom: 15px;
    font-size: var(--FontSizeTbl);
    background-color: var(--CellHeadBgColor);
}

.Request .Button {
    padding: 2px 2px 2px 2px;
}

.Request .Label {
    border-left: 5px solid var(--CellHeadBgColor);
    color: black;
    background-color: var(--CellHeadBgColor);
    font-size: var(--FontSizeM);
    width: 800px;
    padding-left: 5px;
    text-align: left;
}

.Request .Panel {
    margin-bottom: 15px;
    font-size: var(--FontSizeM);
}

.Request .Filter {
    margin-top: 10px;
    border-top: 1px solid var(--CellHeadBgColor);
    padding-top: 10px;
    font-size: var(--FontSizeTbl);
}

.Request input.Date {
    width: 80px;
    text-align: center;
    margin-right: 3px;
    margin-left: 5px;
}

.Request img {
    margin-right: 5px;
}

.RequestList {
    width: 750px;
}

    .RequestList th {
        background-color: var(--CellHeadBgColor);
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 5px;
        padding-right: 5px;
        padding-top: 2px;
        padding-bottom: 2px;
        border-left: solid 5px white;
        border-bottom: solid 3px white;
        white-space: nowrap;
    }

        .RequestList th.ReqInfo {
            background-color: white;
            width: 18px;
            border-left: solid 0px white;
            border-bottom: solid 3px white;
            padding: 0px 0px 0px 0px;
        }

        .RequestList th.ReqKos {
            border-top: solid 5px white;
            background-color: #5076e6;
            color: White;
        }

        .RequestList th.ReqStatus {
            background-color: var(--CellHeadBgColor);
            width: 0px;
            border-left: solid 0px white;
            border-bottom: solid 3px white;
        }


    .RequestList td {
        background-color: var(--CellContentBgColor);
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 5px;
        padding-right: 5px;
        border-left: solid 5px white;
        /*border-bottom:solid 3px white;*/
        border-bottom: solid 1px white;
        border-top: solid 2px white;
        white-space: nowrap;
    }

        .RequestList td.ReqInfo {
            background-color: white;
            /*background-color:#ececec;*/
            width: 18px;
            border-left: solid 0px white;
            /*border-bottom:solid 3px white;*/
            /*border-bottom:solid 2px white;
	border-top:solid 2px white;*/
            padding: 0px 0px 0px 0px;
        }

        .RequestList td.ReqStatus {
            background-color: var(--CellContentBgColor);
            width: 0px;
            border-left: solid 0px white;
            padding-right: 0;
            /*border-bottom:solid 3px white;*/
            /*border-bottom:solid 2px white;
	border-top:solid 2px white;*/
        }

        .RequestList td.ReqEntschiedenG {
            color: green;
        }

        .RequestList td.ReqEntschiedenA {
            color: red;
        }

        .RequestList td.ReqUebernommen {
            color: blue;
        }

.ReqListNew {
    margin-top: 5px;
    margin-left: 21px;
}

.RequestNo {
    display: block;
    margin-left: 21px;
}

/*
	Buchungskorrekturen
*/

.Bookcorrection .Uebersicht th.Kommen,
.Bookcorrection .Uebersicht th.Gehen {
    font-size: var(--FontSizeTbl);
    font-weight: bold;
    text-align: center;
    background-color: var(--CellHeadBgColor);
    padding: 2px 2px 2px 2px;
    border-bottom: 5px solid white;
    width: 220px;
}

.Bookcorrection .Uebersicht th.Space {
    background-color: white;
    width: 10px;
}

.Bookcorrection .TableKommen,
.Bookcorrection .TableGehen {
    width: 100%;
}

    .Bookcorrection .TableKommen th,
    .Bookcorrection .TableGehen th {
        /*width:20px;*/
        font-size: var(--FontSizeTbl);
        font-weight: normal;
        text-align: center;
        background-color: var(--CellHeadBgColor);
        padding: 2px 2px 2px 2px;
        border-bottom: 4px solid white;
        border-right: 4px solid white;
        width: 70px;
    }

        .Bookcorrection .TableKommen th.Choose,
        .Bookcorrection .TableGehen th.Choose {
            border-right: 4px solid white;
            width: 20px;
            padding: 0px 0px 0px 0px;
        }

        .Bookcorrection .TableKommen th.Grund,
        .Bookcorrection .TableGehen th.Grund {
            border-right: 0px solid white;
        }


.Bookcorrection input {
    margin: 0px;
    padding: 0px;
}

.Bookcorrection .TableKommen td,
.Bookcorrection .TableGehen td {
    background-color: var(--CellContentBgColor);
    border-right: 4px solid white;
    font-size: var(--FontSizeTbl);
    /*padding:2px 2px 2px 2px;*/
    border-bottom: 4px solid white;
    text-align: center;
    height: 27px;
}

    .Bookcorrection .TableKommen td.Grund,
    .Bookcorrection .TableGehen td.Grund {
        border-right: 0px solid white;
    }

.Bookcorrection .TableKommen tr.BookIdSelected td,
.Bookcorrection .TableGehen tr.BookIdSelected td {
    background-color: #cccccc;
    border-right: 4px solid white;
    font-size: var(--FontSizeTbl);
    /*padding:2px 2px 2px 2px;*/
    border-bottom: 4px solid white;
    text-align: center;
    height: 27px;
    font-weight: bold;
}

    .Bookcorrection .TableKommen tr.BookIdSelected td.Grund,
    .Bookcorrection .TableGehen tr.BookIdSelected td.Grund {
        border-right: 0px solid white;
    }

.Bookcorrection .TableKommen tr.BookIdSelectedNew td,
.Bookcorrection .TableGehen tr.BookIdSelectedNew td {
    background-color: #00ff00;
    border-right: 4px solid white;
    font-size: var(--FontSizeTbl);
    /*padding:2px 2px 2px 2px;*/
    border-bottom: 4px solid white;
    text-align: center;
    height: 27px;
    font-weight: bold;
}

    .Bookcorrection .TableKommen tr.BookIdSelectedNew td.Grund,
    .Bookcorrection .TableGehen tr.BookIdSelectedNew td.Grund {
        border-right: 0px solid white;
    }


.Bookcorrection .NewBooking {
    background-color: var(--CellContentBgColor);
    /*border-top:10px solid white;*/
    font-size: var(--FontSizeTbl);
    width: 100%;
}

.Bookcorrection .NewBookingSelected {
    background-color: #cccccc;
    /*border-top:10px solid white;*/
    font-size: var(--FontSizeTbl);
    width: 100%;
    font-weight: bold;
}

.Bookcorrection table.BookData th {
    font-size: var(--FontSizeTbl);
    text-align: left;
    vertical-align: bottom;
    border-right: 5px solid white;
    border-bottom: 7px solid white;
    border-top: 7px solid white;
    background-color: var(--CellHeadBgColor);
    padding: 2px 3px 2px 3px;
}

.Bookcorrection table.BookData td {
    font-size: var(--FontSizeTbl);
    /*background-color:#ececec;*/
    /*padding:2px 5px 2px 5px;*/
    border-right: 5px solid white;
    /*border-bottom:5px solid white;*/
}

    .Bookcorrection table.BookData td input {
        font-size: var(--FontSizeTbl);
    }

    .Bookcorrection table.BookData td textarea {
        font-size: var(--FontSizeTbl);
        width: 100%;
        height: 50px;
    }


.Bookcorrection table.Entscheidung {
    width: 530px;
}

    .Bookcorrection table.Entscheidung th {
        border-bottom: 3px solid white;
        background-color: var(--CellHeadBgColor);
        padding: 2px 3px 2px 3px;
        font-size: var(--FontSizeTbl);
        text-align: left
    }

    .Bookcorrection table.Entscheidung td {
        border-bottom: 3px solid white;
        background-color: var(--CellContentBgColor);
        padding: 2px 3px 2px 3px;
        font-size: var(--FontSizeTbl);
        vertical-align: middle;
        text-align: left;
    }

        .Bookcorrection table.Entscheidung td.KeyText {
            border-bottom: 3px solid white;
            background-color: var(--CellHeadBgColor);
            padding: 2px 3px 2px 3px;
            font-size: var(--FontSizeTbl);
            width: 120px;
            border-right: 5px solid white;
            height: 25px;
            vertical-align: middle;
        }

        .Bookcorrection table.Entscheidung td.KeyTextSpace {
            border-bottom: 3px solid white;
            background-color: white;
            padding: 2px 5px 2px 5px;
            font-size: var(--FontSizeTbl);
            width: 120px;
            border-right: 5px solid white;
        }

        .Bookcorrection table.Entscheidung td.Edit {
            border-bottom: 3px solid white;
            font-size: var(--FontSizeTbl);
            padding: 0px 0px 0px 0px;
            background-color: white;
            vertical-align: top;
        }

    .Bookcorrection table.Entscheidung select {
        width: 100%;
    }

    .Bookcorrection table.Entscheidung textarea {
        width: 100%;
        height: 60px;
    }

    .Bookcorrection table.Entscheidung td.Begruendung {
        vertical-align: top;
        padding: 0px 0px 0px 0px;
        background-color: white;
    }

    .Bookcorrection table.Entscheidung div {
        font-size: var(--FontSizeTbl);
    }
/*
    Rahmenzeitkorrekturen
*/

.skeletontimeview {
    display: grid;
    row-gap: 5px;
    column-gap: 5px;
    grid-template-columns: minmax(60px, 25%) minmax(60px, 25%) auto;
}

.skeletontimeview-infocell-timevalue {
    position: relative;
    display: inline-block;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    width: 52px;
    padding: 2px 5px 2px 5px;
}

.skeletontimeview-infocell-textvalue {
    position: relative;
    display: inline-block;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    padding: 2px 5px 2px 5px;
}

    .skeletontimeview-infocell-unmodified {
        color: var(--FrmValueColor);
        background-color: var(--StvUnmodifiedBgColor);
    }

    .skeletontimeview-infocell-requested-added {
        color: var(--StvRequestedColor);
        background-color: var(--StvRequestedAddedBgColor);
    }
        
    .skeletontimeview-infocell-requested-modified {
        color: var(--StvRequestedColor);
        background-color: var(--StvRequestedModifiedBgColor);
    }

@media screen and (min-width: 601px) {
    .skeletontimeview-inputheader {
        padding-top: 3px;
        color: var(--ColorInfo);
        font-size: var(--FontSizeS);
    }
        
    .skeletontimeview-infoheader {
        padding-top: 3px;
        color: var(--ColorLight);
        font-size: var(--FontSizeS);
    }
}

@media screen and (max-width: 600px) {
    .skeletontimeview-inputheader {
        padding-top: 3px;
        color: var(--FrmLabelColorMobile);
        font-size: var(--FontSizeXS);
    }

    .skeletontimeview-infoheader {
        padding-top: 3px;
        color: var(--FrmLabelColorMobile);
        font-size: var(--FontSizeXS);
    }
}

/*
	Datumsbox
*/

input.DateBox {
    width: 90px;
    /*text-align:center;*/
    margin-right: 3px;
    padding-left: 4px;
    margin-left: 0;
}


/* 
	Listen
*/

Table.Listen {
    /*width:600px;*/
}

    Table.Listen th {
        background-color: var(--CellHeadBgColor);
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 5px;
        padding-right: 5px;
        padding-top: 2px;
        padding-bottom: 2px;
        border-left: solid 4px white;
        border-bottom: solid 3px white;
        white-space: nowrap;
    }

        Table.Listen th.Info {
            background-color: white;
            width: 18px;
            border-left: solid 0px white;
            border-bottom: solid 3px white;
            padding: 0px 0px 0px 0px;
            white-space: nowrap;
            width: 40px;
        }

    Table.Listen td {
        /*background-color:#ececec;*/
        background-color: #eeeeee;
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 5px;
        padding-right: 5px;
        border-left: solid 4px white;
        /*border-bottom:solid 3px white;*/
        border-bottom: solid 1px white;
        border-top: solid 2px white;
        white-space: nowrap;
    }

    Table.Listen tr.Selected td {
        /*background-color:#ececec;*/
        /*background-color:#eeeeee;*/
        background-color: #00ff00;
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 5px;
        padding-right: 5px;
        padding-top: 0;
        padding-bottom: 0;
        border-left: solid 4px white;
        /*border-bottom:solid 3px white;*/
        border-bottom: solid 1px white;
        border-top: solid 2px white;
        white-space: nowrap;
    }

        Table.Listen tr.Selected td.Center {
            text-align: center;
        }

        Table.Listen td.Info, Table.Listen tr.Selected td.Info {
            background-color: white;
            /*background-color:#ececec;*/
            border-left: solid 0px white;
            /*border-bottom:solid 3px white;*/
            /*border-bottom:solid 2px white;
	border-top:solid 2px white;*/
            padding: 0px 0px 0px 0px;
            white-space: nowrap;
            /*width:40px;*/
        }

    Table.Listen td.Edit {
        /*background-color:#ececec;*/
        /*background-color:#eeeeee;*/
        background-color: white;
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 0px;
        /*	padding-right:5px;*/
        border-left: solid 4px white;
        /*border-bottom:solid 3px white;*/
        border-bottom: solid 1px white;
        border-top: solid 2px white;
        white-space: nowrap;
        padding: 0 0 0 0;
        text-align: center;
    }

    Table.Listen tr.Selected td.Edit {
        /*background-color:#ececec;*/
        /*background-color:#eeeeee;*/
        background-color: white;
        /*background-color:#00ff00;*/
        /*width:80px;*/
        font-size: var(--FontSizeTbl);
        text-align: left;
        padding-left: 0px;
        /*	padding-right:5px;*/
        border-left: solid 4px white;
        /*border-bottom:solid 3px white;*/
        border-bottom: solid 1px white;
        border-top: solid 2px white;
        white-space: nowrap;
        padding: 0 0 0 0;
        text-align: center;
    }
/* 
	/Listen
*/


/*------------------------------------*\
  #Calendar
\*------------------------------------*/

div.CalendarWrapper {
    z-index: 9999;
    display: none;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    div.CalendarWrapper.active {
        position: absolute;
        display: block;
        border: 1px solid #C5C6C6;
        box-shadow: 2px 2px 3px #909090;
    }

    div.CalendarWrapper span.Calendar {
        display: inline-block;
        margin: auto auto;
        font-size: var(--FontSizeM);
        Z-INDEX: 1000;
        background-color: white;
    }

        div.CalendarWrapper span.Calendar table {
            border: 1px solid #c0c0c0;
            border: none;
            border-spacing: 0 0;
            background-color: var(--BackgroundDefault);
        }

        div.CalendarWrapper span.Calendar td {
            border: none;
            padding: 0;
            text-align: center;
            font-size: var(--FontSizeM);
            background-color: var(--BackgroundDefault);
        }

span.Calendar tr.CalendarHeaderRow td {
    background-color: var(--PrimaryButtonBgColor);
    color: var(--PrimaryButtonColor);
    text-align: center;
    vertical-align: middle;
    height: 40px;
    font-size: var(--FontSizeL);
    font-weight: bold;
}

span.Calendar tr.CalendarSpaceRow td {
    height: 15px;
}

span.Calendar tr.CalendarMonthRow td {
    text-align: center;
    font-size: var(--FontSizeL);
}

    span.Calendar tr.CalendarMonthRow td:first-child {
        padding-left: 10px;
    }

    span.Calendar tr.CalendarMonthRow td:last-child {
        padding-right: 10px;
    }

    span.Calendar tr.CalendarMonthRow td.CalendarMonth {
        border: 0px solid white;
        text-align: center;
        font-size: var(--FontSizeXL);
        font-weight: normal;
        background-color: var(--BackgroundDefault);
        color: var(--ColorLight);
    }

span.Calendar tr.CalendarMonthRow button {
    padding: 0;
    border: none;
    background-color: var(--BackgroundDefault);
    cursor: pointer;
}

    span.Calendar tr.CalendarMonthRow button:focus {
        outline: none;
    }

span.Calendar tr.CalendarMonthRow img {
    margin: 0;
    height: 16px;
}

    span.Calendar tr.CalendarMonthRow img:focus {
        outline: none;
    }

span.Calendar tr.CalendarDayRow td {
    padding: 10px 0 10px 0;
    background-color: var(--BackgroundLight);
}

    span.Calendar tr.CalendarDayRow td:first-child {
        padding-left: 10px;
    }

    span.Calendar tr.CalendarDayRow td:last-child {
        padding-right: 10px;
    }

span.Calendar tr.CalendarWeekRow {
    height: 32px;
}

    span.Calendar tr.CalendarWeekRow td {
        padding: 1px;
        background-color: var(--BackgroundLight);
    }

        span.Calendar tr.CalendarWeekRow td:first-child {
            padding-left: 10px;
        }

        span.Calendar tr.CalendarWeekRow td:last-child {
            padding-right: 10px;
        }

    span.Calendar tr.CalendarWeekRow button {
        width: 28px;
        height: 28px;
        padding: 0;
        text-align: center;
        font-size: var(--FontSizeM);
        background-color: var(--BackgroundLight);
        border: 1px solid var(--BackgroundLight);
        border-radius: 14px;
        cursor: pointer;
    }

        span.Calendar tr.CalendarWeekRow button:focus {
            outline: none;
        }

        span.Calendar tr.CalendarWeekRow button.CalToday {
            border: 2px solid #c4d8fc;
        }

        span.Calendar tr.CalendarWeekRow button.CalSelection {
            color: var(--PrimaryButtonColor);
            background-color: var(--PrimaryButtonBgColor);
            border: 1px solid var(--PrimaryButtonBgColor);
        }

.Calendar tr.CalendarWeekRow button.CalSelection.CalToday {
    border: 3px solid #c4d8fc;
}


span.Calendar tr.CalendarCloseRow td {
    padding: 10px 0 10px 0;
}

@media (max-width: 600px) {

    div.CalendarWrapper.active {
        position: fixed;
        display: flex;
        justify-content: center;
        left: 0;
        top: 0;
        width: 100vw;
        height: 100vh;
        border: none;
        box-shadow: none;
        background-color: var(--OpacityDarkColor);
    }

    div.CalendarWrapper span.Calendar td {
        font-size: var(--FontSizeL);
    }

    span.Calendar tr.CalendarWeekRow {
        height: 38px;
    }

        span.Calendar tr.CalendarWeekRow button {
            width: 36px;
            height: 36px;
            border-radius: 18px;
            font-size: var(--FontSizeL);
        }

            span.Calendar tr.CalendarWeekRow button.CalToday {
                border: 3px solid #c4d8fc;
            }

            span.Calendar tr.CalendarWeekRow button.CalSelection.CalToday {
                border: 4px solid #c4d8fc;
            }
}


/*------------------------------------*\
  #Diverses
\*------------------------------------*/


.Balken {
    width: 600px;
    background-color: var(--CellHeadBgColor);
    padding: 3px;
    font-weight: bold;
}


.BalkenAuto {
    width: auto;
    min-width: 770px;
    background-color: var(--CellHeadBgColor);
    padding: 3px;
    font-weight: bold;
}




.BdKommenGehen label {
    margin-top: -5px;
}


.tab {
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 3px;
    padding-top: 3px;
    border-right: white 1px solid;
    color: white;
    background-color: #5076e6;
    border-bottom: white 1px solid;
}

.tabsel {
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 3px;
    padding-top: 3px;
    border-right: #2F4987 1px solid;
    color: white;
    background-color: #5076e6;
    font-weight: bold;
    border-bottom: #2F4987 1px solid;
}




table.InfoTbl tr th {
    /*padding-left:5px;
	padding-right:5px*/
    padding: 1px 5px 1px 5px;
    font-weight: bold;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellHeadBgColor);
}

table.InfoTbl tr td {
    padding: 1px 5px 1px 5px;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellContentBgColor);
    border-top: 4px solid white;
    width: 100px;
}

    table.InfoTbl tr td.headline {
        background-color: var(--CellHeadBgColor);
        border-right: 8px solid white;
    }


table.TblBuchungen tr th {
    padding: 2px 5px 2px 5px;
    font-weight: bold;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellHeadBgColor);
    border-right: 10px solid white;
    text-align: center;
}

table.TblBuchungen tr td {
    padding: 2px 3px 2px 3px;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellContentBgColor);
    border-right: 5px solid white;
    border-top: 5px solid white;
    width: 70px;
}

    table.TblBuchungen tr td.subheader {
        background-color: var(--CellHeadBgColor);
        text-align: center;
    }

    table.TblBuchungen tr td.subheadergrund {
        background-color: var(--CellHeadBgColor);
        text-align: center;
        border-right: 10px solid white;
    }


    table.TblBuchungen tr td.zeit {
        text-align: center;
    }

    table.TblBuchungen tr td.grund {
        border-right: 10px solid white;
    }




table.TblBuchungenB tr th {
    padding: 2px 5px 2px 5px;
    font-weight: bold;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellHeadBgColor);
    border-right: 5px solid white;
    border-top: 5px solid white;
    text-align: center;
}

    table.TblBuchungenB tr th.subheader {
        font-weight: normal;
        width: 75px;
    }

table.TblBuchungenB tr td {
    padding: 2px 3px 2px 3px;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: var(--CellContentBgColor);
    border-right: 5px solid white;
    border-top: 5px solid white;
}

    table.TblBuchungenB tr td.Zeit {
        text-align: center;
    }

table.TblBuchungenB tr.Other td {
    padding: 0px 0px 0px 0px;
    font-size: var(--FontSizeTbl);
    color: #000000;
    background-color: #FFFFFF;
    border-right: 5px solid white;
    border-top: 5px solid white;
}

table.listeAllg {
    empty-cells: show;
    border-collapse: collapse;
}

    table.listeAllg tr th {
        border: solid 1px white;
        text-align: left;
        padding: 2px 3px 2px 3px;
        background-color: var(--CellHeadBgColor);
    }

    table.listeAllg tr td {
        border: solid 1px white;
        padding: 2px 3px 2px 3px;
        background-color: var(--CellContentBgColor);
    }

.cssInfoList {
    border-spacing: 1px;
    empty-cells: show;
    border-collapse: collapse;
}

    .cssInfoList tr th {
        background-color: var(--CellHeadBgColor);
        padding: 1px 5px 1px 5px;
        border: 1px solid white;
        font-size: var(--FontSizeTbl);
        white-space: nowrap;
    }

    .cssInfoList tr td {
        background-color: var(--CellContentBgColor);
        padding: 1px 5px 1px 5px;
        border: 1px solid white;
        font-size: var(--FontSizeTbl);
        white-space: nowrap;
    }

        .cssInfoList tr td.txtInput {
            padding: 0px 5px 0px 5px;
        }

        .cssInfoList tr td.footer {
            background-color: white;
            padding: 10px 5px 0px 5px;
            border: 1px solid white;
            text-align: right;
            font-size: var(--FontSizeTbl);
            white-space: nowrap;
        }

/*------------------------------------*\
  #Ctl
\*------------------------------------*/

div.CtlLabelBox {
    margin: 0 10px 0 0;
    padding: 3px 10px 2px 5px;
    color: var(--FrmLabelColor);
    background-color: var(--FrmLabelBgColor);
    vertical-align: middle;
}

.ad-button {
    margin: 0 0 0 0;
    padding: 2px 10px 2px 10px;
    line-height: 22px;
    border-radius: 8px;
    cursor: pointer;
    background-color: var(--LightButtonBgColor);
    color: var(--LightButtonColor);
    border: 1px solid var(--LightButtonColor);
}

    .ad-button:focus {
        outline: none;
    }

.ad-button--primary {
    background-color: var(--PrimaryButtonBgColor);
    color: var(--PrimaryButtonColor);
    border-color: var(--PrimaryButtonBgColor);
}

.ad-button--green {
    background-color: var(--GreenButtonBgColor);
    color: var(--GreenButtonColor);
    border-color: var(--GreenButtonBgColor);
}

.ad-button--red {
    background-color: var(--RedButtonBgColor);
    color: var(--RedButtonColor);
    border-color: var(--RedButtonBgColor);
}

.ad-button:disabled {
    background-color: var(--DisabledButtonBgColor);
    color: var(--DisabledButtonColor);
    border-color: var(--DisabledButtonBgColor);
}

.ad-check-container {    
    display: inline-block;
    position: relative;
    height: 24px;
}

    .ad-check-container input.ad-check-round {
        appearance: none;
        position: relative;
        border: 0;
        outline: none;
        transition: all .3s;
        cursor: pointer;
        margin: 0;
        width: 24px;
        height: 24px;
        border: 1px solid #a6a6a6;
        border-radius: 14px;
        background: #fff;
    }

        .ad-check-container input.ad-check-round:checked {
            background: #578cfa;
            border-color: #578cfa;
        }

            .ad-check-container input.ad-check-round:checked + span.ad-check-round-mark {
                display: block;
            }

        .ad-check-container input.ad-check-round + span.ad-check-round-mark {
            display: none;
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            left: 0;
            cursor: pointer;
            pointer-events: none;
        }

            .ad-check-container input.ad-check-round + span.ad-check-round-mark:after {
                content: "";
                position: absolute;
                top: 50%;
                left: 47%;
                margin-top: -4px;
                margin-left: -5px;
                width: 10px;
                height: 4px;
                border-left: 2px solid white;
                border-bottom: 2px solid white;
                transform: rotate(-45deg);
            }

.ad-check-round-label {
    display: inline-block;
}

.ad-check-round-label--left {
    margin-right: 8px;
}

.ad-check-round-label--right {
    margin-left: 8px;
}

input[type=image].CtlInfoButton.InTable {
    width: 18px;
    height: 18px;
    border: none;
}

    input[type=image].CtlInfoButton.InTable:focus {
        outline: none;
    }

div.CtlSelect {
    position: relative;
    vertical-align: top;
    display: inline-flex;
    border: 1px solid var(--ControlBorderColor);
    background-color: var(--ControlBgColor);
    padding: 1px 0 0 0;
}

    div.CtlSelect.disabled {
        border: 1px solid var(--ControlBorderColorDisabled);
        background-color: var(--ControlBgColorDisabled);
    }

select.CtlSelect {
    position: relative;
    display: block;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    padding: 2px 20px 2px 5px;
    border: none;
    background-color: var(--ControlBgColor);
}

select:disabled.CtlSelect {
    background-color: var(--ControlBgColorDisabled);
}

select.CtlSelect:focus {
    outline: none;
}

div.CtlSelectBtn {
    position: absolute;
    top: calc(50% - 6px);
    right: 3px;
    background-image: url('ctl-dropdown.svg');
    background-size: cover;
    width: 12px;
    height: 12px;
    pointer-events: none;
}

    div.CtlSelectBtn.disabled {
        background-image: url('ctl-dropdowndisabled.svg');
    }

div.CtlPrev {
    vertical-align: top;
    position: relative;
    display: inline-flex;
    box-sizing: border-box;
    width: 17px;
    height: 25px;
    margin: 0 5px 0 0;
    border: 1px solid transparent;
    border-radius: 3px;
    background-color: var(--PrimaryButtonBgColor);
    cursor: pointer;
}

    div.CtlPrev > div {
        margin: 3px 0 0 1px;
        width: 12px;
        height: 16px;
        border: none;
        background-image: url('btn-prev.svg');
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
    }

    div.CtlPrev.disabled {
        background-color: var(--DisabledButtonBgColor);
        cursor: initial;
    }

        div.CtlPrev.disabled:before {
            border-right: 6px solid var(--DisabledButtonColor);
        }

        div.CtlPrev.disabled:after {
            border-right: 3px solid var(--DisabledButtonBgColor);
        }

div.CtlNext {
    position: relative;
    display: inline-flex;
    box-sizing: border-box;
    width: 17px;
    height: 25px;
    margin: 0 0 0 5px;
    border: 1px solid transparent;
    border-radius: 3px;
    background-color: var(--PrimaryButtonBgColor);
    text-align: center;
    cursor: pointer;
}

    div.CtlNext > div {
        margin: 3px 0 0 2px;
        width: 12px;
        height: 16px;
        border: none;
        background-image: url('btn-next.svg');
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
    }

    div.CtlNext.disabled {
        background-color: var(--DisabledButtonBgColor);
        cursor: initial;
    }

        div.CtlNext.disabled:before {
            border-left: 6px solid var(--DisabledButtonColor);
        }

        div.CtlNext.disabled:after {
            border-left: 3px solid var(--DisabledButtonBgColor);
        }

div.CtlLabel {
    display: inline-block;
    vertical-align: middle;
}

.CtlText {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    outline: none !important;
    border: 1px solid var(--ControlBorderColor);
    border-radius: 0;
    background-color: var(--ControlBgColor);
    padding: 2px 5px 2px 5px;
}

.CtlTextarea {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    outline: none !important;
    border: 1px solid var(--ControlBorderColor);
    border-radius: 0;
    background-color: var(--ControlBgColor);
    padding: 2px 5px 2px 5px;
}

div.CtlDate {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    align-items: flex-start;
    border: 1px solid var(--ControlBorderColor);
    border-radius: 0;
    background-color: var(--ControlBgColor);
    min-height: 23px;
}

    div.CtlDate input[type=text],
    div.CtlDate input[type=text]:focus {
        position: relative;
        display: inline-block;
        -moz-appearance: none;
        -webkit-appearance: none;
        appearance: none;
        width: 104px;
        padding: 2px 5px 2px 5px;
        border: none;
        background-color: var(--ControlBgColor);
    }

        div.CtlDate input[type=text]:focus {
            box-shadow: none;
            outline: none;
        }

    div.CtlDate button {
        border: none;
        display: block;
        position: absolute;
        top: calc(50% - 12px);
        right: 0;
        width: 18px;
        height: 22px;
        background-color: transparent;
    }

        div.CtlDate button:before {
            display: block;
            position: absolute;
            content: "";
            right: 3px;
            top: 5px;
            width: 12px;
            height: 12px;
            background-image: url('ctl-dropdown.svg');
            background-size: cover;
        }

        div.CtlDate button:focus {
            outline: none;
        }

    div.CtlDate.disabled input[type=text] {
        color: var(--ColorDisabled);
    }


div.CtlTime {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    align-items: flex-start;
    border: 1px solid var(--ControlBorderColor);
    border-radius: 0;
    background-color: var(--ControlBgColor);
    min-height: 23px;
}

    div.CtlTime.disabled {
        border: 1px solid var(--ControlBorderColorDisabled);
        background-color: var(--ControlBgColorDisabled);
    }

    div.CtlTime input[type=text],
    div.CtlTime input[type=text]:focus {
        position: relative;
        display: inline-block;
        -moz-appearance: none;
        -webkit-appearance: none;
        appearance: none;
        width: 60px;
        padding: 2px 5px 2px 5px;
        border: none;
        background-color: var(--ControlBgColor);
    }

        div.CtlTime input[type=text]:focus {
            box-shadow: none;
            outline: none;
        }

    div.CtlTime.disabled input[type=text] {
        background-color: var(--ControlBgColorDisabled);
    }

div.CtlRadio {
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
}

div.CtlRadio--nolabel {
    width: 22px;
}

div.CtlRadio input[type=radio]:first-child {
    opacity: 0;
    position: absolute;
    margin-left: 0;
}

div.CtlRadio label {
    display: inline-block;
    min-height: 22px;
    line-height: 22px;
    padding-left: 29px;
    cursor: pointer;
    margin-bottom: 0;
    max-width: 100%;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    div.CtlRadio label:before {
        content: "";
        display: inline-block;
        position: absolute;
        width: 22px;
        height: 22px;
        border: 2px solid var(--ControlBorderColor);
        margin-left: -29px;
        border-radius: 50%;
        box-sizing: border-box;
    }

div.CtlRadio input[type=radio]:checked ~ label:before {
    background: url('ctl-check.svg') center center no-repeat;
    background-size: contain;
}

div.CtlRadio input[type=radio]:disabled ~ label {
    color: var(--DisabledButtonBgColor);
}

    div.CtlRadio input[type=radio]:disabled ~ label:before {
        border: 2px solid var(--DisabledButtonBgColor);
    }


div.CtlCheckbox {
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
}

    div.CtlCheckbox input[type=checkbox]:first-child {
        opacity: 0;
        position: absolute;
        margin-left: 0;
    }

    div.CtlCheckbox label {
        display: inline-block;
        min-height: 22px;
        line-height: 22px;
        padding-left: 29px;
        cursor: pointer;
        margin-bottom: 0;
        max-width: 100%;
        box-sizing: border-box;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    }

        div.CtlCheckbox label:before {
            content: "";
            display: inline-block;
            position: absolute;
            width: 22px;
            height: 22px;
            border: 2px solid var(--ControlBorderColor);
            margin-left: -29px;
            box-sizing: border-box;
        }

    div.CtlCheckbox input[type=checkbox]:checked ~ label:before {
        background: url('ctl-check.svg') center center no-repeat;
        background-size: contain;
    }

    div.CtlCheckbox input[type=checkbox]:disabled ~ label {
        color: var(--DisabledButtonBgColor);
    }

        div.CtlCheckbox input[type=checkbox]:disabled ~ label:before {
            border: 2px solid var(--DisabledButtonBgColor);
        }

    div.CtlCheckbox.InTable label {
        min-height: 18px;
        line-height: 18px;
        padding-left: 18px;
    }

        div.CtlCheckbox.InTable label:before {
            width: 18px;
            height: 18px;
            margin-left: -18px;
        }

div.CtlToggle {
    height: 24px;
    width: 40px;
    margin: 0;
}

    div.CtlToggle input {
        margin-left: -9999px;
    }

        div.CtlToggle input ~ label {
            position: relative;
            float: left;
            width: 40px;
            height: 25px;
            cursor: pointer;
            -webkit-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none;
        }

            div.CtlToggle input ~ label:before,
            div.CtlToggle input ~ label:after {
                position: absolute;
                display: block;
                content: ' ';
                -webkit-transition: all 250ms cubic-bezier(.4, 0, .2, 1);
                transition: all 250ms cubic-bezier(.4, 0, .2, 1);
            }

            div.CtlToggle input ~ label:before {
                top: 0px;
                left: 0px;
                width: 40px;
                height: 25px;
                border-radius: 13px;
                background-color: #bdbdbd;
            }

            div.CtlToggle input ~ label:after {
                top: 2px;
                left: 0px;
                width: 1.4em;
                height: 8px;
                bottom: 0.1em;
                margin-left: 0.1em;
                background-color: #fff;
                border-radius: 50%;
                width: 17px;
                height: 17px;
                border-radius: 50%;
                border: solid 2px;
                border-color: #fff;
            }

        div.CtlToggle input:checked ~ label:before {
            background-color: var(--GreenButtonBgColor);
        }

        div.CtlToggle input:checked ~ label:after {
            left: 14px;
            background-color: #ffffff;
            border-color: #ffffff;
        }

div.CtlToggleLabel {
    vertical-align: middle;
    line-height: 24px;
}

div.CtlSpaceLeft,
button.CtlSpaceLeft {
    margin-left: 10px;
}

div.CtlSpaceRight,
button.CtlSpaceRight {
    margin-right: 10px;
}

@media (max-width: 600px) {

    .ad-button,
    .ad-button--green,
    .ad-button--red {
        padding: 1px 8px 1px 8px;
    }

    div.CtlSelect {
        background-color: var(--ControlBgColorMobile);
        border-color: var(--ControlBorderColorMobile);
    }

        div.CtlSelect.disabled {
            background-color: var(--ControlBgColorMobileDisabled);
            border-color: var(--ControlBorderColorMobileDisabled);
        }

    select.CtlSelect {
        background-color: var(--ControlBgColorMobile);
    }

    select:disabled.CtlSelect {
        background-color: var(--ControlBgColorMobileDisabled);
    }

    div.CtlPrev.mobileframeless {
        background-color: transparent;
        border: none;
        width: 30px;
        height: 30px;
        margin-right: 15px;
    }

        div.CtlPrev.mobileframeless > div {
            margin: 0;
            width: 30px;
            height: 30px;
            border: none;
            background-image: url('btn-prevframeless-mobile.svg');
        }

        div.CtlPrev.mobileframeless.disabled > div {
            background-image: url('btn-prevframelessdisabled-mobile.svg');
        }

    div.CtlNext.mobileframeless {
        background-color: transparent;
        border: none;
        width: 30px;
        height: 30px;
        margin-left: 15px;
    }

        div.CtlNext.mobileframeless > div {
            margin: 0;
            width: 30px;
            height: 30px;
            border: none;
            background-image: url('btn-nextframeless-mobile.svg');
        }

        div.CtlNext.mobileframeless.disabled > div {
            background-image: url('btn-nextframelessdisabled-mobile.svg');
        }

    .CtlText {
        background-color: var(--ControlBgColorMobile);
        border-color: var(--ControlBorderColorMobile);
        padding: 3px;
    }

    .CtlTextarea {
        background-color: var(--ControlBgColorMobile);
        border-color: var(--ControlBorderColorMobile);
        padding: 3px;
    }

    div.CtlDate {
        background-color: var(--ControlBgColorMobile);
        border-color: var(--ControlBorderColorMobile);
    }

        div.CtlDate input[type=text],
        div.CtlDate input[type=text]:focus {
            background-color: var(--ControlBgColorMobile);
        }

        div.CtlDate button:before {
            top: 6px;
        }

    div.CtlTime {
        background-color: var(--ControlBgColorMobile);
        border-color: var(--ControlBorderColorMobile);
    }

        div.CtlTime.disabled {
            background-color: var(--ControlBgColorMobileDisabled);
            border-color: var(--ControlBorderColorMobileDisabled);
        }

        div.CtlTime input[type=text],
        div.CtlTime input[type=text]:focus {
            background-color: var(--ControlBgColorMobile);
        }

        div.CtlTime.disabled input[type=text],
        div.CtlTime.disabled input[type=text]:focus {
            background-color: var(--ControlBgColorMobileDisabled);
        }

    div.CtlRadio label:before {
        border: 1px solid var(--PrimaryButtonBgColor);
    }

    div.CtlRadio input[type=radio]:disabled ~ label:before {
        border: 1px solid var(--DisabledButtonBgColor);
    }

    div.CtlCheckbox label:before {
        border: 1px solid var(--PrimaryButtonBgColor);
    }

    div.CtlCheckbox input[type=checkbox]:disabled ~ label:before {
        border: 1px solid var(--DisabledButtonBgColor);
    }

    div.CtlToggle input ~ label:after {
        top: 1px;
        left: -1px;
        width: 19px;
        height: 19px;
        box-shadow: 0 3px 4px 0 rgba(0, 0, 0, .14), 0 3px 3px -2px rgba(0, 0, 0, .2), 0 1px 8px 0 rgba(0, 0, 0, .12);
    }
}

span.warning {
    color: var(--ColorWarning);
}

span.error {
    color: var(--ColorError);
}

span.OnlyMobile {
    display: none;
}

span.NotMobile {
    display: inline;
}

@media (max-width: 600px) {

    span.OnlyMobile {
        display: inline;
    }

    span.NotMobile {
        display: none;
    }
}

/*------------------------------------*\
  #ad-floating-action-context-menu
\*------------------------------------*/

.ad-floating-action-context-menu {
    position: absolute;
    z-index: 9300;
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.1s ease;
    margin: 0 0 80px 0;
    padding: 0;
}

    .ad-floating-action-context-menu.active {
        grid-template-rows: 1fr;
    }

    .ad-floating-action-context-menu ul {
        margin: 0;
        padding: 0;
        overflow: hidden;
        background-color: var(--NavigationBgColor);
        border-radius: 10px;
        border-radius: 16px;
        box-shadow: 1px 3px 3px var(--MaterialDesignExtendedFloatingActionButtonBoxShadowColor);
    }

    .ad-floating-action-context-menu li {
        list-style-type: none;
        padding: 0;
        margin: 0;
        padding: 14px 16px;
    }

        .ad-floating-action-context-menu li:first-of-type {
            border-top-left-radius: 16px;
            border-top-right-radius: 16px;
        }

        .ad-floating-action-context-menu li:not(:last-of-type) {
            border-bottom: 1px solid var(--NavigationLineColor);
        }

        .ad-floating-action-context-menu li:last-of-type {
            border-bottom-left-radius: 16px;
            border-bottom-right-radius: 16px;
        }

        .ad-floating-action-context-menu li button {
            display: block;
            width: 100%;
            background-color: transparent;
            border: none;
            text-overflow: ellipsis;
            overflow: hidden;
            white-space: nowrap;
        }

@media screen and (min-width: 601px) {
    .ad-floating-action-context-menu li:hover {
        background-color: var(--NavigationButtonBgColorHover);
    }
}

@media screen and (max-width: 600px) {

    .ad-floating-action-context-menu {
        margin-right: 16px;
        max-width: calc(100vw - 32px);
    }

        .ad-floating-action-context-menu li button {
            max-width: calc(100vw - 64px);
        }
}

/*------------------------------------*\
  #ad-infomessage
\*------------------------------------*/

.ad-infomessage-list {
    list-style: none;
    padding-left: 0;
    width: 100%
}

.ad-list-item.ad-infomessage {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    grid-template-areas: "header" "message" "confirmation";
    align-items: center;
    color: var(--MaterialDesignListItemColor);
}

    .ad-list-item.ad-infomessage:not(:first-child) {
        padding-top: 15px;
        border-top: 1px solid var(--MaterialDesignListItemBorderColor);
    }

    .ad-list-item.ad-infomessage:not(:last-child) {
        margin-bottom: 15px;
    }

.ad-infomessage__header {
    display: flex;
    align-items: center;
    grid-area: header;
    font-size: var(--MaterialDesignFontSizeS);
    font-weight: bold;
}

.ad-infomessage__headeritem {
    display: inline-block;
}

    .ad-infomessage__headeritem::before {
        display: inline-flex;
        position: relative;
        top: 2px;
        content: '';
        background-size: 16px 16px;
        margin-right: 6px;
        height: 16px;
        width: 16px;
    }

.ad-infomessage__headeritem--created::before {
    background-image: url('sym-mail.svg');
}

.ad-infomessage__headeritem--confirmed {
    margin-left: 16px;
}

    .ad-infomessage__headeritem--confirmed::before {
        background-image: url('sym-check.svg');
    }

.ad-infomessage__message {
    display: block;
    grid-area: message;
    padding: 4px 0;
    font-size: var(--MaterialDesignFontSizeL);
}

.ad-infomessage__confirmation {
    display: flex;
    align-items: center;
    grid-area: confirmation;
    align-content: center;
    justify-content: end;
}

@media screen and (max-width: 600px) {

    .ad-list-item.ad-infomessage {
        padding: 0 var(--ContentBorderHorMobile);
    }
}

/*------------------------------------*\
  #ad-infoblock
\*------------------------------------*/

.ad-infoblock {
    height: 40px;
    color: var(--ColorInfo);
    border: 1px solid var(--ColorInfo);
    border-radius: 8px;
    text-align: center;
    line-height: 40px;
}

@media screen and (max-width: 600px) {

    .ad-infoblock {
        margin: var(--ContentBorderHorMobile);
    }
}

/*------------------------------------*\
  Home Button
\*------------------------------------*/

.HomeButton {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: var(--MobileMenuButtonWidth);
    height: calc(var(--HeaderHeightMobile) - 30px);
    z-index: 9900;
    padding: 20px 0px 10px 0px;
    cursor: pointer;
    background-repeat: no-repeat;
    background-position: center;
    background-image: url("btn-home-mobile.svg");
}

body:not(.login) .HomeButton {
    display: block;
}

/*------------------------------------*\
  #MobileMenu
\*------------------------------------*/

.MobileMenuButton {
    position: fixed;
    width: var(--MobileMenuButtonWidth);
    height: calc(var(--HeaderHeightMobile) - 30px);
    right: 0;
    top: 0;
    z-index: 9900;
    display: none;
    padding: 20px 0px 10px 0px;
    cursor: pointer;
}

    .MobileMenuButton .Bar {
        position: absolute;
        left: 14px;
        width: 22px;
        height: 2px;
        background-color: white;
        border-radius: 1px;
        transition: 0.3s;
        transform-origin: center;
    }

div.MobileMenuButton .Bar:nth-child(1) {
    top: 23px;
}

div.MobileMenuButton .Bar:nth-child(2) {
    top: 29px;
}

div.MobileMenuButton .Bar:nth-child(3) {
    top: 35px;
}

body.mobilemenu div.MobileMenuButton .Bar:nth-child(1) {
    transform: translateY(5px) rotate(45deg);
    background-color: #8E8E93;
}

body.mobilemenu div.MobileMenuButton .Bar:nth-child(2) {
    opacity: 0;
}

body.mobilemenu div.MobileMenuButton .Bar:nth-child(3) {
    background-color: #8E8E93;
    transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 600px) {

    #Table1 {
        left: inherit !important;
    }

    #NavigationBar1_pdfFrame {
        width: 100vw;
    }

    body:not(.login) div.MobileMenuButton {
        display: block;
    }
}

img.CalendarButton {
    width: 19px;
    height: 19px;
}

img.EditButton {
    width: 16px;
    height: 16px;
}

img.ControlImage {
    width: 16px;
    height: 16px;
}

input.EditButton {
    width: 16px;
    height: 16px;
}
