/* ==================================================
   CDM BIBLIOTECA v2.3 — CSS con !important donde necesario
   para sobrevivir a Elementor y caché de WordPress
   ================================================== */

#cdm-bib-seccion {
    width: 100% !important;
    font-family: "DM Sans", sans-serif !important;
    padding: 0 32px !important;
    box-sizing: border-box !important;
}

/* ── INTRO ── */
.cdm-bib-intro { margin-bottom: 40px !important; }

.cdm-bib-tag {
    font-size: .7rem !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    color: #5a7a68 !important;
    font-weight: 500 !important;
    margin: 0 0 10px !important;
    display: block !important;
}
.cdm-bib-titulo {
    font-family: "Cormorant Garamond", Georgia, serif !important;
    font-size: clamp(1.7rem, 3vw, 2.4rem) !important;
    font-weight: 500 !important;
    color: #1a1a1a !important;
    line-height: 1.2 !important;
    margin: 0 0 14px !important;
    letter-spacing: -.01em !important;
}
.cdm-bib-subtitulo {
    font-size: .97rem !important;
    color: #4a4a4a !important;
    max-width: 680px !important;
    line-height: 1.8 !important;
    margin: 0 0 20px !important;
}
.cdm-bib-disclaimer {
    background: #faf8f4 !important;
    border: 1px solid #ddd8ce !important;
    border-left: 3px solid #5a7a68 !important;
    border-radius: 0 6px 6px 0 !important;
    padding: 14px 18px !important;
    font-size: .78rem !important;
    color: #4a4a4a !important;
    line-height: 1.7 !important;
    max-width: 760px !important;
}
.cdm-bib-disclaimer a { color: #3d5a4a !important; text-decoration: underline !important; }

/* ── GRILLA 5 COLUMNAS ── */
.cdm-bib-grilla {
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 20px !important;
    align-items: start !important;
    margin-top: 32px !important;
}

/* ── CARD ── */
.cdm-libro-card {
    display: flex !important;
    flex-direction: column !important;
    background: #fff !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    box-shadow: 0 2px 10px rgba(0,0,0,.08) !important;
    transition: transform .28s ease, box-shadow .28s ease !important;
}
.cdm-libro-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.13) !important;
}

/* ── PORTADA BOTÓN ── */
.cdm-libro-portada-wrap {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    padding-bottom: 148% !important;
    overflow: hidden !important;
    background: linear-gradient(140deg, #3d5a4a 0%, #2c4a3a 100%) !important;
    border: none !important;
    cursor: pointer !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    outline: none !important;
}
.cdm-libro-portada {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform .35s ease !important;
}
.cdm-libro-card:hover .cdm-libro-portada { transform: scale(1.05) !important; }

.cdm-portada-placeholder {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
    text-align: center !important;
    gap: 12px !important;
    color: rgba(255,255,255,.75) !important;
    font-size: .82rem !important;
    line-height: 1.4 !important;
}

/* ── HOVER OVERLAY ── */
.cdm-libro-hover {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(26,26,26,.58) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transition: opacity .25s !important;
    /* FIX mobile: pointer-events:none para que el touch llegue al botón */
    pointer-events: none !important;
}
.cdm-libro-card:hover .cdm-libro-hover { opacity: 1 !important; }

.cdm-leer-btn {
    background: #fff !important;
    color: #2c4a3a !important;
    font-size: .82rem !important;
    font-weight: 700 !important;
    padding: 10px 20px !important;
    border-radius: 30px !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.18) !important;
    letter-spacing: .02em !important;
    pointer-events: none !important;
    display: inline-block !important;
}
.cdm-libro-card:hover .cdm-leer-btn {
    background: #3d5a4a !important;
    color: #fff !important;
}

/* ── META ── */
.cdm-libro-meta { padding: 13px 14px 16px !important; }
.cdm-libro-meta h3 {
    font-family: "Cormorant Garamond", Georgia, serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    margin: 0 0 3px !important;
    line-height: 1.3 !important;
}
.cdm-libro-autor {
    font-size: .75rem !important;
    color: #3d5a4a !important;
    font-weight: 500 !important;
    margin: 0 0 5px !important;
}
.cdm-libro-desc {
    font-size: .75rem !important;
    color: #7f8c8d !important;
    margin: 0 !important;
    line-height: 1.5 !important;
}

/* ══════════════════════════════
   MODAL
   FIX: el selector era .cdm-modal-overlay pero el elemento
   en el HTML del shortcode es #cdm-bib-modal. Se unificaron.
══════════════════════════════ */
@keyframes cdmFadeIn  { from{opacity:0}                          to{opacity:1} }
@keyframes cdmSlideUp { from{transform:translateY(32px);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes cdmSpin    { to{transform:rotate(360deg)} }

/* ── Overlay — estado oculto por defecto ── */
#cdm-bib-modal {
    display: none !important;          /* JS lo cambia a flex al abrir */
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(10,10,10,.85) !important;
    z-index: 2147483647 !important;    /* máximo posible */
    align-items: center !important;
    justify-content: center !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    box-sizing: border-box !important;
    /* FIX iOS Safari: evita bugs de scroll con position:fixed */
    -webkit-overflow-scrolling: auto !important;
}

/* ── Overlay — estado visible (JS agrega display:flex inline) ──
   Usamos [style*="flex"] para no depender de una clase extra.  */
#cdm-bib-modal[style*="flex"] {
    display: flex !important;
    animation: cdmFadeIn .2s ease !important;
}

