/* =========================
   BV UI – “blindado”
   ========================= */
:root{
  --bv-bg: #EFF2F5;
  --bv-surface: #ffffff;
  --bv-primary: #00A2DE;
  --bv-primary-2: #005177;
  --bv-text: #002554;
  --bv-muted: rgba(0,37,84,.72);
  --bv-border: rgba(0,0,0,.12);
  --bv-shadow: 0 10px 25px rgba(0,0,0,.08);
  --bv-radius: 16px;
}

.bv, .bv *{
  box-sizing: border-box !important;
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
}

.bv{
  width: 100% !important;
}

/* ====== Material symbols ====== */
.material-symbols-outlined{
  font-family: "Material Symbols Outlined" !important;  /* <-- CLAVE */
  font-weight: normal !important;
  font-style: normal !important;
  font-size: 18px !important;
  line-height: 1 !important;
  display: inline-block !important;
  white-space: nowrap !important;
  word-wrap: normal !important;
  direction: ltr !important;
  -webkit-font-smoothing: antialiased !important;
  text-rendering: optimizeLegibility !important;
  font-variation-settings: "FILL" 0, "wght" 600, "GRAD" 0, "opsz" 24 !important;
}
/* =========================
   Filtros (pro)
   ========================= */
.bv-filtros{
  display:grid !important;
  grid-template-columns: 1.3fr 1fr 1fr !important;
  gap: 12px !important;
  margin: 0 0 16px !important;
  align-items: end !important;
}

.bv-field{ display:flex !important; flex-direction:column !important; gap:6px !important; min-width:0 !important; }

.bv-label{
  font-weight: 800 !important;
  font-size: 12px !important;
  letter-spacing: .02em !important;
  text-transform: uppercase !important;
  color: var(--bv-text) !important;
  opacity: .9 !important;
}

.bv-filtros input[type="text"],
.bv-filtros select{
  width: 100% !important;
  border: 1px solid var(--bv-border) !important;
  border-radius: 14px !important;
  
  font-size: 15px !important;
  background: rgba(255,255,255,.92) !important;
  outline: none !important;
  transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease !important;
}

.bv-filtros input[type="text"]:focus,
.bv-filtros select:focus{
  border-color: rgba(0,162,222,.55) !important;
  box-shadow: 0 0 0 4px rgba(0,162,222,.14) !important;
}

/* Tooltip rating */
.bv-field-rating{ position: relative !important; }
.bv-label-row{ display:flex !important; align-items:center !important; justify-content:space-between !important; gap:.5rem !important; }
.bv-help{
  all: unset !important;
  width: 30px !important;
  height: 30px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius: 999px !important;
  border: 1px solid var(--bv-border) !important;
  cursor:pointer !important;
  background: rgba(255,255,255,.75) !important;
}
.bv-help:focus{ box-shadow: 0 0 0 4px rgba(0,162,222,.14) !important; }

.bv-tooltip{
  position:absolute !important;
  left:0 !important;
  top: calc(100% + 10px) !important;
  z-index: 50 !important;
  width: min(560px, 92vw) !important;
  background:#111 !important;
  color:#fff !important;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  box-shadow: 0 14px 40px rgba(0,0,0,.35) !important;
  opacity:0 !important;
  transform: translateY(-6px) !important;
  pointer-events:none !important;
  transition: opacity .16s ease, transform .16s ease !important;
}
.bv-field-rating.open .bv-tooltip{
  opacity:1 !important;
  transform: translateY(0) !important;
  pointer-events:auto !important;
}

/* =========================
   Grid responsive (pro)
   ========================= */
.bv-grid{
  display:grid !important;
  gap: 16px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  margin: 0 auto !important;
  max-width: 1200px !important;
}

/* =========================
   Cards (portadas iguales + botón siempre visible)
   ========================= */
.bv-card{
  background: var(--bv-bg) !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  border-radius: var(--bv-radius) !important;
  box-shadow: var(--bv-shadow) !important;
  overflow: hidden !important;
  display:flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
  transform: translateZ(0) !important;
  transition: transform .14s ease, box-shadow .14s ease !important;
}

