/* ==========================================================================
   BLOG LIST - Intro section, featured post, card grid
   ========================================================================== */


/* ==========================================================================
   BLOG INTRO SECTION
   Fondo suave compartido por breadcrumb + intro-text + post destacado
   ========================================================================== */

.blog-intro-section {
	background-color: rgba(230, 225, 219, 0.16);
	padding-bottom: var(--space-between-sections-small);
}

/* Reducimos el padding excesivo del bloque intro-text dentro del blog */
.blog-intro-section #sedRhoncusSec {
	padding-top: 48px;
	padding-bottom: 48px;
}


/* ==========================================================================
   POST DESTACADO
   Layout: imagen izquierda (~55%) + texto derecha (~45%), ambos sobre el mismo fondo
   ========================================================================== */

.blog-featured-post {
	padding: 0;
}

.blog-featured-post .row {
	display: flex;
	align-items: flex-end;
}

/* Columna imagen */
.blog-featured-post__image-col {
	flex: 0 0 50%;
	max-width: 50%;
	height: 510px;
	overflow: hidden;
}

.blog-featured-post__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s ease;
}

.blog-featured-post:hover .blog-featured-post__img {
	transform: scale(1.03);
}

/* Columna contenido */
.blog-featured-post__content-col {
	flex: 1 0 0;
	min-width: 0;
	max-width: 40%;
	padding: 0 0 48px 64px;
}

.blog-featured-post__content {
	display: flex;
	flex-direction: column;
	gap: 32px;
	align-items: flex-start;
}

/* Meta: fecha */
.blog-featured-post__meta {
	margin: 0;
}

.blog-featured-post__date {
	font-family: "Urbanist", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-base-blue);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	line-height: 20px;
}

/* Título
   El contenido usa gap: 32px entre hijos; reducimos el gap previo al título
   (date→title) a 8px compensando con margin-top negativo. */
.blog-featured-post__title {
	font-family: "ArgestaHeadline", serif;
	font-size: 3.125rem;
	line-height: 3.75rem;
	font-weight: 400;
	color: var(--color-base-blue);
	margin: -24px 0 0;
}

/* Descripción */
.blog-featured-post__description {
	font-family: "Urbanist", sans-serif;
	font-size: 1rem;
	line-height: 1.75rem;
	color: var(--color-text);
	margin: 0;
}

/* CTA: usa la clase global bubbleButtonLink, sin override necesario */


/* ==========================================================================
   BLOG CARD GRID - Sección principal del listado
   ========================================================================== */

#blogCardGridSec {
	padding: 80px 0 var(--space-between-sections-small);
}

#blogCardGridSec .row {
	margin: 0;
}

/* Cabecera de sección */
.blog-card-grid__header {
	margin-bottom: 48px;
	text-align: center;
}

.blog-card-grid__heading {
	font-family: "ArgestaHeadline", serif;
	font-size: 2.25rem;
	line-height: 2.875rem;
	font-weight: 400;
	color: var(--color-base-blue);
	margin: 0;
}


/* --------------------------------------------------------------------------
   Barra de filtros
   -------------------------------------------------------------------------- */

.blog-card-grid__actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 24px;
}

.blog-card-grid__filter-group,
.blog-card-grid__search-group {
	display: flex;
	align-items: center;
	gap: 8px;
}

.blog-card-grid__filter-label {
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--color-base-blue);
	letter-spacing: 1px;
	white-space: nowrap;
}

/* Dropdown categorías - pill shape */
.blog-card-grid__filter-dropdown {
	position: relative;
}

.blog-card-grid__filter-btn {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 42px 10px 24px;
	background-color: transparent;
	border: 1px solid var(--color-base-blue);
	border-radius: 32px;
	color: var(--color-base-blue);
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 1px;
	cursor: pointer;
	white-space: nowrap;
	position: relative;
	transition: background-color 0.25s, color 0.25s;
}

.blog-card-grid__filter-btn:hover,
.blog-card-grid__filter-btn:focus {
	background-color: var(--color-base-blue);
	color: #fff;
}

