/* ============================================================================
 * Gesvision Shell - Refresh Visual 2026
 * ----------------------------------------------------------------------------
 * Hoja de estilos standalone (sin Tailwind) que define el "chrome" comun
 * entre la web Astro y el blog WordPress: tokens, header, footer,
 * banner de cookies y tipografia editorial (.gv-prose).
 *
 * Es la unica fuente de verdad visual del shell. Cualquier cambio aqui debe
 * reflejarse:
 *   - En la web Astro, importandola desde Layout.astro (ya cubierto).
 *   - En el blog WordPress (gesvision-child), copiando el archivo a
 *     wp-content/themes/gesvision-child/assets/gesvision-shell.css.
 *
 * Las clases publicas viven bajo el prefijo .gv-* para evitar colisiones
 * con contenido legacy o estilos de plugins.
 * ========================================================================== */

/* ---------------------------------------------------------------------------
 * 1. Tokens
 *
 * Copiados de src/styles/tokens.css. Si tokens.css cambia, hay que
 * sincronizar este bloque (en la siguiente fase se hara con un script).
 * ------------------------------------------------------------------------- */

:root {
	--gv-color-brand-50: #eef1ff;
	--gv-color-brand-100: #dde3ff;
	--gv-color-brand-200: #bcc8ff;
	--gv-color-brand-300: #95a5ff;
	--gv-color-brand-400: #6e80f5;
	--gv-color-brand-500: #4e5dec;
	--gv-color-brand-600: #3848d6;
	--gv-color-brand-700: #2c3aaf;
	--gv-color-brand-800: #232d8a;
	--gv-color-brand-900: #1c2470;

	--gv-color-accent-cyan: #00d1ff;
	--gv-color-accent-violet: #6c4ee0;
	--gv-color-accent-pink: #fb47c1;
	--gv-color-accent-amber: #fdc954;

	--gv-color-bg: #ffffff;
	--gv-color-bg-soft: #f8f9fc;
	--gv-color-bg-muted: #f3f5fa;
	--gv-color-bg-inverted: #0b1020;

	--gv-color-fg: #24223e;
	--gv-color-fg-strong: #0b1020;
	--gv-color-fg-muted: #475569;
	--gv-color-fg-subtle: #94a3b8;

	--gv-color-border: #e2e8f0;
	--gv-color-border-soft: rgba(226, 232, 240, 0.6);

	--gv-radius-sm: 8px;
	--gv-radius-md: 12px;
	--gv-radius-lg: 16px;
	--gv-radius-xl: 20px;
	--gv-radius-2xl: 24px;
	--gv-radius-full: 9999px;

	--gv-shadow-sm: 0 2px 6px rgba(15, 23, 42, 0.06);
	--gv-shadow-md: 0 8px 20px rgba(15, 23, 42, 0.08);
	--gv-shadow-lg: 0 18px 36px rgba(15, 23, 42, 0.10);
	--gv-shadow-glow-brand: 0 18px 40px -12px rgba(78, 93, 236, 0.45);

	--gv-gradient-brand: linear-gradient(274deg, #00d1ff 5.87%, #4e5dec 57.41%);

	--gv-font-display:
		"Metropolis", "Geist Variable", "Inter", system-ui, -apple-system,
		"Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--gv-font-sans:
		"Geist Variable", "Metropolis", "Inter", system-ui, -apple-system,
		"Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

	--gv-header-height: 72px;
	--gv-container-max: 1280px;
}

/* ---------------------------------------------------------------------------
 * 2. Utilidades (gradiente de texto)
 * ------------------------------------------------------------------------- */

.gv-text-gradient-brand {
	background-image: var(--gv-gradient-brand);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

/* ---------------------------------------------------------------------------
 * 3. Header
 *
 * Replica el estado visual del navbar.astro: transparente sobre el hero en
 * desktop, glass blanco al hacer scroll y siempre glass en mobile. El blog
 * NO tiene hero, asi que arranca directamente en estado scrolled.
 * ------------------------------------------------------------------------- */

.gv-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	padding: 12px 0;
	font-family: var(--gv-font-sans);
	font-size: 14px;
	color: var(--gv-color-fg-strong);
	background-color: rgba(255, 255, 255, 0.85);
	backdrop-filter: saturate(180%) blur(12px);
	-webkit-backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--gv-color-border-soft);
	transition:
		background-color 0.2s ease,
		backdrop-filter 0.2s ease,
		border-color 0.2s ease;
}

@supports not ((backdrop-filter: blur(12px)) or (-webkit-backdrop-filter: blur(12px))) {
	.gv-header {
		background-color: rgba(255, 255, 255, 1);
	}
}

.gv-header-inner {
	max-width: var(--gv-container-max);
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	gap: 16px;
	min-height: 48px;
}

.gv-header-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--gv-color-fg-strong);
	text-decoration: none;
	transition: opacity 0.18s ease;
	margin-right: auto; /* empuja el nav a la derecha en desktop */
}

.gv-header-brand:hover {
	opacity: 0.7;
}

.gv-header-brand img {
	height: 30px;
	width: 160px;
	display: block;
}

.gv-header-nav-wrap {
	display: flex;
	align-items: center;
	gap: 32px;
}

