.eoe-mp4-video {
    position: relative;
    width: 100%;
    overflow: hidden;
    box-shadow: 6px 8px 15px #0000002e;
    border-radius: 7px;
}

.eoe-mp4-video__media {
    position: relative;
    width: 100%;
    min-height: 12rem;
    background: #111;
}

.eoe-mp4-video__video {
    display: block;
    width: 100%;
    height: auto;
    vertical-align: middle;
    object-fit: cover;
    aspect-ratio: 16 / 9;
}

.eoe-mp4-video__overlay {
    position: absolute;
    left: 0;
    right: 0;
    z-index: 2;
    padding: 1rem 1.25rem;
    color: #fff;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.35));
    pointer-events: none;
     * {color: #FFFFFF !important;}
     a {color: var(--bs-link-color) !important; text-decoration: underline !important;}
}

.eoe-mp4-video__overlay--top {
    top: 0;
    bottom: auto;
    background: linear-gradient(to bottom, rgb(0 0 0 / 48%), #000000ad);
}

.eoe-mp4-video__overlay--bottom {
    bottom: 0;
    top: auto;
    background: linear-gradient(to top, rgb(0 0 0 / 48%), #000000ad);
}

.eoe-mp4-video__overlay a {
    pointer-events: auto;
    color: inherit;
}

.eoe-mp4-video__fullscreen-btn {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    z-index: 50;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: 30px;
    color: #fff;
    background: rgba(255, 255, 255, 0.75);
    cursor: pointer;
    pointer-events: auto;
    transition: all 0.15s ease;
    box-shadow: 1px 0px 10px #00000054;
}

.eoe-mp4-video__fullscreen-btn:hover,
.eoe-mp4-video__fullscreen-btn:focus-visible {
    background: rgba(255, 255, 255, 1);
}

.eoe-mp4-video__below {
    padding: 1rem;
}

.layout-below_video .eoe-mp4-video__overlay {
    display: none;
}

.eoe-mp4-video--preview .eoe-mp4-video__media {
    min-height: 6rem;
}

.eoe-mp4-video__preview-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 6rem;
    padding: 1rem;
    background: #222;
    color: #ddd;
    font-size: 0.875rem;
}

.eoe-mp4-video__preview-placeholder--empty {
    background: #333;
    color: #999;
}