/* ── Caja del modal ── */
.cdm-modal-caja {
    background: #16213e !important;
    border-radius: 14px !important;
    width: min(94vw, 1080px) !important;
    height: min(92vh, 860px) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    box-shadow: 0 30px 70px rgba(0,0,0,.6) !important;
    animation: cdmSlideUp .28s cubic-bezier(.25,.8,.25,1) !important;
    /* Asegura que la caja nunca herede overflow del shortcode wrapper */
    position: relative !important;
    z-index: 1 !important;
    /* FIX iOS Safari: fuerza compositing para evitar bugs con position:fixed + backdrop-filter */
    -webkit-transform: translateZ(0) !important;
    transform: translateZ(0) !important;
}

/* HEADER */
.cdm-modal-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 13px 20px !important;
    background: #0f172a !important;
    border-bottom: 1px solid rgba(255,255,255,.1) !important;
    flex-shrink: 0 !important;
    gap: 12px !important;
}
.cdm-modal-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
    flex: 1 !important;
    overflow: hidden !important;
}
#cdm-modal-titulo {
    font-size: .95rem !important;
    font-weight: 600 !important;
    color: #f1f5f9 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-family: "Cormorant Garamond", Georgia, serif !important;
    display: block !important;
}
#cdm-modal-autor {
    font-size: .75rem !important;
    color: #7c9aaf !important;
    display: block !important;
}

/* ── BOTONES MODAL ── */
.cdm-modal-btns {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}
.cdm-modal-btns button {
    background: rgba(255,255,255,0.18) !important;
    border: 2px solid rgba(255,255,255,0.5) !important;
    color: #ffffff !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 8px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: background .18s, border-color .18s !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
}
.cdm-modal-btns button:hover {
    background: rgba(255,255,255,0.32) !important;
    border-color: rgba(255,255,255,0.8) !important;
}
.cdm-modal-btns button svg,
.cdm-modal-btns button svg line,
.cdm-modal-btns button svg path,
.cdm-modal-btns button svg polyline,
.cdm-modal-btns button svg rect {
    stroke: #ffffff !important;
    color: #ffffff !important;
}

/* CUERPO */
.cdm-modal-cuerpo {
    flex: 1 !important;
    position: relative !important;
    overflow: hidden !important;
    background: #1e293b !important;
}

/* ── FIX TOOLBAR de Drive ──
   Desplaza el iframe 56px hacia arriba para ocultar
   el botón "Abrir en nueva ventana" de Google Drive.  */
#cdm-bib-iframe {
    position: absolute !important;
    top: -56px !important;
    left: 0 !important;
    width: 100% !important;
    height: calc(100% + 56px) !important;
    border: none !important;
    display: block !important;
}
/* En pantalla completa también ocultamos el toolbar */
#cdm-bib-iframe:-webkit-full-screen { top: -56px !important; height: calc(100% + 56px) !important; }
#cdm-bib-iframe:-moz-full-screen    { top: -56px !important; height: calc(100% + 56px) !important; }
#cdm-bib-iframe:fullscreen          { top: -56px !important; height: calc(100% + 56px) !important; }

/* LOADING SPINNER */
#cdm-bib-loading {
    position: absolute !important;
    inset: 0 !important;
    background: #1e293b !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    color: #94a3b8 !important;
    gap: 14px !important;
    z-index: 5 !important;
    font-size: .88rem !important;
    font-family: sans-serif !important;
}
.cdm-spinner {
    width: 44px !important;
    height: 44px !important;
    border: 3px solid rgba(255,255,255,.1) !important;
    border-top-color: #3d5a4a !important;
    border-radius: 50% !important;
    animation: cdmSpin .75s linear infinite !important;
}

/* FOOTER */
.cdm-modal-footer {
    padding: 9px 20px !important;
    background: #0f172a !important;
    border-top: 1px solid rgba(255,255,255,.07) !important;
    font-size: .7rem !important;
    color: rgba(255,255,255,.4) !important;
    text-align: center !important;
    flex-shrink: 0 !important;
}

/* ══════════════════════════════
   RESPONSIVE
══════════════════════════════ */
@media (max-width: 1280px) {
    .cdm-bib-grilla { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 960px) {
    .cdm-bib-grilla { grid-template-columns: repeat(3, 1fr) !important; }
    #cdm-bib-seccion { padding: 0 20px !important; }
}
@media (max-width: 600px) {
    .cdm-bib-grilla { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
    #cdm-bib-seccion { padding: 0 20px !important; }
    .cdm-modal-caja { width: 100% !important; height: 100% !important; border-radius: 0 !important; }
    #cdm-modal-titulo { font-size: .85rem !important; }
    .cdm-bib-titulo { font-size: 1.5rem !important; }
}
@media (max-width: 400px) {
    .cdm-bib-grilla { gap: 10px !important; }
    #cdm-bib-seccion { padding: 0 16px !important; }
}
