/* Favourites Component Styles */

.favourite-toggle-container {
    display: inline-block;
}

.favourite-toggle {
    background-color: var(--light-color);
    border: 1px solid var(--border-color);
    padding: 0.25rem 0.5rem;
    transition: all 0.2s ease;
    color: var(--secondary-color); /* Default text/icon color */
}

.favourite-toggle .bi-heart-fill {
    display: none;
    color: var(--warning-color);
}

.favourite-toggle .bi-heart {
    display: inline-block;
    /* color: var(--secondary-color); Inherits from parent now */
}

.favourite-toggle.is-favourite .bi-heart-fill {
    display: inline-block;
}

.favourite-toggle.is-favourite .bi-heart {
    display: none;
}

.favourite-toggle.is-favourite {
    background-color: var(--warning-light-color);
    border-color: var(--warning-color);
    color: var(--warning-dark-color); /* Color for icon/text when favourited */
}

.favourite-count {
    margin-left: 0.25rem;
    font-size: 0.875rem;
    /* color: inherit; Inherits from parent */
}

/* --- Dark Mode Favourite Toggle --- */
.dark-theme .favourite-toggle:not(.is-favourite),
html.auto-dark-theme .favourite-toggle:not(.is-favourite) {
    background-color: var(--card-bg);
    border-color: rgba(var(--light-color-rgb), 0.2);
    color: rgba(var(--light-color-rgb), 0.7); /* Lighter grey for icon/text */
}

.dark-theme .favourite-toggle.is-favourite,
html.auto-dark-theme .favourite-toggle.is-favourite {
    background-color: rgba(var(--warning-color-rgb), 0.2);
    border-color: rgba(var(--warning-color-rgb), 0.5);
    color: var(--warning-color); /* Keep warning color for icon/text */
}

/* --- Hover styles need dark theme adaptation too --- */
.dark-theme .favourite-toggle:not(.is-favourite):hover,
html.auto-dark-theme .favourite-toggle:not(.is-favourite):hover {
    background-color: rgba(var(--light-color-rgb), 0.1);
    border-color: rgba(var(--light-color-rgb), 0.4);
    color: var(--light-color);
}

.dark-theme .favourite-toggle.is-favourite:hover,
html.auto-dark-theme .favourite-toggle.is-favourite:hover {
    background-color: rgba(var(--warning-color-rgb), 0.3);
    border-color: var(--warning-color);
}
/* End Dark Mode */

/* Favourite badge on cards */
.card .favourite-badge {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    z-index: 1;
}

/* Favourite filter toggle */
.favourite-filter-toggle label {
    cursor: pointer;
    display: flex;
    align-items: center;
}

/* Favourites section */
.favourites-section {
    border-left: 3px solid var(--warning-color);
    padding-left: 1rem;
    margin-bottom: 2rem;
}

@media (max-width: 768px) {
    .favourite-toggle {
        padding: 0.2rem 0.4rem;
    }
    
    .favourite-count {
        font-size: 0.75rem;
    }
} 