﻿:root {
    --HeaderColor: #558DF5;
    --HeaderBgColor: #f6f6fb;
    --HeaderColorMobile: #ffffff;
    --HeaderBgColorMobile: #558DF5;
    --HeaderHeight: 60px;
    --HeaderHeightMobile: 60px;
    --ContentBorderTop: 20px;
    --ContentBorderTopMobile: 15px;
    --ContentBorderHor: 20px;
    --ContentBorderHorMobile: 10px;
    --MobileMenuButtonWidth: 50px;
    --NavigationBgColor: #ffffff;
    --NavigationWidth: 240px;
    --NavigationGroupHeightDefault: 40px;
    --NavigationGroupHeightMobile: 45px;
    --NavigationGroupColor: #8E8E93;
    --NavigationGroupBgColor: #efeff4;
    --NavigationGroupBgColorHover: #eaeaf0;
    --NavigationGroupFontSize: 14px;
    --NavigationButtonHeightDefault: 40px;
    --NavigationButtonHeightMobile: 55px;
    --NavigationButtonColor: #000000;
    --NavigationButtonBgColor: #ffffff;
    --NavigationButtonBgColorHover: #fafafc;
    --NavigationButtonFontSize: 15px;
    --NavigationLineColor: #C8C7CC;
    --NavigationLineColorLight: #DDDDDD;
    --Color: #000000;
    --ColorLight: #343436;
    --ColorInfo: #558DF5;
    --ColorWarning: #FF8800;
    --ColorError: #f44336;
    --ColorDisabled: #C8C7CC;
    --ColorActiveItem: #d4eaf4;
    --BgColor: #ffffff;
    --FrmLineColorMobile: #C8C7CC;
    --FrmHeaderColor: #000000;
    --FrmHeaderBgColor: #88aff8;
    --FrmHeaderColorMobile: #8E8E93;
    --FrmHeaderBgColorMobile: #EFEFF4;
    --FrmHeaderHeight: 28px;
    --FrmHeaderHeightMobile: 42px;
    --FrmLabelColor: #000000;
    --FrmLabelColorMobile: #787878;
    --FrmLabelBgColor: #88aff8;
    --FrmValueColor: #000000;
    --FrmValueBgColor: #f6f6fb;
    --BackgroundDefault: #ffffff;
    --BackgroundLight: #f6f6fb;
    --ControlBgColor: #ffffff;
    --ControlBgColorDisabled: #ffffff;
    --ControlBorderColor: #558DF5;
    --ControlBorderColorDisabled: #C8C7CC;
    --ControlBgColorMobile: #f7faff;
    --ControlBgColorMobileDisabled: #fbfbfb;
    --ControlBorderColorMobile: #d7e4fd;
    --ControlBorderColorMobileDisabled: #C8C7CC;
    --ButtonColor: #ffffff;
    --ButtonBgColor: #558DF5;
    --DisabledButtonColor: #ffffff;
    --DisabledButtonBgColor: #C8C7CC;
    --GreenButtonColor: #ffffff;
    --GreenButtonBgColor: #4caf50;
    --RedButtonColor: #ffffff;
    --RedButtonBgColor: #f44336;
    --PanelBgColor: #efeff4;
    --LoginColor: #558DF5;
    --TableBgColor: #ffffff;
    --TableHeaderColor: #000000;
    --TableHeaderBgColor: #88aff8;
    --TableCellColor: #000000;
    --TableCellBgColor: #f6f6fb;
    --CellHeadBgColor: #88aff8;
    --CellLabelBgColor: #88aff8;
    --CellContentBgColor: #f6f6fb;
    --CellContentBgColorHover: #e4e4e9;
    --FontFamily: 'Roboto', Arial, sans-serif;
    --FontSizeXS: 9px;
    --FontSizeS: 13px;
    --FontSizeM: 15px;
    --FontSizeL: 16px;
    --FontSizeXL: 17pt;
    --FontSizeXXL: 20px;
    --FontSizeTbl: 10pt;
    --OpacityDarkColor: rgba(0, 0, 0, 0.4);
}