.blog-card-grid__filter-btn:hover .blog-card-grid__filter-arrow,
.blog-card-grid__filter-btn:focus .blog-card-grid__filter-arrow {
	filter: brightness(0) invert(1);
}

.blog-card-grid__filter-arrow {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	display: inline-block;
	width: 12px;
	height: 8px;
	background-image: url('../../../images/icons/blog-chevron-down.svg');
	background-repeat: no-repeat;
	background-size: contain;
	transition: transform 0.25s, filter 0.25s;
}

.blog-card-grid__filter-dropdown.is-open .blog-card-grid__filter-arrow {
	transform: translateY(-50%) rotate(180deg);
}

.blog-card-grid__filter-list {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	min-width: 100%;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: 8px;
	list-style: none;
	margin: 0;
	padding: 8px 0;
	z-index: 100;
	display: none;
	box-shadow: 0 4px 16px rgba(0, 48, 92, 0.1);
}

.blog-card-grid__filter-dropdown.is-open .blog-card-grid__filter-list {
	display: block;
}

.blog-card-grid__category-option {
	display: block;
	width: 100%;
	padding: 8px 20px;
	background: none;
	border: none;
	text-align: left;
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--title-black-color);
	cursor: pointer;
	white-space: nowrap;
	transition: background-color 0.2s;
}

.blog-card-grid__category-option:hover,
.blog-card-grid__category-option.is-active {
	background-color: rgba(230, 225, 219, 0.48);
	color: var(--color-base-blue);
	font-weight: 600;
}

/* Búsqueda - pill shape */
.blog-card-grid__search-wrapper {
	position: relative;
	display: flex;
}

.blog-card-grid__search-input {
	padding: 8px 13px;
	border: 1px solid var(--color-base-blue);
	border-radius: 32px;
	background: transparent;
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-base-blue);
	letter-spacing: 1px;
	outline: none;
	width: 172px;
	transition: border-color 0.25s;
}

.blog-card-grid__search-input::placeholder {
	color: transparent;
}

.blog-card-grid__search-input::-webkit-search-cancel-button {
	display: none;
}

.blog-card-grid__search-clear {
	position: absolute;
	right: 32px;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	height: 20px;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--color-base-blue);
	display: none;
	align-items: center;
	justify-content: center;
	padding: 0;
}

.blog-card-grid__search-wrapper.has-value .blog-card-grid__search-clear {
	display: flex;
}

.blog-card-grid__search-btn {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	height: 32px;
	width: 32px;
	background: none;
	border: none;
	border-radius: 32px;
	cursor: default;
	pointer-events: none;
	color: var(--color-base-blue);
	display: flex;
	align-items: center;
	justify-content: center;
}

.blog-card-grid__search-btn svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	display: block;
}

/* Separador */
.blog-card-grid__divider {
	height: 1px;
	background-color: rgba(0, 48, 92, 0.16);
	border-radius: 4px;
	margin-bottom: 48px;
}


/* --------------------------------------------------------------------------
   Grid de cards
   -------------------------------------------------------------------------- */

.blog-card-grid__cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 80px 32px;
}

/* Estado hidden para load-more y filtros */
.blog-card[data-blog-card-hidden] {
	display: none;
}


/* --------------------------------------------------------------------------
   Card individual
   -------------------------------------------------------------------------- */

.blog-card {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

/* Enlace imagen */
.blog-card__image-link {
	display: block;
	text-decoration: none;
	overflow: hidden;
}

.blog-card__image-wrapper {
	position: relative;
	overflow: hidden;
	height: 416px;
}

.blog-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.55s ease;
}

.blog-card:hover .blog-card__image {
	transform: scale(1.04);
}

/* Wrapper categorías - fila, top-right */
.blog-card__categories {
	position: absolute;
	top: 32px;
	right: 32px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 6px;
	max-width: calc(100% - 64px);
}

