/* SS Image Reveal — extensión del widget Single Image */
.ssir-wrap{position:relative;display:block;max-width:100%;line-height:normal}
.ssir-image-box{
    position:relative;display:inline-block;overflow:hidden;
    max-width:100%;line-height:0;vertical-align:top;
}
.ssir-image-box > a,
.ssir-image-box > img{display:block;max-width:100%}
.ssir-has-reveal .ssir-image-box{cursor:pointer}

/* ---- Círculo hover ---- */
.ssir-circle{
    position:absolute;top:0;left:0;
    display:flex;align-items:center;justify-content:center;
    width:120px;height:120px;border-radius:50%;
    pointer-events:none;opacity:0;
    transform:translate(-9999px,-9999px) scale(.6);
    transition:opacity .25s ease, transform .3s cubic-bezier(.22,.61,.36,1);
    text-align:center;line-height:1.1;
    padding:14px;box-sizing:border-box;
    font-weight:600;
    z-index:3;
    will-change:transform,opacity;
}
.ssir-circle .ssir-circle-text{display:block;line-height:1.1;white-space:normal}
.ssir-circle.is-visible{opacity:1}
/* Posiciones fijas (cuando circle_follow_mouse = no) */
.ssir-circle-pos-center       .ssir-circle.is-visible{transform:translate(-50%,-50%) scale(1);top:50%;left:50%}
.ssir-circle-pos-top-left     .ssir-circle.is-visible{transform:translate(0,0) scale(1);top:16px;left:16px}
.ssir-circle-pos-top-right    .ssir-circle.is-visible{transform:translate(0,0) scale(1);top:16px;left:auto;right:16px}
.ssir-circle-pos-bottom-left  .ssir-circle.is-visible{transform:translate(0,0) scale(1);top:auto;bottom:16px;left:16px}
.ssir-circle-pos-bottom-right .ssir-circle.is-visible{transform:translate(0,0) scale(1);top:auto;bottom:16px;left:auto;right:16px}

/* ---- Modo móvil: círculo siempre visible ----
   Se aplica en dispositivos sin hover O pantalla <= 767px.
*/
@media (hover: none), (max-width: 767px){
    .ssir-wrap.ssir-mobile-visible .ssir-circle{
        opacity:1;
        pointer-events:none;
        /* Desactivamos cualquier transform residual de followMouse */
    }
    .ssir-wrap.ssir-mobile-pos-center       .ssir-circle{transform:translate(-50%,-50%) scale(1);top:50%;left:50%;right:auto;bottom:auto}
    .ssir-wrap.ssir-mobile-pos-top-left     .ssir-circle{transform:translate(0,0) scale(1);top:16px;left:16px;right:auto;bottom:auto}
    .ssir-wrap.ssir-mobile-pos-top-right    .ssir-circle{transform:translate(0,0) scale(1);top:16px;right:16px;left:auto;bottom:auto}
    .ssir-wrap.ssir-mobile-pos-bottom-left  .ssir-circle{transform:translate(0,0) scale(1);bottom:16px;left:16px;top:auto;right:auto}
    .ssir-wrap.ssir-mobile-pos-bottom-right .ssir-circle{transform:translate(0,0) scale(1);bottom:16px;right:16px;top:auto;left:auto}
}

/* ---- Reveal overlay ---- */
.ssir-reveal{
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    visibility:hidden;opacity:0;
    transition:opacity .35s ease, visibility 0s linear .35s;
    z-index:10;line-height:1.5;
    border-radius:inherit;overflow:hidden; /* hereda el radio del image-box */
}
.ssir-reveal.ssir-scope-fullscreen{position:fixed;inset:0;z-index:99999;border-radius:0}
.ssir-reveal.is-open{visibility:visible;opacity:1;transition:opacity .35s ease, visibility 0s linear 0s}
.ssir-reveal-panel{position:absolute;inset:0;background:rgba(0,0,0,.85);border-radius:inherit}
.ssir-reveal-inner{
    position:relative;z-index:1;
    max-width:640px;width:calc(100% - 32px);
    padding:30px 40px;box-sizing:border-box;text-align:center;
}

