/*
 * rating-nacional.css — Page-specific styles for the redesigned
 * Rating Nacional template.
 *
 * Loaded only on /rating-nacional/ via conditional enqueue. Uses tokens
 * from tokens.css; the shell (nav/footer/drawer) styles live in
 * shell.css. This file owns the hero, the choropleth map (zoom/pan/
 * tooltip/legend), the ranking table, and the info strip.
 */

.rn-page { font-family: var(--font-body); color: var(--text-primary); }

.rn-container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

/* ============================================================
   HERO
   ============================================================ */
.rn-hero {
	padding: var(--space-12) 0 var(--space-12);
	border-bottom: 1px solid var(--border-default);
}
.rn-hero__grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: var(--space-12);
	align-items: end;
}
.rn-eyebrow {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-secondary);
	margin: 0 0 var(--space-4);
	display: flex;
	align-items: center;
	gap: var(--space-3);
}
.rn-eyebrow::before {
	content: '';
	width: 32px;
	height: 1px;
	background: var(--accent-600);
}
.rn-hero h1 {
	font-family: var(--font-display);
	font-size: clamp(48px, 7vw, 88px);
	font-weight: 500;
	line-height: 0.95;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-6);
	color: var(--text-primary);
}
.rn-hero__lede {
	font-size: 18px;
	line-height: 1.55;
	color: var(--text-secondary);
	max-width: 56ch;
	margin: 0;
}
.rn-hero__stats {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	border-left: 1px solid var(--border-default);
	padding-left: var(--space-6);
}
.rn-stat__label {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--text-tertiary);
	margin-bottom: 4px;
}
.rn-stat__value {
	font-family: var(--font-display);
	font-size: 36px;
	line-height: 1.1;
	color: var(--text-primary);
}
.rn-stat__value .num {
	font-family: var(--font-mono);
	font-weight: 500;
	font-variant-numeric: tabular-nums;
}

/* ============================================================
   MAIN GRID — desktop: sticky map left, ranking right
   ============================================================ */
.rn-main { padding: var(--space-12) 0; }
.rn-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: var(--space-12);
	align-items: start;
}
.rn-section-title {
	font-size: 12px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--text-secondary);
	margin: 0 0 var(--space-6);
	display: flex;
	align-items: center;
	gap: var(--space-3);
}
.rn-section-title::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--border-default);
}

/* ============================================================
   MAP
   ============================================================ */
.rn-map { position: sticky; top: 88px; }

.rn-state-selector { margin-bottom: var(--space-4); }
.rn-state-selector__label {
	display: block;
	font-family: var(--font-mono);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--text-tertiary);
	margin-bottom: 6px;
}
.rn-state-selector__wrap { position: relative; }
.rn-state-selector__wrap select {
	width: 100%;
	font-family: var(--font-body);
	font-size: 14px;
	font-weight: 500;
	padding: 11px 36px 11px 14px;
	background: var(--bg-page);
	border: 1px solid var(--border-strong);
	border-radius: var(--radius-sm);
	appearance: none;
	cursor: pointer;
	color: var(--text-primary);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.rn-state-selector__wrap select:focus {
	outline: none;
	border-color: var(--accent-600);
	box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.15);
}
.rn-state-selector__wrap select:hover { border-color: var(--accent-400); }
.rn-state-selector__chevron {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	color: var(--text-secondary);
	pointer-events: none;
}

.rn-map__card {
	background: var(--bg-elevated);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-md);
	padding: var(--space-4);
}
.rn-map__wrap {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-sm);
	background: var(--bg-page);
	touch-action: none;
}
.rn-map__viewport {
	transform-origin: 0 0;
	transition: transform 200ms cubic-bezier(0.2, 0.8, 0.2, 1);
	will-change: transform;
}
.rn-map__viewport.is-dragging { transition: none; cursor: grabbing; }
.rn-map__viewport.is-zoomed { cursor: grab; }

.rn-map__zoom-indicator {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	z-index: 5;
	background: var(--neutral-1000);
	color: var(--text-on-accent);
	padding: 5px 10px;
	border-radius: var(--radius-sm);
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.04em;
	opacity: 0;
	transition: opacity var(--transition-fast);
	pointer-events: none;
}
.rn-map__zoom-indicator.is-visible { opacity: 1; }
.rn-map__zoom-indicator span { color: var(--accent-200); }

