/* ═══════════════════════════════════════════
   CWA Testimonials Slider — v2.3.0
   Slider · Grid · Masonry · Zéro dépendance
═══════════════════════════════════════════ */

/* ── Reset : neutralise les styles thème (Divi, etc.) ── */
.cwats-wrap blockquote.cwats-text,
.cwats-wrap .cwats-text {
    border: 0 !important;
    border-left: 0 !important;
    padding-left: 0 !important;
    margin: 0;
    background: transparent;
    font-style: italic;
}

.cwats-wrap {
    --cwats-cols: 3;
    --cwats-cols-tablet: 2;
    --cwats-cols-mobile: 1;
    --cwats-accent: #c9a96e;
    --cwats-bg: #ffffff;
    --cwats-text: #333333;
    --cwats-radius: 12px;
    --cwats-gap: 30px;
    --cwats-border-color: #e5e5e5;
    --cwats-border-width: 1px;
    --cwats-font-title: inherit;
    --cwats-font-text: inherit;
    --cwats-font-name: inherit;
    --cwats-fw-title: 700;
    --cwats-fw-text: 400;
    --cwats-fw-name: 700;
    --cwats-title-size: 18px;
    --cwats-title-color: #333333;
    --cwats-text-size: 15px;
    --cwats-name-size: 15px;
    --cwats-stars-size: 16px;
    /* Alignements : --cwats-align est la valeur globale, les autres font fallback dessus */
    --cwats-align: left;
    /* Avatar */
    --cwats-avatar-size: 46px;
    /* Flèches paramétrables */
    --cwats-arrow-size: 42px;
    --cwats-arrow-icon-size: 18px;
    --cwats-arrow-bg: var(--cwats-accent);
    --cwats-arrow-color: #ffffff;
    --cwats-arrow-offset: -20px;
    --cwats-arrow-radius: 50%;
    position: relative;
    width: 100%;
    user-select: none;
}

/* ═══════════════════════════════════════════
   LAYOUTS
═══════════════════════════════════════════ */

/* ── Slider ── */
.cwats-layout-slider .cwats-track-wrap {
    overflow: hidden;
    width: 100%;
}

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

.cwats-layout-slider .cwats-slide {
    flex: 0 0 calc(
        (100% - var(--cwats-gap) * (var(--cwats-cols) - 1)) / var(--cwats-cols)
    );
    min-width: 0;
    display: flex;
}

/* ── Grid ── */
.cwats-layout-grid .cwats-grid {
    display: grid;
    grid-template-columns: repeat(var(--cwats-cols), 1fr);
    gap: var(--cwats-gap);
}

.cwats-layout-grid .cwats-item {
    display: flex;
}

/* ── Masonry (CSS columns, pas de JS) ── */
.cwats-layout-masonry .cwats-masonry {
    column-count: var(--cwats-cols);
    column-gap: var(--cwats-gap);
}

.cwats-layout-masonry .cwats-item {
    break-inside: avoid;
    page-break-inside: avoid;
    -webkit-column-break-inside: avoid;
    margin-bottom: var(--cwats-gap);
    display: block;
}

.cwats-layout-masonry .cwats-card {
    width: 100%;
}

/* ═══════════════════════════════════════════
   CARTE
═══════════════════════════════════════════ */

.cwats-card {
    background: var(--cwats-bg);
    color: var(--cwats-text);
    border-radius: var(--cwats-radius);
    padding: 36px 32px 28px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
    position: relative;
    transition: box-shadow .25s, transform .25s;
}

/* ── Image de fond (globale) ── */
.cwats-has-bg-image .cwats-card:not(.cwats-card-has-bg) {
    background-image: var(--cwats-card-bg-image);
    background-size: cover;
    background-position: center;
}

/* ── Image de fond (par carte) ── */
.cwats-card-has-bg {
    background-size: cover;
    background-position: center;
}

/* Overlay pour lisibilité quand il y a une image de fond */
.cwats-has-bg-image .cwats-card::before,
.cwats-card-has-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--cwats-bg);
    opacity: .88;
    border-radius: inherit;
    z-index: 0;
    pointer-events: none;
}

.cwats-has-bg-image .cwats-card > *,
.cwats-card-has-bg > * {
    position: relative;
    z-index: 1;
}

/* ═══════════════════════════════════════════
   BORDURES
═══════════════════════════════════════════ */