/* Badge individual de categoría - pill */
.blog-card__category {
	background-color: rgba(0, 48, 92, 0.4);
	color: #fff;
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0.5px;
	padding: 4px 16px;
	border-radius: 32px;
	line-height: 24px;
	white-space: nowrap;
}

/* Contenido de la card */
.blog-card__content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding: 0 32px;
}

.blog-card__header {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.blog-card__date {
	font-family: "Urbanist", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-base-blue);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	line-height: 20px;
}

.blog-card__title {
	font-family: "ArgestaHeadline", serif;
	font-size: 1.625rem;
	line-height: 2.25rem;
	font-weight: 400;
	color: var(--color-base-blue);
	margin: 0;
}

.blog-card__description {
	font-family: "Urbanist", sans-serif;
	font-size: 1rem;
	line-height: 1.75rem;
	color: var(--color-text);
	margin: 0;
}

/* CTA: alineado al fondo del flex container para igualar altura entre cards */
.blog-card__cta {
	margin-top: auto;
}


/* --------------------------------------------------------------------------
   Cargar más - pill shape
   -------------------------------------------------------------------------- */

.blog-card-grid__load-more {
	display: flex;
	justify-content: center;
	padding-top: 80px;
}

.blog-card-grid__load-more-btn {
	padding: 8px 24px;
	background-color: transparent;
	border: 1px solid var(--color-base-blue);
	border-radius: 32px;
	color: var(--color-base-blue);
	font-family: "Urbanist", sans-serif;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.5px;
	cursor: pointer;
	line-height: 24px;
	transition: background-color 0.25s, color 0.25s;
}

.blog-card-grid__load-more-btn:hover {
	background-color: var(--color-base-blue);
	color: #fff;
}

/* Ocultar botón cuando no quedan más cards */
.blog-card-grid__load-more[data-blog-all-loaded] {
	display: none;
}

/* Estado sin resultados */
.blog-card-grid__no-results {
	grid-column: 1 / -1;
	text-align: center;
	padding: 64px 0;
	font-family: "Urbanist", sans-serif;
	font-size: 1rem;
	color: var(--color-text);
}


/* ==========================================================================
   RESPONSIVE - Desktop grande (>1920px)
   ========================================================================== */

@media (min-width: 1921px) {

	.blog-featured-post__title {
		font-size: 3.5rem;
		line-height: 4rem;
	}

	.blog-card-grid__cards {
		gap: 80px 40px;
	}
}

@media (max-width: 1024px) {
	.blog-featured-post__content-col {
		max-width: unset;
	}
}


/* ==========================================================================
   RESPONSIVE - Tablet / Mobile (<992px)
   ========================================================================== */

@media (max-width: 991px) {

	/* Intro section */
	.blog-intro-section {
		padding-bottom: 48px;
	}

	/* Featured post: apilado vertical */
	.blog-featured-post {
		padding: 0;
	}

	.blog-featured-post .row {
		flex-direction: column;
		gap: 0;
		align-items: stretch;
	}

	.blog-featured-post__image-col {
		flex: none;
		max-width: 100%;
		width: 100%;
		height: 280px;
	}

	.blog-featured-post__content-col {
		padding: 32px 24px 40px;
	}

	.blog-featured-post__title {
		font-size: 1.875rem;
		line-height: 2.375rem;
	}

	.blog-featured-post__content {
		gap: 20px;
	}

	/* Card grid */
	#blogCardGridSec {
		padding: 48px 0;
	}

	.blog-card-grid__actions {
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}

	.blog-card-grid__filter-group,
	.blog-card-grid__search-group {
		width: 100%;
		justify-content: space-between;
	}

	.blog-card-grid__search-input {
		flex: 1;
	}

	.blog-card-grid__cards {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.blog-card__image-wrapper {
		height: 260px;
	}

	.blog-card__content {
		padding: 0 16px;
		gap: 20px;
	}

	.blog-card__title {
		white-space: normal;
		text-overflow: unset;
		overflow: visible;
	}
}
