/*--------------------------------------------------------------
Page Header - Estilos
--------------------------------------------------------------*/

.page-header {
}

/*
 * Evita margen inferior “colgando” tras el último bloque: el espacio bajo la cabecera
 * lo marca solo lo que venga después (p. ej. .gap-M), no margin-bottom del último hijo.
 */
.page-header .contenedor > :last-child {
	margin-bottom: 0;
}

.page-header-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	margin-bottom: 0;
	color: var(--body-text-100);
}

.page-header-breadcrumb + .page-header__row {
	margin-top: 1rem;
}

.page-header-breadcrumb-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	text-decoration: none;
	transition: opacity 0.3s ease;
	margin-right: 24px;
}

.page-header-breadcrumb-icon:hover {
	opacity: 0.8;
}

.page-header-breadcrumb-icon img {
	width: 40px;
	height: 40px;
	display: block;
}

.page-header-breadcrumb-item {
	color: var(--body-text-100);
	text-decoration: none;
	transition: color 0.3s ease;
	margin-right: 24px;
}

.page-header-breadcrumb-item:last-child {
	margin-right: 0;
}

.page-header-breadcrumb-item:hover {
	color: var(--secondary-100);
}

.page-header-breadcrumb-item.current {
	color: var(--black-60);
	cursor: default;
}

.page-header-breadcrumb-item.current:hover {
	color: var(--black-60);
}

.page-header-breadcrumb-separador {
	display: flex;
	align-items: center;
	color: var(--secondary-60);
	flex-shrink: 0;
	margin-right: 24px;
}

.page-header-breadcrumb-separador svg {
	width: 12px;
	height: 12px;
	display: block;
	transform: rotate(-90deg);
}

.page-header__row {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 1.5rem;
}

.page-header__copy {
	flex: 0 1 auto;
	width: 100%;
	min-width: 0;
}

.page-header__aside {
	display: flex;
	flex-shrink: 0;
	flex-direction: column;
	justify-content: flex-end;
	align-items: flex-end;
	align-self: flex-end;
	gap: 12px;
}

.page-header__secondary-btn {
	flex-shrink: 0;
	white-space: nowrap;
	text-align: center;
}

.page-header-heading {
	margin-bottom: 1rem;
	color: var(--secondary-100);
	text-wrap: balance;
}

/* Si hay subtítulo o intro, el espacio lo aportan ellos por arriba (mejor alineación con .page-header__aside). */
.page-header__copy:has(.page-header-subheading) .page-header-heading,
.page-header__copy:has(.page-header-texto) .page-header-heading {
	margin-bottom: 0;
}

.page-header__copy > .page-header-subheading:first-child,
.page-header__copy > .page-header-texto:first-child {
	margin-top: 0;
}

.page-header-subheading {
	margin-top: 1rem;
	margin-bottom: 0;
	color: var(--secondary-60);
	text-wrap: balance;
}

/* Nombre de cliente (caso de éxito): escala title-XS + peso light, familia y color de texto body */
.page-header-subheading.page-header-subheading--text-body {
	font-family: var(--font-body);
	color: var(--body-text-100);
}

.page-header-texto {
	margin-top: 1rem;
	margin-bottom: 0;
	color: var(--body-text-100);
}

@media screen and (min-width: 992px) {
	.page-header__row {
		flex-direction: row;
		flex-wrap: wrap;
		align-items: stretch;
		justify-content: space-between;
	}

	.page-header__copy {
		flex: 1 1 0;
		max-width: 900px;
	}

	.page-header__aside {
		align-self: stretch;
	}

	.page-header-breadcrumb-item {
		margin-right: 56px;
	}

	.page-header-breadcrumb-separador {
		margin-right: 56px;
	}
}

.page-header-texto p {
	margin-bottom: 1rem;
}

.page-header-texto p:last-child {
	margin-bottom: 0;
}

/* Responsive */
@media screen and (max-width: 767px) {
	.page-header {
		padding-top: 1.5rem;
	}
	
	.page-header-heading {
		margin-bottom: 0.75rem;
	}

	.page-header__copy:has(.page-header-subheading) .page-header-heading,
	.page-header__copy:has(.page-header-texto) .page-header-heading {
		margin-bottom: 0;
	}

	.page-header-subheading {
		margin-top: 0.75rem;
		margin-bottom: 0;
	}
}

/*--------------------------------------------------------------
Calendly FAB (global; se incluye desde header.php)
--------------------------------------------------------------*/

/* Sin AOS en el pie: el FAB puede llevar .calendly-fab--ready ya en el HTML; el script solo refuerza y gestiona ocultar ante footer. */
.calendly-fab {
	--calendly-fab-fade-dur: 0.55s;
	--calendly-fab-fade-ease: cubic-bezier(0.4, 0, 0.2, 1);
	--calendly-fab-appear-dur: 0.65s;
	--calendly-fab-pulse-period: 0.9s;
	--calendly-fab-btn-size: 60px;
	position: fixed;
	z-index: 10060;
	/* Doble declaración: fallback plano primero, luego con safe-area-inset */
	right: 48px;
	right: calc( 48px + env( safe-area-inset-right, 0px ) );
	bottom: 48px;
	bottom: calc( 48px + env( safe-area-inset-bottom, 0px ) );
	/* Tamaño explícito: evita el cálculo erróneo de max-content en grids Android */
	display: block;
	width: 60px;
	width: var( --calendly-fab-btn-size );
	height: 60px;
	height: var( --calendly-fab-btn-size );
	overflow: visible;
	opacity: 0;
	visibility: visible;
	transition: opacity var(--calendly-fab-appear-dur) var(--calendly-fab-fade-ease);
}

