/* ==================================================
   FRONT-POST.CSS
   Tipo: Página específica
   Ámbito: Solo posts individuales (is_singular post)
   Define: Layout y estilos del artículo (cabecera,
           imagen destacada, contenido, galería, pie
           de foto, noticias relacionadas, sidebar,
           publicidad, más leído)
   Depende de: front-base.css
   ================================================== */

/* --------------------------------------------------
   5.1 Contenedor
   -------------------------------------------------- */
.lavoz-post-wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 var(--lavoz-gap-md) 0;
}

/* --------------------------------------------------
   5.2 Título
   -------------------------------------------------- */
.lavoz-post-header {
    margin-bottom: var(--lavoz-gap-md);
}

.lavoz-post-epigrafe {
    display: inline-block;
    font-family: var(--lavoz-font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #fff;
    background: var(--lavoz-color-accent);
    padding: 3px 10px;
    border-radius: 2px;
    margin: 0 0 var(--lavoz-gap-sm) 0;
}

.lavoz-post-titulo {
    font-size: var(--lavoz-title-size-lg);
    margin: 0 0 var(--lavoz-gap-md) 0;
    padding: 0;
}

/* --------------------------------------------------
   5.3 Subtítulo
   -------------------------------------------------- */
.lavoz-post-subtitulo {
    font-style: normal;
    margin: 0 0 var(--lavoz-gap-sm) 0;
}

.lavoz-post-dateline {
    font-family: var(--lavoz-font-body);
    font-size: 0.85rem;
    font-weight: 400;
    color: var(--lavoz-color-meta);
}

/* --------------------------------------------------
   5.4 Autor y Fecha
   -------------------------------------------------- */
.lavoz-post-autor {
    font-family: var(--lavoz-font-body);
    font-size: 1rem;
    color: var(--lavoz-color-meta);
    margin: var(--lavoz-gap-sm) 0;
    padding: var(--lavoz-gap-xs) 0;
    border-top: 1px solid var(--lavoz-color-border);
    border-bottom: 1px solid var(--lavoz-color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.lavoz-post-autor-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.lavoz-post-autor-info {
    display: block;
}

.lavoz-share-icons {
    display: flex;
    gap: 12px;
    align-items: center;
}

.lavoz-share-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--lavoz-color-muted);
    transition: color 0.2s ease;
}

.lavoz-share-icon:hover {
    color: var(--lavoz-color-accent);
}

.lavoz-post-autor-link {
    color: var(--lavoz-color-accent);
    text-decoration: none;
    font-weight: 600;
}

.lavoz-post-autor-link:hover {
    text-decoration: underline;
}

.lavoz-post-separador {
    margin: 0 var(--lavoz-gap-xs);
    color: var(--lavoz-color-border);
}

.lavoz-post-fecha {
    color: var(--lavoz-color-meta);
    font-weight: 500;
}

/* --------------------------------------------------
   5.5 Noticias Relacionadas (excepción: Libre Baskerville)
   -------------------------------------------------- */
.lavoz-post-relacionadas {
    margin: 0;
    padding: 0;
    background: var(--lavoz-color-bg);
}

.lavoz-post-relacionadas-lista {
    list-style: none;
    padding-left: var(--lavoz-gap-md);
    margin: 0 0 var(--lavoz-gap-md) 0;
}

.lavoz-post-relacionadas-item {
    margin-bottom: 0;
    line-height: var(--lavoz-lh-base);
    position: relative;
    padding-left: 18px;
}

.lavoz-post-relacionadas-item::before {
    content: '•';
    position: absolute;
    left: 0;
    color: var(--lavoz-color-accent);
    font-size: 1.5em;
    line-height: 1;
    top: 0;
}

.lavoz-post-relacionadas-link {
    font-family: var(--lavoz-font-heading);
    font-size: 1.05rem;
    color: var(--lavoz-color-accent);
    text-decoration: none;
    transition: color 0.2s ease;
}

.lavoz-post-relacionadas-link:hover {
    color: var(--lavoz-color-accent-hover);
    text-decoration: none;
}

/* --------------------------------------------------
   5.6 Layout 2 Columnas
   -------------------------------------------------- */
.lavoz-post-layout {
    display: grid;
    grid-template-columns: 70% 30%;
    gap: var(--lavoz-card-gap);
    margin: 0;
}

/* --------------------------------------------------
   5.7 Contenido
   -------------------------------------------------- */
.lavoz-post-contenido {
    font-family: var(--lavoz-font-body);
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--lavoz-color-text);
    overflow-x: hidden;
}

