/*--------------------------------------------------------------
# Landing Contacto (page-contacto.php) — maquetación alineada con Figma
--------------------------------------------------------------*/

.contacto-landing__marca-wrap {
	display: flex;
	justify-content: center;
}

.contacto-landing__marca {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	box-sizing: border-box;
	border: 1px solid var(--primary-60, #bed9e2);
	background-color: var(--white-100, #fff);
}

.contacto-landing__marca-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

 
.contacto-landing__cards {
	padding: clamp(1rem, 3vw, 2rem) 0;
}

.contacto-landing__cards-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 3vw, 1.5rem);
}

@media (min-width: 768px) {
	.contacto-landing__cards-inner {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.contacto-card {
	box-sizing: border-box;
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: clamp(0.75rem, 2vw, 1rem);
	margin: 0;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	text-align: left;
	background-color: var(--white-100, #fff);
	border: 1px solid var(--primary-60, #bed9e2);
	border-radius: 24px;
	min-width: 0;
}

.contacto-card__icon {
	display: flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	margin: 0;
	border-radius: 50%;
	background-color: var(--secondary-100, #196c87);
	color: var(--white-100, #fff);
}

.contacto-card__body {
	flex: 1;
	min-width: 0;
}

.contacto-card__titulo {
	margin: 0 0 32px;
	color: var(--secondary-100, #196c87);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	text-align: left;
}

.contacto-card__icon-img {
	display: block;
	width: 28px;
	height: 28px;
	margin: 0 auto;
	object-fit: contain;
}

.contacto-card__direccion p,
.contacto-card__correo-html p {
	margin: 0;
}

.contacto-card__direccion p + p,
.contacto-card__correo-html p + p {
	margin-top: 0.35em;
}

.contacto-card__texto {
	margin: 0;
}

.contacto-card__texto + .contacto-card__texto {
	margin-top: 0.25rem;
}

/* Tarjeta email: mailto como texto body (make_clickable + enlaces explícitos), todos los estados */
.contacto-card__correo-html a,
.contacto-card__texto a.contacto-card__link {
	color: var(--body-text-100);
	text-decoration: none;
	font-weight: inherit;
}

.contacto-card__correo-html a:link,
.contacto-card__correo-html a:visited,
.contacto-card__correo-html a:hover,
.contacto-card__correo-html a:active,
.contacto-card__correo-html a:focus,
.contacto-card__correo-html a:focus-visible,
.contacto-card__texto a.contacto-card__link:link,
.contacto-card__texto a.contacto-card__link:visited,
.contacto-card__texto a.contacto-card__link:hover,
.contacto-card__texto a.contacto-card__link:active,
.contacto-card__texto a.contacto-card__link:focus,
.contacto-card__texto a.contacto-card__link:focus-visible {
	color: var(--body-text-100);
	text-decoration: none;
}

.contacto-card__correo-html a:focus-visible,
.contacto-card__texto a.contacto-card__link:focus-visible {
	outline: 2px solid var(--body-text-100);
	outline-offset: 2px;
}

/* En móvil, permitir partir emails largos dentro de la tarjeta. */
.contacto-card__correo-html,
.contacto-card__texto--mailto,
.contacto-card__correo-html a,
.contacto-card__texto--mailto a.contacto-card__link {
	overflow-wrap: anywhere;
	word-break: break-word;
}

.contacto-card__social {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	gap: 0.5rem;
	color: inherit;
	text-decoration: none;
	font-weight: 400;
}

.contacto-card__social:hover,
.contacto-card__social:focus-visible {
	color: var(--secondary-100, #196c87);
}

.contacto-card__linkedin {
	flex-shrink: 0;
	color: var(--secondary-60, #75a7b7);
}

.contacto-landing__formulario {
	padding: 0 0 clamp(1.5rem, 4vw, 2.5rem);
}

.contacto-landing__formulario-caja {
	box-sizing: border-box;
	padding: 32px;
	background-color: var(--white-100, #fff);
	border: 1px solid var(--primary-60, #bed9e2);
	border-radius: 24px;
}

@media (min-width: 992px) {
	.contacto-landing__formulario-caja {
		padding: 64px;
	}
}

.contacto-landing__notice {
	margin: 0 0 1.25rem;
	padding: 0.75rem 1rem;
	border-radius: 12px;
}

.contacto-landing__notice--ok {
	background-color: var(--accent-20, #e7f4f2);
	color: var(--secondary-100, #196c87);
}

.contacto-landing__notice--err {
	background-color: var(--primary-20, #e9f2f5);
	color: var(--body-text-100, #545454);
}

.contacto-landing__form-titulo {
	margin: 0 0 0.75rem;
	color: var(--secondary-100, #196c87);
}

.contacto-landing__form-titulo-line {
	height: 1px;
	width: 100%;
	background-color: var(--primary-60, #bed9e2);
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.contacto-form {
	position: relative;
}

.contacto-form__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 2.5vw, 1.25rem);
}

@media (min-width: 768px) {
	.contacto-form__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.contacto-form__field--full {
	grid-column: 1 / -1;
}

.contacto-form__label {
	display: block;
	margin: 0 0 0.35rem;
}

.contacto-form__req {
	color: var(--secondary-60, #75a7b7);
	margin-left: 0.15em;
}

.contacto-form__input,
.contacto-form__textarea,
.contacto-form__select {
	box-sizing: border-box;
	width: 100%;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--primary-60, #bed9e2);
	border-radius: 12px;
	background-color: var(--white-100, #fff);
	color: var(--body-text-100, #545454);
	font-family: inherit;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.contacto-form__input::placeholder,
.contacto-form__textarea::placeholder {
	color: var(--black-40, #a6a7a9);
	opacity: 1;
}

.contacto-form__select:required:invalid {
	color: var(--black-40, #a6a7a9);
}

.contacto-form__input:focus,
.contacto-form__textarea:focus,
.contacto-form__select:focus {
	outline: none;
	border-color: var(--secondary-100, #196c87);
	box-shadow: 0 0 0 2px rgba(25, 108, 135, 0.15);
}

.contacto-form__textarea {
	resize: vertical;
	min-height: 8rem;
}

.contacto-form__select-wrap {
	position: relative;
}

.contacto-form__select {
	appearance: none;
	padding-right: 2.5rem;
	background-image: url('../img/svg/chevron.svg');
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
	background-size: 14px 14px;
}

.contacto-form__recaptcha {
	margin-top: clamp(1rem, 2.5vw, 1.5rem);
}

.contacto-form__footer {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 1.25rem;
	margin-top: clamp(1.25rem, 3vw, 1.75rem);
}

.contacto-form__priv {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	max-width: 28rem;
	text-align: right;
	color: var(--body-text-100, #545454);
	cursor: pointer;
}

.contacto-form__priv input {
	flex-shrink: 0;
}

.contacto-form__priv a {
	color: var(--secondary-100, #196c87);
	text-decoration: underline;
	text-underline-offset: 0.12em;
}

.contacto-form__priv-falta {
	text-decoration: underline;
	color: var(--secondary-100, #196c87);
}

.contacto-form__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	margin: 0;
	padding: 0;
	border: 0;
	opacity: 0;
	overflow: hidden;
}

.contacto-landing__mapa {
	padding: clamp(1.25rem, 3vw, 2rem) 0;
}

.contacto-landing__mapa-box {
	width: 100%;
	border: 1px solid var(--primary-60, #bed9e2);
	border-radius: 20px;
	overflow: hidden;
	background-color: var(--secondary-10, #e8f0f3);
}

.contacto-landing__mapa-viewport {
	position: relative;
	width: 100%;
	height: 400px;
	overflow: hidden;
	background-color: var(--secondary-10, #e8f0f3);
}

.contacto-landing__mapa-google {
	position: absolute;
	inset: 0;
	z-index: 2;
	cursor: pointer;
}

.contacto-landing__mapa-viewport iframe {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
	z-index: 0;
}

.contacto-landing__mapa-google-embed--built {
	pointer-events: none;
	background-color: var(--secondary-10, #e8f0f3);
}

.contacto-landing__mapa-velo {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background-color: rgba(147, 191, 207, 0.29);
	background-color: color-mix(in srgb, #93bfcf 29%, transparent);
}

.contacto-landing__mapa-google:focus-visible {
	outline: 2px solid var(--secondary-100, #196c87);
	outline-offset: 2px;
}

.contacto-landing__extra-inner {
	max-width: 48rem;
	margin-left: auto;
	margin-right: auto;
}

.contacto-landing__extra-inner > *:first-child {
	margin-top: 0;
}

@media (max-width: 991px) {
	.contacto-landing__formulario-caja {
		padding: 20px 10px;
	}

	.contacto-landing__mapa-viewport {
		height: 500px;
	}

	.contacto-form__submit {
		width: 100%;
		justify-content: center !important;
		gap: 0.6rem;
		padding: 0 20px;
	}

	.contacto-form__submit.boton.primary.dark::after {
		position: relative;
		top: auto;
		right: auto;
		transform: none;
		margin-left: 0.15rem;
		flex: 0 0 auto;
	}
}