.rn-map__controls {
	position: absolute;
	top: var(--space-3);
	right: var(--space-3);
	z-index: 5;
	display: flex;
	flex-direction: column;
	gap: 1px;
	background: var(--border-default);
	border-radius: var(--radius-sm);
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.rn-map__ctrl {
	width: 36px;
	height: 36px;
	background: var(--bg-page);
	color: var(--text-secondary);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border: 0;
	transition: background var(--transition-fast), color var(--transition-fast), opacity var(--transition-fast);
}
.rn-map__ctrl svg { width: 18px; height: 18px; }
.rn-map__ctrl:hover:not(:disabled) {
	background: var(--bg-muted);
	color: var(--text-primary);
}
.rn-map__ctrl:disabled { opacity: 0.35; cursor: not-allowed; }

.rn-map__hint {
	margin-top: var(--space-3);
	font-family: var(--font-mono);
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--text-tertiary);
	text-align: center;
}

.rn-map__svg { width: 100%; height: auto; display: block; }
.rn-map__svg .mx-state {
	stroke: var(--neutral-0);
	stroke-width: 0.8;
	/* Lock the stroke to screen pixels so it doesn't bloat when the viewport
	   gets CSS-transformed by the zoom controls. Without this, a 1.6px
	   selected-state stroke renders as ~8px at scale(5). */
	vector-effect: non-scaling-stroke;
	cursor: pointer;
	transition: opacity var(--transition-fast), stroke-width var(--transition-fast);
}
.rn-map__svg .mx-state:hover { opacity: 0.8; }
.rn-map__svg .mx-state.is-selected {
	stroke: var(--neutral-1000);
	stroke-width: 1.6;
}
.rn-map__svg .mx-state.ramp-0 { fill: #F5F5F0; }
.rn-map__svg .mx-state.ramp-1 { fill: #DCE6F1; }
.rn-map__svg .mx-state.ramp-2 { fill: #B8C8DC; }
.rn-map__svg .mx-state.ramp-3 { fill: #4A6B8E; }
.rn-map__svg .mx-state.ramp-4 { fill: #1E3A5F; }
.rn-map__svg .mx-state.ramp-5 { fill: #163049; }

.rn-map__tooltip {
	position: absolute;
	pointer-events: none;
	background: var(--neutral-1000);
	color: var(--text-on-accent);
	padding: 8px 12px;
	border-radius: var(--radius-sm);
	font-size: 12px;
	opacity: 0;
	transition: opacity 100ms;
	transform: translate(-50%, -100%);
	white-space: nowrap;
	z-index: 10;
	margin-top: -10px;
}
.rn-map__tooltip.is-visible { opacity: 1; }
.rn-map__tooltip .name { display: block; font-weight: 500; }
.rn-map__tooltip .num {
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	color: var(--accent-200);
	font-size: 11px;
}

.rn-map__legend {
	margin-top: var(--space-4);
	padding-top: var(--space-4);
	border-top: 1px solid var(--border-default);
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--text-secondary);
	letter-spacing: 0.04em;
}
.rn-map__legend-bar {
	flex: 1;
	display: flex;
	height: 8px;
	border-radius: 2px;
	overflow: hidden;
}
.rn-map__legend-bar div { flex: 1; }

.rn-map__filter-banner {
	display: none;
	margin-top: var(--space-4);
	padding: var(--space-3) var(--space-4);
	background: var(--bg-accent-subtle);
	border: 1px solid var(--accent-200);
	border-radius: var(--radius-sm);
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
}
.rn-map__filter-banner.is-visible { display: flex; }
.rn-map__filter-banner .label { font-size: 13px; color: var(--accent-800); }
.rn-map__filter-banner .label strong { font-weight: 600; }
.rn-map__filter-banner button {
	font-size: 12px;
	color: var(--accent-600);
	text-decoration: underline;
	font-weight: 500;
	background: none;
	border: 0;
	cursor: pointer;
}
.rn-state-profile-link {
	font-size: 12px;
	font-weight: 500;
	color: var(--accent-600);
	text-decoration: none;
	border-bottom: 0.5px solid currentColor;
	padding-bottom: 1px;
	white-space: nowrap;
}
.rn-state-profile-link:hover { color: var(--accent-800); }

/* ── State silhouette (dedicated /rating-nacional/estado-X/ pages) ── */
.rn-state-card {
	background: var(--bg-elevated);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-md);
	padding: var(--space-6) var(--space-4);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-4);
}
.rn-state-card__svg {
	width: 100%;
	max-width: 320px;
	height: auto;
	display: block;
	filter: drop-shadow(0 4px 16px rgba(30, 58, 95, 0.18));
}
.rn-state-card__svg path {
	transition: fill var(--transition-base);
}
.rn-state-card__label {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding-top: var(--space-3);
	border-top: 1px solid var(--border-default);
	width: 100%;
}
.rn-state-card__code {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	color: var(--text-tertiary);
	text-transform: uppercase;
}
.rn-state-card__name {
	font-family: var(--font-display);
	font-size: 24px;
	font-weight: 500;
	color: var(--text-primary);
	letter-spacing: -0.01em;
}

.rn-hero__back {
	display: inline-block;
	margin-top: var(--space-3);
	font-size: 14px;
	font-weight: 500;
	color: var(--accent-600);
	border-bottom: 0.5px solid currentColor;
	padding-bottom: 1px;
	text-decoration: none;
}
.rn-hero__back:hover { color: var(--accent-800); }

/* "Otros estados" grid — only shown on /estado-X/ pages for sideways nav. */
.rn-other-states {
	margin-top: var(--space-12);
	padding-top: var(--space-8);
	border-top: 1px solid var(--border-default);
}
.rn-other-states__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: var(--space-2);
}
.rn-other-states__grid a {
	display: grid;
	grid-template-columns: 44px 1fr auto;
	align-items: center;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-sm);
	background: var(--bg-page);
	color: var(--text-primary);
	text-decoration: none;
	transition: border-color var(--transition-fast), background var(--transition-fast);
}
.rn-other-states__grid a:hover {
	border-color: var(--accent-600);
	background: var(--bg-accent-subtle);
}
.rn-other-states__code {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.04em;
	color: var(--text-secondary);
	background: var(--bg-muted);
	padding: 4px 6px;
	border-radius: 3px;
	text-align: center;
}
.rn-other-states__grid a:hover .rn-other-states__code {
	color: var(--accent-600);
	background: var(--accent-50);
}
.rn-other-states__name {
	font-size: 14px;
	font-weight: 500;
}
.rn-other-states__count {
	font-family: var(--font-mono);
	font-size: 12px;
	color: var(--text-tertiary);
	font-variant-numeric: tabular-nums;
}

/* ============================================================
   RANKING
   ============================================================ */
.rn-search-row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--space-2);
	margin-bottom: var(--space-3);
}
.rn-filter-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2);
	margin-bottom: var(--space-4);
}
.rn-search { position: relative; }
.rn-search input {
	width: 100%;
	font-family: var(--font-body);
	font-size: 15px;
	padding: 11px 12px 11px 40px;
	border: 1px solid var(--border-strong);
	border-radius: var(--radius-sm);
	background: var(--bg-page);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.rn-search input:focus {
	outline: none;
	border-color: var(--accent-600);
	box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.15);
}
.rn-search svg {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	color: var(--text-secondary);
}
.rn-btn-search {
	padding: 0 20px;
	font-size: 14px;
	font-weight: 500;
	background: var(--accent-600);
	color: var(--text-on-accent);
	border-radius: var(--radius-sm);
	border: 0;
	cursor: pointer;
	white-space: nowrap;
	line-height: 1;
	transition: background var(--transition-fast);
}
.rn-btn-search:hover { background: var(--accent-800); }
.rn-btn-search:active { transform: translateY(1px); }

