/* =============================================================================
   11. AVIS CLIENTS & TEMOIGNAGES
   ============================================================================= */

/* 11.1 - Avis Card (Composant de base) */
.avis-card {
    display: flex;
    flex-direction: column;
    position: relative;
    box-sizing: border-box;
    background: var(--fond-page);
    border: var(--border-card);
    border-radius: var(--radius-default);
    transition: all 0.3s ease;
}
.avis-card:hover {
    border-color: var(--border-card-hover);
    box-shadow: var(--shadow-card-hover);
}
.avis-card-link {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 1em;
    padding: 2em 1.5em;
    text-align: left;
    text-decoration: none;
}
.avis-card-link:is(:hover, :active) {
    text-decoration: none;
}
.avis-card-title {
    font-family: var(--family-corps);
    font-size: var(--taille-font-xl);
    font-weight: 600;
    color: var(--typo-titre);
    transition: color 0.3s ease;
}
.avis-card-meta {
    margin: 0;
    font-family: var(--family-titre);
    font-size: var(--taille-font-sm);
    color: rgb(from var(--typo-titre) r g b / 0.7);
}
.avis-card-meta i {
    color: var(--typo-titre);
}
.avis-card-rating {
    display: flex;
    gap: 0.3em;
    margin: 0.1em 0;
}
.avis-card-rating .fa {
    font-size: var(--font-base);
    color: var(--couleur-puces);
    transition: all 0.3s ease;
}
.avis-card:hover .avis-card-rating .fa {
    color: var(--fond-bouton-hover);
    transform: scale(1.1);
}
.avis-card-body {
    position: relative;
    font-family: var(--family-titre);
    font-size: var(--font-base);
    line-height: 1.8;
    text-align: left;
    color: var(--typo-titre);
}
.avis-card-body p {
    margin-bottom: 0;
}
.avis-card-body p::before {
    content: '\00AB';
    display: inline-block;
    margin-right: 0.25rem;
}
.avis-card-body p::after {
    content: '\00BB';
    display: inline-block;
    margin-left: 0.25rem;
}

/* 11.2 - Grilles & Layouts spécifiques */
.avis-clients {
    text-align: center;
}
.avis-swiper.frame {
    padding-bottom: 2rem;
}
.avis-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2em;
    padding: 2em 0 0;
}
.avis-grid .avis-card {
    gap: 0.8em;
    padding: 2em;
    opacity: 0;
    animation: fadeInUp 0.6s ease forwards;
}
.avis-grid .avis-card:target {
    opacity: 1;
    scroll-margin-top: 6em;
    animation: none;
}
.avis-grid .avis-card-body::after {
    content: '\f10d';
    position: absolute;
    top: -2em;
    right: 1em;
    z-index: -1;
    font-family: 'Font Awesome 6 Free';
    font-size: var(--taille-font-4xl);
    font-weight: 900;
    color: rgb(from var(--typo-titre) r g b / 0.08);
    pointer-events: none;
    transition: all 0.3s ease;
}

/* 11.3 - Modales & Formulaires (Spécificité contrôlée) */
.modal {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: auto;
    overflow-y: scroll;
    padding: 1rem;
    font-size: var(--font-base);
    color: var(--typo-sur-fond-sombre);
    outline: 0;
    z-index: 9999;
}
.modal-open .modal {
    font-family: Arial, Helvetica, sans-serif;
    color: var(--typo-titre);
    background: var(--overlay-lt);
    text-shadow: none;
    z-index: 9997;
}
.modal-content .btn-close {
    position: absolute;
    top: 1rem;
    right: 2rem;
    font-size: var(--taille-font-lg);
    color: var(--typo-titre);
    opacity: 0.2;
    background: transparent;
    border: none;
}
.modal-content .btn-close:is(:hover, :focus) {
    opacity: 0.5;
}
.add-review-container {
    text-align: center;
}
.add-review-container .conditions {
    display: block;
    clear: both;
    font-size: var(--font-base);
    font-weight: 400;
    font-style: italic;
    text-align: justify;
    color: var(--typo-titre);
    opacity: 0.6;
}

/* 11.4 - Media Queries & Animations */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 991px) {
    .avis-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5em;
    }
    .avis-swiper.frame {
        padding: 2rem 1rem 2.5rem;
    }
}
@media (max-width: 767px) {
    .avis-grid {
        grid-template-columns: 1fr;
    }
    .avis-grid .avis-card {
        padding: 1.2em;
    }
    .avis-grid .avis-card-body::after {
        right: 0;
    }
}