/**
 * UNIVGA — Ré-habillage « Bibliothèque » (ULAB) intégrée à l'application.
 * Scopé sur .univga-library-embed (uniquement l'onglet interne de l'espace
 * compte) → la page publique [univga_ulab_shelf] conserve son style natif.
 *
 * Le shortcode pose beaucoup de styles inline ; on les surpasse avec
 * !important, sans toucher au code d'origine de la bibliothèque.
 */

.univga-library-embed {
  --uvglib-indigo: #16234d;
  --uvglib-indigo-2: #243a78;
  --uvglib-gold: #d4a853;
  --uvglib-gold-soft: #f2d79a;
  --uvglib-ink: #16263a;
  --uvglib-muted: #6b7a90;
  --uvglib-bg: #f4f7fb;
  --uvglib-card: #ffffff;
  --uvglib-line: rgba(11, 79, 140, .12);
  width: 100%;
}

/* ═══════════ Conteneur : neutralise le full-bleed (100vw) du site ═══════════ */
.univga-library-embed .ulab-library-container {
  width: 100% !important;
  position: static !important;
  left: auto !important;
  right: auto !important;
  margin: 0 !important;
  padding: 14px 14px calc(28px + env(safe-area-inset-bottom, 0px)) !important;
  background: var(--uvglib-bg) !important;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
  box-sizing: border-box !important;
}

/* ═══════════ Bannière d'accueil (premium indigo/or) ═══════════ */
.univga-library-embed .ulab-welcome-banner {
  background: linear-gradient(140deg, #16234d 0%, #0f1a3c 55%, #0a1230 100%) !important;
  border: 1px solid rgba(212, 168, 83, .35) !important;
  border-radius: 20px !important;
  padding: 18px 16px !important;
  margin: 0 0 16px !important;
  gap: 12px !important;
  box-shadow: 0 14px 34px rgba(10, 18, 48, .28) !important;
}
.univga-library-embed .ulab-welcome-banner > div[style*="3.5em"] {
  font-size: 1.8em !important;
  color: var(--uvglib-gold) !important;
}
.univga-library-embed .ulab-welcome-banner h2 {
  font-size: 1.12rem !important;
  line-height: 1.25 !important;
  margin: 0 0 4px !important;
}
.univga-library-embed .ulab-welcome-banner p {
  font-size: .82rem !important;
  line-height: 1.45 !important;
}
.univga-library-embed .ulab-welcome-banner p br { display: none; }
/* Icônes décoratives latérales masquées sur mobile (gain de place) */
@media (max-width: 720px) {
  .univga-library-embed .ulab-welcome-banner > div[style*="3.5em"] { display: none !important; }
  .univga-library-embed .ulab-welcome-banner { text-align: center; }
}

/* ═══════════ Mise en page : colonne unique, mobile-first ═══════════ */
.univga-library-embed .ulab-library-wrapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  align-items: stretch !important;
}
.univga-library-embed .ulab-main-content { order: 1; min-width: 0 !important; }
.univga-library-embed .ulab-sidebar-left { order: 2; }
.univga-library-embed .ulab-sidebar-right { order: 3; }

.univga-library-embed .ulab-sidebar {
  width: 100% !important;
  flex-shrink: 1 !important;
  background: var(--uvglib-card) !important;
  border: 1px solid var(--uvglib-line) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  box-shadow: 0 8px 22px rgba(11, 79, 140, .07) !important;
  box-sizing: border-box !important;
}
.univga-library-embed .ulab-sidebar h3 {
  font-size: .95rem !important;
  color: var(--uvglib-ink) !important;
  border-bottom: 1px solid var(--uvglib-line) !important;
}

/* ═══════════ En-tête « UNIVGA SMART LIBRARY » ═══════════ */
.univga-library-embed .ulab-header { margin-bottom: 16px !important; }
.univga-library-embed .ulab-header h2 { font-size: 1.25rem !important; flex-wrap: wrap; }
.univga-library-embed .ulab-header > p {
  font-size: .82rem !important;
  color: var(--uvglib-muted) !important;
  margin: 8px 0 14px !important;
}

/* ═══════════ Barre de recherche (pilule premium) ═══════════ */
.univga-library-embed .ulab-search-bar { max-width: 100% !important; gap: 8px !important; }
.univga-library-embed .ulab-search-input {
  padding: 12px 16px !important;
  border: 1px solid var(--uvglib-line) !important;
  border-radius: 14px !important;
  font-size: .92rem !important;
  background: #fff !important;
}
.univga-library-embed .ulab-search-input:focus {
  border-color: var(--uvglib-gold) !important;
  box-shadow: 0 0 0 3px rgba(212, 168, 83, .18) !important;
}
.univga-library-embed .ulab-search-btn {
  padding: 12px 18px !important;
  background: linear-gradient(135deg, var(--uvglib-indigo) 0%, var(--uvglib-indigo-2) 100%) !important;
  border: 0 !important;
  border-radius: 14px !important;
  color: #fff !important;
}

