/* Favorit-hjärtan – egna färger (index.php åsidosätter .text-primary med vinröd) */
.fav-heart-daniel {
    color: #198754 !important;
}
.fav-heart-jenny {
    color: #0d6efd !important;
}
.badge-fav-daniel {
    background-color: #d1e7dd !important;
    color: #0f5132 !important;
    border: 1px solid #a3cfbb !important;
}
.badge-fav-jenny {
    background-color: #cfe2ff !important;
    color: #084298 !important;
    border: 1px solid #9ec5fe !important;
}

/* Hjärtan direkt på etikettbilden – uppe till vänster */
.vin-img-wrap,
.vin-photo-slot {
    position: relative;
    line-height: 0;
}

/* Startsida: bild fyller kortets bildyta */
.vin-card .vin-img-wrap {
    display: block;
    width: 100%;
    border-radius: 8px 8px 0 0;
    overflow: hidden;
}

.vin-card .vin-img-wrap .vin-bild {
    display: block;
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 0;
}

.vin-card .vin-img-wrap .placeholder-bild {
    display: flex;
    width: 100%;
    height: 200px;
}

/* Vin-sida: wrapper följer bildens faktiska storlek (inte hela knappytan) */
.vin-photo-slot {
    display: block;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.vin-photo-slot .vin-hero {
    display: block;
    max-width: 100%;
    max-height: 70vh;
    width: auto;
    height: auto;
    border-radius: 12px;
}

.vin-fav-overlay {
    position: absolute;
    top: 0.45rem;
    left: 0.45rem;
    z-index: 5;
    display: flex;
    flex-direction: row;
    gap: 0.25rem;
    pointer-events: none;
}

/* Hjärtan ovanpå foto – skugga för läsbarhet, ingen stor vit bubbla */
.vin-fav-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    line-height: 1;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.85)) drop-shadow(0 0 6px rgba(0, 0, 0, 0.5));
}

.vin-fav-chip .fas {
    -webkit-text-stroke: 1px rgba(255, 255, 255, 0.85);
    paint-order: stroke fill;
}
