/**
 * WS Booster - Widget Flip Card
 * v3.6.0 : ajout back_image + dimensions image recto/verso + transitions fade & zoom
 */

.ws-flip-card {
    position: relative;
    width: 100%;
    max-width: 380px;
    height: 360px;
    aspect-ratio: 1 / 1.15;
    perspective: 1400px;
    cursor: pointer;
    margin: 0 auto;
}

.ws-flip-card__inner {
    position: absolute;
    inset: 0;
    transform-style: preserve-3d;
    transition: transform var(--ws-flip-duration, 0.7s) cubic-bezier(0.65, 0, 0.35, 1);
    will-change: transform;
}

/* ===== Faces (commun) ===== */
.ws-flip-card__face {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    border-radius: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.ws-flip-card__front {
    background: #f3f4f6;
}

/* !important neutralise piege theme WP img {max-width:100%; height:auto !important} */
.ws-flip-card__img,
.ws-flip-card__back-img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover;
    object-position: center center;
    display: block;
    pointer-events: none;
}

/* Si l'utilisateur reduit width/height en %, l'image se centre dans la card */
.ws-flip-card__img,
.ws-flip-card__back-img {
    margin: auto;
}

.ws-flip-card__overlay,
.ws-flip-card__back-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    pointer-events: none;
}

.ws-flip-card__content {
    position: relative;
    z-index: 2;
    padding: 24px;
    text-align: center;
}

.ws-flip-card__back {
    background: #1a1a2e;
    color: #fff;
    justify-content: center;
}

.ws-flip-card__title {
    margin: 0 0 8px;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.ws-flip-card__subtitle {
    margin: 0;
    font-size: 14px;
    opacity: 0.85;
}

.ws-flip-card__text {
    margin: 0 0 18px;
    font-size: 15px;
    line-height: 1.5;
}

.ws-flip-card__btn {
    display: inline-block;
    padding: 10px 22px;
    background: #ef3340;
    color: #fff;
    text-decoration: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ws-flip-card__btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}

/* ============================================================
   TRANSITION : FLIP-Y (horizontal, defaut)
   ============================================================ */
.ws-flip-card--flip-y .ws-flip-card__back {
    transform: rotateY(180deg);
}
.ws-flip-card--flip-y.ws-flip-card--hover:hover .ws-flip-card__inner,
.ws-flip-card--flip-y.is-flipped .ws-flip-card__inner {
    transform: rotateY(180deg);
}

/* ============================================================
   TRANSITION : FLIP-X (vertical)
   ============================================================ */
.ws-flip-card--flip-x .ws-flip-card__back {
    transform: rotateX(180deg);
}
.ws-flip-card--flip-x.ws-flip-card--hover:hover .ws-flip-card__inner,
.ws-flip-card--flip-x.is-flipped .ws-flip-card__inner {
    transform: rotateX(180deg);
}

/* ============================================================
   TRANSITION : FADE (cross-fade smooth, pas de 3D)
   ============================================================ */
.ws-flip-card--fade {
    perspective: none;
}
.ws-flip-card--fade .ws-flip-card__inner {
    transform-style: flat;
    transition: none;
}
.ws-flip-card--fade .ws-flip-card__face {
    backface-visibility: visible;
    -webkit-backface-visibility: visible;
    transition: opacity var(--ws-flip-duration, 0.7s) cubic-bezier(0.65, 0, 0.35, 1);
}
.ws-flip-card--fade .ws-flip-card__back {
    opacity: 0;
    transform: none;
}
.ws-flip-card--fade.ws-flip-card--hover:hover .ws-flip-card__front,
.ws-flip-card--fade.is-flipped .ws-flip-card__front {
    opacity: 0;
}
.ws-flip-card--fade.ws-flip-card--hover:hover .ws-flip-card__back,
.ws-flip-card--fade.is-flipped .ws-flip-card__back {
    opacity: 1;
}

/* ============================================================
   TRANSITION : ZOOM (recto zoom out + fade, verso zoom in + fade)
   ============================================================ */
.ws-flip-card--zoom {
    perspective: none;
}
.ws-flip-card--zoom .ws-flip-card__inner {
    transform-style: flat;
    transition: none;
}
.ws-flip-card--zoom .ws-flip-card__face {
    backface-visibility: visible;
    -webkit-backface-visibility: visible;
    transition: opacity var(--ws-flip-duration, 0.7s) cubic-bezier(0.65, 0, 0.35, 1),
                transform var(--ws-flip-duration, 0.7s) cubic-bezier(0.65, 0, 0.35, 1);
}
.ws-flip-card--zoom .ws-flip-card__front {
    transform: scale(1);
    opacity: 1;
}
.ws-flip-card--zoom .ws-flip-card__back {
    transform: scale(0.85);
    opacity: 0;
}
.ws-flip-card--zoom.ws-flip-card--hover:hover .ws-flip-card__front,
.ws-flip-card--zoom.is-flipped .ws-flip-card__front {
    transform: scale(1.15);
    opacity: 0;
}
.ws-flip-card--zoom.ws-flip-card--hover:hover .ws-flip-card__back,
.ws-flip-card--zoom.is-flipped .ws-flip-card__back {
    transform: scale(1);
    opacity: 1;
}

/* ============================================================
   RETROCOMPAT : ancien .ws-flip-card--axis-y / --axis-x
   (widgets sauvegardes avant v3.6.0)
   ============================================================ */
.ws-flip-card--axis-y .ws-flip-card__back {
    transform: rotateY(180deg);
}
.ws-flip-card--axis-y.ws-flip-card--hover:hover .ws-flip-card__inner,
.ws-flip-card--axis-y.is-flipped .ws-flip-card__inner {
    transform: rotateY(180deg);
}
.ws-flip-card--axis-x .ws-flip-card__back {
    transform: rotateX(180deg);
}
.ws-flip-card--axis-x.ws-flip-card--hover:hover .ws-flip-card__inner,
.ws-flip-card--axis-x.is-flipped .ws-flip-card__inner {
    transform: rotateX(180deg);
}

@media (prefers-reduced-motion: reduce) {
    .ws-flip-card__inner,
    .ws-flip-card__face {
        transition: none;
    }
}
