.view-switcher-container {
    background: var(--pico-contrast-background);
    padding: 0.25rem;
    border-radius: 0.5rem;
    display: inline-flex;
    gap: 0.25rem;
}

.view-switcher {
    padding: 0.5rem;
    border-radius: 0.375rem;
    background: transparent;
    border: none;
    color: var(--pico-contrast-inverse);
    cursor: pointer;
    transition: all 0.2s;
}

.view-switcher:hover {
    background: var(--pico-contrast-hover-background);
}

.view-switcher.active {
    background: var(--pico-contrast-focus);
    color: var(--pico-contrast-inverse);
    box-shadow: var(--pico-card-box-shadow);
}

.sort-btn {
    padding: 0.5rem;
    border-radius: 0.375rem;
    border: 1px solid var(--pico-muted-border-color);
    background: var(--pico-contrast-background);
    color: var(--pico-contrast-inverse);
    cursor: pointer;
    transition: background-color 0.2s;
}

.sort-btn:hover {
    background: var(--pico-contrast-hover-background);
}

.view-container {
    display: none;
}

.view-container.active {
    display: block;
}

.empty-state {
    text-align: center;
    padding: 3rem 0;
}

.empty-state-icon {
    width: 6rem;
    height: 6rem;
    margin: 0 auto 1rem;
    background: var(--pico-contrast-background);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--pico-muted-color);
}
.view-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}

.hidden {
    display: none !important;
}
