.sets-container {
    flex: 1;
    padding: 2rem;
}

.sets-header {
    margin-bottom: 2rem;
}

.sets-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
}


/* Table — base styles in app-table.css */

/* Character Link */
.char-link {
    text-decoration: none;
    font-weight: 600;
    transition: opacity 0.2s;
}

.char-link:hover {
    opacity: 0.8;
}

.player-name {
    color: var(--text-muted);
}

.class-name {
    color: var(--text-primary);
    font-size: 0.9rem;
}

/* Set Status */
.set-status {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
}

.set-status--need {
    background: rgba(231, 76, 60, 0.15);
    color: var(--color-danger);
    border: 1px solid rgba(231, 76, 60, 0.3);
}

.set-status--owned {
    background: rgba(46, 204, 113, 0.15);
    color: var(--color-success-alt-2);
    border: 1px solid rgba(46, 204, 113, 0.3);
}

.set-status--owned.set-status--normal {
    background: rgba(52, 152, 219, 0.15);
    color: var(--color-normal);
    border: 1px solid rgba(52, 152, 219, 0.3);
}

.set-status--owned.set-status--heroic {
    background: rgba(155, 89, 182, 0.15);
    color: var(--color-heroic);
    border: 1px solid rgba(155, 89, 182, 0.3);
}

.set-status--owned.set-status--mythic {
    background: rgba(230, 126, 34, 0.15);
    color: var(--color-mythic);
    border: 1px solid rgba(230, 126, 34, 0.3);
}

.set-status--none {
    background: var(--bg-input-faint);
    color: var(--text-subtle);
    border: 1px solid var(--border-faint);
}

/* Catalyst info icon */
.catalyst-info {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-left: 0.2rem;
    color: var(--color-gold);
    cursor: default;
    flex-shrink: 0;
}

.catalyst-info::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-surface-1);
    color: var(--text-primary);
    border: 1px solid var(--border-subtle);
    border-radius: 6px;
    padding: 0.3rem 0.6rem;
    font-size: 0.78rem;
    font-weight: 600;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    z-index: 10;
}

.catalyst-info:hover::after {
    opacity: 1;
}

/* Set Bonus Indicators */
.set-bonus {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    font-size: 1.1rem;
    font-weight: 700;
}

.set-bonus--active {
    background: rgba(46, 204, 113, 0.2);
    color: var(--color-success-alt-2);
    border: 2px solid rgba(46, 204, 113, 0.4);
}

.set-bonus--inactive {
    background: var(--bg-input-faint);
    color: var(--text-subtle);
    border: 2px solid var(--border-faint);
}

/* Missing Pieces Characters */
.missing-char-item {
    padding: 0.25rem 0.5rem;
    background: var(--bg-input-faint);
    border-radius: 4px;
    transition: all 0.2s ease;
    width: 100%;
}

.missing-char-item:hover {
    background: var(--bg-primary-faint);
}

.missing-char-item a:hover {
    opacity: 0.8;
}

