.pagination {
    gap: 5px;
    margin-top: 2rem;
}

.pagination > * {
    margin: 0 3px;
}

.pagination .page-link {
    width: 35px;
    height: 35px;
    padding: 0;
    border-radius: 50% !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    border: none;
    background-color: #f8f9fa;
    color: #6c757d;
    transition: all 0.3s ease;
}

.pagination .page-link:hover {
    background-color: #e9ecef;
    color: var(--bs-primary);
    transform: translateY(-2px);
}

.pagination .active > .page-link {
    background-color: var(--bs-primary);
    color: white;
}

.pagination .active > .page-link:hover {
    background-color: var(--bs-primary);
}

.pagination .disabled > .page-link {
    background-color: #e9ecef;
    color: #adb5bd;
    cursor: not-allowed;
}

/* Add icons */
.pagination .first::before {
    content: "\F12F";
    font-family: "bootstrap-icons";
}

.pagination .prev::before {
    content: "\F284";
    font-family: "bootstrap-icons";
}

.pagination .next::before {
    content: "\F285";
    font-family: "bootstrap-icons";
}

.pagination .last::before {
    content: "\F133";
    font-family: "bootstrap-icons";
}
