/* ============================================
   LineupIQ Views
   ============================================ */

/* Contests Workspace */
.contests-workspace {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1.5rem;
    background: var(--liq-bg-primary);
}

.contests-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--liq-border-color);
}

    .contests-header h5 {
        color: var(--liq-text-primary);
        margin: 0;
    }

        .contests-header h5 i {
            color: #3b82f6;
        }

.contests-content {
    flex: 1;
    overflow: auto;
}

.contests-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 300px;
}

    .contests-empty-state i {
        color: var(--liq-text-secondary);
    }

    .contests-empty-state h5 {
        color: var(--liq-text-primary);
    }

    .contests-empty-state p {
        color: var(--liq-text-secondary);
    }

.contests-table-container {
    overflow-x: auto;
}

.contests-table {
    margin-bottom: 0;
    background: var(--liq-bg-secondary);
    border-radius: 8px;
    overflow: hidden;
}

    .contests-table thead th {
        background: var(--liq-bg-tertiary);
        color: var(--liq-text-secondary);
        font-size: 0.8rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        border-bottom: 1px solid var(--liq-border-color);
        padding: 0.75rem 1rem;
    }

    .contests-table tbody td {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--liq-border-color);
        color: var(--liq-text-primary);
        vertical-align: middle;
    }

    .contests-table tbody tr:last-child td {
        border-bottom: none;
    }

.contest-row {
    cursor: pointer;
    transition: background-color 0.15s ease;
}

    .contest-row:hover {
        background-color: var(--liq-bg-hover);
    }

.contest-name {
    font-weight: 500;
    color: var(--liq-text-primary);
}

.contest-row small {
    color: var(--liq-text-secondary);
}

.view-contest-btn {
    white-space: nowrap;
}

    .view-contest-btn:disabled {
        opacity: 0.5;
        cursor: not-allowed;
    }

/* Contest Cards */
.contests-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1rem;
    padding: 0.5rem 0;
}

.contest-card {
    background: var(--liq-bg-secondary);
    border: 1px solid var(--liq-border-color);
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .contest-card:hover {
        border-color: var(--liq-accent-blue);
        box-shadow: 0 4px 12px var(--liq-shadow);
        transform: translateY(-2px);
    }

.contest-card-header {
    padding: 0.875rem 1rem;
    background: var(--liq-bg-tertiary);
    border-bottom: 1px solid var(--liq-border-color);
}

.contest-name-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.contest-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--liq-text-primary);
    line-height: 1.3;
}

.contest-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.contest-badge {
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    white-space: nowrap;
}

    .contest-badge.guaranteed {
        background: rgba(16, 185, 129, 0.15);
        color: var(--liq-accent-green);
    }

    .contest-badge.single-entry {
        background: rgba(59, 130, 246, 0.15);
        color: var(--liq-accent-blue);
    }

    .contest-badge.multi-entry {
        background: rgba(255, 193, 7, 0.15);
        color: #d69e00;
    }

    .contest-badge.game-type {
        background: var(--liq-bg-primary);
        color: var(--liq-text-secondary);
    }

.contest-card-body {
    padding: 1rem;
}

.contest-stats {
    display: flex;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.contest-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

    .contest-stat.primary .stat-value {
        color: var(--liq-accent-green);
        font-size: 1.1rem;
    }

.stat-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--liq-text-primary);
    line-height: 1.2;
}

.stat-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--liq-text-secondary);
    margin-top: 0.125rem;
}

