.favorites-page {
    min-height: 70vh;
    padding-bottom: 80px;
}

.favorites-page__header {
    background: var(--light-warm, #F8F2EF);
    border-bottom: 1px solid rgba(55, 36, 28, 0.08);
    padding: 40px 24px 32px;
}

.favorites-page__header-inner {
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 20px;
}

.favorites-page__header-icon {
    font-size: 40px;
    color: var(--main-color-orange, #FF7312);
    flex-shrink: 0;
}

.favorites-page__title {
    font-family: var(--font-rubik, 'Rubik', sans-serif);
    font-size: 28px;
    font-weight: 700;
    color: var(--dark1, #37241C);
    margin: 0 0 4px;
}

.favorites-page__subtitle {
    font-size: 14px;
    color: var(--gray-system, #8E8E93);
    margin: 0;
}

.favorites-page__content {
    max-width: 1280px;
    margin: 40px auto;
    padding: 0 24px;
}

.favorites-page__loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 80px 0;
    color: var(--gray-system, #8E8E93);
    font-size: 15px;
}

.favorites-page__loading i {
    font-size: 36px;
    color: var(--main-color-orange, #FF7312);
}

.favorites-page__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 80px 0;
    text-align: center;
}

.favorites-page__empty i {
    font-size: 38px;
    opacity: 0.4;
}

.favorites-page__empty-message {
    font-size: 16px;
    color: var(--gray-system, #8E8E93);
    margin: 0;
}

.favorites-page__empty-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--main-color-orange, #FF7312);
    color: #fff;
    font-family: var(--font-rubik, 'Rubik', sans-serif);
    font-size: 14px;
    font-weight: 500;
    padding: 12px 24px;
    border-radius: 100px;
    text-decoration: none;
    transition: background 0.22s ease, transform 0.18s ease;
}

.favorites-page__empty-cta:hover {
    background: #e05e00;
    transform: translateY(-1px);
}