.calendly-fab.calendly-fab--ready {
	opacity: 1;
}

/*
 * Disco semitransparente detrás del botón (relleno uniforme, sin borde hueco).
 * Al escalar, la corona entre el borde del botón y el borde exterior es color continuo;
 * no aparece el fondo de la página en una ranura como con un anillo solo-borde.
 */
.calendly-fab .calendly-fab__pulse {
	/* Superpuesto al botón mediante posición absoluta (el FAB fixed actúa como containing block) */
	position: absolute;
	inset: 0;
	display: block;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 50%;
	/* secondary-100 semitransparente: contraste con accent-80 del botón (antes que igualar al fondo). */
	background-color: rgba(25, 108, 135, 0.34);
	pointer-events: none;
	z-index: 0;
	transform-origin: center center;
}

.calendly-fab.calendly-fab--ready .calendly-fab__pulse {
	animation: calendly-fab-pulse-disk var(--calendly-fab-pulse-period) linear infinite;
}

/*
 * Ciclo 900ms: abrir 400ms (ease-out) → cerrar 250ms (ease-out) → reposo 250ms.
 * Opacidad: hasta el pico (~44.4%) 0.88→0.1; +80ms hasta ~53.3% 0.1→0 (igual ritmo que antes con ciclo 1s).
 */
@keyframes calendly-fab-pulse-disk {
	0% {
		transform: scale(1);
		opacity: 0.88;
		animation-timing-function: ease-out;
	}
	44.44% {
		transform: scale(1.62);
		opacity: 0.1;
		animation-timing-function: ease-out;
	}
	53.33% {
		transform: scale(1.4);
		opacity: 0;
		animation-timing-function: ease-out;
	}
	58.33% {
		transform: scale(1.28);
		opacity: 0;
		animation-timing-function: ease-out;
	}
	72.22% {
		transform: scale(1);
		opacity: 0;
		animation-timing-function: linear;
	}
	72.23%,
	100% {
		transform: scale(1);
		opacity: 0;
	}
}

/* visibility: hidden al instante mata el fundido de opacity: el cambio a hidden va al acabar el fade. */
.calendly-fab.calendly-fab--hidden {
	pointer-events: none;
	visibility: hidden;
	opacity: 0;
	transition:
		opacity var(--calendly-fab-fade-dur) var(--calendly-fab-fade-ease),
		visibility 0s var(--calendly-fab-fade-ease) var(--calendly-fab-fade-dur);
}

.calendly-fab .calendly-fab__btn {
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 50%;
	background-color: var( --accent-80, #9ed3c9 );
	color: var( --secondary-100, #196c87 );
	text-decoration: none;
	cursor: pointer;
	line-height: 0;
	overflow: visible;
	box-shadow: 0 6px 20px rgba( 25, 108, 135, 0.18 );
	transition: opacity 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.calendly-fab .calendly-fab__btn:hover {
	opacity: 0.95;
	transform: scale( 0.96 );
	box-shadow: 0 10px 28px rgba( 25, 108, 135, 0.22 );
}

.calendly-fab .calendly-fab__btn:active {
	transform: scale( 0.94 );
	box-shadow: 0 6px 16px rgba( 25, 108, 135, 0.16 );
}

.calendly-fab .calendly-fab__btn:focus-visible {
	outline: 2px solid var( --secondary-100, #196c87 );
	outline-offset: 3px;
}

.calendly-fab .calendly-fab__icon {
	display: block;
	width: 28px;
	height: 28px;
	flex-shrink: 0;
}

@media (max-width: 360px) {
	.calendly-fab {
		right: 12px;
		right: calc( 12px + env( safe-area-inset-right, 0px ) );
		bottom: 12px;
		bottom: calc( 12px + env( safe-area-inset-bottom, 0px ) );
	}
}

@media (prefers-reduced-motion: reduce) {
	.calendly-fab {
		--calendly-fab-fade-dur: 0.01ms;
		--calendly-fab-appear-dur: 0.01ms;
		/* .calendly-fab--ready lo aplica el script al inicio; transición casi instantánea. */
	}

	.calendly-fab .calendly-fab__btn,
	.calendly-fab .calendly-fab__btn:hover,
	.calendly-fab .calendly-fab__btn:active {
		transition-duration: 0.01ms;
		transform: none;
	}

	.calendly-fab .calendly-fab__btn:hover,
	.calendly-fab .calendly-fab__btn:active {
		box-shadow: 0 6px 20px rgba( 25, 108, 135, 0.18 );
	}

	.calendly-fab.calendly-fab--ready .calendly-fab__pulse {
		animation: none;
		opacity: 0;
	}
}