/* roboto-regular - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    src: url('../../fonts/roboto-v20-latin-regular.eot'); /* IE9 Compat Modes */
    src: local('Roboto'), local('Roboto-Regular'), url('../../fonts/roboto-v20-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../../fonts/roboto-v20-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
    url('../../fonts/roboto-v20-latin-regular.woff') format('woff'), /* Modern Browsers */
    url('../../fonts/roboto-v20-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
    url('../../fonts/roboto-v20-latin-regular.svg#Roboto') format('svg'); /* Legacy iOS */
}

/* roboto-700 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 700;
    src: url('../../fonts/roboto-v20-latin-700.eot'); /* IE9 Compat Modes */
    src: local('Roboto Bold'), local('Roboto-Bold'), url('../../fonts/roboto-v20-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('../../fonts/roboto-v20-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
    url('../../fonts/roboto-v20-latin-700.woff') format('woff'), /* Modern Browsers */
    url('../../fonts/roboto-v20-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
    url('../../fonts/roboto-v20-latin-700.svg#Roboto') format('svg'); /* Legacy iOS */
}

/*------------------------------------*\
  #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);
}

/*------------------------------------*\
  #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;
    border: solid 1px var(--ButtonBgColor);
    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_msgboxbtnok {
    color: var(--GreenButtonColor);
    background-color: var(--GreenButtonBgColor);
}

#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;
    border: solid 1px var(--ButtonBgColor);
    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);
}

#HdrLogoWrapper {
    position: absolute;
    display: none;
    left: 0;
    top: 0;
    width: var(--NavigationWidth);
    height: calc(var(--HeaderHeight) - 1px);
    background-color: #e9e9ee;
    background-color: #f1f1f8;
    background-color: #ffffff;
    z-index: 20000;
}

body:not(.login) #HdrLogoWrapper {
    display: block;
}

#HdrLogoImage {
    margin: 6px 0 0 35px;
    width: 170px;
    height: 46px;
    content: url('headerlogo.png');
}

#HdrMsp {
    position: absolute;
    left: var(--NavigationWidth);
    top: 10px;
    width: calc(100% - var(--NavigationWidth));
    height: 26px;
    text-align: center;
    vertical-align: middle;
    font-size: var(--FontSizeXXL);
    line-height: 20px;
}

#HdrTitle {
    display: none;
}

#HdrUserAndTitle {
    position: absolute;
    display: block;
    left: var(--NavigationWidth);
    bottom: 5px;
    width: calc(100% - var(--NavigationWidth));
    height: 20px;
    text-align: center;
    vertical-align: middle;
    font-size: var(--FontSizeS);
    line-height: 20px;
}

#HdrLine {
    display: block;
    position: absolute;
    bottom: 0px;
    width: 100%;
    height: 1px;
    background-color: #DDDDDD;
}

@media (max-width: 600px) {
    #MspHeader {
        display: block;
        height: var(--HeaderHeightMobile);
        background-color: var(--HeaderBgColorMobile);
    }

    #HdrWrapper {
        color: var(--HeaderColorMobile);
    }

    #HdrLogoWrapper,
    body:not(.login) #HdrLogoWrapper {
        display: none;
    }

    #HdrMsp {
        display: block;
        left: 0;
        top: 10px;
        width: 100%;
        height: 26px;
        text-align: center;
        vertical-align: middle;
        color: #ffffff;
        font-size: var(--FontSizeXXL);
        line-height: 20px;
    }

    #HdrTitle {
        position: absolute;
        display: block;
        left: 0;
        bottom: 5px;
        width: 100%;
        height: 20px;
        text-align: center;
        vertical-align: middle;
        font-size: var(--FontSizeS);
        line-height: 20px;
    }

    #HdrUserAndTitle {
        display: none;
    }

    body:not(.login) #HdrMsp {
        right: var(--MobileMenuButtonWidth);
        width: calc(100% - var(--MobileMenuButtonWidth) + 14px);
    }

    body:not(.login) #HdrTitle {
        right: var(--MobileMenuButtonWidth);
        width: calc(100% - var(--MobileMenuButtonWidth) + 14px);
    }
}

/*------------------------------------*\
  #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(--ButtonBgColor);
    border-radius: 17px;
    cursor: pointer;
    background-color: var(--ButtonBgColor);
    color: var(--ButtonColor);
}

    .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;
    }
}

/*------------------------------------*\
  #Olb Navigation
\*------------------------------------*/

.CSSOlbContentDark {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--OpacityDarkColor);
    z-index: 9000;
}

.CSSOlbBackground,
.CSSOlbBackground * {
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.CSSOlbBackground {
    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);
}

.CSSOlbMenu {
    display: block;
    width: 100%;
    height: calc(100vh - var(--HeaderHeight) - 42px);
    overflow-x: hidden;
    overflow-y: auto;
}

.CSSOlbGroupUl {
    width: 100%;
    margin: 0;
    padding: 0;
}

.CSSOlbGroupLi {
    display: block;
    margin: 0;
    padding: 0;
}

.CSSOlbGroupItem {
    position: relative;
    display: block;
    width: 100%;
    height: var(--NavigationGroupHeightDefault);
    background-color: var(--NavigationGroupBgColor);
    border-bottom: solid 1px var(--NavigationLineColor);
    text-transform: uppercase;
}

    .CSSOlbGroupItem a {
        display: inline-flex;
        width: 100%;
        height: 100%;
        vertical-align: middle;
    }

        .CSSOlbGroupItem a:link {
            text-decoration: none;
        }

        .CSSOlbGroupItem a:visited {
            text-decoration: none;
        }

        .CSSOlbGroupItem a:hover {
            text-decoration: none;
        }

        .CSSOlbGroupItem a img {
            width: 24px;
            height: 24px;
            margin: auto 0 auto 10px;
            padding: 0;
        }

        .CSSOlbGroupItem a div {
            margin: auto 0 auto 10px;
            padding: 0;
            text-align: left;
            font-size: var(--NavigationGroupFontSize);
            color: var(--NavigationGroupColor);
        }

@media (hover: hover) {
    .CSSOlbGroupItem:hover {
        background-color: var(--NavigationGroupBgColorHover);
    }
}

.CSSOlbOpener:after {
    content: "";
    display: block;
    position: absolute;
    right: 10px;
    top: 10px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #8E8E93;
    border-right: 2px solid #8E8E93;
    transform: rotate(135deg);
    pointer-events: none;
}

.CSSOlbGroupLi.opengroup .CSSOlbOpener:after {
    top: 17px;
    transform: rotate(315deg);
}

.CSSOlbGroupLi:not(.opengroup) .CSSOlbContentUl {
    display: none;
}

.CSSOlbContentUl {
    margin: 0;
    padding: 0;
}

.CSSOlbContentItem {
    width: 100%;
    height: var(--NavigationGroupHeightDefault);
    background-color: var(--NavigationButtonBgColor);
    border-bottom: 1px solid var(--NavigationLineColor);
}

    .CSSOlbContentItem a {
        display: inline-flex;
        width: 100%;
        height: 100%;
        vertical-align: middle;
    }

        .CSSOlbContentItem a:link {
            text-decoration: none;
        }

        .CSSOlbContentItem a:visited {
            text-decoration: none;
        }

        .CSSOlbContentItem a:hover {
            text-decoration: none;
        }

        .CSSOlbContentItem a img {
            width: 24px;
            height: 24px;
            margin: auto 0 auto 10px;
            padding: 0;
        }

        .CSSOlbContentItem a div {
            margin: auto 0 auto 10px;
            padding: 0;
            text-align: left;
            font-size: var(--NavigationButtonFontSize);
            font-weight: normal;
            color: var(--NavigationButtonColor);
        }

@media (hover: hover) {
    .CSSOlbContentItem:hover {
        background-color: var(--NavigationButtonBgColorHover);
    }
}

.CssOlbInfo {
    display: block;
    position: fixed;
    left: 0;
    bottom: 0;
    width: calc(var(--NavigationWidth) - 1px);
    height: 42px;
    margin: 0;
    padding: 0;
    background-color: var(--NavigationBgColor);
}

    .CssOlbInfo.withborder {
        border-top: solid 1px var(--NavigationLineColorLight);
    }

    .CssOlbInfo div {
        display: block;
        margin: 5px 10px 5px 10px;
        padding: 0;
        color: #909090;
        font-size: var(--FontSizeS);
    }

@media screen and (max-width: 600px) {

    body.mobilemenu .CSSOlbContentDark {
        display: block;
    }

    .CSSOlbBackground {
        left: auto;
        right: -100vw;
        top: 0;
        width: 85vw;
        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 .CSSOlbBackground {
        right: 0;
        visibility: visible;
        opacity: 1;
    }

    .CSSOlbMenu {
        border-top: solid 1px var(--NavigationLineColor);
    }

    .CSSOlbGroupItem {
        height: var(--NavigationGroupHeightMobile);
    }

        .CSSOlbGroupItem img {
            width: 20px;
            height: 20px;
            margin: auto 0 auto 13px;
            padding: 0;
        }

        .CSSOlbGroupItem a div {
            margin: auto 0 auto 13px;
            padding: 0;
        }

    .CSSOlbContentItem {
        height: var(--NavigationGroupHeightMobile);
    }

        .CSSOlbContentItem a img {
            margin: auto 0 auto 20px;
            width: 20px;
            height: 20px;
        }

        .CSSOlbContentItem a div {
            margin: auto 0 auto 13px;
            padding: 0;
        }

    li.CSSOlbOpener:after {
        top: 13px;
    }

    .CSSOlbGroupUl.opengroup li.CSSOlbOpener:after {
        top: 20px;
    }

    div.CssOlbInfo {
        left: auto;
        width: 85vw;
        right: -100vw;
        visibility: hidden;
        opacity: 0;
        transition: all 0.2s, visibility 0.2s, opacity 0.2s linear;
    }

    body.mobilemenu .CssOlbInfo {
        right: 0;
        visibility: visible;
        opacity: 1;
    }
}

/*------------------------------------*\
  #WrpFrm
\*------------------------------------*/

div.WrpFrmFormArea {
    display: grid;
    grid-template-columns: minmax(min-content, min-content) 1fr;
    grid-gap: 0.1em;
    max-width: 540px;
    margin: 0 0 25px 0;
}

    div.WrpFrmFormArea.WrpFrmWide {
        max-width: none; /* 800px; */
    }

    div.WrpFrmFormArea.WrpFrmClosed {
        height: var(--FrmHeaderHeight);
        overflow: hidden;
    }

div.WrpFrmHeadRow {
    display: flex;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    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;
}

    div.WrpFrmHeadRow span {
        display: inline-block;
        height: var(--FrmHeaderHeight);
        line-height: var(--FrmHeaderHeight);
        vertical-align: middle;
    }

    div .WrpFrmHeadRow.OnlyMobile {
        display: none;
    }

div.WrpHeaderBtnContainer {
    display: inline-block;
    height: var(--FrmHeaderHeight);
    overflow-y: hidden;
}

    div.WrpHeaderBtnContainer.OnlyMobile {
        display: none;
    }

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;
}

div.WrpFrmFormArea.WrpFrmClosed div.WrpHeaderBtnOpenClose {
    background-image: url('btn-frmheaderopen.svg');
}

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;
}