.contest-fill-bar {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.fill-bar-track {
    height: 6px;
    background: var(--liq-bg-tertiary);
    border-radius: 3px;
    overflow: hidden;
}

.fill-bar-progress {
    height: 100%;
    background: var(--liq-accent-green);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.fill-bar-label {
    font-size: 0.7rem;
    color: var(--liq-text-secondary);
    text-align: right;
}

.contest-card-footer {
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--liq-border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

    .contest-card-footer .btn {
        transition: all 0.15s ease;
    }

    .contest-card-footer .btn-outline-success {
        border-color: var(--liq-accent-blue);
        color: var(--liq-accent-blue);
        background: transparent;
    }

        .contest-card-footer .btn-outline-success:hover {
            background: var(--liq-accent-blue);
            border-color: var(--liq-accent-blue);
            color: #fff;
        }

.contest-card:hover .contest-card-footer .btn-outline-success {
    background: var(--liq-accent-blue);
    border-color: var(--liq-accent-blue);
    color: #fff;
}

.contest-footer-left {
    display: flex;
    align-items: center;
}

.contest-footer-right {
    display: flex;
    align-items: center;
}

/* Contest State Badges */
.contest-state-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.contest-state-live {
    background-color: rgba(16, 185, 129, 0.15);
    color: var(--liq-accent-green);
    animation: pulse-live 2s infinite;
}

.contest-state-upcoming {
    background-color: rgba(255, 193, 7, 0.15);
    color: #d69e00;
}

.contest-state-completed {
    background-color: rgba(107, 114, 128, 0.15);
    color: var(--liq-text-secondary);
}

.contest-state-postponed {
    background-color: rgba(249, 115, 22, 0.15);
    color: #f97316;
}

.contest-state-cancelled {
    background-color: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.contest-state-unknown {
    background-color: rgba(107, 114, 128, 0.15);
    color: var(--liq-text-secondary);
}

@keyframes pulse-live {
    0%, 100% {
        opacity: 1;
    }

    50% {
        opacity: 0.6;
    }
}

/* Contest Card States */
.contest-card.upcoming {
    opacity: 0.7;
}

    .contest-card.upcoming:hover {
        transform: none;
        box-shadow: none;
        border-color: var(--liq-border-color);
        cursor: default;
    }

    .contest-card.upcoming .contest-card-footer .btn {
        cursor: not-allowed;
    }

.contest-badge.upcoming {
    background: rgba(255, 193, 7, 0.15);
    color: #d69e00;
}

.contest-card.no-entries {
    opacity: 0.6;
}

    .contest-card.no-entries:hover {
        transform: none;
        box-shadow: none;
        border-color: var(--liq-border-color);
        cursor: default;
    }

    .contest-card.no-entries .contest-card-footer .btn {
        cursor: not-allowed;
    }

.contest-badge.no-data {
    background: rgba(108, 117, 125, 0.15);
    color: var(--liq-text-secondary);
}

/* Contest Build Header */
.player-grid-header.contest-build-header {
    background: linear-gradient(135deg, rgba(32, 201, 151, 0.05) 0%, transparent 100%);
    border-bottom: 1px solid rgba(32, 201, 151, 0.2);
}

.contest-research-label {
    color: var(--liq-text-secondary);
    font-size: 0.9rem;
}

    .contest-research-label i {
        color: #20c997;
    }

.contest-header-stats {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.contest-header-stat {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
}

    .contest-header-stat .stat-label {
        color: var(--liq-text-secondary);
        font-weight: 400;
        font-size: inherit;
        text-transform: none;
        letter-spacing: normal;
        margin-top: 0;
    }

    .contest-header-stat .stat-value {
        color: var(--liq-text-primary);
        font-weight: 600;
        font-size: inherit;
        line-height: inherit;
    }

        .contest-header-stat .stat-value.text-success {
            color: #20c997 !important;
        }

/* Contest Entry Stats */
#contestEntryStats {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

    #contestEntryStats span {
        padding: 0.25rem 0.6rem;
        background: var(--liq-bg-secondary);
        border: 1px solid var(--liq-border-color);
        border-radius: 4px;
        font-size: 0.75rem;
    }

    #contestEntryStats strong {
        color: var(--liq-accent-green);
    }

/* Entry Name Cells */
.entry-name-cell {
    display: flex;
    align-items: center;
    gap: 6px;
    height: 100%;
}

.entry-name-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Favorites Empty State */
.favorites-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 300px;
}

    .favorites-empty-state .empty-state-content {
        text-align: center;
        padding: 2rem;
    }

    .favorites-empty-state h5 {
        color: var(--liq-text-primary);
        font-weight: 600;
    }

    .favorites-empty-state p {
        font-size: 0.9rem;
        line-height: 1.6;
        color: var(--liq-text-secondary);
    }

/* Empty States */
.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 4rem 2rem;
    color: var(--liq-text-secondary);
    min-height: calc(100vh - 180px);
}

.empty-state-icon {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--liq-bg-tertiary);
    border-radius: 50%;
    margin-bottom: 1.5rem;
}

    .empty-state-icon i {
        font-size: 2.25rem;
        color: var(--liq-accent-green);
        opacity: 0.8;
    }

