
.calendar {
    width: 100%;
    max-width: 600px;
    margin: auto;
}

.calendar-row {
    display: flex;
    width: 100%;
    margin: 8px 0;
}

.calendar-row.past {
    opacity: 60%;
}


.calendar-date {
    display: grid;
    width: 110px;
    max-width: 110px;
    min-width: 110px;

    padding: 16px;
    background-color: black;
    color: #f8f8f8;
    border-radius: 8px 0 0 8px;

    align-items: center;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
}


.calendar-desc {
    flex-grow: 1;
    background-color: #f8f8f8;
    border-radius: 0 8px 8px 0;
    padding: 16px;

    text-align: left;
}

.calendar-desc p {
    margin: 6px 0;
}

.calendar-loc, .calendar-time, .calendar-cup {
    text-indent: ;
}

.calendar-loc::before, .calendar-time::before, .calendar-cup::before {
    font-family: "Font Awesome 7 Free";
    font-weight: bold;
    text-align: center;
}

.calendar-loc::before {
    content: "\f3c5";
    padding: 0 10px 0 2px;
}

.calendar-time::before {
    content: "\f017";
    padding-right: 8px;
}

.calendar-cup::before {
    content: "\f091";
    padding-right: 8px;
}