@media screen and (min-width: 601px) {
    div.WrpHeaderBtnOpenClose.OnlyMobile {
        display: none;
    }

    div.WrpHeaderBtnMaximize.OnlyMobile {
        display: none;
    }
}

div.WrpFrmInfoRow {
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    padding: 2px 0 2px 0;
    margin: 0 0 5px 0;
}

div.WrpFrmCaptionRow {
    box-sizing: border-box;
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    padding: 15px 0 2px 0;
    margin: 0 0 5px 0;
    color: var(--ColorInfo);
}

div.WrpFrmCtrlRow {
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    padding: 2px 0 2px 0;
    margin: 0 0 5px 0;
}

    div.WrpFrmCtrlRow.WrpFrmLabelAndCtrl {
        max-width: 540px;
        display: grid;
        grid-template-columns: 1fr minmax(min-content, min-content);
    }

div.WrpFrmTableRow {
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
}

div.WrpFrmSpaceRow {
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    height: 25px;
    margin: 0;
}

div.WrpFrmLineRow {
    display: block;
    position: relative;
    grid-column: 1 / span 2;
    box-sizing: border-box;
    height: 20px;
    margin: 0 0 20px 0;
    border-bottom: 1px solid var(--FrmLabelBgColor);
}

div.WrpFrmLabelCell {
    display: block;
    position: relative;
    white-space: nowrap;
    color: var(--FrmLabelColor);
    background-color: var(--FrmLabelBgColor);
    padding: 2px 5px 2px 5px;
    margin: 0 5px 5px 0;
    min-width: 130px;
}