.rn-filter-row select {
	font-family: var(--font-body);
	font-size: 13px;
	padding: 9px 32px 9px 12px;
	background: var(--bg-page);
	border: 1px solid var(--border-strong);
	border-radius: var(--radius-sm);
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888780' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 10px center;
	cursor: pointer;
}

.rn-filter-status {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--text-tertiary);
	margin-bottom: var(--space-4);
	letter-spacing: 0.04em;
}
.rn-filter-status .num { color: var(--text-secondary); font-weight: 500; }

.rn-table { width: 100%; border-collapse: collapse; }
.rn-table thead th {
	font-family: var(--font-mono);
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--text-tertiary);
	padding: var(--space-3) var(--space-2);
	border-bottom: 1px solid var(--border-default);
	text-align: left;
	font-weight: 500;
}
.rn-table thead th.num,
.rn-table tbody td.num {
	text-align: right;
	font-variant-numeric: tabular-nums;
	font-family: var(--font-mono);
}
.rn-table tbody tr {
	cursor: pointer;
	transition: background var(--transition-fast);
}
.rn-table tbody tr:hover { background: var(--bg-muted); }
.rn-table tbody td {
	padding: var(--space-3) var(--space-2);
	border-bottom: 1px solid var(--border-default);
	vertical-align: middle;
}
.rn-table tbody tr.is-top-3 .rn-rank-cell {
	color: var(--accent-600);
	font-weight: 600;
}
.rn-table .rn-rank-cell { width: 36px; }
.rn-table .rn-name-cell { font-weight: 500; }
.rn-table .rn-meta-cell {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	margin-top: 2px;
	flex-wrap: wrap;
}
.rn-table .rn-state-badge {
	background: var(--bg-muted);
	padding: 1px 6px;
	border-radius: 2px;
	font-family: var(--font-mono);
	font-size: 10px;
	color: var(--text-secondary);
	letter-spacing: 0.04em;
}
.rn-table .rn-age {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--text-tertiary);
}
.rn-table .rn-title {
	background: var(--accent-600);
	color: var(--text-on-accent);
	padding: 1px 4px;
	border-radius: 2px;
	font-family: var(--font-mono);
	font-size: 9px;
	font-weight: 600;
	letter-spacing: 0.05em;
}
.rn-table .rn-rating-cell {
	font-size: 17px;
	font-weight: 500;
	width: 80px;
}
.rn-table.is-loading { opacity: 0.5; pointer-events: none; }

