.recipe-card {
    overflow: hidden;
    transition: transform 0.12s ease-out, box-shadow 0.12s ease-out, border-color 0.12s ease-out, background 0.12s ease-out;
}

.recipe-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-strong);
    border-color: var(--accent-border);
    background: radial-gradient(circle at top left, var(--accent-halo-strong), transparent 60%), var(--bg-card);
}

.recipe-link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}

.recipe-link.is-disabled {
    pointer-events: none;
    opacity: 0.85;
}

.recipe-thumb-wrapper {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1;
    border-radius: var(--radius-lg);
}

.cooked-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.2rem 1rem 0.3rem 1rem;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 600;
    border: 1px solid var(--accent);
    background: var(--accent-border);
    color: white;
    backdrop-filter: blur(6px);
}

body.is-guest .cooked-badge {
    filter: saturate(0);
}

.planned-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.2rem 1rem 0.3rem 1rem;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 600;
    border: 1px solid var(--accent-secondary);
    background: var(--accent-secondary-border);
    color: white;
    backdrop-filter: blur(6px);
}

.recipe-thumb {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.03);
    transition: filter 0.4s ease, opacity 0.3s ease;
    filter: blur(3px) saturate(0.8);
    opacity: 0.8;
}

.recipe-thumb.loaded-full {
    filter: blur(0) saturate(1.1);
    opacity: 1;
}

.recipe-card:hover .recipe-thumb {
    transform: scale(1.06);
    filter: saturate(1.15);
}

.recipe-body {
    padding: 0.75rem 0 0;
}

.recipe-title {
    margin: 0 0 0.35rem;
    font-size: 1rem;
}
