p:has(video) {
    width: 100% !important;
    position: relative;
    display: block;
}
video {
    position: relative;
    display: block;
    max-width: max(20vw, 370px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: .75rem;
}
img {
    margin-top: .5rem;
    margin-bottom: .75rem;
}

figure.image {
    display: inline-block;
    border: 1px solid #f4f4f4;
    margin: .25rem 1rem .25rem 1px;
    background: #fefefe;
    border-radius: 12px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px;
}

figure.align-left {
    float: left;
}

figure.align-right {
    float: right;
}

figure.align-center {
    display: block;
    width: fit-content;
    margin-left: auto !important;
    margin-right: auto !important;
}

figure.image img {
    margin: 8px 8px 0 8px;
}

figure.image figcaption {
    margin: 6px 8px 6px 8px;
    text-align: center;
    font-size: 0.85em;
    font-weight: 500;
    color: #686868;
}

img,
figure.image img {
    max-width: 100% !important;
    max-height: 320px;
}

@media (min-width: 768px) {
    video {
        position: relative;
        display: block;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    img,
    figure.image img {
        max-height: 540px;
    }
    img[style*="float: left;"] {
        margin-right: .75rem;
    }
    img[style*="float: right;"] {
        margin-left: .75rem;
    }
}
