/* Fichier : assets/css/public.css */

.ose-similar-projects-container {
    margin: 2em 0;
    font-family: inherit;
    position: relative; /* Pour positionner les flèches */
    padding: 0 60px; /* Espace pour les flèches sur les côtés */
    --swiper-navigation-color: #ffffff;
    --swiper-pagination-color: #ffffff;
}

@media (max-width: 767px) {
    .ose-similar-projects-container {
        padding: 0 40px; /* Moins d'espace perdu sur mobile */
    }
}

/* =========================================
   Mode Grille
========================================= */
.ose-sp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

@media (max-width: 980px) {
    .ose-sp-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 767px) {
    .ose-sp-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================
   Mode Slider (Swiper)
========================================= */
.ose-sp-swiper {
    width: 100%;
    padding-bottom: 40px !important; /* Espace pour la pagination */
}

/* Pagination en blanc */
.ose-similar-projects-container .swiper-pagination {
    display: block !important;
    bottom: 0 !important;
    z-index: 20 !important;
}
.ose-similar-projects-container .swiper-pagination-bullet {
    background: #fff !important;
    opacity: 0.5;
}
.ose-similar-projects-container .swiper-pagination-bullet-active {
    opacity: 1;
}

/* Flèches à l'extérieur */
.ose-similar-projects-container .swiper-button-next,
.ose-similar-projects-container .swiper-button-prev {
    position: absolute !important; /* Important si Swiper scope son CSS */
    top: 50%;
    transform: translateY(-50%);
    margin-top: -20px; /* Compense la pagination en bas */
    z-index: 10;
    font-size: 24px; /* Taille de la flèche unicode */
    font-weight: bold;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    color: #fff !important; /* Force la couleur blanche pour le texte unicode */
    cursor: pointer;
}

/* Cache les icônes de la police CDN par défaut de Swiper au cas où elles chargeraient quand même */
.ose-similar-projects-container .swiper-button-next::after,
.ose-similar-projects-container .swiper-button-prev::after {
    display: none !important;
}

.ose-similar-projects-container .swiper-button-prev {
    left: 0;
}

.ose-similar-projects-container .swiper-button-next {
    right: 0;
}

/* Important: Permet aux slides d'avoir la même hauteur et de s'étirer */
.ose-sp-swiper .swiper-slide {
    height: auto;
}

/* =========================================
   Carte Individuelle
========================================= */
.ose-sp-item {
    display: flex;
    height: auto;
}

.ose-similar-projects-card {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%; /* Important pour que toutes les cartes fassent la même hauteur */
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    border: 1px solid #f0f0f0;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ose-similar-projects-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.ose-sp-image-wrapper {
    position: relative;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9; /* Proportions plus adaptées pour un portfolio */
    overflow: hidden;
    border-radius: 8px;
}

.ose-sp-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.ose-similar-projects-card:hover .ose-sp-img {
    transform: scale(1.05);
}

.ose-sp-no-img {
    width: 100%;
    height: 100%;
    background: #eee;
}

.ose-sp-content {
    padding: 30px;
    display: flex;
    flex-direction: column;
    align-items: center; /* Centre les éléments horizontalement */
    text-align: center; /* Centre le texte */
    flex-grow: 1;
}

.ose-sp-title {
    margin: 0 0 10px 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: #333;
    line-height: 1.4;
}

.ose-sp-excerpt {
    margin: 0 0 20px 0;
    font-size: 0.95rem;
    line-height: 1.6;
    flex-grow: 1;
    /* Couleur gérée dynamiquement en PHP */
}

.ose-sp-btn-wrapper {
    margin-top: auto;
}

.ose-sp-btn {
    display: inline-block;
    padding: 12px 28px;
    border-radius: 50px; /* Bouton arrondi style pill */
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-align: center;
    transition: background-color 0.3s ease, transform 0.3s ease;
    /* Couleurs gérées dynamiquement en PHP */
}

.ose-sp-btn:hover {
    transform: scale(1.05);
}