.empty-state h3 {
    color: var(--liq-text-primary);
    font-size: 1.35rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.empty-state p {
    color: var(--liq-text-secondary);
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
    max-width: 300px;
}

.empty-state-btn {
    border-color: var(--liq-accent-green);
    color: var(--liq-accent-green);
    padding: 0.625rem 1.5rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

    .empty-state-btn:hover {
        background: var(--liq-accent-green);
        border-color: var(--liq-accent-green);
        color: #fff;
    }

.lineup-pool-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--liq-text-secondary);
    text-align: center;
    padding: 2rem;
}

    .lineup-pool-empty i {
        font-size: 3rem;
        margin-bottom: 1rem;
        opacity: 0.5;
    }

    .lineup-pool-empty h4 {
        color: var(--liq-text-primary);
        margin-bottom: 0.5rem;
    }

    .lineup-pool-empty p {
        font-size: 0.9rem;
    }

/* Generation Progress */
.generation-progress {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 300px;
    padding: 2rem;
    text-align: center;
    color: var(--liq-text-secondary);
}

.generation-progress h4 {
    color: var(--liq-text-primary);
    margin-bottom: 1rem;
}

.generation-progress .progress-container {
    width: 100%;
    max-width: 400px;
    margin-bottom: 1rem;
}

.generation-progress .progress {
    background-color: var(--liq-bg-tertiary);
    border-radius: 12px;
    overflow: hidden;
}

.generation-progress .progress-bar {
    font-weight: 600;
    font-size: 0.85rem;
    transition: width 0.2s ease;
}

.generation-progress .progress-status {
    font-size: 0.9rem;
    margin-bottom: 0;
}

/* Lineup Builder Preview */
.lineup-builder-preview {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1rem 1.25rem;
    background: var(--liq-bg-primary);
    overflow-y: auto;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.lineup-card {
    position: relative;
    border: 1px solid var(--liq-accent-green);
    border-radius: 10px;
    overflow: hidden;
    background: var(--liq-bg-secondary);
    flex-shrink: 0;
    box-shadow: 0 2px 12px rgba(16, 185, 129, 0.08);
}

.lineup-card-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    background: var(--liq-bg-secondary);
    border: 1px solid var(--liq-border-color);
    border-radius: 6px;
    padding: 1rem 1.5rem;
    z-index: 10;
    box-shadow: 0 2px 8px var(--liq-shadow);
}

.lineup-card-overlay-text {
    font-size: 0.85rem;
    color: var(--liq-text-secondary);
    text-align: center;
    line-height: 1.5;
    margin: 0;
}

.lineup-card-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.625rem 1rem;
    background: rgba(16, 185, 129, 0.06);
    border-bottom: 1px solid rgba(16, 185, 129, 0.12);
    font-size: 0.85rem;
}

