body {
    font-size: 0.9rem
}

.btn {
    font-size: 0.9rem;
}

.dropdown-menu {
    font-size: 0.9rem;
}

.popover-body, .popover-header {
    font-size: 0.9rem;
}

.form-switch > .form-check-input {
    margin-top: .25em;
    margin-right: .75em;
}

.login {
    border-color: lightgray;
    border-width: 1px;
    border-style: solid;
    border-radius: 15px;
    padding: 15px;
    background-color: #F5F5F5;
}

.button-hidden {
    visibility: hidden;
}

.two-td-left {
    border-right: none !important;
}

.two-td-right {
    border-left: none !important;
}

.reservation {
    border-left: none !important;
    border-right: none !important;
    padding: 8px 2px !important;
}

.reservation-inner {
    border: 1px solid #666;
    color: #fff;
    padding: 3px;
}

.reservation-confirmed {
    background-color: #2D9434;
}

.reservation-option {
    background-color: #f6e95c;
    color: #666;
    border-color: #999;
}

.reservation-table-weekend-single {
    background-color: #EEE !important;
}

.mouse-pointer {
    cursor: pointer;
}

.border-left-thick {
    border-left: 2px solid #ddd;
}

.cell-selected {
    background-color: #f5f5f5;
}

.table-reservation .ui-selecting { 
    background: #FECA40 !important;
}
.table-reservation .ui-selected { 
    background: #F39814;
}

/* reset 2px border of tbody */
.table-reservation > :not(:first-child) {
    border-top: 1px solid currentColor;
}

.table-reservation {
    overflow: hidden;
}

.table-reservation .table-days > th {
    position: relative;
}

.reservation-table-weekend::before {
    content: '';
    position: absolute;
    top: 0;
    left: -1px;
    right: -1px;
    bottom: -5000px;
    z-index: -1;
    background-color: #EEE !important;
}

#reservation-table th,td {
    background-color: transparent !important;
}

/* remove bottom border of tr for multiple reservations of one apartment (select tr where the next tr has border-top-0 class) */
#reservation-table tr:has( + .border-top-0) {
    border-bottom: 0 !important;
}

#reservation-table .room-info {
    white-space: nowrap;
    vertical-align: middle;
}

/* fix for autocomplete not  shown */
.ui-front { 
    z-index: 9999; 
}

.price-period .badge {
    font-size: 90%;
    margin: 4px;
}

.badge .close {
    margin-left: .25rem;
    color: inherit;
    font-size: medium;
    font-weight: bold;
}

/* yearly reservation overview */
.reservation-yearly-parent { 
    padding: 0 !important; 
    position: relative; 
    overflow:hidden; 
}

.no-pointer-events {
    pointer-events: none;
}

div .reservation-yearly {
    padding: .5rem;
    width: 100%; 
    height: 100%;
    pointer-events: auto; 
    z-index: 1;
    cursor: pointer;
}

div .reservation-yearly-day {
    width: 100%; 
    height: 100%; 
    position: absolute; 
    left: 0; 
    top: 0; 
    z-index: 2; 
    padding: .5rem;
}
.month-reservationstartend {
    flex: 1 0 100%;
}
.month-reservation-end {
    transform: skewY(-45deg);
    transform-origin: bottom left;
}

.month-reservation-start {
    transform: skewX(-45deg);
    transform-origin: top right;
}
.month-reservation-onlystart {
    transform: skewY(-45deg);
}

.dummy-day {
    position: absolute;
    width: 100%;
    height: 100%;
    transform-origin: unset;
    pointer-events: auto;
    z-index: 1;
}
.month-reservation-start.dummy-day {
    left: 1.4rem;
}

.month-reservation-end.dummy-day {
    left: -1.4rem;
    transform: skewX(-45deg);
}

/*
 * Forms
 */
/* reduce default font size of labels in modals */
.modal-body .col-form-label {
    font-size: 14px;
}

/* add hint to required fields */
#accordionSettings label.required:after {
    content: " *";
}