.lavoz-post-contenido p {
    margin-bottom: 1.5em;
}

.lavoz-post-contenido h2,
.lavoz-post-contenido h3,
.lavoz-post-contenido h4 {
    font-weight: 400;
    color: var(--lavoz-title-color);
    margin-top: 2em;
    margin-bottom: 0.8em;
    line-height: 1.3;
}

.lavoz-post-contenido h2 { font-size: 2rem; }
.lavoz-post-contenido h3 { font-size: 1.6rem; }
.lavoz-post-contenido h4 { font-size: 1.3rem; }

.lavoz-post-contenido blockquote {
    font-size: 1.4rem;
    font-style: italic;
    color: var(--lavoz-subtitle-color);
    margin: 2em 0;
    padding-left: var(--lavoz-gap-lg);
    border-left: 4px solid var(--lavoz-color-accent);
    line-height: var(--lavoz-lh-base);
}

.lavoz-post-contenido ul,
.lavoz-post-contenido ol {
    margin: 1.5em 0;
    padding-left: var(--lavoz-gap-lg);
}

.lavoz-post-contenido li {
    margin-bottom: 0.8em;
}

.lavoz-post-contenido a {
    color: var(--lavoz-color-accent);
    text-decoration: underline;
    font-weight: 700;
}

.lavoz-post-contenido a:hover {
    color: var(--lavoz-color-accent-hover);
}

.lavoz-post-contenido img {
    max-width: 100%;
    height: auto;
    display: block;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
}

/* Figure + pie de foto */
.lavoz-contenido-imagen,
.wp-caption {
    margin: 2.5em 0;
    max-width: 100%;
    width: auto;
    position: relative;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
    overflow: hidden;
}

.lavoz-contenido-imagen img,
.wp-caption img {
    max-width: 100%;
    width: 100% !important;
    height: auto !important;
    display: block;
    margin: 0 !important;
    padding: 0;
    border: none;
    border-radius: 0;
    vertical-align: bottom;
}

.lavoz-post-imagen-caption,
.wp-caption-text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    font-family: var(--lavoz-font-body);
    font-size: 0.85rem;
    color: var(--lavoz-color-bg);
    line-height: 1.3;
    margin: 0;
    padding: 12px var(--lavoz-gap-md);
    background: var(--lavoz-overlay-bg);
    text-align: right;
    font-style: normal;
    font-weight: 400;
}

.lavoz-post-video .lavoz-post-video-caption {
    font-family: var(--lavoz-font-body);
    font-size: 0.85rem;
    color: var(--lavoz-color-bg);
    line-height: 1.3;
    margin: 0;
    padding: 12px var(--lavoz-gap-md);
    background: var(--lavoz-video-caption-bg);
    text-align: right;
    font-style: normal;
    font-weight: 400;
}

/* WordPress alignments */
.wp-caption.alignleft  { float: left;  margin: 0.5em 2em 1.5em 0; max-width: 45%; width: auto; }
.wp-caption.alignright { float: right; margin: 0.5em 0 1.5em 2em; max-width: 45%; width: auto; }
.wp-caption.aligncenter { display: block; clear: both; max-width: 100%; width: auto; }
.wp-caption.alignnone { margin: 2.5em 0; clear: both; max-width: 100%; width: auto; }

.lavoz-post-contenido figure[style*="width"] {
    width: auto;
    max-width: 100%;
}

/* Imagen destacada */
.lavoz-post-imagen {
    margin: 0 0 var(--lavoz-gap-md) 0;
    position: relative;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
    overflow: hidden;
}

.lavoz-post-imagen img {
    width: 100%;
    height: auto;
    display: block;
}

.lavoz-post-video {
    margin: 0 0 var(--lavoz-gap-md) 0;
    border-radius: 0;
    border: 1px solid var(--lavoz-color-border-light);
    overflow: hidden;
    position: relative;
}

.lavoz-post-video .wp-video,
.lavoz-post-video .mejs-container {
    width: 100% !important;
    max-width: 100%;
}

.lavoz-post-contenido .wp-video {
    border: 1px solid var(--lavoz-color-border-light);
    overflow: hidden;
}