/* ═══════════ Boutons langue + catégories ═══════════ */
.univga-library-embed .ulab-lang-btn.active {
  border-color: var(--uvglib-indigo) !important;
  background: #eef2fb !important;
  color: var(--uvglib-indigo) !important;
}
.univga-library-embed .ulab-category-btn {
  border-radius: 10px !important;
  border: 1px solid var(--uvglib-line) !important;
  background: #f6f8fc !important;
}
.univga-library-embed .ulab-category-btn:hover,
.univga-library-embed .ulab-category-btn.active {
  background: linear-gradient(135deg, var(--uvglib-indigo), var(--uvglib-indigo-2)) !important;
  border-color: var(--uvglib-indigo) !important;
  color: #fff !important;
}

/* ═══════════ Étagère : on allège le bois, look « app » épuré ═══════════ */
.univga-library-embed .ulab-shelf-row {
  padding: 0 12px 0 !important;
  background: linear-gradient(180deg, #ffffff 0%, #eef3fb 100%) !important;
  border-bottom: 6px solid var(--uvglib-gold) !important;
  border-radius: 14px 14px 0 0 !important;
  box-shadow: 0 12px 18px -12px rgba(11, 79, 140, .35) !important;
  gap: 16px 12px !important;
}
.univga-library-embed .ulab-shelf-row::after {
  background: linear-gradient(90deg, var(--uvglib-gold-soft), var(--uvglib-gold)) !important;
  opacity: 1 !important;
  border-radius: 0 0 8px 8px;
  box-shadow: inset 0 2px 4px rgba(192, 143, 58, .4) !important;
}
.univga-library-embed .ulab-shelf-top-board {
  background: #e7eef8 !important;
  border-radius: 8px;
}
.univga-library-embed .ulab-shelf-top-board::after {
  background: linear-gradient(90deg, var(--uvglib-gold-soft), var(--uvglib-gold)) !important;
  opacity: .9 !important;
}

/* Livres : un peu plus compacts pour le mobile */
.univga-library-embed .ulab-book-item { width: 122px !important; height: 188px !important; }
@media (max-width: 380px) {
  .univga-library-embed .ulab-book-item { width: 104px !important; height: 162px !important; }
}

/* ═══════════ Pagination ═══════════ */
.univga-library-embed .ulab-page-btn {
  border-radius: 10px !important;
  border: 1px solid var(--uvglib-line) !important;
}
.univga-library-embed .ulab-page-btn.active {
  background: linear-gradient(135deg, var(--uvglib-indigo), var(--uvglib-indigo-2)) !important;
  border-color: var(--uvglib-indigo) !important;
  color: #fff !important;
}

/* ═══════════ Masquer les 2 images publicitaires (app uniquement) ═══════════ */
.univga-library-embed .ulab-sidebar-right > div:has(a > img[alt="Publicité"]),
.univga-library-embed .ulab-sidebar-right > div:has(> img[alt="Publicité"]) {
  display: none !important;
}
/* Repli si :has() indisponible : on masque au moins l'image */
.univga-library-embed .ulab-sidebar-right img[alt="Publicité"] { display: none !important; }

/* ═══════════ Smart Reader (modal contenu dans l'embed) ═══════════ */
.univga-library-embed .ulab-reader-modal { z-index: 2147483600 !important; }
.univga-library-embed .ulab-reader-content {
  width: 96% !important;
  height: 92% !important;
  border-radius: 16px !important;
}

/* ═══════════ Tablette / desktop : on rétablit 2-3 colonnes ═══════════ */
@media (min-width: 860px) {
  .univga-library-embed .ulab-library-wrapper {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 22px !important;
    align-items: flex-start !important;
  }
  .univga-library-embed .ulab-sidebar-left { order: 1; width: 230px !important; flex-shrink: 0 !important; }
  .univga-library-embed .ulab-main-content { order: 2; flex: 1 !important; }
  .univga-library-embed .ulab-sidebar-right { order: 3; width: 260px !important; flex-shrink: 0 !important; }
  .univga-library-embed .ulab-book-item { width: 150px !important; height: 230px !important; }
}