@media (hover:hover){
  .bv-card:hover{
    transform: translateY(-2px) !important;
    box-shadow: 0 18px 42px rgba(0,0,0,.10) !important;
  }
}

.bv-card__media{
  padding: 14px 14px 0 !important;
  display:flex !important;
  justify-content:center !important;
  position: relative !important;
}

/* Portadas MISMO tamaño: ratio fijo */
.bv-card__media img{
  width: 100% !important;
  max-width: 230px !important;
  aspect-ratio: 2 / 3 !important;     /* <-- clave */
  object-fit: cover !important;        /* <-- recorta bonito */
  border-radius: 14px !important;
  display:block !important;
  background: rgba(255,255,255,.9) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.10) !important;
}

.bv-card__badge{
  position: absolute !important;
  left: 16px !important;
  top: 16px !important;
  display:inline-flex !important;
  align-items:center !important;
  gap: 6px !important;
  padding: 8px 10px !important;
  border-radius: 999px !important;
  background: rgba(0,0,0,.55) !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  backdrop-filter: blur(6px) !important;
}

.bv-card__content{
  padding: 12px 14px 14px !important;
  display:flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  min-height: 0 !important;
}

.bv-card__title{
  margin: 10px 0 8px !important;
  color: var(--bv-text) !important;
  font-weight: 900 !important;
  font-size: 16px !important;
  line-height: 1.18 !important;

  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow:hidden !important;
}

.bv-card__author{
  margin: 0 !important;
  color: var(--bv-muted) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  display:flex !important;
  align-items:center !important;
  gap: 6px !important;

  display: -webkit-box !important;
  -webkit-line-clamp: 1 !important;
  -webkit-box-orient: vertical !important;
  overflow:hidden !important;
}

.bv-card__footer{
  margin-top: auto !important; /* botón siempre abajo */
  padding-top: 12px !important;
}

/* Botón */
.bv-btn{
  width: 100% !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 8px !important;
  background: var(--bv-primary) !important;
  color:#fff !important;
  border:0 !important;
  border-radius: 999px !important;
  padding: 12px 16px !important;
  font-weight: 900 !important;
  cursor:pointer !important;
  font-size: 13px !important;
  transition: filter .14s ease, transform .14s ease !important;
}

.bv-btn:hover{ filter: brightness(.95) !important; }
.bv-btn:active{ transform: translateY(1px) !important; }
.bv-btn:focus{ box-shadow: 0 0 0 4px rgba(0,162,222,.18) !important; outline:none !important; }

/* =========================
   Paginación pro
   ========================= */
.bv-paginacion-wrap{ text-align:center !important; margin: 18px 0 10px !important; }
.bv-paginacion{ display:inline-flex !important; gap: 8px !important; align-items:center !important; flex-wrap: wrap !important; justify-content:center !important; }

.bv-pagina-leidos,.bv-pagina-library,.bv-ml-pagina{
  background: rgba(0,0,0,.10) !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  font-weight: 900 !important;
  cursor:pointer !important;
  color: var(--bv-text) !important;
}
.bv-pagina-leidos.active,.bv-pagina-library.active,.bv-ml-pagina.active{
  background: var(--bv-text) !important;
  color:#fff !important;
  border-color: rgba(0,0,0,.0) !important;
}
.bv-ellipsis{ opacity:.7 !important; }

/* =========================
   Más leídos (pro)
   ========================= */
.bv-ml-row{
  display:grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

.bv-ml-card{
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: var(--bv-radius) !important;
  padding: 14px !important;
  background: rgba(255,255,255,.0) !important;
  box-shadow: var(--bv-shadow) !important;
  display:grid !important;
  grid-template-columns: 210px 1fr !important;
  gap: 14px !important;
  align-items: center !important;
}

.bv-ml-card__media img{
  width: 100% !important;
  aspect-ratio: 2/3 !important;
  object-fit: cover !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.10) !important;
  background: #fff !important;
}