.lineup-card-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
    border: none;
}

    .lineup-card-table thead th {
        padding: 0.5rem 0.5rem;
        text-align: left;
        font-weight: 600;
        font-size: 0.7rem;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        color: var(--liq-text-secondary);
        background: transparent;
        border: none;
        border-bottom: 1px solid var(--liq-border-color);
    }

    .lineup-card-table tbody tr {
        transition: background-color 0.15s ease;
        border: none;
    }

        .lineup-card-table tbody tr.filled {
            background: transparent;
        }

        .lineup-card-table tbody tr.empty {
            background: transparent;
        }

            .lineup-card-table tbody tr.empty td {
                opacity: 0.35;
            }

        .lineup-card-table tbody tr:hover {
            background: var(--liq-bg-hover);
        }

    .lineup-card-table td {
        padding: 0.6rem 0.5rem;
        vertical-align: middle;
        border: none;
    }

    .lineup-card-table .col-pos {
        width: 45px;
        white-space: nowrap;
        color: var(--liq-text-secondary);
        font-weight: 500;
    }

    .lineup-card-table .col-name {
        text-align: left;
    }

    .lineup-card-table .col-action {
        width: 32px;
        text-align: center;
    }

    .lineup-card-table .col-salary {
        width: 70px;
        text-align: right;
    }

    .lineup-card-table .col-fpts {
        width: 60px;
        text-align: right;
        padding-right: 0.75rem;
    }

    .lineup-card-table thead .col-salary,
    .lineup-card-table thead .col-fpts {
        text-align: right;
    }

    .lineup-card-table thead .col-fpts {
        padding-right: 0.75rem;
    }

    .lineup-card-table tfoot {
        background: var(--liq-bg-tertiary);
    }

        .lineup-card-table tfoot td {
            padding: 0.6rem 0.5rem;
            border: none;
            border-top: 1px solid var(--liq-border-color);
            font-weight: 600;
        }

.totals-row td {
    color: var(--liq-accent-green);
}

.lineup-builder-footer {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 0.5rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
    gap: 0.5rem;
    flex-shrink: 0;
}

    .lineup-builder-footer .btn-save-favorites {
        background: var(--liq-accent-yellow);
        border-color: var(--liq-accent-yellow);
        color: #000;
        font-weight: 500;
        transition: all 0.15s ease;
    }

        .lineup-builder-footer .btn-save-favorites:hover:not(:disabled) {
            background: #e6ac00;
            border-color: #e6ac00;
            color: #000;
        }

        .lineup-builder-footer .btn-save-favorites:disabled {
            background: transparent;
            border: 1px solid rgba(255, 193, 7, 0.35);
            color: rgba(255, 193, 7, 0.5);
            opacity: 1;
        }

[data-bs-theme="dark"] .lineup-builder-footer .btn-save-favorites:disabled {
    border-color: rgba(255, 193, 7, 0.3);
    color: rgba(255, 193, 7, 0.45);
}

.lineup-builder-footer .btn-clear-locks {
    background: transparent;
    border: 1px solid var(--liq-accent-green);
    color: var(--liq-accent-green);
    font-weight: 500;
    transition: all 0.15s ease;
}

    .lineup-builder-footer .btn-clear-locks:hover:not(:disabled) {
        background: rgba(16, 185, 129, 0.1);
        border-color: var(--liq-accent-green);
        color: var(--liq-accent-green);
    }

    .lineup-builder-footer .btn-clear-locks:disabled {
        background: transparent;
        border: 1px solid var(--liq-border-color);
        color: var(--liq-text-secondary);
        opacity: 0.5;
    }

.lineup-builder-footer .btn-optimize {
    background: var(--liq-accent-green);
    border-color: var(--liq-accent-green);
    color: #fff;
    font-weight: 500;
    transition: all 0.15s ease;
}

    .lineup-builder-footer .btn-optimize:hover:not(:disabled) {
        background: #0ea472;
        border-color: #0ea472;
        color: #fff;
    }

    .lineup-builder-footer .btn-optimize:disabled {
        background: transparent;
        border: 1px solid rgba(16, 185, 129, 0.35);
        color: rgba(16, 185, 129, 0.5);
        opacity: 1;
    }

[data-bs-theme="dark"] .lineup-builder-footer .btn-optimize:disabled {
    border-color: rgba(16, 185, 129, 0.3);
    color: rgba(16, 185, 129, 0.45);
}

