/* Biblioteca */
.library-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.875rem; }
@media (min-width: 480px) { .library-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); } }

.library-card { background: var(--surface); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); overflow: hidden; cursor: pointer; transition: var(--transition); }
.library-card:hover { border-color: var(--border); transform: translateY(-2px); }
.library-cover-icon { width: 100%; height: 100px; background: var(--gold-muted); display: flex; align-items: center; justify-content: center; color: var(--gold); }
.library-cover-icon .icon-svg { width: 36px; height: 36px; }
.library-body { padding: 0.875rem; }
.library-type { font-size: 0.7rem; text-transform: uppercase; color: var(--gold); font-weight: 700; letter-spacing: 0.5px; margin-bottom: 0.25rem; }
.library-title { font-size: 0.875rem; font-weight: 700; line-height: 1.3; }
.library-desc { font-size: 0.775rem; color: var(--text-muted); margin-top: 0.25rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Bloqueio por pontos / premium ──────────────────────────────── */
.library-card.lib-locked { border-style: dashed; cursor: default; }
.library-card.lib-locked:hover { transform: none; border-color: var(--border-subtle); }

.lib-lock-badge {
  position: absolute; top: 0.5rem; right: 0.5rem;
  font-size: 0.68rem; font-weight: 700;
  padding: 0.2rem 0.5rem; border-radius: 99px;
  display: flex; align-items: center; gap: 0.25rem;
}
.lib-lock-badge.points-lock { background: var(--gold-muted); color: var(--gold); }
.lib-lock-badge.premium-lock { background: color-mix(in srgb, #ce93d8 20%, var(--surface)); color: #ce93d8; }
.lib-lock-badge .icon-svg { width: 10px; height: 10px; }

.lib-lock-info { font-size: 0.75rem; color: var(--text-muted); margin-top: 0.375rem; font-style: italic; }
