/* ================================================
   MODAL DIFUSIÓN GLOBAL
================================================ */
#MODAL-DIFUSION-GLOBAL {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}

#MODAL-DIFUSION-GLOBAL[style*="flex"] {
    display: flex !important;
    position: fixed !important;
    z-index: 999999 !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
}

.difusion-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.difusion-modal-box {
    background: #fff;
    border-radius: 16px;
    width: 100%;
    max-width: 520px;
    max-height: 85vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0,0,0,0.2);
    animation: difusion-entrada 0.3s ease;
}

.difusion-adj-etiqueta {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 10px;
    margin: 10px 0 -5px;
    letter-spacing: 0.03em;
}

.difusion-adj-etiqueta--imagen {
    background: #e8f0fe;
    color: #1a6bc4;
}

.difusion-adj-etiqueta--video {
    background: #fde8e8;
    color: #c0392b;
}

.difusion-adj-etiqueta--pdf {
    background: #fef6e4;
    color: #d4830a;
}

@keyframes difusion-entrada {
    from { opacity: 0; transform: translateY(20px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0)   scale(1);    }
}

/* ── HEADER ── */
.difusion-modal-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 20px;
    border-bottom: 1px solid #f0eee8;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

.difusion-modal-titulo {
    flex: 1;
    font-size: 1rem;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0;
}

.difusion-modal-cerrar {
    background: none;
    border: none;
    font-size: 1.1rem;
    color: #aaa;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.15s;
}
.difusion-modal-cerrar:hover { background: #f0eee8; color: #333; }

.difusion-modal-badge {
    font-size: 0.68rem;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    flex-shrink: 0;
}

.difusion-modal-badge.info    { background: #e8f0fe; color: #1a6bc4; }
.difusion-modal-badge.success { background: #e6f4ea; color: #1e7e34; }
.difusion-modal-badge.warning { background: #fef6e4; color: #d4830a; }
.difusion-modal-badge.error   { background: #fde8e8; color: #c0392b; }

/* ── BODY ── */
.difusion-modal-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
}

.difusion-modal-mensaje.ql-editor {
    padding: 0;
    font-size: 0.95rem;
    color: #444;
    line-height: 1.7;
    white-space: normal;
    overflow: visible;
    min-height: unset;
    border: none;
}

/* ── ADJUNTOS ── */
.difusion-modal-adjuntos {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.difusion-modal-adjuntos img {
    width: 100%;
    border-radius: 10px;
    object-fit: cover;
    cursor: pointer;
}

.difusion-modal-adjuntos video {
    width: 100%;
    border-radius: 10px;
    max-height: 280px;
}

.difusion-adj-pdf {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    background: #fef9f0;
    border: 1px solid #f0d0a0;
    border-radius: 10px;
    text-decoration: none;
    color: #d4830a;
    font-size: 0.875rem;
    font-weight: 500;
    transition: background 0.15s;
}
.difusion-adj-pdf:hover { background: #fef3e0; }

/* ── META ── */
.difusion-modal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 0.78rem;
    color: #aaa;
    padding-top: 8px;
    border-top: 1px solid #f0eee8;
}

/* ── FOOTER ── */
.difusion-modal-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-top: 1px solid #f0eee8;
    position: sticky;
    bottom: 0;
    background: #fff;
}

.difusion-paginador {
    font-size: 0.8rem;
    color: #aaa;
}

.difusion-btn-cerrar {
    background: #1a6bc4;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 9px 22px;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s;
}
.difusion-btn-cerrar:hover { background: #155aa0; }

/* ── RESPONSIVE ── */
@media (max-width: 480px) {
    .difusion-modal-box { max-width: 100%; border-radius: 12px; }
}