.calendar-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1380px;
    margin: auto;
    background: linear-gradient(135deg, #ff7e6, #f7f1e1);
    padding: 2em 0.2 0 0.2em;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    border-radius: 12px;
    overflow: hidden;
}

.calendar-slot {
    position: relative;
    flex: 1;
    border: 0.1px solid #f0f0f0;
    text-align: center;
    padding: 10px;
    box-sizing: border-box;
    border-radius: 12px;
    background-color: none;
 }

.calendar-slot.calendar-slot-today-first {
    border-left: 2px solid gray;
}

.calendar-slot.calendar-slot-today-last {
    border-right: 2px solid gray;
}

.calendar-slot.calendar-slot-selected {
    border-top: 2px solid gray;
    border-bottom: 2px solid gray;
}

.calendar-slot.calendar-slot-weekend {
    background-color: #EEF;
}

.calendar-slot.calendar-slot-today {
    background-color: #CFF;
}

.calendar-slot.calendar-slot-has-entries {
    background-color: #ABC;
}

.calendar-slot.calendar-slot-booked.workorder-cancelled{
    background-color: #DDD;
}

.calendar-slot.calendar-slot-booked {
    background-color: #DD4;
}

.calendar-slot.calendar-slot-overbooked {
    background-color: #F66;
}

.calendar-slot.calendar-slot-booked.workorder-finished {
    background-color: #4D4;
}

.calendar-slot a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    color: rgba(0,0,0,0);
    background: none;
    text-decoration: inherit;
    z-index: 1;
}

.calendar-slot a:hover {
    color: black;
    background: rgba(80, 120, 255, 0.5);
}

.calendar {
    display: flex;
    flex-direction: column;
    text-align: center;
}

.calendar-head {
    display: flex;
    flex-direction: column;
}

.calendar-head-row {
    display: flex;
    justify-content: space-between;
    background-color: rgba(84, 180, 211, 0.3);
    border-bottom: 1px solid rgba(85,85,85,.3);
}

.calendar-head.cal-week {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    box-sizing: border-box;
    margin: auto;
    padding: 0 10px;
    overflow: hidden;
}

.calendar-head-row.cal-day, .calendar-head-row.cal-weekday {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    box-sizing: border-box;
    height: 2.2em;
    width: 100%;
    margin: auto;
    padding: 0 10px;
    overflow: hidden;
}

.calendar-head-row i {
    color: #fff;
}

.calendar-head-row > div:nth-child(odd) {
    background-color: rgb(247, 247, 247);
    padding: 0.5em;
}

.calendar-head-row > div:nth-child(even) {
    padding: 0.5em;
}

.calendar-head-row > div:only-child {
    background-color: rgb(25,110, 255);
    padding: 0.5em;
    color: #fff;
}

.current-date {
    background-color: rgb(25,110,255);
    color: #fff;
}

.calendar-body-row {
    display: flex;
    height: 2.2em;
    border-bottom: 1px solid rgba(85,85,85,.3);
}

.calendar-body-row > * > span {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    margin: auto;
    box-sizing: border-box;
    z-index:1;
    position: relative;
    color: rgba(255, 255, 255, 1);
    text-shadow: 0 0 3px black;
    top: 0.5em;
    overflow: hidden;
}

#title {
    text-align: left;
    background-color: rgb(0, 82, 133);
    padding: 0.3em;
}

/*.calendar-body-row > div:nth-child(odd) {
    background-color: rgb(180, 200, 180);
}*/

.calendar-body-row-overlay {
    position: relative;
    top: -2em;
    margin-bottom: -2em;
    text-align: left;
    height: 2em;
}

.calendar-body-row-overlay > div {
    position: absolute;
    display: inline-block;
    box-shadow: 0 0 3px black inset;
}

.calendar-overlay-note {
    background-color: rgba(0, 0, 255, 0.5);/*rgba(120, 120, 80, 0.5);*/
}

