
#event-nav .nav-link {
    --bs-nav-link-color: curentcolor;
    --bs-nav-link-hover-color: curentcolor;
    font-size: 1.25rem;
}

#event-nav .nav-link:focus-visible {
    outline: 2px solid white;
    outline-offset: 2px;
}

/* list view */
#event-list {
    transition: padding ease 300ms;
    padding: 0 0 5rem 0;
    max-height: 80vh;
    overflow: auto;
}

#event-list:hover {
    padding: 0;
}

.event-list-item {
    border-bottom: 1px solid #eee !important;
    cursor: pointer;
    transition: padding ease 300ms;
    padding: 0;
}

.event-list-item > * {
    margin: 0 auto;
    height: 5rem;
    transition: height ease 300ms;
}

.event-list-item > div {
    overflow: hidden;
    padding: 0 2rem;
    flex-basis: 15rem;
}

.event-list-item p {
    max-height: 5em;
    margin: 0;
    overflow: clip;
}

.event-list-item:hover > *,
.event-list-item:focus-within > * {
    height: 10rem;
}

.event-list-item:hover,
.event-list-item:focus-within {
    background-color: #fff !important;
}

.event-list-item:hover::after,
.event-list-item:focus-within::after {
    content: '▽';
    width: 0;
    margin: .25em 1.25em 0 -1.25em;

    /* */
    content: "";
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 16 16%27 fill=%27%233c3c3b%27%3e%3cpath fill-rule=%27evenodd%27 d=%27M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z%27/%3e%3c/svg%3e");
    background-image: var(--bs-accordion-btn-icon);
    background-repeat: no-repeat;
    background-size: var(--bs-accordion-btn-icon-width);
    transition: var(--bs-accordion-btn-icon-transition);
    /* */

}

.showfull {
    padding: 2rem;
}

.showfull > * {
    height: 25rem !important;
}

.showfull > div {
    overflow: auto;
}

.showfull p {
    height: auto;
    max-height: revert;
    overflow: visible;
}

.event-list-btn {
    aspect-ratio: 1;
    cursor: zoom-in !important;
}

.showfull .event-list-btn {
    cursor: zoom-out !important;
}

/* calendar */
#calendar-header {
    height: 4rem;
}

.calendar-body {
    table-layout: fixed;
}

.calendar-body td {
    height: 4rem;
    border: 1px solid #ccc;
    position: relative;
    text-align: center;
}

@media (min-width: 768px) {
    .calendar-body td {
        height: 5rem;
    }
}

.inactive {
    opacity: .5;
}

.today {
    color: var(--ccp-red);
    font-weight: bold;
}

.calendar-body .btn-clear {
    height: 90%;
    width: 90%;
    font-size: 1.75em;
    text-shadow: 0 0 4px #fffc, 0 0 6px #fff9;
    font-weight: bold;
}

.calendar-body .btn-clear:hover {
    background-color: #fff2;
}

.today .btn-clear {
    color: var(--ccp-red);
}

#calendar-prev, #calendar-next {
    background: #fff1;
    padding: 1rem 1.5rem;
    width: 4rem;
    font-size: 1.5rem;
    line-height: 0;
    transition: background-color 200ms;
}

#calendar-prev:hover, #calendar-next:hover {
    background: #fff3;
}

#events, #no-events {
    margin-top: 4rem;
}

.hide-card {
    animation: 500ms ease 0s forwards card-hide;
    top: 4rem;
}

@media screen and (prefers-reduced-motion: reduce) {
    .flip-right, .flip-left {
        display: none
    }

    #events > div {
        transition: opacity 300ms ease;
    }

    #events > div.show {
        animation: zoom-in 300ms ease;
    }

    #events > div.hide {
        opacity: 0;
    }

    #events > div.next {
        opacity: .6;
    }

    @keyframes zoom-in {
        0% {
            opacity: 0;
        }
        100% {
            opacity: 1;
        }
    }

    @keyframes flip {
        0% {
            display: none;
        }
    }

    @keyframes card-hide {
        0% {
            opacity: 1;
        }
        100% {
            opacity: 0;
        }
    }
}

@media screen and (prefers-reduced-motion: no-preference) {

    #calendar-container {
        perspective: 60cm;
        transform-style: preserve-3d;
    }

    .flip-right {
        transform-origin: right;
        /*backface-visibility: hidden;*/
        transform: rotateY(85deg);
        animation: 600ms ease 0s forwards flip;
    }

    .flip-left {
        transform-origin: left;
        /*backface-visibility: hidden;*/
        transform: rotateY(-85deg);
        animation: 600ms ease 0s forwards flip;
    }

    #events > div {
        transition: transform 300ms ease;
    }

    #events > div.hide {
        transform: scale(0%);
    }

    #events > div.show {
        animation: zoom-in 300ms ease;
    }

    #events > div.next {
        transform: scale(110%);
    }

    @keyframes zoom-in {
        0% {
            transform: scale(115%);
            opacity: 0;
        }
        100% {
            transform: scale(100%);
            opacity: 1;
        }
    }

    @keyframes flip {
        0% {
            transform: rotateY(0);
            opacity: 1;
        }
        50% {
            opacity: 1;
        }
        100% {
            opacity: 0;
        }
    }

    @keyframes card-hide {
        0% {
            transform: scale(100%);
            opacity: 1;
        }
        100% {
            transform: scale(10%);
            opacity: 0;
        }
    }
}