.builder-status-text {
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* Enhanced Contests View Styles */
.contests-header .btn-group .btn.active {
    background-color: #212529;
    border-color: #212529;
    color: white;
}

.contests-filters {
    background: var(--liq-background-secondary);
    border: 1px solid var(--liq-border-color);
    border-radius: 8px;
    margin-bottom: 20px;
    overflow: hidden;
}

.filters-container {
    padding: 20px;
}

.contests-list {
    background: var(--liq-background-primary);
    border: 1px solid var(--liq-border-color);
    border-radius: 8px;
    overflow: hidden;
}

.contest-list-header {
    display: grid;
    grid-template-columns: 2fr 1fr 1.2fr 1.2fr 1fr 1fr 1.2fr;
    gap: 12px;
    padding: 16px 20px;
    background: var(--liq-background-secondary);
    border-bottom: 1px solid var(--liq-border-color);
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--liq-text-secondary);
}

.contest-list-row {
    display: grid;
    grid-template-columns: 2fr 1fr 1.2fr 1.2fr 1fr 1fr 1.2fr;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--liq-border-color);
    cursor: pointer;
    transition: background-color 0.2s ease;
    align-items: center;
}

    .contest-list-row:hover {
        background: var(--liq-background-hover);
    }

.contest-list-col {
    display: flex;
    align-items: center;
    min-height: 40px;
}

.contest-name-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.progress-bar-mini {
    width: 100%;
    height: 4px;
    background: var(--liq-border-color);
    border-radius: 2px;
    margin: 4px 0 2px 0;
}

.progress-fill {
    height: 100%;
    background: var(--liq-success-color);
    border-radius: 2px;
}

.contest-actions {
    display: flex;
    gap: 4px;
    justify-content: flex-end;
}

/* Add this to views.css */

/* ============================================
   Contest List Cards (Horizontal Card Style)
   ============================================ */

.contests-list-cards {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.contest-list-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--liq-bg-secondary);
    border: 1px solid var(--liq-border-color);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .contest-list-card:hover {
        border-color: var(--liq-accent-blue);
        box-shadow: 0 2px 8px var(--liq-shadow);
    }

    .contest-list-card.upcoming,
    .contest-list-card.cancelled,
    .contest-list-card.no-entries {
        opacity: 0.6;
        cursor: default;
    }

        .contest-list-card.upcoming:hover,
        .contest-list-card.cancelled:hover,
        .contest-list-card.no-entries:hover {
            border-color: var(--liq-border-color);
            box-shadow: none;
        }

.contest-list-card-main {
    display: flex;
    align-items: center;
    gap: 2rem;
    flex: 1;
    min-width: 0;
}

.contest-list-card-info {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 200px;
    max-width: 350px;
}

.contest-list-card-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--liq-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.contest-list-card-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.contest-list-badge {
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.15rem 0.4rem;
    border-radius: 3px;
    white-space: nowrap;
}

    .contest-list-badge.game-type {
        background: var(--liq-bg-tertiary);
        color: var(--liq-text-secondary);
    }

    .contest-list-badge.entry-type {
        background: rgba(59, 130, 246, 0.12);
        color: var(--liq-accent-blue);
    }

    .contest-list-badge.guaranteed {
        background: rgba(16, 185, 129, 0.12);
        color: var(--liq-accent-green);
    }

.contest-list-card-stats {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.contest-list-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-width: 70px;
}

    .contest-list-stat .stat-value {
        font-size: 0.9rem;
        font-weight: 700;
        color: var(--liq-text-primary);
        line-height: 1.2;
    }

    .contest-list-stat.primary .stat-value {
        color: var(--liq-accent-green);
    }

    .contest-list-stat .stat-label {
        font-size: 0.6rem;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        color: var(--liq-text-secondary);
        margin-top: 0.1rem;
    }

.contest-list-card-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

    .contest-list-card-actions .btn {
        white-space: nowrap;
    }

    .contest-list-card-actions .contest-state-badge {
        margin-right: 0.25rem;
    }