.calendar-overlay-metering {
    background-color: rgba(255, 0, 0, 0.5);/*rgba(120, 120, 80, 0.5);*/
}

.calendar-overlay-connection_project_metering {
    background-color: rgba(255, 0, 0, 0.5);/*rgba(120, 120, 80, 0.5);*/
}

.calendar-overlay-vacation {
    background-color: rgba(0, 255, 0, 0.5);/*rgba(120, 120, 80, 0.5);*/
}

#CalendarReservations {
    padding-left: 0.5em;
}


.month-calendar-body {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.month-calendar-cell {
    display:flex;
    flex-direction:column;
    line-height:1;
    padding: 3px;
    height: 120px;
    border: 1px solid;
    border-color: #888;
    overflow:hidden;
}
.pointer {
    cursor:pointer;
}
.month-calendar-cell-day {
    margin-top:auto;
    text-align:right;
}
.month-calendar-cell.today {
    background-color: #fdfdd4;
}
.month-calendar-cell.selected {
    border: 2px solid #0d6efd;
    border-radius: 2px;
}
.cell-outside-month {
    color:#999;
}
.month-calendar-label {
    font-weight:bold;
    padding-right:3px;
    text-align:right;
}
.month-calendar-label.weekend {
    color:red;
}
.calendar-header-left {
    background-color:#E1F4FE;
    padding:5px;
}
.calendar-header-right {
    float:right;
    background-color:#E1F4FE;
    padding:5px;
}

.calendar-chevrons {
    padding-left:20px;
}
.calendar-name {
    padding-left:20px;
}
.calendar-title {
    background-color:#0d6efd;
    color:white;
    font-size: 2rem;
    line-height:1;
    padding:10px;
}
.calendar-header {
    margin-top:15px;
    margin-bottom:20px;
    font-size:x-large;
}
.calendar-sidebar {
    margin-top:60px;
}
.calendar-reservation {
    white-space:nowrap;
    font-size:x-small;
    line-height:1.5;
}

.dot {
    height: 6px;
    width: 6px;
    border-radius: 50%;
    display: inline-block;
}

.large-dot {
    height: 10px;
    width: 10px;
    border-radius: 50%;
    display: inline-block;
}

/*Adjust for Landscape mode */
@media (max-width: 992px) and (orientation: landscape) {
    .calendar-comtainer {
        max-width: 90%;
        padding; 1.5em 1em;
        box-shadow: 0 2px 5px rgba(0, 0, 0, 1);
    }
}

@media only screen and (max-width: 786px) {
    .calendar-container {
        padding: 1.5em 0.5em;
        box-shadow: none;
    }
}

@media only screen and (max-width: 480px) {
    .calendar-container {
        max-width: 95%;
        padding: 1em;
    }
}

@media only screen and (max-width: 64em) {
    .calendar-head-row.cal-week {
        grid-template-columns: repeat(auto-fit, minmax(150px 1fr));
        padding: 0 8px;
    }
    .calendar-head-row.cal-day {
        grid-template-columns: repeat(auto-fit, minmax(2px, 1fr));
        padding: 0 5px;
    }
    .calendar-head-row.cal-weekday {
        grid-template-columns: repeat(auto-fit, minmax(2px, 1fr));
        padding: 0 4px;
    }
}

@media only screen and (max-width: 60em) {
    .calendar-head-row.cal-week {
        grid-template-columns: repeat(auto-fit, minmax(50px 1fr));
        padding: 0 8px;
    }
    .calendar-head-row.cal-day {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 2px;
    }
    .calendar-head-row.cal-weekday {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 1px;
    }
    .calendar-body-row > * > span {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 1px;
    }
}

@media only screen and (max-width: 41em) {
    .calendar-head-row.cal-week {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 6px;
    }
    .calendar-head-row.cal-day {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 1px;
    }
    .calendar-head-row.cal-weekday {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 1px;
    }
    .calendar-body-row > * > span {
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
        padding: 0 1px;
    }
}