.gv-header-nav {
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.gv-header-nav a {
	display: inline-flex;
	align-items: center;
	padding: 8px 14px;
	color: inherit;
	text-decoration: none;
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0;
	border-radius: var(--gv-radius-sm);
	transition: color 0.18s ease, background-color 0.18s ease;
	white-space: nowrap;
}

.gv-header-nav a:hover,
.gv-header-nav a[aria-current="page"] {
	color: var(--gv-color-brand-600);
}

.gv-header-actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.gv-header-actions .gv-text-link {
	color: inherit;
	font-weight: 500;
	text-decoration: none;
	font-size: 14px;
	white-space: nowrap;
	transition: color 0.18s ease;
}

.gv-header-actions .gv-text-link:hover {
	color: var(--gv-color-brand-600);
}

.gv-header-toggle {
	display: none;
	background: transparent;
	border: 0;
	padding: 8px;
	cursor: pointer;
	color: var(--gv-color-fg-strong);
	border-radius: var(--gv-radius-sm);
}

.gv-header-toggle:hover {
	background-color: var(--gv-color-brand-50);
}

.gv-header-toggle svg {
	width: 24px;
	height: 24px;
	display: block;
}

@media (max-width: 1023px) {
	.gv-header-inner {
		position: relative;
	}

	.gv-header-toggle {
		display: inline-flex;
	}

	.gv-header-nav-wrap {
		display: none;
		position: absolute;
		top: calc(100% + 12px);
		left: 16px;
		right: 16px;
		background: #fff;
		border: 1px solid var(--gv-color-border);
		border-radius: 12px;
		box-shadow: 0 20px 45px rgba(15, 23, 42, 0.15);
		padding: 16px;
		flex-direction: column;
		align-items: stretch;
		gap: 16px;
	}

	.gv-header[data-mobile-open="true"] .gv-header-nav-wrap {
		display: flex;
	}

	.gv-header-nav {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		width: 100%;
	}

	.gv-header-nav a {
		padding: 12px 10px;
	}

	.gv-header-actions {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}

	.gv-header-actions .gv-text-link {
		padding: 10px;
	}
}

/* Compensador del header fijo: el body de WP necesita padding-top o el
   contenido queda oculto bajo la barra. */
.gv-has-fixed-header {
	padding-top: var(--gv-header-height);
}

/* ---------------------------------------------------------------------------
 * 4. Botones (.gv-btn-*)
 * ------------------------------------------------------------------------- */

.gv-btn,
a.gv-btn,
button.gv-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 12px;
	font-family: var(--gv-font-sans);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2;
	cursor: pointer;
	text-decoration: none;
	border: 1px solid transparent;
	transition: all 0.2s ease;
	white-space: nowrap;
}

.gv-btn:focus-visible {
	outline: none;
	box-shadow: 0 0 0 2px var(--gv-color-brand-300), 0 0 0 4px rgba(255, 255, 255, 0.9);
}

.gv-btn-primary {
	background-color: var(--gv-color-brand-600);
	color: #fff;
	box-shadow: var(--gv-shadow-glow-brand);
}

.gv-btn-primary:hover {
	background-color: var(--gv-color-brand-700);
	transform: translateY(-1px);
	color: #fff;
}

.gv-btn-outline {
	background-color: #fff;
	color: var(--gv-color-brand-700);
	border-color: var(--gv-color-brand-200);
}

.gv-btn-outline:hover {
	background-color: var(--gv-color-brand-50);
	border-color: var(--gv-color-brand-300);
	transform: translateY(-1px);
}

.gv-btn-ghost {
	background-color: rgba(255, 255, 255, 0.05);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(4px);
}

.gv-btn-ghost:hover {
	background-color: rgba(255, 255, 255, 0.12);
	transform: translateY(-1px);
	color: #fff;
}

/* ---------------------------------------------------------------------------
 * 5. Footer (oscuro, alineado con footer.astro)
 * ------------------------------------------------------------------------- */

.gv-footer {
	position: relative;
	overflow: hidden;
	background-color: var(--gv-color-bg-inverted);
	color: rgba(203, 213, 225, 0.85);
	font-family: var(--gv-font-sans);
	font-size: 14px;
	isolation: isolate;
}

.gv-footer-aurora {
	position: absolute;
	inset: 0 0 auto 0;
	height: 420px;
	pointer-events: none;
	z-index: -1;
}

.gv-footer-aurora::before,
.gv-footer-aurora::after {
	content: "";
	position: absolute;
	width: 18rem;
	height: 18rem;
	border-radius: 9999px;
	filter: blur(64px);
}

.gv-footer-aurora::before {
	left: 10%;
	top: 40px;
	background-color: rgba(78, 93, 236, 0.2);
}

.gv-footer-aurora::after {
	right: 15%;
	top: 80px;
	background-color: rgba(0, 209, 255, 0.1);
}

.gv-footer-top {
	max-width: var(--gv-container-max);
	margin: 0 auto;
	padding: 64px 24px 48px;
	display: grid;
	gap: 40px;
}

@media (min-width: 1024px) {
	.gv-footer-top {
		grid-template-columns: 1.4fr 1fr;
		align-items: end;
		padding: 80px 32px 48px;
	}
}

