/* =========================================================
   Video facade (click-to-load) — fills the existing 9:16 .gls-mv-video /
   .gls-tmv-video box exactly like the iframe it replaces, so layout is unchanged.
========================================================= */
.gls-video-facade {
    /* Default: own a 16:9 relative box (used e.g. inside .about-video flex wrapper). */
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    margin: 0;
    padding: 0;
    border: 0;
    background: #111;
    cursor: pointer;
    display: block;
    overflow: hidden;
}

/* Inside the vertical 9:16 carousel boxes, fill the pre-sized container instead. */
.gls-mv-video .gls-video-facade,
.gls-tmv-video .gls-video-facade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
}

.gls-video-facade__poster {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .35s ease, filter .35s ease;
}

.gls-video-facade__play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: grid;
    place-items: center;
    filter: drop-shadow(0 4px 10px rgba(0, 0, 0, .35));
    transition: transform .2s ease;
    pointer-events: none;
}

.gls-video-facade:hover .gls-video-facade__poster,
.gls-video-facade:focus-visible .gls-video-facade__poster {
    transform: scale(1.04);
    filter: brightness(.9);
}

.gls-video-facade:hover .gls-video-facade__play,
.gls-video-facade:focus-visible .gls-video-facade__play {
    transform: translate(-50%, -50%) scale(1.08);
}

.gls-video-facade:focus-visible {
    outline: 3px solid #fff;
    outline-offset: -3px;
}