/* Hover effect for view button */
.contest-list-card:hover .btn-outline-success:not(:disabled) {
    background: var(--liq-accent-blue);
    border-color: var(--liq-accent-blue);
    color: #fff;
}

/* ============================================
   Persistent Filters Panel
   ============================================ */

.contests-filters {
    background: var(--liq-bg-secondary);
    border: 1px solid var(--liq-border-color);
    border-radius: 8px;
    margin-bottom: 1rem;
    overflow: hidden;
}

.contests-filters-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    background: var(--liq-bg-tertiary);
    border-bottom: 1px solid var(--liq-border-color);
}

    .contests-filters-header h6 {
        margin: 0;
        font-size: 0.8rem;
        font-weight: 600;
        color: var(--liq-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.03em;
    }

.contests-filters-close {
    background: transparent;
    border: none;
    color: var(--liq-text-secondary);
    padding: 0.25rem;
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
}

    .contests-filters-close:hover {
        color: var(--liq-text-primary);
        background: var(--liq-bg-hover);
    }

.filters-container {
    padding: 1rem;
}

.filters-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem;
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

    .filter-group label {
        font-size: 0.7rem;
        font-weight: 600;
        color: var(--liq-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.03em;
    }

    .filter-group .filter-inputs {
        display: flex;
        gap: 0.35rem;
    }

    .filter-group input,
    .filter-group select {
        font-size: 0.8rem;
        padding: 0.35rem 0.5rem;
        width: 80px;
    }

    .filter-group select {
        width: auto;
        min-width: 120px;
    }

.filter-actions {
    display: flex;
    gap: 0.5rem;
    margin-left: auto;
}

    .filter-actions .btn {
        font-size: 0.8rem;
        padding: 0.35rem 0.75rem;
    }

/* Active filter indicator */
#contestFiltersBtn.has-filters {
    background: rgba(16, 185, 129, 0.1);
    border-color: var(--liq-accent-blue);
    color: var(--liq-accent-blue);
}

/* ============================================
   Mobile Adjustments for List Cards
   ============================================ */

@media (max-width: 992px) {
    .contest-list-card-info {
        min-width: 150px;
        max-width: 250px;
    }

    .contest-list-card-stats {
        gap: 1rem;
    }

    .contest-list-stat {
        min-width: 60px;
    }
}

@media (max-width: 768px) {
    .contest-list-card {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        padding: 0.75rem;
    }

    .contest-list-card-main {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
    }

    .contest-list-card-info {
        min-width: 0;
        max-width: none;
    }

    .contest-list-card-stats {
        justify-content: space-around;
    }

    .contest-list-card-actions {
        justify-content: space-between;
        padding-top: 0.5rem;
        border-top: 1px solid var(--liq-border-color);
    }

    /* Filters mobile */
    .filters-row {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-group {
        width: 100%;
    }

        .filter-group .filter-inputs {
            flex: 1;
        }

        .filter-group input {
            flex: 1;
            width: auto;
        }

        .filter-group select {
            width: 100%;
        }

    .filter-actions {
        margin-left: 0;
        margin-top: 0.5rem;
    }
}

/* Contest view toggle buttons */
.contests-header .btn-group .btn-outline-secondary {
    border-color: var(--liq-accent-blue);
    color: var(--liq-accent-blue);
}

    .contests-header .btn-group .btn-outline-secondary:hover {
        background: var(--liq-accent-blue-hover);
        border-color: var(--liq-accent-blue);
        color: var(--liq-accent-blue);
    }

    .contests-header .btn-group .btn-outline-secondary.active {
        background: var(--liq-accent-blue);
        border-color: var(--liq-accent-blue);
        color: #fff;
    }

/* Apply button filled style */
.contests-workspace .btn-contest-primary-filled {
    background: var(--liq-accent-blue);
    border: 1px solid var(--liq-accent-blue);
    color: #fff;
    transition: all 0.15s ease;
}

    .contests-workspace .btn-contest-primary-filled:hover:not(:disabled) {
        background: #2563eb;
        border-color: #2563eb;
    }