.gv-footer-claim {
	font-family: var(--gv-font-display);
	font-size: clamp(1.875rem, 4vw, 3rem);
	line-height: 1.15;
	color: #fff;
	font-weight: 600;
	letter-spacing: -0.02em;
	margin: 0;
}

.gv-footer-claim-muted {
	color: var(--gv-color-fg-subtle);
}

.gv-footer-sub {
	margin-top: 16px;
	max-width: 36rem;
	color: var(--gv-color-fg-subtle);
	font-size: 16px;
}

.gv-footer-cta-row {
	margin-top: 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

@media (min-width: 640px) {
	.gv-footer-cta-row {
		flex-direction: row;
	}
}

.gv-footer-divider {
	max-width: var(--gv-container-max);
	margin: 0 auto;
	padding: 0 24px;
}

.gv-footer-divider > span {
	display: block;
	height: 1px;
	width: 100%;
	background: linear-gradient(
		to right,
		transparent,
		rgba(255, 255, 255, 0.15),
		transparent
	);
}

.gv-footer-cols {
	max-width: var(--gv-container-max);
	margin: 0 auto;
	padding: 56px 24px;
	display: grid;
	gap: 40px;
}

@media (min-width: 640px) {
	.gv-footer-cols {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.gv-footer-cols {
		grid-template-columns: 3fr 3fr 2fr 2fr 2fr;
		gap: 32px;
		padding: 56px 32px;
	}
}

.gv-footer-col h5 {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--gv-color-fg-subtle);
	margin: 0 0 16px;
}

.gv-footer-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.gv-footer-col a {
	color: rgba(203, 213, 225, 0.85);
	text-decoration: none;
	display: inline-block;
	transition: color 0.18s ease, transform 0.18s ease;
}

.gv-footer-col a:hover {
	color: #fff;
	transform: translateX(2px);
}

.gv-footer-brand-block .gv-footer-tagline {
	margin-top: 16px;
	max-width: 18rem;
	color: var(--gv-color-fg-subtle);
	line-height: 1.6;
}

.gv-footer-fiscal {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 24px;
	padding: 6px 12px;
	border-radius: 9999px;
	background-color: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--gv-color-fg-subtle);
}

.gv-footer-fiscal strong {
	color: #fff;
	font-weight: 700;
	text-transform: none;
	letter-spacing: 0;
	font-size: 12px;
}

.gv-footer-fiscal em {
	color: var(--gv-color-brand-300);
	font-style: normal;
	font-size: 12px;
}

.gv-footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.05);
	background-color: rgba(0, 0, 0, 0.3);
}

.gv-footer-bottom-inner {
	max-width: var(--gv-container-max);
	margin: 0 auto;
	padding: 20px 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	font-size: 12px;
	color: var(--gv-color-fg-subtle);
}

@media (min-width: 640px) {
	.gv-footer-bottom-inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		padding: 20px 32px;
	}
}

.gv-footer-status {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: rgba(203, 213, 225, 0.85);
}

.gv-footer-status-dot {
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 9999px;
	background-color: #34d399;
	box-shadow: 0 0 0 2px rgba(52, 211, 153, 0.3);
}

.gv-footer-presence {
	justify-self: start;
}

@media (min-width: 1024px) {
	.gv-footer-presence {
		justify-self: end;
	}
}

.gv-footer-presence-label {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--gv-color-fg-subtle);
	margin: 0;
}

.gv-footer-presence-list {
	margin: 12px 0 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.gv-footer-presence-list a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.25rem;
	border-radius: 4px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	overflow: hidden;
	text-decoration: none;
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.gv-footer-presence-list a:hover {
	border-color: rgba(255, 255, 255, 0.4);
	transform: translateY(-1px);
}

.gv-footer-presence-list .fi {
	width: 100%;
	height: 100%;
	border-radius: 3px;
}

.gv-footer-phones {
	margin-top: 24px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	color: var(--gv-color-fg-subtle);
}

.gv-footer-phones a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: inherit;
	text-decoration: none;
	transition: color 0.18s ease;
}

.gv-footer-phones a:hover {
	color: #fff;
}

.gv-sr-only,
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.screen-reader-text:focus {
	z-index: 100000;
	top: 12px;
	left: 12px;
	width: auto;
	height: auto;
	padding: 10px 14px;
	margin: 0;
	overflow: visible;
	clip: auto;
	white-space: normal;
	border-radius: var(--gv-radius-sm);
	background: #fff;
	box-shadow: var(--gv-shadow-md);
	color: var(--gv-color-fg-strong);
	font-weight: 700;
	text-decoration: none;
}

@media (prefers-reduced-motion: reduce) {
	.gv-footer-col a,
	.gv-footer-presence-list a {
		transition: none;
	}

	.gv-footer-col a:hover,
	.gv-footer-presence-list a:hover {
		transform: none;
	}
}

/* ---------------------------------------------------------------------------
 * 6. Tipografia editorial (.gv-prose)
 *
 * Aplica al cuerpo de los posts del blog. Usa los mismos tokens que la
 * web para que titulos, cuerpos y enlaces sientan la misma marca.
 * ------------------------------------------------------------------------- */

