:root {
    --label-color1: rgb(132, 169, 240);
    --label-color2: rgb(80, 100, 208);
    --label-color3: rgb(146, 73, 234);
    --label-color4: rgb(193, 104, 234);
}

body {
    overflow-y: scroll;
}

.image-stack {
    float: right;
    margin: 10px;
    margin-top: 0px;
    width: 30%;
}

.demo-video {
    width: 65%;
    aspect-ratio: 16/9;
}

.image-stack img {
    width: 100%;
    cursor: zoom-in;
}

#project-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    grid-row: 5px;
    row-gap: 5px;
}

#label-list {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 5px;
    margin-bottom: 10px;
}

.project {
    display: inline-block;

    width: 49%;
    padding: 10px;
    background-color: var(--bg-color2);
    border: 1px solid;
    border-radius: 10px;
    border-color: var(--bg-color3);

    color: var(--text-color);
    text-decoration: none;
}

.project-hidden {
    display: none;
}

.project:nth-child(odd of :not(.project-hidden)) {
    margin-right: auto;
}

.project-title {
    font-size: 1.5em;
    margin-bottom: 5px;
    font-weight: normal;
}

.project-date {
    font-size: 1em;
    color: var(--text-color-gray);
    font-weight: bold;
}

.project-labels {
    margin-top: 10px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 5px;
}

.label {
    display: inline-block;
    border-radius: 5px;
    padding-left: 5px;
    padding-right: 5px;
    background-color: gray;
    border: 2px solid transparent;
    cursor: pointer;
}

.label-selected {
    border-color: var(--text-color);
}

.label-disabled {
    opacity: 0.5;
}

.label-type {
    background-color: var(--label-color1);
    color: black;
}

.label-topic {
    background-color: var(--label-color2);
    color: black;
}

.label-language {
    background-color: var(--label-color3);
    color: rgb(0, 0, 0);
}

.label-framework {
    background-color: var(--label-color4);
    color: black;
}

#clear-filters-button {
    border: 1px solid var(--bg-color2);
}