/* Unificar play overlay en todos los vídeos (WP MediaElement) */
.lavoz-post-video .mejs-overlay-button,
.lavoz-post-contenido .mejs-overlay-button {
    position: absolute;
    width: 70px !important;
    height: 70px !important;
    background: rgba(0, 0, 0, 0.7) !important;
    border: 3px solid rgba(255, 255, 255, 0.9) !important;
    border-radius: 50% !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='rgba(255,255,255,0.9)'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: 55% center !important;
    background-size: 40px 40px !important;
    margin: 0 !important;
    top: 12px !important;
    left: 12px !important;
    transform: none !important;
}

.lavoz-post-video .mejs-overlay-loading,
.lavoz-post-contenido .mejs-overlay-loading {
    background: transparent !important;
}

/* --------------------------------------------------
   5.7.1 Bloques editoriales (TinyMCE)
   Clases insertadas por el editor: entradilla, cita,
   recuadro, contexto, anotación. Se renderizan en el
   frontend dentro de .lavoz-post-contenido.
   -------------------------------------------------- */

.lavoz-entradilla {
    font-family: var(--lavoz-font-heading);
    font-size: 1.25rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--lavoz-color-text);
    border-left: 4px solid var(--lavoz-color-text);
    padding: 0.5em 0 0.5em 1.2em;
    margin: 1.5em 0;
}

.lavoz-cita-destacada {
    font-family: var(--lavoz-font-heading);
    font-size: 1.3rem;
    font-style: italic;
    font-weight: 400;
    line-height: 1.5;
    color: var(--lavoz-color-text);
    text-align: center;
    padding: 1.5em 2em;
    margin: 2em 0;
    border-top: 2px solid var(--lavoz-color-text);
    border-bottom: 2px solid var(--lavoz-color-text);
}

.lavoz-cita-destacada::before { content: '\201C'; }
.lavoz-cita-destacada::after  { content: '\201D'; }

.lavoz-recuadro-informativo {
    font-family: var(--lavoz-font-body);
    font-size: 0.95rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--lavoz-color-text);
    background: #f5f5f0;
    border: 1px solid var(--lavoz-color-border);
    border-left: 4px solid var(--lavoz-color-border);
    padding: 1.2em 1.5em;
    margin: 1.5em 0;
    border-radius: 3px;
}

.lavoz-contexto {
    font-family: var(--lavoz-font-body);
    font-size: 0.92rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--lavoz-color-meta);
    background: #fafaf5;
    border: 1px dashed var(--lavoz-color-border);
    padding: 1.2em 1.5em;
    margin: 1.5em 0;
    border-radius: 3px;
}

.lavoz-anotacion {
    font-family: var(--lavoz-font-body);
    font-size: 0.85rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--lavoz-color-muted);
    font-style: italic;
    border-bottom: 1px solid var(--lavoz-color-border-light);
    padding: 0.5em 0;
    margin: 1.5em 0;
}

/* --------------------------------------------------
   5.7.2 Galería de imágenes — Carrusel
   El JS de front-gallery.js transforma .gallery y .wp-block-gallery
   en .lavoz-carrusel antes de pintarse. El CSS solo estiliza .lavoz-carrusel.
   -------------------------------------------------- */

/* Contenedor principal del carrusel */
.lavoz-carrusel {
    position: relative;
    margin: 2.5em 0 0;
    background: #000;
    border-radius: var(--lavoz-img-radius) var(--lavoz-img-radius) 0 0;
    overflow: hidden;
    user-select: none;
}

/* Pista de slides */
.lavoz-carrusel-track {
    display: flex;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

/* Cada slide */
.lavoz-carrusel-slide {
    flex: 0 0 100%;
    width: 100%;
    position: relative;
    line-height: 0;
}

.lavoz-carrusel-slide img {
    width: 100%;
    height: auto;
    max-height: 560px;
    object-fit: contain; /* contain para no recortar fotos de prensa */
    display: block;
    border: none;
    border-radius: 0;
    margin: 0;
}

/* Caption fuera del recuadro — pegado al carrusel, estilo cinta */
.lavoz-carrusel-caption {
    display: block;
    margin: 0 0 2.5em;
    padding: 10px var(--lavoz-gap-md);
    background: var(--lavoz-overlay-bg);
    font-family: var(--lavoz-font-body);
    font-size: 0.82rem;
    color: #fff;
    line-height: 1.35;
    text-align: right;
    border-radius: 0 0 var(--lavoz-img-radius) var(--lavoz-img-radius);
}

/* Barras laterales oscuras con flecha centrada */
.lavoz-carrusel-btn {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.45);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background 0.2s ease;
    z-index: 2;
}