.gv-prose {
	color: var(--gv-color-fg);
	font-family: var(--gv-font-sans);
	font-size: 17px;
	line-height: 1.7;
	max-width: 720px;
	margin: 0 auto;
}

.gv-prose h1,
.gv-prose h2,
.gv-prose h3,
.gv-prose h4 {
	color: var(--gv-color-fg-strong);
	font-family: var(--gv-font-display);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.gv-prose h1 {
	font-size: clamp(2rem, 4vw, 2.75rem);
	margin: 0 0 24px;
}

.gv-prose h2 {
	font-size: clamp(1.5rem, 2.5vw, 1.875rem);
	margin: 48px 0 16px;
}

.gv-prose h3 {
	font-size: 1.25rem;
	margin: 32px 0 12px;
}

.gv-prose p {
	margin: 0 0 18px;
}

.gv-prose .gv-editorial-lead {
	padding: 18px 22px;
	border: 1px solid var(--gv-color-border);
	border-left: 4px solid var(--gv-color-brand-500);
	border-radius: var(--gv-radius-md);
	background: var(--gv-color-bg-soft);
	color: var(--gv-color-fg-strong);
}

.gv-prose a {
	color: var(--gv-color-brand-700);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color 0.18s ease;
}

.gv-prose a:hover {
	color: var(--gv-color-brand-500);
}

.gv-prose ul,
.gv-prose ol {
	margin: 0 0 24px;
	padding-left: 1.5rem;
}

.gv-prose ul li,
.gv-prose ol li {
	margin: 8px 0;
}

.gv-prose blockquote {
	margin: 32px 0;
	padding: 8px 24px;
	border-left: 3px solid var(--gv-color-brand-500);
	color: var(--gv-color-fg-muted);
	font-style: italic;
	background-color: var(--gv-color-bg-soft);
	border-radius: 0 var(--gv-radius-sm) var(--gv-radius-sm) 0;
}

.gv-prose img,
.gv-prose figure {
	max-width: 100%;
	height: auto;
	border-radius: var(--gv-radius-md);
	margin: 24px 0;
}

.gv-prose code {
	background-color: var(--gv-color-bg-muted);
	padding: 2px 6px;
	border-radius: 6px;
	font-size: 0.9em;
}

.gv-prose pre {
	background-color: var(--gv-color-fg-strong);
	color: #f8f9fc;
	padding: 16px 20px;
	border-radius: var(--gv-radius-md);
	overflow-x: auto;
	margin: 24px 0;
	font-size: 0.9em;
}

.gv-prose pre code {
	background: transparent;
	padding: 0;
	color: inherit;
}

/* Hero y listado del blog. */
.gv-blog-hero {
	background-color: var(--gv-color-bg-soft);
	padding: 96px 16px 56px;
}

.gv-blog-hero-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 8px;
}

@media (min-width: 640px) {
	.gv-blog-hero {
		padding: 112px 32px 64px;
	}
	.gv-blog-hero-inner {
		padding: 0;
	}
}

.gv-blog-hero-title {
	font-family: var(--gv-font-display);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	color: var(--gv-color-fg-strong);
	margin: 16px 0 12px;
	line-height: 1.15;
}

.gv-blog-hero-sub {
	color: var(--gv-color-fg-muted);
	font-size: 18px;
	max-width: 640px;
	line-height: 1.6;
	margin: 0;
}

.gv-blog-list {
	background: #fff;
	padding: 48px 16px 96px;
}

.gv-blog-list-inner {
	max-width: 1200px;
	margin: 0 auto;
}

@media (min-width: 640px) {
	.gv-blog-list {
		padding: 56px 32px 96px;
	}
}

/* Listado responsive: 1 columna en mobile, 2 en tablet, 3 en desktop.
   Las cards llevan card chrome ligero (anillo + sombra) para que el grid
   no se vea como una lista plana en pantallas anchas. */
.gv-blog-list-grid {
	display: grid;
	gap: 24px;
	grid-template-columns: 1fr;
}

@media (min-width: 720px) {
	.gv-blog-list-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 28px;
	}
}

@media (min-width: 1024px) {
	.gv-blog-list-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 32px;
	}
}

.gv-blog-card {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 0;
	background: var(--gv-color-bg);
	border: 1px solid var(--gv-color-border-soft);
	border-radius: var(--gv-radius-lg);
	box-shadow: var(--gv-shadow-sm);
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.gv-blog-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--gv-shadow-md);
	border-color: var(--gv-color-brand-200);
}

.gv-blog-card-thumb {
	display: block;
	aspect-ratio: 16 / 9;
	background-color: var(--gv-color-bg-muted);
	overflow: hidden;
}

.gv-blog-card-thumb-fallback {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	background: var(--gv-gradient-brand);
	color: #fff;
	font-family: var(--gv-font-display);
	font-weight: 600;
	font-size: 1.5rem;
	letter-spacing: -0.02em;
}

.gv-blog-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.gv-blog-card:hover .gv-blog-card-thumb img {
	transform: scale(1.04);
}

.gv-blog-card-body {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 20px 22px 22px;
	flex: 1;
}

