.apo h2 {
    color: #c00205;
}

.apo {
    text-align: center;
    /*padding-left: 80px;*/
}

.apo-sidebar {
    position: fixed;
    left: 0%;
    display: flex;
    top: 0%;
    height: 100vh;
    width: 80px;
    background-color: #700002;
    flex-direction: column;
}

.oeffnungszeiten-table {
    width: 100%; 
    margin-left: auto; 
    margin-right: auto; 
    white-space: nowrap;
    border: unset !important;
}

.oeffnungszeiten-table td:nth-of-type(1) {
    text-align: right;
    font-weight: 700;
}

.oeffnungszeiten-table td {
    border: unset !important;
    padding-top: 0px;
    padding-bottom: 0px;
    font-size: 17px;
}

@media (max-width: 600px) {
    .oeffnungszeiten-table td {
        font-size: 14px;
    }
}

.apo-sidebar .spacer {
    flex-grow: 1;
}

.apo-sidebar a {
    position: relative;
    height: 80px;
    width: 80px;
    float: left;
}

.apo-sidebar a.choosen {
    background-color: #c00205;
}

.apo-sidebar a div {
    width: 100%;
    height: 100%;
    text-align: center;
    line-height: 77px;
    color: white;
    font-size: 30px;
}

.apo .styled-button.styled-button-disabled {
    opacity: 0.5;
}

.apo .styled-button {
    height: 43px;
    font-size: 16px;
    border-radius: 6px;
}

.apo .styled-button-a-tag {
    height: 43px;
    line-height: 43px;
    background-color: #c00205;
    color: white;
    display: inline-block;
    border-radius: 6px;
    padding-left: 10px;
    padding-right: 10px;
    margin-left: 5px;
}

.apo .styled-button-a-tag:hover {
    color: black;
    background-color: #ff696b;
}

.apo .styled-button.green {
    background-color: #00b834;
}

.apo .styled-button.yellow {
    background-color: #fcce03;
    color: black;
}

.apo .styled-button.green:hover {
    background-color: #56cc77;
}

.apo .styled-button.yellow:hover {
    background-color: #fae175;
    color: white;
}

.hidden {
    display: none;
    visibility: hidden;
}

.apo select {
    height: 43px;
}

#data-con p {
    text-align: left;
}

/* Table */

.apo .apo-data-table {
    border-radius: 8px;
    margin-bottom: 30px;
    display: inline-block;
}

.apo .table-outer {
    display: inline-grid;
    width: auto;
}

.apo .tabulator-header {
    height: 43px !important;
}

.apo .tabulator-headers {
    height: 43px !important;
}

.apo .tabulator-col {
    height: 43px !important;
    background-color: white !important;
    color: #c00205 !important;
    line-height: 34px !important;
}

.apo .tabulator-paginator .tabulator-page:not(.active) {
    color: #555 !important
}

.apo .tabulator-paginator .tabulator-page.active {
    color: #c00205 !important
}

/* Data con */
#data-con {
    position: relative;
}

#data-con-overlay {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0.4;
    border-radius: 10px;
    background-color: #555;
    z-index: 999;
}

/* Zeiten */
#zeitfenster {
    margin-bottom: 30px;
}

#zeitfenster .dates {
    max-width: 1100px;
    height: 60px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}

#zeitfenster .dates .arrow-box {
    width: 50px;
    height: 100%;
    float: left;
    font-size: 33px;
    color: #c00205;
    line-height: 54px;
    cursor: pointer;
}

#zeitfenster .dates a {
    cursor: pointer;
}

#zeitfenster .dates .date-box {
    float: left;
    width: 194px;
    margin-right: 3px;
    margin-left: 3px;
    height: 100%;
    border-radius: 8px;
    border: 1px solid lightgray;
    cursor: pointer;
}

#zeitfenster .dates .date-box.active {
    background-color: #c00205;
    color: white;
}

#zeitfenster .times {
    max-width: 540px;
    overflow-y: scroll;
    max-height: 600px;
    height: auto;
    margin-left: auto;
    margin-right: auto;
}

#zeitfenster .times a {
    height: auto;
    width: auto;
    display: inline-block;
    cursor: pointer;
}

#zeitfenster .times .time-box {
    float: left;
    width: 124px;
    margin-right: 3px;
    margin-left: 3px;
    margin-bottom: 3px;
    margin-top: 3px;
    height: 60px;
    border-radius: 8px;
    border: 1px solid lightgray;
}

#zeitfenster .times .time-box.active {
    background-color: #c00205;
    color: white;
}


.apo-public-login-con {
    width: 100%;
    text-align: center;
}

.apo-public-login {
    width: 100%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    max-width: 800px;
    height: auto;
    display: inline-block;
}

.noselect {
    -webkit-touch-callout: none; /* iOS Safari */
      -webkit-user-select: none; /* Safari */
       -khtml-user-select: none; /* Konqueror HTML */
         -moz-user-select: none; /* Old versions of Firefox */
          -ms-user-select: none; /* Internet Explorer/Edge */
              user-select: none; /* Non-prefixed version, currently
                                    supported by Chrome, Edge, Opera and Firefox */
  }

.apo-public-login .stepbar {
    width: 100%;
    height: 40px;
    text-align: center;
}

.apo-public-login .stepbar span {
    width: 24px;
    height: 24px;
    line-height: 24px;
    border-radius: 12px;
    text-align: center;
    background-color: rgba(30, 39, 51, 0.2);
    display: inline-block;
}

.apo-public-login .stepbar p {
    height: 24px;
    line-height: 24px;
    display: inline-block;
}

.apo-public-login .stepbar span.active {
    background-color: #c00205;
    color: white;
}