/* none — pas de bordure ni ombre */
.cwats-border-none .cwats-card {
    border: none;
    box-shadow: none;
}

/* shadow — ombre douce uniquement (défaut) */
.cwats-border-shadow .cwats-card {
    border: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 2px 16px rgba(0,0,0,.07);
}

.cwats-border-shadow .cwats-card:hover {
    box-shadow: 0 6px 28px rgba(0,0,0,.11);
    transform: translateY(-2px);
}

/* solid — bordure pleine */
.cwats-border-solid .cwats-card {
    border: var(--cwats-border-width) solid var(--cwats-border-color);
    box-shadow: none;
}

/* dashed — bordure pointillée */
.cwats-border-dashed .cwats-card {
    border: var(--cwats-border-width) dashed var(--cwats-border-color);
    box-shadow: none;
}

/* double — bordure double */
.cwats-border-double .cwats-card {
    border: var(--cwats-border-width) double var(--cwats-border-color);
    box-shadow: none;
    /* Le style double nécessite minimum 3px pour s'afficher */
    border-width: max(var(--cwats-border-width), 3px);
}

/* ═══════════════════════════════════════════
   CONTENU CARTE
═══════════════════════════════════════════ */

.cwats-quote-icon {
    color: var(--cwats-accent);
    opacity: .25;
    position: absolute;
    top: 20px;
    right: 24px;
    width: 36px;
    height: auto;
    pointer-events: none;
    z-index: 2;
}

.cwats-quote-icon svg { width: 100%; height: auto; }

/* ─── Étoiles ─── */
/* Conversion text-align → justify-content pour les éléments flex */
.cwats-stars {
    display: flex;
    gap: 3px;
    justify-content: var(--cwats-align-stars-flex,
        var(--cwats-align-flex, flex-start));
}

.cwats-star {
    width: var(--cwats-stars-size);
    height: var(--cwats-stars-size);
    fill: none;
    stroke: var(--cwats-accent);
    stroke-width: 1.5;
}

.cwats-star.is-filled {
    fill: var(--cwats-accent);
    stroke: var(--cwats-accent);
}

.cwats-title {
    margin: 0;
    padding: 0;
    font-family: var(--cwats-font-title);
    font-weight: var(--cwats-fw-title);
    font-size: var(--cwats-title-size);
    line-height: 1.3;
    color: var(--cwats-title-color);
    text-align: var(--cwats-align-title, var(--cwats-align));
}

.cwats-text {
    margin: 0;
    padding: 0;
    font-family: var(--cwats-font-text);
    font-weight: var(--cwats-fw-text);
    font-style: italic;
    line-height: 1.7;
    color: var(--cwats-text);
    flex: 1;
    font-size: var(--cwats-text-size);
    text-align: var(--cwats-align-text, var(--cwats-align));
}

/* ─── Auteur (avatar + nom + rôle) ─── */
.cwats-author {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 4px;
    justify-content: var(--cwats-align-author-flex,
        var(--cwats-align-flex, flex-start));
}

/* Avatar — taille commune */
.cwats-avatar {
    width: var(--cwats-avatar-size);
    height: var(--cwats-avatar-size);
    flex-shrink: 0;
    object-fit: cover;
    /* line-height pour que l'initiale soit centrée verticalement */
    line-height: var(--cwats-avatar-size);
    text-align: center;
}