.gv-blog-card-title {
	font-family: var(--gv-font-display);
	font-size: clamp(1.125rem, 2vw, 1.375rem);
	font-weight: 600;
	letter-spacing: -0.015em;
	line-height: 1.25;
	margin: 0;
	overflow-wrap: break-word;
}

.gv-blog-card-title a {
	color: var(--gv-color-fg-strong);
	text-decoration: none;
}

.gv-blog-card-title a:hover {
	color: var(--gv-color-brand-700);
}

.gv-blog-card-excerpt {
	color: var(--gv-color-fg-muted);
	font-size: 14.5px;
	line-height: 1.55;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.gv-blog-card-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px 10px;
	font-size: 12.5px;
	color: var(--gv-color-fg-subtle);
	margin-top: auto;
}

@media (prefers-reduced-motion: reduce) {
	.gv-blog-card,
	.gv-blog-card-thumb img {
		transition: none;
	}

	.gv-blog-card:hover {
		transform: none;
	}

	.gv-blog-card:hover .gv-blog-card-thumb img {
		transform: none;
	}
}

.gv-blog-pagination {
	margin-top: 48px;
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

.gv-blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 14px;
	border-radius: 10px;
	border: 1px solid var(--gv-color-border);
	color: var(--gv-color-fg-strong);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.gv-blog-pagination .page-numbers:hover {
	background: var(--gv-color-brand-50);
	border-color: var(--gv-color-brand-200);
}

.gv-blog-pagination .page-numbers.current {
	background: var(--gv-color-brand-600);
	border-color: var(--gv-color-brand-600);
	color: #fff;
}

/* ---------------------------------------------------------------------------
 * Single post: breadcrumbs, layout 2 columnas, share, related y CTA.
 * ------------------------------------------------------------------------- */

.gv-breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 8px;
	font-size: 13px;
	color: var(--gv-color-fg-subtle);
	margin: 0 0 16px;
	padding: 0;
	list-style: none;
}

.gv-breadcrumbs li {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.gv-breadcrumbs a {
	color: var(--gv-color-fg-muted);
	text-decoration: none;
	transition: color 0.18s ease;
}

.gv-breadcrumbs a:hover {
	color: var(--gv-color-brand-700);
}

.gv-breadcrumbs li[aria-current="page"] {
	color: var(--gv-color-fg-strong);
	font-weight: 500;
}

.gv-breadcrumbs-sep {
	color: var(--gv-color-fg-subtle);
}

/* Wrapper del single. En desktop pasa a 2 columnas con sidebar derecha. */
.gv-single {
	background: #fff;
	padding: 88px 16px 48px;
}

@media (min-width: 640px) {
	.gv-single { padding: 104px 32px 64px; }
}

.gv-single-inner {
	max-width: 1180px;
	margin: 0 auto;
	display: grid;
	gap: 48px;
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 1024px) {
	.gv-single-inner {
		grid-template-columns: minmax(0, 1fr) 280px;
	}
}

.gv-single-main {
	min-width: 0;
}

.gv-single-main .gv-prose,
.gv-single-main .gv-tldr,
.gv-single-main .gv-toc,
.gv-single-main .gv-faq,
.gv-single-main .gv-sources,
.gv-single-main .gv-author-card {
	max-width: 720px;
	margin-left: 0;
	margin-right: 0;
}

.gv-post-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 12px;
	color: var(--gv-color-fg-muted);
	font-size: 14px;
}

.gv-post-meta a {
	color: inherit;
	text-decoration: none;
	font-weight: 500;
}

.gv-post-meta a:hover {
	color: var(--gv-color-brand-700);
}

.gv-post-hero-image {
	margin: 0 0 32px;
	max-width: 720px;
}

.gv-post-hero-image img {
	width: 100%;
	height: auto;
	border-radius: var(--gv-radius-lg);
	display: block;
}

/* Sidebar (desktop only). Sticky con TOC, autor mini y CTA.
 *
 * Sin max-height ni overflow: el contenedor sticky se ancla al hacer
 * scroll y, si el contenido excede el viewport, el final queda cortado
 * abajo (es lo que hacen Stripe, Notion, etc.). Si en algun post real
 * el sidebar acaba siendo demasiado alto, lo que se hace es acortar el
 * TOC, no anadir scrollbars internos.
 */
.gv-single-side {
	display: none;
}

@media (min-width: 1024px) {
	.gv-single-side {
		display: block;
		position: sticky;
		top: calc(var(--gv-header-height) + 24px);
		align-self: start;
		font-size: 13.5px;
	}
}

.gv-side-block {
	background: var(--gv-color-bg-soft);
	border: 1px solid var(--gv-color-border-soft);
	border-radius: var(--gv-radius-lg);
	padding: 18px 20px;
	margin-bottom: 16px;
}

.gv-side-block h4 {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--gv-color-fg-muted);
	margin: 0 0 10px;
}

.gv-side-toc ol {
	list-style: decimal;
	padding-left: 1.15rem;
	margin: 0;
	color: var(--gv-color-fg-strong);
}

.gv-side-toc li {
	margin: 8px 0;
	padding-left: 3px;
	line-height: 1.35;
}

.gv-side-toc li::marker {
	color: var(--gv-color-fg-muted);
	font-size: 12px;
	font-weight: 600;
}

