/* ============================================================
   La Vanguardia · Módulo "Apertura de Opinión"
   Cabecera de columna: sello "Opinión", banda de autor, titular
   centrado, entradilla y fecha. El CUERPO es el de la noticia
   genérica (lo monta ArticlePage). (Handoff
   design/noticia/apertura-opinion-modulo, integrado en app/.)
   ------------------------------------------------------------
   Tokens del design system con fallback embebido. Único ajuste
   sobre el handoff: la fuente serif del sitio es --f-text (no
   define --f-serif/--f-serif-text). Responsive: centrado a gran
   escala en desktop, compacto en <= 600px o con .lv-op-open--compact.
   ============================================================ */

.lv-op-open {
	--_blue: var(--lv-blue, #001c4c);
	--_ink: var(--ink, #15171a);
	--_ink-soft: var(--ink-soft, #2a2d33);
	--_meta: var(--meta, #6b6960);
	--_hair: var(--hair, #d9d5ca);
	--_paper-2: var(--paper-2, #f2f0e9);
	--_r-pill: var(--r-pill, 999px);
	--_f-headline: var(--f-headline, "Tiempos Headline", Georgia, serif);
	--_f-serif: var(--f-text, "Tiempos Text", "Source Serif 4", Georgia, serif);
	--_f-text: var(--f-text, "Tiempos Text", "Source Serif 4", Georgia, serif);
	--_f-mono: var(--f-mono, "JetBrains Mono", ui-monospace, monospace);

	text-align: center;
}

/* — Sello "Opinión" con filetes — */
.lv-op-open__flag {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin-bottom: 26px;
}
.lv-op-open__rule {
	flex: 0 1 110px;
	height: 1px;
	background: var(--_hair);
}
.lv-op-open__flag-word {
	font-family: var(--_f-headline);
	font-style: italic;
	font-weight: 100;
	font-size: 32px;
	line-height: 1;
	color: var(--_blue);
}

/* — Banda de autor (pill) — */
.lv-op-open__author {
	display: inline-flex;
	align-items: center;
	gap: 18px;
	max-width: 100%;
	padding: 14px 30px;
	border: 1px solid var(--_hair);
	border-radius: var(--_r-pill);
	background: var(--_paper-2);
	text-align: left;
	vertical-align: top;
}
.lv-op-open__avatar {
	position: relative;
	width: 76px;
	height: 76px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
	border: 1px solid var(--_hair);
	background: var(--_paper-2);
	display: grid;
	place-items: center;
	font-family: var(--_f-headline);
	font-weight: 600;
	font-size: 27px;
	color: var(--_blue);
	letter-spacing: 0;
}
.lv-op-open__avatar img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.lv-op-open__author-name {
	font-family: var(--_f-headline);
	font-weight: 700;
	font-size: 34px;
	line-height: 1;
	letter-spacing: -0.01em;
	color: var(--_ink);
	margin-bottom: 6px;
	white-space: nowrap;
}
.lv-op-open__author-role {
	font-family: var(--_f-mono);
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--_meta);
	white-space: nowrap;
}

.opinion .article__audio-inline {
	margin-top: 0 !important;
}

.opinion .article__head {
	margin-bottom: 50px !important;
}

/* — Titular centrado — */
.lv-op-open__title {
	margin: 34px auto 0;
	max-width: 980px;
	font-family: var(--_f-headline);
	font-weight: 600;
	font-size: clamp(var(--fs-31), 3.6vw, var(--fs-56));
	line-height: 1.04;
	letter-spacing: -0.01em;
	color: var(--_ink);
	text-wrap: balance;
}

/* — Entradilla centrada — */
.lv-op-open__deck {
	margin: 18px auto 0;
	max-width: 720px;
	font-family: var(--_f-text);
	font-weight: 400;
	font-size: 22px;
	line-height: 1.4;
	color: var(--_ink-soft);
	text-wrap: pretty;
}

/* — Fecha — */
.lv-op-open__date {
	margin-top: 20px;
	font-family: var(--_f-mono);
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--_meta);
}

/* — Fila fecha + utilidades (tamaño de texto, compartir, guardar) — */
.lv-op-open__meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 18px;
	flex-wrap: wrap;
	margin-top: 20px;
}
.lv-op-open__meta .lv-op-open__date {
	margin-top: 0;
}

/* ============================================================
   COMPACTO  ·  móvil
   Auto en <= 600px o forzado con .lv-op-open--compact
   ============================================================ */
@media (max-width: 600px) {
	.lv-op-open__flag {
		gap: 14px;
		margin-bottom: 18px;
	}
	.lv-op-open__rule {
		flex-basis: 70px;
	}
	.lv-op-open__flag-word {
		font-size: 24px;
	}
	.lv-op-open__author {
		gap: 14px;
		padding: 12px 18px;
	}
	.lv-op-open__avatar {
		width: 56px;
		height: 56px;
		font-size: 20px;
	}
	.lv-op-open__author-name {
		font-size: 23px;
	}
	.lv-op-open__title {
		margin-top: 22px;
		font-size: 30px;
		line-height: 1.08;
		letter-spacing: -0.015em;
	}
	.lv-op-open__deck {
		margin-top: 16px;
		font-size: 17px;
	}
	.lv-op-open__date {
		margin-top: 16px;
	}
}

.lv-op-open--compact .lv-op-open__flag {
	gap: 14px;
	margin-bottom: 18px;
}
.lv-op-open--compact .lv-op-open__rule {
	flex-basis: 70px;
}
.lv-op-open--compact .lv-op-open__flag-word {
	font-size: 24px;
}
.lv-op-open--compact .lv-op-open__author {
	gap: 14px;
	padding: 12px 18px;
}
.lv-op-open--compact .lv-op-open__avatar {
	width: 56px;
	height: 56px;
	font-size: 20px;
}
.lv-op-open--compact .lv-op-open__author-name {
	font-size: 23px;
}
.lv-op-open--compact .lv-op-open__title {
	margin-top: 22px;
	font-size: 30px;
	line-height: 1.08;
	letter-spacing: -0.015em;
}
.lv-op-open--compact .lv-op-open__deck {
	margin-top: 16px;
	font-size: 17px;
}
.lv-op-open--compact .lv-op-open__date {
	margin-top: 16px;
}