/* Style : circle (défaut) */
.cwats-avatar-style-circle .cwats-avatar {
    border-radius: 50%;
    border: 2px solid var(--cwats-accent);
}
.cwats-avatar-style-circle .cwats-avatar-initials {
    background: var(--cwats-accent);
    color: #fff;
    font-weight: 700;
    font-size: calc(var(--cwats-avatar-size) * .42);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Style : square (carré arrondi) */
.cwats-avatar-style-square .cwats-avatar {
    border-radius: 6px;
    border: 2px solid var(--cwats-accent);
}
.cwats-avatar-style-square .cwats-avatar-initials {
    background: var(--cwats-accent);
    color: #fff;
    font-weight: 700;
    font-size: calc(var(--cwats-avatar-size) * .42);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Style : plain — initiale seule, pas de fond, pas de bordure */
.cwats-avatar-style-plain .cwats-avatar-initials {
    background: transparent;
    color: var(--cwats-accent);
    font-weight: 800;
    font-size: calc(var(--cwats-avatar-size) * .8);
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
}
.cwats-avatar-style-plain .cwats-avatar:not(.cwats-avatar-initials) {
    /* Image avatar : on garde un bord léger pour ne pas avoir l'air "cassé" */
    border-radius: 50%;
    border: 0;
}

.cwats-author-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    /* Alignement à l'intérieur du bloc info (titre/rôle) */
    text-align: var(--cwats-align-author, var(--cwats-align));
    align-items: var(--cwats-align-author-flex,
        var(--cwats-align-flex, flex-start));
}

.cwats-name {
    font-family: var(--cwats-font-name);
    font-weight: var(--cwats-fw-name);
    font-size: var(--cwats-name-size);
    color: var(--cwats-text);
}

.cwats-role {
    font-size: .83rem;
    color: var(--cwats-accent);
    font-weight: 500;
    text-align: var(--cwats-align-role, var(--cwats-align-author, var(--cwats-align)));
}

/* ═══════════════════════════════════════════
   SLIDER : flèches et dots (v2.2.0 — paramétrables)
═══════════════════════════════════════════ */

.cwats-btn {
    z-index: 10;
    background: var(--cwats-arrow-bg);
    border: none;
    border-radius: var(--cwats-arrow-radius);
    width: var(--cwats-arrow-size);
    height: var(--cwats-arrow-size);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    transition: filter .2s, box-shadow .2s, transform .2s, background .2s;
    box-shadow: 0 2px 10px rgba(0,0,0,.16);
}

.cwats-btn:hover {
    filter: brightness(.88);
    box-shadow: 0 4px 18px rgba(0,0,0,.2);
}

.cwats-btn svg {
    width: var(--cwats-arrow-icon-size);
    height: var(--cwats-arrow-icon-size);
    stroke: var(--cwats-arrow-color);
}

/* ─── Style : circle (défaut) ─── */
.cwats-arrow-style-circle .cwats-btn {
    /* hérite : full background, full shadow */
}

/* ─── Style : square ─── */
.cwats-arrow-style-square .cwats-btn {
    border-radius: 4px;
}

/* ─── Style : minimal (sans fond ni ombre) ─── */
.cwats-arrow-style-minimal .cwats-btn {
    background: transparent;
    box-shadow: none;
}
.cwats-arrow-style-minimal .cwats-btn svg {
    stroke: var(--cwats-arrow-bg); /* dans minimal, la couleur "bg" devient l'icône */
}
.cwats-arrow-style-minimal .cwats-btn:hover {
    background: transparent;
    box-shadow: none;
    transform: scale(1.15);
}

/* ─── Style : outline (bordure seule, fond transparent) ─── */
.cwats-arrow-style-outline .cwats-btn {
    background: transparent;
    border: 2px solid var(--cwats-arrow-bg);
    box-shadow: none;
}
.cwats-arrow-style-outline .cwats-btn svg {
    stroke: var(--cwats-arrow-bg);
}
.cwats-arrow-style-outline .cwats-btn:hover {
    background: var(--cwats-arrow-bg);
}
.cwats-arrow-style-outline .cwats-btn:hover svg {
    stroke: var(--cwats-arrow-color);
}

/* ─── Position : inside (par défaut, collées au bord) ─── */
.cwats-arrow-pos-inside .cwats-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.cwats-arrow-pos-inside .cwats-btn:hover {
    transform: translateY(-50%) scale(1.08);
}
.cwats-arrow-pos-inside .cwats-prev { left: var(--cwats-arrow-offset); }
.cwats-arrow-pos-inside .cwats-next { right: var(--cwats-arrow-offset); }

/* ─── Position : outside (à l'extérieur du slider) ─── */
.cwats-arrow-pos-outside {
    padding-left: calc(var(--cwats-arrow-size) + 12px);
    padding-right: calc(var(--cwats-arrow-size) + 12px);
}
.cwats-arrow-pos-outside .cwats-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.cwats-arrow-pos-outside .cwats-btn:hover {
    transform: translateY(-50%) scale(1.08);
}
.cwats-arrow-pos-outside .cwats-prev { left: 0; }
.cwats-arrow-pos-outside .cwats-next { right: 0; }

/* ─── Position : bottom (sous le slider, centrées) ─── */
.cwats-arrow-pos-bottom .cwats-btns-bottom {
    display: flex;
    justify-content: center;
    gap: 14px;
    padding-top: 16px;
}
.cwats-arrow-pos-bottom .cwats-btn {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
}
.cwats-arrow-pos-bottom .cwats-btn:hover {
    transform: scale(1.08);
}

/* Dots */
.cwats-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 20px 0 4px;
    flex-wrap: wrap;
}