.lavoz-carrusel-btn:hover {
    background: rgba(0, 0, 0, 0.72);
}

.lavoz-carrusel-btn--prev { left: 0; }
.lavoz-carrusel-btn--next { right: 0; }

/* Ocultar flechas si solo hay una imagen */
.lavoz-carrusel--single .lavoz-carrusel-btn {
    display: none;
}

/* SVG de la flecha */
.lavoz-carrusel-btn svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: #fff;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    flex-shrink: 0;
}

/* --------------------------------------------------
   5.8 Sidebar
   -------------------------------------------------- */
#lavoz-post-sidebar {
    position: sticky;
    bottom: var(--lavoz-gap-md);
    align-self: end;
    border-left: 1px solid var(--lavoz-color-border);
    padding-left: var(--lavoz-card-gap);
    padding-right: var(--lavoz-card-gap);
}

.lavoz-sidebar-mas-noticias {
    background: var(--lavoz-color-bg);
    padding: 0;
    overflow: hidden;
}

.lavoz-sidebar-titulo {
    display: inline-block;
    position: relative;
    background: var(--lavoz-color-accent);
    color: var(--lavoz-color-bg);
    padding: 8px 20px;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin: 0 0 var(--lavoz-gap-md) 0;
}

.lavoz-sidebar-titulo::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 100%;
    width: 200vw;
    height: 1px;
    background: var(--lavoz-color-accent);
}

.lavoz-sidebar-noticias-lista {
    display: flex;
    flex-direction: column;
    gap: var(--lavoz-card-gap);
}

.lavoz-sidebar-noticia-item {
    padding-bottom: var(--lavoz-content-pad);
    border-bottom: 1px dotted var(--lavoz-color-border);
}

.lavoz-sidebar-noticia-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

/* Solo la primera noticia muestra imagen */
.lavoz-sidebar-noticia-item:not(:first-child) .lavoz-sidebar-noticia-imagen {
    display: none;
}

.lavoz-sidebar-noticia-link {
    display: flex;
    flex-direction: column;
    gap: 3px;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.lavoz-sidebar-noticia-link .lavoz-sidebar-noticia-titulo {
    font-size: 0.9rem;
    margin-bottom: 0;
}

.lavoz-sidebar-noticia-link .lavoz-autor {
    font-size: 0.75rem;
}

.lavoz-sidebar-noticia-link:hover {
    opacity: 0.8;
}

/* Excepción: imagen sidebar */
.lavoz-sidebar-noticia-imagen {
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
    margin-bottom: var(--lavoz-gap-xs);
}

.lavoz-sidebar-noticia-imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.lavoz-sidebar-noticia-link:hover .lavoz-sidebar-noticia-imagen img {
    transform: var(--lavoz-img-hover-scale);
}

/* --------------------------------------------------
   5.9 Otras Noticias
   -------------------------------------------------- */
.lavoz-post-otras-noticias {
    margin: 60px 0 0;
    padding-top: var(--lavoz-card-gap);
    overflow: hidden;
}

.lavoz-otras-noticias-titulo {
    display: inline-block;
    position: relative;
    background: var(--lavoz-color-accent);
    color: var(--lavoz-color-bg);
    padding: 8px 20px;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: var(--lavoz-card-gap);
}

.lavoz-otras-noticias-titulo::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 100%;
    width: 200vw;
    height: 1px;
    background: var(--lavoz-color-accent);
}

.lavoz-otras-noticias-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--lavoz-card-gap);
}

/* Primera noticia: destacada horizontal — texto izquierda, imagen derecha */
.lavoz-otra-noticia-destacada .lavoz-card-link {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--lavoz-card-gap);
    align-items: center;
}

.lavoz-otra-noticia-destacada {
    margin-bottom: var(--lavoz-gap-sm);
}

.lavoz-otra-noticia-destacada .lavoz-otra-noticia-contenido {
    order: -1;
}

.lavoz-otra-noticia-destacada .lavoz-otra-noticia-imagen {
    aspect-ratio: 16 / 9;
}

/* Resto: fila de 3 */
.lavoz-otras-noticias-fila {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--lavoz-card-gap);
}

.lavoz-otra-noticia-card {
    background: var(--lavoz-color-bg);
    overflow: hidden;
    border-radius: var(--lavoz-img-radius);
}

