/* =============================================================================
 * Catálogo de Biblias — SOBICAIN
 * =============================================================================
 *
 * Estilos del shortcode [sobicain_catalogo_biblias] y [sobicain_biblias].
 * También cubren el single y las páginas de taxonomía (se añaden luego).
 *
 * Heredamos la tipografía y colores del padre (Hello Elementor + custom).
 * Solo añadimos lo específico del catálogo.
 * ========================================================================= */

:root {
	--sobi-accent:       #8a1a1a;   /* guinda SOBICAIN, se usa en títulos y acentos */
	--sobi-accent-soft:  #f4e9e9;
	--sobi-ink:          #1f1c1a;
	--sobi-muted:        #6b6461;
	--sobi-rule:         #e6e1dc;
	--sobi-bg:           #ffffff;
	--sobi-bg-soft:      #faf7f3;

	--sobi-radius:       .5rem;

	/* Gap entre cards: doble de lo anterior. */
	--sobi-gap:          clamp(2rem, 4vw, 3rem);
}

/* =============================================================================
 * Contenedor del catálogo
 * ========================================================================= */

.sobicain-catalogo {
	margin: 2rem 0;
	color: var(--sobi-ink);
}

.sobicain-empty {
	padding: 2rem 0;
	color: var(--sobi-muted);
	text-align: center;
	font-style: italic;
}

/* =============================================================================
 * Barra de filtros sticky (con <select>)
 * ========================================================================= */

.sobicain-filtros {
	position: sticky;
	top: 0;
	z-index: 30;
	margin: 0 0 2.5rem;
	padding: .75rem 0;
	background: rgba(255, 255, 255, .92);
	backdrop-filter: saturate(180%) blur(8px);
	-webkit-backdrop-filter: saturate(180%) blur(8px);
	border-bottom: 1px solid var(--sobi-rule);
}

/* Fallback para navegadores sin backdrop-filter. */
@supports not ((-webkit-backdrop-filter: blur(8px)) or (backdrop-filter: blur(8px))) {
	.sobicain-filtros { background: var(--sobi-bg); }
}

.sobicain-filtros__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem 1.5rem;
	padding: 0 1rem;
}

.sobicain-filtros__campo {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
}

.sobicain-filtros__titulo {
	font-size: .8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--sobi-muted);
	white-space: nowrap;
}

.sobicain-select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	font-family: inherit;
	font-size: .9rem;
	color: var(--sobi-ink);
	background-color: var(--sobi-bg);
	/* Flechita SVG inline como fondo (gris tenue) */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6' fill='%236b6461'%3E%3Cpath d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right .75rem center;
	background-size: .625rem auto;
	border: 1px solid var(--sobi-rule);
	border-radius: .375rem;
	padding: .4rem 2rem .4rem .75rem;
	cursor: pointer;
	min-width: 9rem;
	transition: border-color .15s ease, color .15s ease;
}

.sobicain-select:hover,
.sobicain-select:focus {
	border-color: var(--sobi-accent);
	color: var(--sobi-accent);
	outline: none;
}

/* =============================================================================
 * Bloques de grupo (cabecera + cards)
 * ========================================================================= */

.sobicain-grupo {
	margin: 0 0 7rem;
	scroll-margin-top: 8rem; /* evita que quede oculto tras la barra sticky al saltar por anchor */
}

.sobicain-grupo[hidden] { display: none; }

.sobicain-grupo__header {
	display: grid;
	grid-template-columns: minmax(160px, 220px) 1fr;
	align-items: center;
	gap: clamp(1rem, 3vw, 2.5rem);
	padding: 1.5rem 0;
	border-bottom: 1px solid var(--sobi-rule);
	margin-bottom: 2.5rem;
}

@media (max-width: 640px) {
	.sobicain-grupo__header {
		grid-template-columns: 1fr;
		gap: 1rem;
		text-align: left;
	}
	.sobicain-grupo__media {
		max-width: 200px;
	}
}

/* Imagen del grupo: sin círculo, rectangular, respeta proporción natural. */
.sobicain-grupo__media img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}

.sobicain-grupo__titulo {
	margin: 0 0 .5rem;
	font-size: clamp(1.5rem, 5vw, 3rem);
	line-height: 1.15;
	color: var(--sobi-accent);
	font-weight: 400;
	letter-spacing: -.01em;
}

.sobicain-grupo__titulo a {
	color: inherit;
	text-decoration: none;
}
.sobicain-grupo__titulo a:hover { text-decoration: underline; }

.sobicain-grupo__desc {
	color: var(--sobi-ink);
	font-size: 1rem;
	line-height: 1.6;
}
.sobicain-grupo__desc > :last-child { margin-bottom: 0; }
.sobicain-grupo__desc > :first-child { margin-top: 0; }

/* =============================================================================
 * Rejilla de tarjetas (gap doble, limpio)
 * ========================================================================= */

.sobicain-cards {
	display: grid;
	gap: var(--sobi-gap);
	grid-template-columns: repeat(var(--sobi-cols, 4), minmax(0, 1fr));
}

.sobicain-cards--cols-2 { --sobi-cols: 2; }
.sobicain-cards--cols-3 { --sobi-cols: 3; }
.sobicain-cards--cols-4 { --sobi-cols: 4; }
.sobicain-cards--cols-5 { --sobi-cols: 5; }

@media (max-width: 1024px) {
	.sobicain-cards--cols-4,
	.sobicain-cards--cols-5 { --sobi-cols: 3; }
}
@media (max-width: 720px) {
	.sobicain-cards {
		--sobi-cols: 2;
		gap: 1.5rem;
	}
}

/* =============================================================================
 * Tarjeta de biblia — estilo limpio, sin fondo ni bordes
 * ========================================================================= */

.sobicain-card {
	display: flex;
	flex-direction: column;
	background: transparent;
	border: 0;
	border-radius: 0;
}

.sobicain-card[hidden] { display: none !important; }

.sobicain-card__media {
	display: block;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	margin-bottom: 1.5rem;
}

.sobicain-card__media img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left center;
}

.sobicain-card__no-image {
	display: block;
	width: 100%;
	height: 100%;
	background:
		repeating-linear-gradient(135deg, transparent 0 10px, rgba(0,0,0,.025) 10px 11px),
		var(--sobi-bg-soft);
}

.sobicain-card__body {
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: .4rem;
	flex: 1;
}

.sobicain-card__title {
	margin: 0;
	font-size: 1.0625rem;
	line-height: 1.25;
	font-weight: 600;
	color: var(--sobi-ink);
}

.sobicain-card__subtitle {
	margin: 0;
	color: var(--sobi-muted);
	font-size: .875rem;
	font-style: italic;
}

.sobicain-card__meta {
	margin: .25rem 0 0;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: .1rem .75rem;
	font-size: .8125rem;
	line-height: 1.4;
}

.sobicain-card__meta > div {
	display: contents;
}

.sobicain-card__meta dt {
	color: var(--sobi-muted);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .04em;
	font-size: .6875rem;
	padding-top: .15em;
}

.sobicain-card__meta dd {
	margin: 0;
	color: var(--sobi-ink);
}

.sobicain-card__aviso {
	margin: .2rem 0 0;
	color: #799558;
	font-size: .875rem;
	font-weight: 600;
	letter-spacing: .02em;
}

/* =============================================================================
 * Accesibilidad: reducir movimiento si el usuario lo prefiere
 * ========================================================================= */

@media (prefers-reduced-motion: reduce) {
	.sobicain-select {
		transition: none;
	}
}
