/* Library custom styles */
.library-recordings-grid .card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    border: 1px solid #e0e0e0;
}

.library-recordings-grid .card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.card-image-container {
    position: relative;
    background: #f8f9fa;
}

.card-image-container img {
    transition: transform 0.3s ease;
}

.card:hover .card-image-container img {
    transform: scale(1.05);
}

/* Badge styles */
.badge-level {
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
}

.badge-a1 { background-color: #28a745; color: white; }
.badge-a2 { background-color: #17a2b8; color: white; }
.badge-b1 { background-color: #ffc107; color: black; }
.badge-b2 { background-color: #fd7e14; color: white; }

/* Card body spacing */
.recording-card .card-body {
    padding: 1rem;
}

.recording-card .card-title {
    min-height: 2.8rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.recording-card .card-text {
    min-height: 2.8rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Button container */
.recording-card .card-footer {
    padding: 0 1rem 1rem 1rem;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .library-recordings-grid .col-md-4 {
        margin-bottom: 1.5rem;
    }
    
    .recording-card .card-title {
        font-size: 1rem;
        min-height: auto;
    }
}

/* Filter styles */
.library-level-filters .btn-group {
    flex-wrap: wrap;
}

.library-level-filters .btn {
    margin-bottom: 0.25rem;
}

.library-search-filters .form-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.library-search-filters .form-group {
    margin-bottom: 0.5rem;
}