.apo-public-login .step {
    overflow: hidden;
    position: absolute;
    height: auto;
    width: 100%;
}

.step-2-time {
    width: 120px;
    height: 60px;
    line-height: 60px;
    margin-left: 6px;
    margin-right: 6px;
    margin-top: 4px;
    margin-bottom: 4px;
    text-align: center;
    font-size: 20px;
    color: white;
    border: 2px solid transparent;
    background-color: #14b359;
    border-radius: 6px;
    display: inline-block;
    transition: box-shadow 200ms, border 100ms;
    box-shadow: 1px 1px rgba(0, 0, 0, 0);
    box-sizing: inherit;
    cursor: pointer;
}

.step-2-time:not(.disabled):hover {
    color: #c00205;
    border: 2px solid #c00205;
}

.step-2-time.disabled {
    outline: none;
    color: #3a3a3a;
    border: 2px solid transparent;
    box-sizing: inherit;
    cursor: not-allowed;
    background-color: rgba(30, 39, 51, 0.2);
    box-shadow: 1px 1px rgba(0, 0, 0, 0);
}

.step-2-time.selected {
    outline: none;
    color: #c00205;
    border: 2px solid #c00205;
    box-sizing: inherit;
}

#s2-times {
    max-width: 659px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
    margin-bottom: 10px;
}

.nextstep {
    border-radius: 6px;
}
.nextstep:disabled {
    opacity: 0.5;
    cursor: default;
}

#step-1 {
    z-index: 3;
    min-height: 600px;
}

#step-2 {
    z-index: 4;
    background-color: white;
    opacity: 0.0;
    min-height: 600px;
}

#step-3 {
    z-index: 5;
    background-color: white;
    opacity: 0.0;
    min-height: 600px;
}

.apo-public-login .step-outer {
    overflow: hidden;
    position: relative;
    width: 100%;
    float: right;
    min-height: 600px;
}

.apo-public-login .step-header {
    font-size: 22px;
}

.apo-public-login .step-con {

}

#calendar #navigation-wrapper {
    padding: 0.5em 0 5.9em !important;
}

#calendar #navigation-wrapper button {
    width: 1em !important;
    fill: #c00205 !important;
}
#calendar #calendar-grid {
    grid-template-rows: unset !important;
    margin-bottom: 10px !important;
}

@media (max-width: 500px) {
    #calendar {
        grid-template-columns: 1fr 2em !important;
    }

    #calendar #navigation-wrapper button {
        font-size: 2.5em !important;
    }
}

@media (max-width: 400px) {
    #calendar section {
        padding-left: 0px !important;
        padding-right: 8px !important;
    }

    #calendar #calendar-wrapper {
        padding: 0.5em 0 1.9em !important;
    }

    #calendar #navigation-wrapper {
        padding: 0.5em 0 0.9em !important;
    }
}

@media (max-width: 374px) {
    #calendar #calendar-grid > time {
        padding: 0.4em 0.1em !important;
        margin: 0.25em !important;
    }
}

/* Elementor Carousel Arrow Safari Fix */
.dialog-type-lightbox {
	transform: translate3d(0,0,2px);
}

/* Loader */
.apo-loader {
    position: fixed;
    overflow: hidden;
    width: 0;
    height: 40px;
    z-index: 999999999999;
    top: 20px;
    right: 0%;
    font-size: 20px;
    line-height: 38px;
    border-top-left-radius: 6px;
    border-bottom-left-radius: 6px;
    border: 1px solid #333333;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}

/* Pers Lot Per Date */
#perSlotPerDateOpener {
    margin-top: 30px;
}

/* Auswahlfeld Testtyp */
.testtypes-con {
    display: inline-block;
}
.testtypes {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;

max-width: 650px;
padding: 4px 4px;
-webkit-box-sizing: border-box;
box-sizing: border-box;
background: #fff;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
}

.testtypes .plan input[type="radio"] {
position: absolute;
opacity: 0;
}

.testtypes .plan {
cursor: pointer;
width: 100%;
margin-bottom: 6px;
margin-left: 0px !important;
}

.testtypes .plan .plan-details {
padding-right: 25px;
}

.testtypes .plan .plan-content {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
padding: 12px 10px;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border: 2px solid #e1e2e7;
border-radius: 6px;
-webkit-transition: -webkit-box-shadow 0.4s;
transition: -webkit-box-shadow 0.4s;
-o-transition: box-shadow 0.4s;
transition: box-shadow 0.4s;
transition: box-shadow 0.4s, -webkit-box-shadow 0.4s;
position: relative;
}

.testtypes .plan .plan-content.dis {
    background-color: lightgray !important;
}

.testtypes .plan .plan-details span {
display: block;
font-size: 17px;
line-height: 17px;
text-align: left;
color: #252f42;
}

.testtypes .plan .plan-content:hover {
-webkit-box-shadow: 0px 3px 5px 0px #e8e8e8;
box-shadow: 0px 3px 5px 0px #e8e8e8;
}

.testtypes .plan input[type="radio"]:checked + .plan-content:after {
content: "";
position: absolute;
height: 8px;
width: 8px;
background: #c00205;
right: 20px;
top: 50%;
transform: translateY(-50%);
border-radius: 100%;
border: 3px solid #fff;
-webkit-box-shadow: 0px 0px 0px 2px #c00205;
box-shadow: 0px 0px 0px 2px #c00205;
}

.testtypes .plan input[type="radio"]:checked + .plan-content {
border: 2px solid #c00205;
background: #c0020510;
-webkit-transition: ease-in 0.3s;
-o-transition: ease-in 0.3s;
transition: ease-in 0.3s;
}