.bv-ml-title{
  margin: 8px 0 8px !important;
  color: var(--bv-text) !important;
  font-weight: 900 !important;
  font-size: 18px !important;
  line-height: 1.18 !important;

  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow:hidden !important;
}
.bv-ml-categoria,.bv-ml-autor,.bv-ml-detalles{
  margin: 0 0 6px !important;
  color: var(--bv-muted) !important;
  font-weight: 650 !important;
}

/* =========================
   Modal (móvil sin cortes + scroll real)
   ========================= */
.bv-modal{ position: fixed !important; inset: 0 !important; z-index: 99999 !important; display:none !important; }
.bv-modal.is-open{ display:block !important; }

.bv-modal__backdrop{ position:absolute !important; inset:0 !important; background: rgba(0,0,0,.86) !important; }

.bv-modal__dialog{
  position: relative !important;
  width: min(980px, 94vw) !important;
  max-height: 92vh !important;
  margin: 4vh auto !important;
  background: #0b0b0b !important;
  color: #fff !important;
  border-radius: 18px !important;
  overflow: auto !important;
  box-shadow: 0 22px 60px rgba(0,0,0,.55) !important;
}

.bv-modal__close {
    position: absolute !important;
    right: 12px !important;
    top: 12px !important;
    width: 32px !important;
    height
: 32px !important;
    padding: 10px;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, .28) !important;
    background: rgba(255, 255, 255, .06) !important;
    color: #fff !important;
    font-size: 24px !important;
    display: flex;
    cursor: pointer !important;
    align-items: center;
    justify-content: center;
}

.bv-modal__body{
  display:grid !important;
  grid-template-columns: 360px 1fr !important;
  max-height: 92vh !important;
}

/* Área imagen */
.bv-modal__media{
  padding: 18px !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  border-right: 1px solid rgba(255,255,255,.08) !important;
}
.bv-modal__img{
  width: 100% !important;
  max-width: 320px !important;
  aspect-ratio: 2/3 !important;
  object-fit: cover !important;
  border-radius: 14px !important;
  background: #fff !important;
}

/* IMPORTANTE: scroll aquí (no se corta en móvil) */
.bv-modal__content{
  padding: 20px !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

.bv-modal__categoria{
  margin: 0 0 6px !important;
  color: rgba(255,255,255,.75) !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-transform: uppercase !important;
  font-size: 12px !important;
}
.bv-modal__titulo{
  margin: 0 0 10px !important;
  font-size: 30px !important;
  line-height: 1.12 !important;
  font-weight: 900 !important;
}
.bv-modal__autor{
  margin: 0 0 10px !important;
  color: rgba(255,255,255,.86) !important;
  font-weight: 650 !important;
}
.bv-modal__detalles{
  margin: 0 0 14px !important;
  color: rgba(255,255,255,.72) !important;
  font-weight: 600 !important;
}
.bv-modal__sinopsis{
  margin: 0 0 16px !important;
  color: rgba(255,255,255,.90) !important;
  line-height: 1.55 !important;
}

.bv-modal__btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 8px !important;
  width: min(360px, 100%) !important;
  background: var(--bv-primary) !important;
  color:#fff !important;
  text-decoration:none !important;
  padding: 12px 16px !important;
  border-radius: 999px !important;
  font-weight: 900 !important;
}

/* =========================
   Responsive breakpoints
   ========================= */
@media (max-width: 1024px){
  .bv-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}
@media (max-width: 820px){
  .bv-filtros{ grid-template-columns: 1fr !important; }
  .bv-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .bv-ml-row{ grid-template-columns: 1fr !important; }
  .bv-ml-card{ grid-template-columns: 160px 1fr !important; }
  .bv-modal__body{ grid-template-columns: 1fr !important; }
  .bv-modal__media{ border-right: 0 !important; border-bottom: 1px solid rgba(255,255,255,.08) !important; }
}
@media (max-width: 480px){
  .bv-grid{ grid-template-columns: 1fr !important; }
  .bv-ml-card{ grid-template-columns: 1fr !important; }
}

