/* =========================================
   Avis Carrousel — Frontend Styles
   Typographie : Inter
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600&display=swap');

:root {
    --avis-bg:          #f0ebe2;
    --avis-card-bg:     #ffffff;
    --avis-text:        #2B5A55;
    --avis-text-light:  #666666;
    --avis-star:        #5b8c75;
    --avis-star-empty:  #d9cfc4;
    --avis-border:      #e8e0d6;
    --avis-accent:      #5b8c75;
    --avis-radius:      16px;
    --avis-shadow:      0 4px 24px rgba(58,51,40,.08);
    --avis-gap:         28px;
}

/* Wrapper */
.avis-carrousel-wrapper {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 0 20px;
    font-family: "Inter", Sans-serif;
}

/* Track */
.avis-track-outer {
    overflow: hidden;
    width: 100%;
}

.avis-track {
    display: flex;
    gap: var(--avis-gap);
    transition: transform .45s cubic-bezier(.4, 0, .2, 1);
    will-change: transform;
    align-items: stretch;
}

/* Card */
.avis-card {
    background: var(--avis-card-bg);
    border-radius: var(--avis-radius);
    box-shadow: var(--avis-shadow);
    padding: 32px 28px;
    box-sizing: border-box;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
    border: 1px solid var(--avis-border);
    transition: box-shadow .2s, transform .2s;
}

.avis-card:hover {
    box-shadow: 0 8px 36px rgba(58,51,40,.13);
    transform: translateY(-2px);
}

/* Header */
.avis-card__header {
    display: flex;
    align-items: center;
    gap: 14px;
}

.avis-card__avatar {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    border: 2px solid var(--avis-border);
}

.avis-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.avis-card__avatar-initials {
    width: 100%;
    height: 100%;
    background: var(--avis-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Inter", Sans-serif;
    font-size: 1.3rem;
    font-weight: 600;
    color: #666666;
    text-transform: uppercase;
}

.avis-card__identity {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.avis-card__name {
    font-family: "Inter", Sans-serif;
    font-size: 20px;
    font-weight: 600;
    color: #2B5A55;
    line-height: 1.4em;
    letter-spacing: 0px;
    text-transform: none;
    font-style: normal;
    text-decoration: none;
}

.avis-card__job {
    font-family: "Inter", Sans-serif;
    font-size: 17px;
    font-weight: 400;
    color: #666666;
    line-height: 1.7em;
    letter-spacing: 0px;
    text-transform: none;
    font-style: normal;
    text-decoration: none;
}

/* Stars */
.avis-card__stars {
    display: flex;
    gap: 3px;
    line-height: 1;
}

.avis-star {
    font-size: 1.25rem;
    color: var(--avis-star-empty);
    transition: color .1s;
}

.avis-star--filled { color: var(--avis-star); }

/* Quote */
.avis-card__text {
    text-align: start;
    font-family: "Inter", Sans-serif;
    font-size: 17px;
    font-weight: 400;
    color: #666666;
    line-height: 1.7em;
    letter-spacing: 0px;
    text-transform: none;
    font-style: italic;
    text-decoration: none;
    margin: 0;
    flex: 1;
    border: none;
    padding: 0;
}

/* Controls */
.avis-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 28px;
}

.avis-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1.5px solid var(--avis-border);
    background: var(--avis-card-bg);
    color: var(--avis-text-light);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    padding: 0;
    box-shadow: 0 2px 8px rgba(58,51,40,.06);
}

.avis-btn:hover {
    background: var(--avis-accent);
    border-color: var(--avis-accent);
    color: #fff;
    box-shadow: 0 4px 16px rgba(91,140,117,.25);
}

.avis-btn:disabled {
    opacity: .35;
    cursor: default;
    pointer-events: none;
}

/* Dots */
.avis-dots {
    display: flex;
    gap: 8px;
    align-items: center;
}

.avis-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--avis-border);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: all .25s;
}

.avis-dot--active {
    background: var(--avis-accent);
    width: 22px;
    border-radius: 4px;
}

/* ===== RESPONSIVE ===== */

/* Desktop: 3 cards */
@media (min-width: 1024px) {
    .avis-card {
        width: calc((100% - var(--avis-gap) * 2) / 3);
    }
}

/* Tablet: 2 cards */
@media (min-width: 640px) and (max-width: 1023px) {
    .avis-card {
        width: calc((100% - var(--avis-gap)) / 2);
    }
}

/* Mobile: 1 card */
@media (max-width: 639px) {
    .avis-card {
        width: 100%;
        padding: 24px 20px;
    }

    .avis-carrousel-wrapper {
        padding: 10px 0 16px;
    }
}

/* Voir plus / Voir moins */
.avis-voir-plus {
    display: inline-block;
    margin-top: 8px;
    background: none;
    border: none;
    padding: 0;
    font-family: "Inter", Sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #2B5A55;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: opacity .15s;
}

.avis-voir-plus:hover { opacity: .7; }

.avis-text-full {
    font-family: "Inter", Sans-serif;
    font-size: 17px;
    font-weight: 400;
    font-style: italic;
    color: #666666;
    line-height: 1.7em;
}