.rn-pagination {
	margin-top: var(--space-6);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-1);
	flex-wrap: wrap;
}
.rn-pagination button {
	min-width: 36px;
	height: 36px;
	padding: 0 12px;
	font-size: 13px;
	border: 1px solid var(--border-default);
	border-radius: var(--radius-sm);
	color: var(--text-secondary);
	background: var(--bg-page);
	cursor: pointer;
	transition: all var(--transition-fast);
}
.rn-pagination button:hover:not(:disabled):not(.is-current) {
	background: var(--bg-muted);
	color: var(--text-primary);
}
.rn-pagination button.is-current {
	background: var(--accent-600);
	color: var(--text-on-accent);
	border-color: var(--accent-600);
}
.rn-pagination button:disabled { opacity: 0.35; cursor: not-allowed; }
.rn-pagination .ellipsis {
	padding: 0 6px;
	color: var(--text-tertiary);
	user-select: none;
}

/* ============================================================
   INFO STRIP
   ============================================================ */
.rn-info-strip {
	margin-top: var(--space-12);
	padding-top: var(--space-8);
	border-top: 1px solid var(--border-default);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-12);
}
.rn-info__eyebrow {
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--accent-600);
	margin: 0 0 var(--space-3);
	font-weight: 500;
}
.rn-info-block h3 {
	font-family: var(--font-display);
	font-size: 22px;
	font-weight: 500;
	margin: 0 0 var(--space-2);
}
.rn-info-block p {
	font-size: 14px;
	line-height: 1.6;
	color: var(--text-secondary);
	margin: 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
	.rn-hero__grid { grid-template-columns: 1fr; gap: var(--space-8); }
	.rn-hero__stats {
		flex-direction: row;
		border-left: none;
		border-top: 1px solid var(--border-default);
		padding-left: 0;
		padding-top: var(--space-6);
		gap: var(--space-12);
	}
	.rn-grid { grid-template-columns: 1fr; gap: var(--space-12); }
	.rn-map { position: static; }
	.rn-info-strip { grid-template-columns: 1fr; gap: var(--space-8); }

	/* Break the map card out of container padding so the SVG can use the
	   full viewport width. Drops side borders + radius for a clean
	   edge-to-edge band; top/bottom borders stay for visual separation. */
	.rn-map__card {
		margin-left: calc(-1 * var(--container-padding));
		margin-right: calc(-1 * var(--container-padding));
		border-left: 0;
		border-right: 0;
		border-radius: 0;
		padding-left: var(--space-2);
		padding-right: var(--space-2);
	}
}

