.card {
    --card-color: white;

    display: flex;
    background-color: transparent;
    flex-direction: column;
    padding-left: var(--padding);
    border-left: 3px solid var(--card-color);
    border-radius: 3px;
    gap: calc(var(--padding) * 0.5);

    &.red {
        --card-color: var(--soft-red);      
    }

    &.orange {
        --card-color: var(--soft-orange);      
    }

    &.blue {
        --card-color: var(--soft-blue);
    }

    &.green {
        --card-color: var(--soft-green);
    }

    &.purple {
        --card-color: var(--soft-purple);
    }

    &.yellow {
        --card-color: var(--soft-yellow);
    }

    &.black {
        --card-color: black;
    }

    &.bg {
        background-color: color-mix(in srgb, var(--card-color) 20%, transparent);
        padding: var(--padding);

        &.blur {
            backdrop-filter: blur(10px);
        }
    }

    a {
        max-width: 100%;
    }

    img {
        line-height: 0;
        display: block;
    }

    img.wide {
        max-width: 600px;
    }

    .footnote {
        opacity: 75%;
    }
}

.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;
        }
    }
}

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

    .music-card {
        --card-color: white;
        
        align-items: flex-start;
        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;
        display: flex;
        flex-direction: row;
        gap: var(--padding);
        
        a {
            display: flex;
            flex-direction: row;
            gap: var(--padding);
            align-items: center;
            font-size: 1.3em;
            img {
                border-radius: 10px;
                min-width: 150px;
                max-width: 150px;
            }
        }

        .music-card-info {
            display: flex;
            flex-direction: column;
            gap:calc(var(--padding) * 0.5);
            margin-top: -5px;

            h3 {
                margin-bottom: -5px;
            }

            audio {
                max-width: 500px;
                border-radius: 15px;
                backdrop-filter: blur(10px);
                box-shadow: 2px 2px 5px rgb(0, 0, 0, 0.6);
            }
        }

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

        &.red {
            --card-color: var(--soft-red);
        }

        &.blue {
            --card-color: var(--soft-blue);
        }

        &.green {
            --card-color: var(--soft-green);
        }

        &.purple {
            --card-color: var(--soft-purple);
        }

        &.yellow {
            --card-color: var(--soft-yellow);
        }

        &.trans {
            background-color: transparent;
        }

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

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

.park-card {
    --card-color: white;

    display: flex;
    background-color: transparent;
    flex-direction: row;
    padding-left: var(--padding);
    border-left: 3px solid var(--card-color);
    border-radius: 3px;
    gap: calc(var(--padding) * 2);

    &.red {
        --card-color: var(--soft-red);      
    }

    &.orange {
        --card-color: var(--soft-orange);      
    }

    &.blue {
        --card-color: var(--soft-blue);
    }

    &.green {
        --card-color: var(--soft-green);
    }

    &.purple {
        --card-color: var(--soft-purple);
    }

    &.yellow {
        --card-color: var(--soft-yellow);
    }

    &.black {
        --card-color: black;

        .card-right p {
            color: white;
        }
        
        .card-right .links a {
            border-color: #cccccc;
            color: #cccccc;
        }
    }

    &.bg {
        background-color: color-mix(in srgb, var(--card-color) 20%, transparent);
        padding: var(--padding);

        &.blur {
            backdrop-filter: blur(10px);
        }
    }

    a {
        max-width: 100%;
    }

    img {
        line-height: 0;
        display: block;
    }

    img.wide {
        max-width: 600px;
    }

    .footnote {
        opacity: 75%;
    }

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

    .card-right {
        display: flex;
        flex-direction: column;
        gap: calc(var(--padding) * 0.5);

        p {
            color: var(--card-color);
        }

        ul {
            line-height: 20px;
        }
    }

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

        a {
            display: flex;
            border: 2px solid var(--card-color);
            padding: var(--padding);
            border-radius: 7px;
            font-weight: 500;
            text-decoration: none;
            justify-content: center;
            align-items: center;
            gap: var(--padding);
            color: var(--card-color);

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

.video-card {
    --card-color: white;

    display: flex;
    background-color: transparent;
    flex-direction: row;
    padding-left: var(--padding);
    border-left: 3px solid var(--card-color);
    border-radius: 3px;
    gap: calc(var(--padding) * 2);

    &.red {
        --card-color: var(--soft-red);      
    }

    &.orange {
        --card-color: var(--soft-orange);      
    }

    &.blue {
        --card-color: var(--soft-blue);
    }

    &.green {
        --card-color: var(--soft-green);
    }

    &.purple {
        --card-color: var(--soft-purple);
    }

    &.yellow {
        --card-color: var(--soft-yellow);
    }

    &.black {
        --card-color: black;

        .card-right p {
            color: white;
        }
        
        .card-right .links a {
            border-color: #cccccc;
            color: #cccccc;
        }
    }

    &.bg {
        background-color: color-mix(in srgb, var(--card-color) 20%, transparent);
        padding: var(--padding);

        &.blur {
            backdrop-filter: blur(10px);
        }
    }

    a {
        max-width: 100%;
    }

    img {
        line-height: 0;
        display: block;
    }

    img.wide {
        max-width: 600px;
    }

    .footnote {
        opacity: 75%;
    }

    .card-left {
        display: flex;
        flex-direction: column;
        gap: calc(var(--padding));

        .img-logo {
            margin-top: -12px;
            min-width: 100%;
        }
    }

    .card-right {
        display: flex;
        flex-direction: column;
        gap: calc(var(--padding) * 0.5);

        p {
            color: var(--card-color);
        }

        ul {
            line-height: 20px;
        }
    }

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

        a {
            display: flex;
            border: 2px solid var(--card-color);
            padding: var(--padding);
            border-radius: 7px;
            font-weight: 500;
            text-decoration: none;
            justify-content: center;
            align-items: center;
            gap: var(--padding);
            color: var(--card-color);

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

.interests {
    display: flex;
    flex-direction: column;
    gap: calc(var(--padding) * 0.5);

    details {
        justify-items: center;
        --card-color: white;
        display: flex;
        background-color: transparent;
        flex-direction: column;
        padding: var(--padding) var(--padding) var(--padding) var(--padding);
        border-left: 3px solid var(--card-color);
        border-radius: 3px;
        overflow: hidden;
        gap: calc(var(--padding) * 0.5);

        &[open] {
            height: auto;

            h3 {
                color: white;
            }
        }

        summary {
            margin: 0;
            padding: 0;
            color: color-mix(in srgb, var(--card-color) 20%, white);

            h3 {
                display: inline;
            }
        }

        .interest-detail {
            margin-left: 15px;
            text-shadow: 2px 2px 2px black;
            line-height: 25px;
            display: flex;
            flex-direction: column;
            gap: var(--padding);

            ul {
                display: flex;
                flex-direction: column;
                gap: calc(var(--padding) * 0.75);
                font-weight: normal;
                font-style: normal;

                span {
                    font-weight: bold;
                    font-style: italic;
                    text-decoration: underline;
                }
            }
        }

        &.bg {
            background-color: color-mix(in srgb, var(--card-color) 20%, transparent);

            &.blur {
                backdrop-filter: blur(10px);
            }
        }

        &.red {
            --card-color: var(--soft-red);      
        }

        &.orange {
            --card-color: var(--soft-orange);      
        }

        &.blue {
            --card-color: var(--soft-blue);
        }

        &.green {
            --card-color: var(--soft-green);
        }

        &.purple {
            --card-color: var(--soft-purple);
        }

        &.yellow {
            --card-color: var(--soft-yellow);
        }

        &.black {
            --card-color: black;

            .card-right p {
                color: white;
            }
            
            .card-right .links a {
                border-color: #cccccc;
                color: #cccccc;
            }
        }

        a {
            max-width: 100%;
        }

        img {
            line-height: 0;
            display: block;
        }

        img.wide {
            max-width: 600px;
        }

        .footnote {
            opacity: 75%;
        }
    }
}


.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 {
            transform: scale(1.1);
            box-shadow: 4px 4px 10pxblack;
            color: white;
            border-color: white;
        }
    }
}

@media (max-width: 756px) {

    .links {
        flex-direction: column;
    }

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

    .park-card {
        .card-left {
            text-align: left;
            padding-bottom: calc(var(--padding) * 0.5);
        }

        flex-direction: column;
    }

    .video-card {
        .card-left {
            text-align: left;
            gap: calc(var(--padding) * 0.5);
            padding-bottom: 0;
        }
        
        flex-direction: column;
    }
}