.cwats-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 2px solid var(--cwats-accent);
    background: transparent;
    cursor: pointer;
    padding: 0;
    transition: background .25s, transform .25s;
}

.cwats-dot.is-active {
    background: var(--cwats-accent);
    transform: scale(1.4);
}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */

@media (max-width: 1024px) {
    .cwats-layout-slider .cwats-slide {
        flex-basis: calc(
            (100% - var(--cwats-gap) * (var(--cwats-cols-tablet) - 1)) / var(--cwats-cols-tablet)
        );
    }
    .cwats-layout-grid .cwats-grid {
        grid-template-columns: repeat(var(--cwats-cols-tablet), 1fr);
    }
    .cwats-layout-masonry .cwats-masonry {
        column-count: var(--cwats-cols-tablet);
    }
}

@media (max-width: 768px) {
    .cwats-layout-slider .cwats-slide {
        flex-basis: calc(
            (100% - var(--cwats-gap) * (var(--cwats-cols-mobile) - 1)) / var(--cwats-cols-mobile)
        );
    }
    .cwats-layout-grid .cwats-grid {
        grid-template-columns: repeat(var(--cwats-cols-mobile), 1fr);
    }
    .cwats-layout-masonry .cwats-masonry {
        column-count: var(--cwats-cols-mobile);
    }
    .cwats-card { padding: 28px 22px 22px; }

    /* ─────────────────────────────────────────
       v2.4.1 — Flèches sur mobile (≤ 768px)
       Force "inside" + centrage vertical sur la zone visible du slider.
       Approche : on positionne les boutons absolument à l'intérieur de
       .cwats-track-wrap (qui ne contient QUE les slides, pas les dots).
    ───────────────────────────────────────── */

    /* Annule padding éventuel hérité de outside */
    .cwats-layout-slider {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Track-wrap devient le référentiel positionnel */
    .cwats-layout-slider .cwats-track-wrap {
        position: relative;
    }

    /* Mode "bottom" : les boutons sont dans .cwats-btns-bottom — on le promote en overlay */
    .cwats-layout-slider .cwats-btns-bottom {
        position: absolute !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        left: 0 !important;
        right: 0 !important;
        width: 100%;
        padding-top: 0 !important;
        gap: 0 !important;
        justify-content: space-between !important;
        pointer-events: none;
        z-index: 5;
    }
    .cwats-layout-slider .cwats-btns-bottom .cwats-btn {
        pointer-events: auto;
    }

    /* Modes "inside" / "outside" : les boutons sont enfants directs de .cwats-wrap.
       On les positionne par rapport au track-wrap qui les "contient visuellement". */
    .cwats-layout-slider .cwats-wrap > .cwats-btn,
    .cwats-layout-slider > .cwats-btn,
    .cwats-layout-slider .cwats-track-wrap ~ .cwats-btn {
        /* fallback générique */
        position: absolute !important;
    }

    /* Position GAUCHE/DROITE pour tous les boutons */
    .cwats-layout-slider .cwats-btn.cwats-prev {
        left: 8px !important;
        right: auto !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    .cwats-layout-slider .cwats-btn.cwats-next {
        right: 8px !important;
        left: auto !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
    }

    /* En mode inside/outside, le centre vertical du WRAP inclut les dots.
       On compense pour que les flèches soient sur le centre du TRACK-WRAP.
       Hauteur dots ≈ 38px, donc remonter de ~19px par rapport au centre du wrap. */
    .cwats-arrow-pos-inside .cwats-btn.cwats-prev,
    .cwats-arrow-pos-inside .cwats-btn.cwats-next,
    .cwats-arrow-pos-outside .cwats-btn.cwats-prev,
    .cwats-arrow-pos-outside .cwats-btn.cwats-next {
        top: calc(50% - 19px) !important;
    }

    /* Hover : préserver l'effet scale */
    .cwats-layout-slider .cwats-btn.cwats-prev:hover,
    .cwats-layout-slider .cwats-btn.cwats-next:hover {
        transform: translateY(-50%) scale(1.08) !important;
    }
}
