/**
 * Página del Alcalde — perfil institucional estático.
 */

.ngz-page-hero--alcalde {
	background: linear-gradient(135deg, rgba(13, 51, 32, 0.05) 0%, rgba(45, 140, 86, 0.1) 100%);
}

.ngz-page--alcalde .ngz-page__body {
	padding-top: 2rem;
	padding-bottom: 3.5rem;
}

.ngz-alcalde-profile {
	display: grid;
	grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
	gap: 2rem 2.5rem;
	align-items: start;
	margin-bottom: 2.5rem;
}

.ngz-alcalde-profile__photo-wrap {
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 18px 40px rgba(13, 51, 32, 0.14);
	border: 1px solid rgba(45, 140, 86, 0.12);
}

.ngz-alcalde-profile__photo-wrap::before {
	content: '';
	position: absolute;
	inset: auto -18% -18% auto;
	width: 72%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(45, 140, 86, 0.22) 0%, transparent 70%);
	pointer-events: none;
}

.ngz-alcalde-profile__photo {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.ngz-alcalde-profile__period {
	margin: 0 0 0.35rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ngz-verde-2, #2d8c56);
}

.ngz-alcalde-profile__name {
	margin: 0 0 0.35rem;
	font-family: var(--ngz-font-serif, 'Lora', serif);
	font-size: clamp(1.5rem, 2.4vw, 2rem);
	line-height: 1.15;
	color: var(--ngz-oscuro, #0d3320);
}

.ngz-alcalde-profile__role {
	margin: 0 0 1.25rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--ngz-suave, #4a6355);
}

.ngz-alcalde-profile__vision {
	margin: 0;
	padding: 1.1rem 1.25rem;
	border-left: 4px solid var(--ngz-dorado, #e8b923);
	border-radius: 0 0.75rem 0.75rem 0;
	background: rgba(45, 140, 86, 0.06);
}

.ngz-alcalde-profile__vision p {
	margin: 0;
	font-family: var(--ngz-font-serif, 'Lora', serif);
	font-size: 1.0625rem;
	line-height: 1.65;
	font-style: italic;
	color: var(--ngz-oscuro, #0d3320);
}

.ngz-alcalde-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.25rem;
	margin-bottom: 2.5rem;
}

.ngz-alcalde-section {
	padding: 1.25rem 1.35rem;
	border: 1px solid rgba(13, 51, 32, 0.08);
	border-radius: 0.85rem;
	background: #fff;
	box-shadow: 0 8px 24px rgba(13, 51, 32, 0.04);
}

.ngz-alcalde-section__title {
	margin: 0 0 0.75rem;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ngz-verde-2, #2d8c56);
}

.ngz-alcalde-section p {
	margin: 0 0 0.85rem;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--ngz-texto, #1a2e24);
}

.ngz-alcalde-section p:last-child {
	margin-bottom: 0;
}

.ngz-alcalde-feature {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(260px, 42%);
	gap: 2rem;
	align-items: center;
	margin-bottom: 2.5rem;
	padding: 1.5rem;
	border-radius: 1rem;
	background: linear-gradient(135deg, rgba(13, 51, 32, 0.03) 0%, rgba(45, 140, 86, 0.05) 100%);
}

.ngz-alcalde-feature--reverse {
	grid-template-columns: minmax(260px, 42%) minmax(0, 1fr);
}

.ngz-alcalde-feature--reverse .ngz-alcalde-feature__media {
	order: 2;
}

.ngz-alcalde-feature--reverse .ngz-alcalde-feature__body {
	order: 1;
}

.ngz-alcalde-feature__media img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 0.85rem;
	box-shadow: 0 12px 28px rgba(13, 51, 32, 0.12);
}

.ngz-alcalde-feature__title {
	margin: 0 0 0.35rem;
	font-family: var(--ngz-font-serif, 'Lora', serif);
	font-size: 1.375rem;
	color: var(--ngz-oscuro, #0d3320);
}

.ngz-alcalde-feature__subtitle {
	margin: 0 0 0.85rem;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ngz-verde-2, #2d8c56);
}

.ngz-alcalde-feature__body p {
	margin: 0;
	font-size: 0.96875rem;
	line-height: 1.7;
	color: var(--ngz-texto, #1a2e24);
}

.ngz-alcalde-contact {
	padding: 1.5rem 1.75rem;
	border-radius: 1rem;
	border: 1px solid rgba(45, 140, 86, 0.14);
	background: rgba(45, 140, 86, 0.05);
}

.ngz-alcalde-contact__title {
	margin: 0 0 1rem;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ngz-verde-2, #2d8c56);
}

.ngz-alcalde-contact__list {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem 1.5rem;
	margin: 0;
}

.ngz-alcalde-contact__item {
	margin: 0;
}

.ngz-alcalde-contact__item dt {
	margin: 0 0 0.25rem;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: rgba(13, 51, 32, 0.55);
}

.ngz-alcalde-contact__item dd {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--ngz-oscuro, #0d3320);
}

.ngz-alcalde-contact__item a {
	color: var(--ngz-verde-1, #0d3320);
	font-weight: 600;
	text-decoration: none;
}

.ngz-alcalde-contact__item a:hover {
	color: var(--ngz-verde-2, #2d8c56);
	text-decoration: underline;
}

@media (max-width: 960px) {
	.ngz-alcalde-grid {
		grid-template-columns: 1fr;
	}

	.ngz-alcalde-feature,
	.ngz-alcalde-feature--reverse {
		grid-template-columns: 1fr;
	}

	.ngz-alcalde-feature--reverse .ngz-alcalde-feature__media,
	.ngz-alcalde-feature--reverse .ngz-alcalde-feature__body {
		order: initial;
	}

	.ngz-alcalde-contact__list {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.ngz-alcalde-profile {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}

	.ngz-alcalde-profile__photo-wrap {
		max-width: 280px;
	}
}
