/* Favourite Heart Button on Cards */
.btn-favourite {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 2px solid #e0e0e0;
    border-radius: 50%;
    background: #fff;
    color: #999;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
    outline: none;
    position: relative;
    flex-shrink: 0;
}

.btn-favourite:hover {
    border-color: #e1273d;
    color: #e1273d;
    transform: scale(1.1);
}

.btn-favourite.active {
    background: #e1273d;
    border-color: #e1273d;
    color: #fff;
    animation: favouritePulse 0.4s ease;
}

.btn-favourite.active:hover {
    background: #c41f33;
    border-color: #c41f33;
}

.btn-favourite.active i {
    font-weight: 900;
}

@keyframes favouritePulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.3); }
    100% { transform: scale(1); }
}

/* Header Favourite Icon */
.header-favourite-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    color: #333;
    font-size: 20px;
    transition: color 0.3s ease;
    text-decoration: none;
}

.header-favourite-icon:hover {
    color: #e1273d;
    text-decoration: none;
}

.favourite-badge {
    position: absolute;
    top: 2px;
    right: 0;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: #e1273d;
    color: #fff;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
}

/* Mobile header icon variant */
.mobile-header-icon.header-favourite-icon {
    width: 32px;
    height: 32px;
    font-size: 18px;
}

.mobile-header-icon.header-favourite-icon .favourite-badge {
    top: 0;
    right: -4px;
    min-width: 16px;
    height: 16px;
    font-size: 9px;
    line-height: 16px;
}

/* Interior Gallery Card - position favourite button */
.interior-gallery-card > .btn-favourite {
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 25;
    opacity: 0;
    transform: translateY(-10px);
    transition: all 0.3s ease;
}

.interior-gallery-card:hover > .btn-favourite {
    opacity: 1;
    transform: translateY(0);
}

.interior-gallery-card > .btn-favourite.active {
    opacity: 1;
    transform: translateY(0);
}

[dir="rtl"] .interior-gallery-card > .btn-favourite {
    left: auto;
    right: 15px;
}

/* RTL Support */
[dir="rtl"] .favourite-badge {
    right: auto;
    left: 0;
}

[dir="rtl"] .mobile-header-icon.header-favourite-icon .favourite-badge {
    right: auto;
    left: -4px;
}