div.WrpFrmValueCell {
    display: block;
    position: relative;
    min-height: 19px;
    color: var(--FrmValueColor);
    background-color: var(--FrmValueBgColor);
    margin: 0 0 5px 0;
    padding: 2px 5px 2px 5px;
}

div.WrpFrmControlCell {
    display: block;
    position: relative;
    margin: 0 0 5px 0;
}

div.WrpFrmButtonArea {
    max-width: 540px;
    padding: 20px 0 0 0;
    border-top: 1px solid var(--FrmLabelBgColor);
}

.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;
    }

div.WrpFrmFormArea div.WrpFrmRowSpaceTop,
div.WrpFrmFormArea div.WrpFrmCtrlRow.WrpFrmRowSpaceTop {
    padding-top: 25px;
}

div.WrpFrmFormArea div.WrpFrmRowSpaceBottom,
div.WrpFrmFormArea div.WrpFrmCtrlRow.WrpFrmRowSpaceBottom {
    padding-bottom: 25px;
}

@media screen and (max-width: 600px) {

    div.WrpFrmFormArea {
        display: grid;
        grid-template-columns: 1fr;
        width: 100vw;
        max-width: 100vw;
        background-color: #ffffff;
        margin-bottom: 0;
    }

        div.WrpFrmFormArea.WrpFrmClosed {
            height: calc(var(--FrmHeaderHeightMobile) + 4px);
            overflow: hidden;
        }

        div.WrpFrmFormArea div.WrpFrmHeadRow,
        div.WrpFrmFormArea div.WrpFrmInfoRow,
        div.WrpFrmFormArea div.WrpFrmCaptionRow,
        div.WrpFrmFormArea div.WrpFrmCtrlRow,
        div.WrpFrmFormArea div.WrpFrmTableRow,
        div.WrpFrmFormArea div.WrpFrmSpaceRow,
        div.WrpFrmFormArea div.WrpFrmLineRow {
            grid-column: 1;
            width: 100vw;
            max-width: 100vw;
        }

    div.WrpFrmHeadRow,
    div.WrpFrmHeadRow.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-bottom: 1px solid var(--FrmLineColorMobile);
    }

        div.WrpFrmHeadRow.WrpFrmHeadButtons,
        div.WrpFrmHeadRow.WrpFrmHeadButtons.OnlyMobile {
            height: calc(var(--FrmHeaderHeightMobile) + 4px);
        }

        div.WrpFrmHeadRow.WrpFrmBorderTop,
        div.WrpFrmHeadRow.WrpFrmBorderTop.OnlyMobile {
            border-top: 1px solid var(--FrmLineColorMobile);
        }

        div.WrpFrmHeadRow > 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;
    }

    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;
    }

    div.WrpFrmFormArea.WrpFrmClosed div.WrpHeaderBtnOpenClose {
        background-image: url('btn-frmheaderopen-mobile.svg');
    }

    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;
    }

    div.WrpFrmFormArea div.WrpFrmInfoRow {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    div.WrpFrmFormArea div.WrpFrmCaptionRow {
        margin: 0;
        padding: 15px var(--ContentBorderHorMobile) 2px var(--ContentBorderHorMobile);
    }

    div.WrpFrmFormArea div.WrpFrmTableRow {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    div.WrpFrmFormArea div.WrpFrmLineRow {
        margin: 0;
        border-bottom: 1px solid var(--FrmLineColorMobile);
    }

    div.WrpFrmFormArea div.WrpFrmCtrlRow {
        margin: 0;
        padding: 8px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
        border-bottom: 1px solid var(--FrmLineColorMobile);
    }

        div.WrpFrmFormArea div.WrpFrmCtrlRow.WrpFrmLabelAndCtrl {
            max-width: none;
        }

    div.WrpFrmLabelCell {
        font-size: var(--FontSizeS);
        color: var(--FrmLabelColorMobile);
        background-color: inherit;
        margin: 0 0 0 0;
        padding: 2px var(--ContentBorderHorMobile) 2px var(--ContentBorderHorMobile);
    }

    div.WrpFrmValueCell {
        background-color: inherit;
        border-bottom: 1px solid var(--FrmLineColorMobile);
        margin: 0 0 0 0;
        padding: 2px var(--ContentBorderHorMobile) 4px var(--ContentBorderHorMobile);
    }

    div.WrpFrmControlCell {
        background-color: inherit;
        border-bottom: 1px solid var(--FrmLineColorMobile);
        margin: 0 0 0 0;
        padding: 2px var(--ContentBorderHorMobile) 12px var(--ContentBorderHorMobile);
    }

    div.WrpFrmButtonArea {
        max-width: none;
        margin: 0;
        padding: 20px var(--ContentBorderHorMobile) 0 var(--ContentBorderHorMobile);
        border-top: none;
    }

    div.WrpFrmBorderBottomMobile {
        border-bottom: 1px solid var(--FrmLineColorMobile);
    }
}

div.WrpFrmFormArea div.WrpFrmNoBorderTop {
    border-top: none;
}

div.WrpFrmFormArea div.WrpFrmNoBorderBottom {
    border-bottom: none;
}

div.WrpFrmInvisible {
    display: none;
}

/*------------------------------------*\
  #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(--ButtonBgColor);
            }

                div.MessageSection ul > li.infolink:before {
                    background-color: var(--ButtonBgColor);
                }

/*------------------------------------*\
  #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(--ButtonBgColor);
    color: var(--ButtonColor);
}

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;
    }


/*
	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(--ButtonBgColor);
    color: var(--ButtonColor);
    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(--ButtonColor);
            background-color: var(--ButtonBgColor);
            border: 1px solid var(--ButtonBgColor);
        }

.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;
}

button.CtlButton {
    height: 34px;
    margin: 0 0 0 0;
    padding: 2px 10px 2px 10px;
    line-height: 22px;
    border: 1px solid transparent;
    border-radius: 3px;
    cursor: pointer;
    background-color: var(--ButtonBgColor);
    color: var(--ButtonColor);
}

    button.CtlButton:focus {
        outline: none;
    }

button.CtlButtonGreen {
    height: 34px;
    margin: 0 0 0 0;
    padding: 2px 10px 2px 10px;
    line-height: 22px;
    border: 1px solid transparent;
    border-radius: 3px;
    cursor: pointer;
    background-color: var(--GreenButtonBgColor);
    color: var(--GreenButtonColor);
}

    button.CtlButtonGreen:focus {
        outline: none;
    }

button.CtlButtonRed {
    height: 34px;
    margin: 0 0 0 0;
    padding: 2px 10px 2px 10px;
    line-height: 22px;
    border: 1px solid transparent;
    border-radius: 3px;
    cursor: pointer;
    background-color: var(--RedButtonBgColor);
    color: var(--RedButtonColor);
}

    button.CtlButtonRed:focus {
        outline: none;
    }

    button.CtlButton:disabled,
    button.CtlButtonGreen:disabled,
    button.CtlButtonRed:disabled {
        color: var(--DisabledButtonColor);
        background-color: var(--DisabledButtonBgColor);
    }

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(--ButtonBgColor);
}

    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);
    }

        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(--ButtonBgColor);
    text-align: center;
}

    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);
    }

        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: 150px;
            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) {

    button.CtlButton,
    button.CtlButtonGreen,
    button.CtlButtonRed {
        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(--ButtonBgColor);
    }

    div.CtlRadio input[type=radio]:disabled ~ label:before {
        border: 1px solid var(--DisabledButtonBgColor);
    }

    div.CtlCheckbox label:before {
        border: 1px solid var(--ButtonBgColor);
    }

    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;
    }
}

/*------------------------------------*\
  #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 {
        margin-left: -2px;
        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;
}