.gv-side-toc a {
	color: var(--gv-color-fg-strong);
	text-decoration: none;
	display: inline-block;
}

.gv-side-toc a:hover {
	color: var(--gv-color-brand-600);
	text-decoration: underline;
}

.gv-side-author {
	display: flex;
	align-items: center;
	gap: 12px;
}

.gv-side-author img {
	width: 44px;
	height: 44px;
	border-radius: 9999px;
	object-fit: cover;
	flex-shrink: 0;
}

.gv-side-author-name {
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	font-size: 14px;
	line-height: 1.2;
	margin: 0;
}

.gv-side-author-role {
	font-size: 12.5px;
	color: var(--gv-color-fg-muted);
	margin: 2px 0 0;
}

.gv-side-cta {
	background: linear-gradient(135deg, var(--gv-color-brand-50), #fff 80%);
	border-color: var(--gv-color-brand-200);
}

.gv-side-cta h4 {
	color: var(--gv-color-brand-700);
}

.gv-side-cta p {
	margin: 0 0 14px;
	color: var(--gv-color-fg-muted);
	font-size: 13.5px;
	line-height: 1.55;
}

.gv-side-cta .gv-btn {
	width: auto;
	min-width: 170px;
	justify-content: center;
	padding-inline: 22px;
}

/* CTA contextual brand inline. */
.gv-inline-cta {
	margin: 32px 0;
	padding: 24px 24px 26px;
	border-radius: var(--gv-radius-lg);
	background: linear-gradient(135deg, var(--gv-color-brand-50), #fff 80%);
	border: 1px solid var(--gv-color-brand-200);
	display: flex;
	flex-direction: column;
	gap: 10px;
	max-width: 720px;
}

.gv-inline-cta-title {
	margin: 0;
	font-size: 18px;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	font-family: var(--gv-font-display);
	letter-spacing: -0.01em;
}

.gv-inline-cta p {
	margin: 0;
	color: var(--gv-color-fg-muted);
	font-size: 14.5px;
	line-height: 1.55;
}

.gv-inline-cta-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 6px;
}

/* Botones de compartir. */
.gv-share {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin: 16px 0 0;
	max-width: 720px;
}

.gv-share-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gv-color-fg-subtle);
	margin-right: 4px;
}

.gv-share button,
.gv-share a.gv-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 36px;
	height: 36px;
	border-radius: 9999px;
	border: 1px solid var(--gv-color-border);
	background: #fff;
	color: var(--gv-color-fg-muted);
	cursor: pointer;
	text-decoration: none;
	font-size: 13px;
	transition: color 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, transform 0.18s ease;
}

.gv-share button:hover,
.gv-share a.gv-share-btn:hover {
	color: var(--gv-color-brand-700);
	border-color: var(--gv-color-brand-300);
	background: var(--gv-color-brand-50);
	transform: translateY(-1px);
}

.gv-share button[data-copied="true"] {
	color: #16a34a;
	border-color: #86efac;
	background: #f0fdf4;
}

/* Tags del post. */
.gv-post-tags {
	margin: 32px 0 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	max-width: 720px;
}

.gv-post-tags-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gv-color-fg-subtle);
	margin-right: 4px;
}

.gv-post-tags a {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 9999px;
	background: var(--gv-color-bg-muted);
	color: var(--gv-color-fg-muted);
	font-size: 12.5px;
	font-weight: 500;
	text-decoration: none;
	transition: background-color 0.18s ease, color 0.18s ease;
}

.gv-post-tags a:hover {
	background: var(--gv-color-brand-50);
	color: var(--gv-color-brand-700);
}

/* Posts relacionados con thumbnails. */
.gv-related {
	margin: 64px 0 0;
	padding-top: 40px;
	border-top: 1px solid var(--gv-color-border-soft);
}

.gv-related-title {
	font-family: var(--gv-font-display);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	letter-spacing: -0.015em;
	margin: 0 0 20px;
}

.gv-related-grid {
	display: grid;
	gap: 20px;
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 720px) {
	.gv-related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.gv-related-card {
	display: flex;
	flex-direction: column;
	gap: 10px;
	background: #fff;
	border: 1px solid var(--gv-color-border-soft);
	border-radius: var(--gv-radius-md);
	overflow: hidden;
	text-decoration: none;
	transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.gv-related-card:hover {
	transform: translateY(-2px);
	border-color: var(--gv-color-brand-200);
	box-shadow: var(--gv-shadow-sm);
}

.gv-related-thumb {
	display: block;
	aspect-ratio: 16 / 9;
	background: var(--gv-color-bg-muted);
	overflow: hidden;
}

.gv-related-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.gv-related-body {
	padding: 12px 14px 16px;
}

.gv-related-cat {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gv-color-brand-600);
}

.gv-related-card-title {
	font-size: 15px;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	line-height: 1.3;
	margin: 6px 0 0;
	font-family: var(--gv-font-display);
	letter-spacing: -0.01em;
}

/* Anterior / siguiente. */
.gv-prev-next {
	margin: 40px 0 0;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 720px) {
	.gv-prev-next { grid-template-columns: 1fr 1fr; gap: 16px; }
}

.gv-prev-next a {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 14px 16px;
	border: 1px solid var(--gv-color-border-soft);
	border-radius: var(--gv-radius-md);
	background: var(--gv-color-bg-soft);
	text-decoration: none;
	transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.gv-prev-next a:hover {
	background: var(--gv-color-brand-50);
	border-color: var(--gv-color-brand-200);
	transform: translateY(-1px);
}

.gv-prev-next-label {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gv-color-fg-subtle);
}

.gv-prev-next-title {
	font-size: 14.5px;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	line-height: 1.3;
}

.gv-prev-next-next {
	text-align: right;
}

@media (prefers-reduced-motion: reduce) {
	.gv-share button,
	.gv-share a.gv-share-btn,
	.gv-related-card,
	.gv-prev-next a {
		transition: none;
	}
	.gv-share button:hover,
	.gv-share a.gv-share-btn:hover,
	.gv-related-card:hover,
	.gv-prev-next a:hover {
		transform: none;
	}
}

/* Pretitle pill para categoria/etiquetas. */
.gv-pretitle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 12px;
	border-radius: 9999px;
	background-color: var(--gv-color-brand-50);
	color: var(--gv-color-brand-700);
	border: 1px solid var(--gv-color-brand-200);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-decoration: none;
}