/* Tipografía: forzamos la herencia con !important porque el tema (Leksa) y
   el elementor-post-X.css suelen aplicar font-size/line-height a p/h* con
   alta especificidad, y si no no gana nunca el valor del control. */
.ssir-reveal-content{color:#fff}
.ssir-reveal-content p,
.ssir-reveal-content li,
.ssir-reveal-content span,
.ssir-reveal-content a,
.ssir-reveal-content strong,
.ssir-reveal-content em,
.ssir-reveal-content div{
    font-size:inherit !important;
    line-height:inherit !important;
    letter-spacing:inherit !important;
    font-family:inherit !important;
}
.ssir-reveal-content h1,.ssir-reveal-content h2,.ssir-reveal-content h3,
.ssir-reveal-content h4,.ssir-reveal-content h5,.ssir-reveal-content h6{
    font-size:inherit !important;
    line-height:inherit !important;
    font-family:inherit !important;
    letter-spacing:inherit !important;
    margin:0 0 .6em;
}
.ssir-reveal-content p{margin:0 0 .6em}
.ssir-reveal-content > *:last-child{margin-bottom:0}
.ssir-reveal-content a{text-decoration:underline}

/* ---- Botón cerrar (arriba-derecha del overlay = de la imagen) ---- */
.ssir-close{
    position:absolute;top:10px;right:10px;z-index:3;
    width:40px;height:40px;
    background:rgba(0,0,0,.35);border:0;color:#fff;
    line-height:1;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    opacity:.9;transition:opacity .2s, background-color .2s;
    padding:0;border-radius:50%;
}
.ssir-close svg{display:block;width:22px;height:22px}
.ssir-close:hover,.ssir-close:focus{opacity:1;background:rgba(0,0,0,.55);outline:none}

/* Scroll lock para pantalla completa */
body.ssir-lock-scroll{overflow:hidden}

/* ---- Animaciones de entrada ---- */
.ssir-reveal .ssir-reveal-inner{
    transition-property:transform, opacity, filter, clip-path;
    transition-duration:.5s;
    transition-timing-function:cubic-bezier(.22,.61,.36,1);
    will-change:transform, opacity, filter;
}
.ssir-anim-fade     .ssir-reveal-inner{opacity:0}
.ssir-anim-fade.is-open .ssir-reveal-inner{opacity:1}
.ssir-anim-scale    .ssir-reveal-inner{opacity:0;transform:scale(.7)}
.ssir-anim-scale.is-open .ssir-reveal-inner{opacity:1;transform:scale(1)}
.ssir-anim-slide-up .ssir-reveal-inner{opacity:0;transform:translateY(60px)}
.ssir-anim-slide-up.is-open .ssir-reveal-inner{opacity:1;transform:translateY(0)}
.ssir-anim-zoom     .ssir-reveal-inner{opacity:0;transform:scale(.4);filter:blur(12px)}
.ssir-anim-zoom.is-open .ssir-reveal-inner{opacity:1;transform:scale(1);filter:blur(0)}
.ssir-anim-reveal   .ssir-reveal-inner{clip-path:inset(0 100% 0 0)}
.ssir-anim-reveal.is-open .ssir-reveal-inner{clip-path:inset(0 0 0 0);transition-duration:.7s}

/* Panel fade (fondo) */
.ssir-reveal .ssir-reveal-panel{opacity:0;transition:opacity .35s ease}
.ssir-reveal.is-open .ssir-reveal-panel{opacity:1}

/* Respeto a prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
    .ssir-circle,
    .ssir-reveal,
    .ssir-reveal-inner,
    .ssir-reveal-panel{transition-duration:.01s !important}
}
