/* Model Catalog List/Filtering Styles */

.model-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--spacing-md);
}

.selected-models-container {
    background-color: rgba(var(--primary-color-rgb), 0.05);
    border-radius: var(--border-radius);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    border: 1px solid rgba(var(--primary-color-rgb), 0.1);
}

.selected-model-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-xs);
    background-color: var(--card-bg);
    border-radius: var(--border-radius-sm);
    border: 1px solid var(--border-color);
    color: var(--dark-color);
}

.model-card {
    transition: transform 0.3s ease;
    height: 100%;
}

.model-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.filter-sidebar {
    background-color: var(--light-color);
    padding: 20px;
    border-radius: 10px;
}

.context-length {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.model-description {
    height: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
}

.filter-group {
    margin-bottom: 1.5rem;
}

.filter-group h4 {
    margin-bottom: 0.75rem;
}

.range-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 0.25rem;
    font-size: 0.8rem;
    color: var(--text-muted);
}

.filter-badge {
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
    display: inline-block;
}

.active-filters {
    margin-bottom: 1rem;
}

/* Responsive adjustments */
@media (max-width: 767.98px) {
    .model-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    }
}

.filter-section.card { 
   overflow: visible; /* Allow dropdowns to overflow */
   position: relative; /* Establish stacking context */
   z-index: 2; /* Lift card above subsequent static content */
} 
.filter-bar > form > * { margin-right: 0.5rem; margin-bottom: 0.5rem; }
.dropdown-menu { max-height: 300px; overflow-y: auto; z-index: 1030; /* Ensure dropdown is above pager */ }
.dropdown-item.active, .dropdown-item:active {
    background-color: var(--primary-color);
    color: var(--text-on-primary) !important;
}
.dropdown-item label { cursor: pointer; width: 100%; }
.dropdown-toggle::after { margin-left: 0.5em; }
.dropdown-header { font-size: 0.8em; font-weight: bold; text-transform: uppercase; color: var(--text-muted); padding: 0.5rem 1rem; }
.filter-actions { padding-top: 0.5rem; }
.form-check-label.small { font-size: 0.875em; }
.dropdown-item.ps-3 { padding-left: 1rem !important; } /* Align checkbox text */ 

/* Dark Theme Specific Overrides */
.dark-theme .selected-models-container,
:root.auto-dark-theme .selected-models-container {
    background-color: rgba(var(--primary-color-rgb), 0.1);
    border-color: rgba(var(--primary-color-rgb), 0.2);
}

.dark-theme .selected-model-item,
:root.auto-dark-theme .selected-model-item {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--light-color);
}

.dark-theme .filter-sidebar,
:root.auto-dark-theme .filter-sidebar {
    background-color: var(--dark-color);
    border: 1px solid var(--border-color);
}

.dark-theme .dropdown-menu,
:root.auto-dark-theme .dropdown-menu {
    background-color: var(--card-bg);
    border-color: var(--border-color);
}

.dark-theme .dropdown-item,
:root.auto-dark-theme .dropdown-item {
    color: var(--light-color);
}

.dark-theme .dropdown-item:hover,
:root.auto-dark-theme .dropdown-item:hover,
.dark-theme .dropdown-item:focus,
:root.auto-dark-theme .dropdown-item:focus {
    background-color: rgba(var(--primary-color-rgb), 0.15);
    color: var(--primary-color);
}

.dark-theme .dropdown-item.active,
:root.auto-dark-theme .dropdown-item.active,
.dark-theme .dropdown-item:active,
:root.auto-dark-theme .dropdown-item:active {
    background-color: var(--primary-color);
    color: var(--text-on-primary) !important;
}

.dark-theme .dropdown-header,
:root.auto-dark-theme .dropdown-header {
    color: var(--text-muted);
} 

/* Limit width of search input in filter bar */
.filter-bar .input-group {
    max-width: 300px;
} 