/* TL;DR card AEO. */
.gv-tldr {
	margin: 0 0 32px;
	padding: 20px 24px;
	border-radius: var(--gv-radius-lg);
	background-color: var(--gv-color-brand-50);
	border-left: 3px solid var(--gv-color-brand-500);
}

.gv-tldr-label {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--gv-color-brand-700);
	margin-bottom: 6px;
}

.gv-tldr p {
	margin: 0;
	color: var(--gv-color-fg-strong);
	font-size: 16px;
	line-height: 1.6;
}

/* Tabla de contenidos. */
.gv-toc {
	margin: 0 0 32px;
	padding: 16px 20px;
	border-radius: var(--gv-radius-md);
	background-color: var(--gv-color-bg-soft);
	border: 1px solid var(--gv-color-border-soft);
}

.gv-toc-title {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--gv-color-fg-muted);
	margin: 0 0 8px;
}

.gv-toc ol {
	list-style: decimal;
	padding-left: 1.25rem;
	margin: 0;
}

.gv-toc li {
	margin: 4px 0;
}

.gv-toc a {
	color: var(--gv-color-fg-strong);
	text-decoration: none;
}

.gv-toc a:hover {
	color: var(--gv-color-brand-600);
	text-decoration: underline;
}

/* Author card. */
.gv-author-card {
	display: flex;
	align-items: center;
	gap: 16px;
	margin: 32px 0 0;
	padding: 16px 20px;
	border-radius: var(--gv-radius-lg);
	background-color: var(--gv-color-bg-soft);
	border: 1px solid var(--gv-color-border-soft);
}

.gv-author-card img {
	width: 56px;
	height: 56px;
	border-radius: 9999px;
	object-fit: cover;
	flex-shrink: 0;
}

.gv-author-card-name {
	margin: 0;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
}

.gv-author-card-meta {
	margin: 4px 0 0;
	font-size: 13px;
	color: var(--gv-color-fg-muted);
}

/* FAQ block. */
.gv-faq {
	margin: 48px 0 0;
	border-top: 1px solid var(--gv-color-border);
	padding-top: 32px;
}

.gv-faq h2 {
	margin-top: 0;
}

.gv-faq-item {
	border-bottom: 1px solid var(--gv-color-border-soft);
	padding: 16px 0;
}

.gv-faq-item summary {
	cursor: pointer;
	font-weight: 600;
	color: var(--gv-color-fg-strong);
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.gv-faq-item summary::-webkit-details-marker {
	display: none;
}

.gv-faq-item summary::after {
	content: "+";
	font-size: 20px;
	color: var(--gv-color-brand-600);
	font-weight: 400;
}

.gv-faq-item[open] summary::after {
	content: "-";
}

.gv-faq-item p {
	margin: 12px 0 4px;
	color: var(--gv-color-fg-muted);
}

/* Sources block. */
.gv-sources {
	margin: 32px 0 0;
	padding: 16px 20px;
	background-color: var(--gv-color-bg-muted);
	border-radius: var(--gv-radius-md);
	font-size: 14px;
}

.gv-sources-title {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--gv-color-fg-muted);
	margin: 0 0 8px;
}

.gv-sources ul {
	margin: 0;
	padding-left: 1.25rem;
}

/* ---------------------------------------------------------------------------
 * 7. Cookie banner overrides (vanilla-cookieconsent)
 *
 * Re-aplicamos las reglas del archivo cookie.css del Astro pero sin
 * depender de la clase .cc--light-funky para que los plugins WP que
 * inyectan el banner sin esa clase tambien queden estilados.
 * ------------------------------------------------------------------------- */