/* Excepción: imagen con altura fija */
.lavoz-otra-noticia-imagen {
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
}

.lavoz-otra-noticia-imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.lavoz-otra-noticia-contenido {
    padding: var(--lavoz-content-pad);
}

/* --------------------------------------------------
   5.10 Responsive — Post
   -------------------------------------------------- */
@media (max-width: 1024px) {
    .lavoz-post-layout {
        grid-template-columns: 1fr;
    }

    #lavoz-post-sidebar {
        position: static;
    }

    .lavoz-otras-noticias-fila {
        grid-template-columns: repeat(2, 1fr);
    }

    .lavoz-otra-noticia-destacada .lavoz-card-link {
        grid-template-columns: 1fr;
    }

    .lavoz-otra-noticia-destacada .lavoz-otra-noticia-contenido {
        order: 0;
    }
}

@media (max-width: 640px) {
    .lavoz-post-wrap {
        padding: 0 var(--lavoz-gap-sm) var(--lavoz-gap-xl);
    }

    .lavoz-post-titulo {
        font-size: 2rem;
    }

    .lavoz-post-contenido {
        font-size: 1.05rem;
    }

    .lavoz-otras-noticias-fila {
        grid-template-columns: 1fr;
    }
}


/* ==================================================
   PUBLICIDAD
   ================================================== */

#lavoz-post-sidebar > .lavoz-publicidad:first-child,
.lavoz-portada-column-right > .lavoz-publicidad:first-child {
    margin-top: 0;
}

/* Estilos de publicidad — definidos en front-base.css */


/* ==================================================
   SINGLE — BLOQUE INFERIOR MÁS NOTICIAS
   ================================================== */

.lavoz-post-inferior {
    max-width: 1100px;
    margin: var(--lavoz-gap-lg) auto 0;
    overflow: hidden;
}

.lavoz-post-inferior > .lavoz-otras-noticias-titulo {
    margin-bottom: var(--lavoz-gap-md);
}

/* Fila de 2 columnas iguales */
.lavoz-otras-noticias-fila--2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--lavoz-gap-md);
    margin-bottom: var(--lavoz-gap-md);
}

/* Fila de 4 columnas iguales */
.lavoz-otras-noticias-fila--4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--lavoz-gap-md);
}

@media (max-width: 768px) {
    .lavoz-otras-noticias-fila--2 {
        grid-template-columns: repeat(2, 1fr);
    }
    .lavoz-otras-noticias-fila--4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .lavoz-otras-noticias-fila--2,
    .lavoz-otras-noticias-fila--4 {
        grid-template-columns: 1fr;
    }
}


/* ==================================================
   SINGLE — LO MÁS LEÍDO (sidebar)
   ================================================== */

.lavoz-sidebar-mas-leido {
    margin-top: var(--lavoz-gap-md);
    overflow: hidden;
}

.lavoz-mas-leido-lista {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: mas-leido;
}

.lavoz-mas-leido-item {
    counter-increment: mas-leido;
    display: flex;
    align-items: baseline;
    gap: var(--lavoz-gap-xs);
    padding: var(--lavoz-gap-sm) 0;
    border-bottom: 1px solid var(--lavoz-color-border);
}

.lavoz-mas-leido-item:last-child {
    border-bottom: none;
}

.lavoz-mas-leido-item::before {
    content: counter(mas-leido);
    font-family: var(--lavoz-font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--lavoz-color-accent);
    min-width: 24px;
    line-height: 1;
    flex-shrink: 0;
}

.lavoz-mas-leido-link {
    font-family: var(--lavoz-font-heading);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--lavoz-color-text);
    text-decoration: none;
    line-height: var(--lavoz-lh-heading);
    transition: color 0.2s ease;
}

.lavoz-mas-leido-link:hover {
    color: var(--lavoz-color-accent);
}

/* ── Float de imágenes en cuerpo del post ── */
.lavoz-post-contenido img.alignleft,
.lavoz-post-contenido img.alignright {
    display: inline;
    max-width: 45%;
    height: auto;
}

.lavoz-post-contenido img.alignleft  { float: left;  margin: 0.5em 2em 1.5em 0; }
.lavoz-post-contenido img.alignright { float: right; margin: 0.5em 0 1.5em 2em; }
.lavoz-post-contenido img.aligncenter { display: block; margin: 1.5em auto; }

.lavoz-post-contenido::after {
    content: '';
    display: table;
    clear: both;
}
