.links {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--padding);

    a {
        display: flex;
        border: 2px solid color-mix(in srgb, var(--primary-color) 30%, white);
        padding: var(--padding);
        border-radius: 7px;
        font-weight: 500;
        text-decoration: none;
        justify-content: center;
        align-items: center;
        gap: var(--padding);

        svg {
            height: 1em;
            width: auto;
            fill: currentColor;
        }
        
        &:focus, &:hover {
            box-shadow: 4px 4px 10pxblack;
            color: white;
            border-color: white;
        }
    }
}

.graphic-cards {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: var(--padding);

    .graphic-card {
        --card-color: rgb(0, 0, 0);
        
        background-color: color-mix(in srgb, var(--card-color) 20%, transparent);
        backdrop-filter: blur(10px);
        padding: var(--padding);
        border-left: 3px solid var(--card-color);
        border-radius: 3px;
        gap: var(--padding);

        .graphic-card-text {
            margin-bottom: var(--padding);
        }
        
        .graphic-holder {
            display: flex;
            flex-direction: row;
            flex-wrap: wrap;
            gap: var(--padding);
            align-items: stretch;
        }

        img {
            border-radius: 10px;
            height: 150px;
            width: auto;
            min-width: unset;
            max-width: 100%;
            object-fit: contain;
            transition: all 0.1s;

            &:hover, &:focus {
                transform: scale(1.05);
            }
        }

        p a {
            all: unset;
            color: white;
            cursor: pointer;
            text-decoration: none;
            &:focus, &:hover {
                color: color-mix(in srgb, var(--secondary-color) 50%, white);
            }
        }

        &.trans {
            background-color: transparent;
        }

        img:not([src]), img[src=""] {
            display: none;
        }

        a:has(img:not([src])), a:has(img[src=""]) {
            display: none;
        }
    }
}

.lightbox {
    display: none;
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.85);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    padding: var(--padding);
    cursor: pointer;
    overflow-y: auto;

    &.active {
        display: flex;
        flex-direction: column;
    }

    img {
        max-width: 90vw;
        max-height: 90vh;
        min-height: 0;
        object-fit: contain;
        border-radius: 10px;
        flex-shrink: 1;
    }

    &.has-caption img {
        max-height: 70vh;
    }

    .lightbox-text {
        max-width: 80%;
        flex-shrink: 0;
        margin-top: var(--padding);
        text-align: center;
        font-style: italic;

        #lightbox-caption {
            opacity: 80%;
            margin-bottom: var(--padding);
            &:empty { display: none; }
        }
        p {
            opacity: 50%;
        }
    }
}

@media (max-width: 500px) {

    .links {
        flex-direction: column;
    }

    .music-cards .music-card {
        flex-direction: column;
    }
}