#cc-main {
	--cc-bg: #f9faff;
	--cc-primary-color: #112954;
	--cc-secondary-color: #112954;

	--cc-btn-primary-bg: #3859d0;
	--cc-btn-primary-color: var(--cc-bg);
	--cc-btn-primary-hover-bg: #213657;
	--cc-btn-primary-hover-color: #fff;

	--cc-btn-secondary-bg: #dfe7f9;
	--cc-btn-secondary-color: var(--cc-secondary-color);
	--cc-btn-secondary-hover-bg: #c6d1ea;
	--cc-btn-secondary-hover-color: #000;

	--cc-cookie-category-block-bg: #ebeff9;
	--cc-cookie-category-block-border: #ebeff9;
	--cc-cookie-category-block-hover-bg: #dbe5f9;
	--cc-cookie-category-block-hover-border: #dbe5f9;
	--cc-cookie-category-expanded-block-hover-bg: #ebeff9;
	--cc-cookie-category-expanded-block-bg: #ebeff9;

	--cc-overlay-bg: rgba(219, 232, 255, 0.85) !important;

	--cc-toggle-readonly-bg: #cbd8f1;
	--cc-toggle-on-knob-bg: var(--cc-bg);
	--cc-toggle-off-bg: #8fa8d6;
	--cc-toggle-readonly-knob-bg: var(--cc-bg);

	--cc-separator-border-color: #f1f3f5;

	--cc-footer-border-color: #f1f3f5;
	--cc-footer-bg: var(--cc-bg);

	--cc-btn-border-radius: 1rem 0.6rem 1.3rem 0.5rem / 0.5rem 1rem;
	--cc-modal-border-radius: var(--cc-btn-border-radius);
	--cc-pm-toggle-border-radius: var(--cc-btn-border-radius);
}

#cc-main .toggle__icon:after {
	border-radius: var(--cc-btn-border-radius);
}

#cc-main .cm__btn--close {
	border-radius: var(--cc-btn-border-radius);
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}

#cc-main .cm__btn[data-role="all"],
#cc-main .pm__btn[data-role="all"] {
	background-color: #3859d0;
	border: 1px solid #3859d0;
	color: #ffffff;
	font-weight: 600;
}

#cc-main .cm__btn[data-role="all"]:hover,
#cc-main .pm__btn[data-role="all"]:hover {
	background-color: #213657;
	border-color: #213657;
	color: #ffffff;
}

#cc-main .cm__btn[data-role="necessary"],
#cc-main .pm__btn[data-role="necessary"] {
	background-color: #eef2fb;
	border: 1px solid #eef2fb;
	color: #112954;
}

#cc-main .cm__btn[data-role="necessary"]:hover,
#cc-main .pm__btn[data-role="necessary"]:hover {
	background-color: #dfe7f9;
	border-color: #dfe7f9;
	color: #000;
}

#cc-main .cm__btn[data-role="show"] {
	background-color: transparent;
	border: none;
	color: #6b7280;
	text-decoration: none;
	padding: 0 0.5rem;
	margin: 0;
	font-weight: 400;
	font-size: 0.8125rem;
	line-height: 1.3;
	box-shadow: none;
	min-width: 0;
	min-height: 0;
	height: auto;
	flex: 0 0 auto;
	align-self: center;
}

#cc-main .cm__btn[data-role="show"]:hover {
	background-color: transparent;
	color: #112954;
	text-decoration: underline;
}

/* ---------------------------------------------------------------------------
 * 8. Banderas (subset flag-icons)
 *
 * En la web Astro se cargan via flag-icons-subset.css. En el blog se cargan
 * desde el tema (assets/flags/*.svg). Mantenemos las clases `.fi.fi-XX`
 * compatibles con el sistema flag-icons original para reusar el HTML.
 *
 * El blog sobreescribe la propiedad `--gv-flag-base` con la URL real de
 * los SVG del tema. Si --gv-flag-base no esta definido, las banderas
 * apuntan a /flags/4x3/ (ruta de la web Astro).
 * ------------------------------------------------------------------------- */

:root {
	--gv-flag-base: '/flags/4x3';
}

.fib,
.fi {
	background-size: contain;
	background-position: 50%;
	background-repeat: no-repeat;
	position: relative;
	display: inline-block;
	width: 1.33333333em;
	line-height: 1em;
}

.fib::before,
.fi::before {
	content: "\00a0";
}

.fis,
.fi.fis {
	width: 1em;
}

.fi-bo { background-image: var(--gv-flag-bo, url('/flags/4x3/bo.svg')); }
.fi-cl { background-image: var(--gv-flag-cl, url('/flags/4x3/cl.svg')); }
.fi-co { background-image: var(--gv-flag-co, url('/flags/4x3/co.svg')); }
.fi-ec { background-image: var(--gv-flag-ec, url('/flags/4x3/ec.svg')); }
.fi-es { background-image: var(--gv-flag-es, url('/flags/4x3/es.svg')); }
.fi-hn { background-image: var(--gv-flag-hn, url('/flags/4x3/hn.svg')); }
.fi-mx { background-image: var(--gv-flag-mx, url('/flags/4x3/mx.svg')); }
.fi-pa { background-image: var(--gv-flag-pa, url('/flags/4x3/pa.svg')); }
.fi-pe { background-image: var(--gv-flag-pe, url('/flags/4x3/pe.svg')); }
.fi-sv { background-image: var(--gv-flag-sv, url('/flags/4x3/sv.svg')); }
.fi-ve { background-image: var(--gv-flag-ve, url('/flags/4x3/ve.svg')); }
