/* ==========================================================
   UI propia de la demo (NO del handoff). Estilos globales de
   componentes añadidos por nosotros: pie del sitio y panel de
   demo. Están aquí (y no como <style> scoped en el componente)
   para no emitir atributos data-astro-cid en el HTML.
   Requiere tokens.css cargado antes (usa var(--lv-blue), etc.).
   ========================================================== */

/* — Pie del sitio (multicolumna, del handoff design/noticia/noticia_v1 · chrome.css).
     Global: aplica a portada y detalle. CSS provisional v1 (lo lleva el usuario). — */
.site-footer {
	margin-top: 64px;
	background: var(--lv-blue);
	color: #fff;
}
.site-footer__top {
	max-width: var(--content-max);
	margin-inline: auto;
	padding: 44px var(--content-pad) 36px;
	display: grid;
	grid-template-columns: 1.4fr repeat(4, 1fr);
	gap: var(--gap);
}
.site-footer__brand-col {
	display: grid;
	gap: 16px;
	align-content: start;
}
.site-footer__logo {
	height: 30px;
	width: auto;
}
.site-footer__tagline {
	font-family: var(--f-text);
	font-size: var(--fs-14);
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.7);
	max-width: 30ch;
}
.site-footer__social {
	display: flex;
	gap: 10px;
}
.site-footer__social a {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.25);
	color: #fff;
	display: grid;
	place-items: center;
	transition:
		background 0.15s,
		border-color 0.15s;
}
.site-footer__social a:hover {
	background: rgba(255, 255, 255, 0.16);
	border-color: rgba(255, 255, 255, 0.55);
}
.site-footer__col h3 {
	margin: 0 0 14px;
	font-family: var(--f-sans);
	font-weight: 700;
	font-size: var(--fs-12);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
}
.site-footer__col ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 10px;
}
.site-footer__col a {
	font-family: var(--f-sans);
	font-size: var(--fs-13_5);
	color: rgba(255, 255, 255, 0.88);
	transition: color 0.15s;
}
.site-footer__col a:hover {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 3px;
}
.site-footer__legal {
	border-top: 1px solid rgba(255, 255, 255, 0.14);
}
.site-footer__legal-inner {
	max-width: var(--content-max);
	margin-inline: auto;
	padding: 18px var(--content-pad);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
}
.site-footer__copy {
	font-family: var(--f-sans);
	font-size: var(--fs-12);
	color: rgba(255, 255, 255, 0.6);
}
.site-footer__legal-links {
	display: flex;
	gap: 18px;
	flex-wrap: wrap;
}
.site-footer__legal-links a {
	font-family: var(--f-sans);
	font-size: var(--fs-12);
	color: rgba(255, 255, 255, 0.75);
}
.site-footer__legal-links a:hover {
	color: #fff;
}

@media (max-width: 1024px) {
	.site-footer__top {
		grid-template-columns: 1fr 1fr 1fr;
		row-gap: 36px;
	}
	.site-footer__brand-col {
		grid-column: 1 / -1;
	}
}
@media (max-width: 640px) {
	.site-footer {
		margin-top: 48px;
	}
	.site-footer__top {
		grid-template-columns: 1fr 1fr;
		padding: 32px 16px 28px;
		gap: 24px;
	}
	.site-footer__brand-col {
		grid-column: 1 / -1;
	}
	.site-footer__legal-inner {
		padding: 16px;
	}
}

/* — Lightbox del detalle (galería / imagen). Del handoff (estaba inline). — */
.lv-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: rgba(8, 10, 14, 0.96);
	display: flex;
	flex-direction: column;
}
.lv-lightbox[hidden] {
	display: none;
}
.lv-lightbox__bar {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 2;
	padding: 16px 20px;
}
.lv-lightbox__close {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.25);
	background: rgba(8, 10, 14, 0.4);
	color: #fff;
	cursor: pointer;
	font-size: 16px;
}
.lv-lightbox__stage {
	flex: 1 1 auto;
	min-height: 0;
	display: grid;
	place-items: center;
	padding: 0;
}
.lv-lightbox__stage img {
	width: auto;
	height: calc(100vh - 160px);
	object-fit: contain;
}
.lv-lightbox__cap {
	flex: 0 0 auto;
	max-width: 900px;
	margin-inline: auto;
	padding: 14px 24px 22px;
	color: rgba(255, 255, 255, 0.85);
	font-family: var(--f-sans);
	font-size: var(--fs-13);
	line-height: 1.45;
	text-align: center;
}
.lv-lightbox__cap:empty {
	display: none;
}

/* — Panel flotante de demo (alternar variante de apertura). Demo-only. — */
.demo-panel {
	position: fixed;
	right: 16px;
	bottom: 16px;
	z-index: 9999;
	font-family: var(--f-sans, system-ui, sans-serif);
	color: var(--ink, #0a0d12);
}
.demo-panel__box {
	width: 260px;
	max-width: calc(100vw - 32px);
	background: #fff;
	border: 1px solid var(--hair, #d8dce3);
	box-shadow: 0 8px 30px rgba(8, 12, 20, 0.18);
	border-radius: 10px;
	overflow: hidden;
}
.demo-panel__toggle {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	cursor: pointer;
	padding: 11px 14px;
	background: var(--lv-blue, #001c4c);
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.02em;
	user-select: none;
}
.demo-panel__toggle::-webkit-details-marker {
	display: none;
}
.demo-panel__gear {
	font-size: 15px;
	line-height: 1;
}
/* Indicador de plegado: la flecha gira al abrir */
.demo-panel__toggle::after {
	content: "▾";
	margin-left: auto;
	transition: transform 0.18s ease;
}
details[open] > .demo-panel__toggle::after {
	transform: rotate(180deg);
}

.demo-panel__body {
	padding: 10px 12px 12px;
	max-height: 70vh;
	overflow-y: auto;
}
.demo-panel__group + .demo-panel__group {
	margin-top: 12px;
}
.demo-panel__legend {
	margin: 0 0 7px;
	font-size: 10.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--meta, #6b6960);
}
.demo-panel__opts {
	display: grid;
	gap: 6px;
}
.demo-panel__opt {
	display: block;
	padding: 7px 10px;
	border: 1px solid var(--hair, #d8dce3);
	border-radius: 7px;
	text-decoration: none;
	color: var(--ink, #0a0d12);
	background: #fff;
	transition:
		border-color 0.15s,
		background 0.15s;
}
.demo-panel__opt:hover {
	border-color: var(--lv-blue, #001c4c);
	background: var(--paper-2, #f2f4f8);
}
.demo-panel__opt b {
	display: block;
	font-size: 13px;
	font-weight: 600;
}
.demo-panel__opt small {
	display: block;
	font-size: 11px;
	color: var(--meta, #6b6960);
	margin-top: 1px;
}
.demo-panel__opt.is-active {
	border-color: var(--lv-blue, #001c4c);
	background: var(--lv-blue, #001c4c);
}
.demo-panel__opt.is-active b,
.demo-panel__opt.is-active small {
	color: #fff;
}
.demo-panel__opt:focus-visible {
	outline: 2px solid var(--lv-blue, #001c4c);
	outline-offset: 2px;
}

@media (max-width: 640px) {
	.demo-panel {
		right: 10px;
		bottom: 10px;
	}
	.demo-panel__box {
		width: 220px;
	}
}
@media print {
	.demo-panel {
		display: none;
	}
}
