h1 {
    margin-block-end: 0.5rem;
}

category-filter {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-block-end: 2rem;

    & button {
        font: inherit;
        font-size: 0.875rem;
        cursor: pointer;
        padding: 0.2rem 0.75rem;
        border: 1px solid currentColor;
        border-radius: 2rem;
        background: none;
        color: inherit;
        opacity: 0.5;
        transition: opacity 0.15s;

        &:hover {
        opacity: 1;
        }

        &.active {
        opacity: 1;
        font-weight: 600;
        }
    }
}

.wish-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
    gap: 1.5rem;
}

wish-card[hidden] {
    display: none;
}

.wish-card {
    display: block;
    text-decoration: none;
    color: inherit;

    & img {
        display: block;
        inline-size: 100%;
        aspect-ratio: 1;
        object-fit: cover;
        border-radius: 0.5rem;
    }

    & h2 {
        font-size: 1rem;
        margin-block-start: 0.5rem;
    }

    & .meta {
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: 0.875rem;
        opacity: 0.7;
        margin-block-start: 0.25rem;
    }
}