@media (max-width: 720px) {
	.rn-hero__stats { flex-direction: column; gap: var(--space-4); }
	.rn-stat__value { font-size: 28px; }

	/* Mobile ranking: stack into card-style rows */
	.rn-table thead { display: none; }
	.rn-table, .rn-table tbody, .rn-table tr, .rn-table td { display: block; width: 100%; }
	.rn-table tbody tr {
		display: grid;
		grid-template-columns: 32px 1fr auto;
		gap: var(--space-3);
		padding: var(--space-3) 0;
		align-items: center;
		border-bottom: 1px solid var(--border-default);
	}
	.rn-table tbody td { padding: 0; border-bottom: none; }
	.rn-table .rn-rank-cell {
		font-family: var(--font-mono);
		color: var(--text-tertiary);
		text-align: right;
	}
	.rn-table .rn-player-cell { min-width: 0; }
	.rn-table .rn-player-cell .rn-name-cell {
		font-size: 14px;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}
	.rn-table .rn-rating-cell { font-size: 16px; }
}

/* ============================================================
   PROMO MODAL ("¿Eres tú?")
   ============================================================ */
.rn-promo-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
}
.rn-promo-modal[hidden] { display: none; }
.rn-promo-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(22, 22, 22, 0.6);
	backdrop-filter: blur(2px);
}
.rn-promo-modal__card {
	position: relative;
	width: 100%;
	max-width: 460px;
	padding: var(--space-8) var(--space-6) var(--space-6);
	background: var(--bg-page);
	border: 1px solid var(--border-default);
	border-radius: var(--radius-md, 6px);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
	text-align: center;
}
.rn-promo-modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 32px;
	height: 32px;
	padding: 0;
	background: transparent;
	border: 0;
	font-size: 22px;
	line-height: 1;
	color: var(--text-tertiary);
	cursor: pointer;
}
.rn-promo-modal__close:hover { color: var(--text-primary); }
.rn-promo-modal__eyebrow {
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-tertiary);
	margin: 0 0 var(--space-3);
}
.rn-promo-modal__title {
	font-family: var(--font-display);
	font-size: 28px;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--text-primary);
	margin: 0 0 var(--space-3);
}
.rn-promo-modal__body {
	font-size: 15px;
	color: var(--text-secondary);
	margin: 0 0 var(--space-6);
}
.rn-promo-modal__actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: center;
}
.rn-promo-modal__dismiss {
	background: transparent;
	border: 0;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-tertiary);
	cursor: pointer;
	padding: 6px 8px;
}
.rn-promo-modal__dismiss:hover { color: var(--text-primary); }

/* ============================================================
   CROSS-LINK CTA (bottom banner)
   Mirrors .tn-cross-link pattern (torneos.css).
   ============================================================ */
.rn-cross-link {
	padding: var(--space-16) var(--container-padding);
	background: var(--neutral-1000);
	color: var(--text-on-accent);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.rn-cross-link::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		conic-gradient(from 90deg at 8px 8px, rgba(255, 255, 255, 0.025) 90deg, transparent 0 180deg, rgba(255, 255, 255, 0.025) 0 270deg, transparent 0) 0 0 / 16px 16px,
		radial-gradient(ellipse at 20% 30%, rgba(74, 107, 142, 0.30), transparent 50%),
		radial-gradient(ellipse at 80% 70%, rgba(30, 58, 95, 0.25), transparent 50%);
	pointer-events: none;
	opacity: 0.95;
}
.rn-cross-link__inner { position: relative; max-width: 720px; margin: 0 auto; }
.rn-cross-link__eyebrow {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--accent-200);
	margin: 0 0 var(--space-4);
}
.rn-cross-link h2 {
	font-family: var(--font-display);
	font-size: clamp(32px, 6vw, 52px);
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.01em;
	margin: 0 0 var(--space-4);
}
.rn-cross-link h2 em { font-style: italic; color: var(--accent-200); }
.rn-cross-link p {
	font-size: 16px;
	color: var(--neutral-200);
	margin: 0 auto var(--space-8);
	max-width: 540px;
}
.rn-cta-primary {
	display: inline-block;
	padding: 14px 28px;
	background: var(--neutral-1000);
	color: var(--text-on-accent);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: background var(--transition-fast);
}
.rn-cta-primary:hover { background: var(--accent-600); }
.rn-cta-primary[hidden] { display: none; }
/* On the dark cross-link banner, invert: white fill on dark surroundings. */
.rn-cross-link .rn-cta-primary {
	background: var(--neutral-0);
	color: var(--text-primary);
}
.rn-cross-link .rn-cta-primary:hover { background: var(--accent-50); }
