/* ──────────────────────────────────────────────────────────────────
   Creinsa — sistema visual
   Marca: Azul #255E8A · Amarillo #F3CC13 · Azul oscuro #243263
   Tipografías: Oswald (display) · Inter (texto)
   ────────────────────────────────────────────────────────────── */

:root {
	--c-azul:        #255E8A;
	--c-azul-d:      #243263;
	--c-azul-2:      #1f4d72;
	--c-amarillo:    #F3CC13;
	--c-amarillo-2:  #FDDB58;
	--c-gris:        #EDEDEC;
	--c-gris-2:      #d8d8d6;
	--c-text:        #111418;
	--c-text-2:      #4a5563;
	--c-bg:          #ffffff;
	--c-bg-soft:     #f6f6f4;
	--c-line:        rgba(17,20,24,.12);

	--ff-display: "Oswald", "Helvetica Neue", Arial, sans-serif;
	--ff-body:    "Inter", "Helvetica Neue", Arial, sans-serif;

	/* Títulos: mínimo más bajo en móvil + subida progresiva en pantallas anchas (menos “torre” de líneas) */
	--fs-h1: clamp(1.65rem, 0.82rem + 4.1vw, 5.35rem);
	--fs-h2: clamp(1.38rem, 0.72rem + 2.65vw, 3.35rem);
	--fs-h3: clamp(1.4rem, 2vw, 1.9rem);
	--fs-body: 1.05rem;
	--fs-lead: 1.25rem;
	--fs-sm: .92rem;
	--fs-eyebrow: .82rem;

	--container: 1280px;
	--container-wide: 1480px;
	--gap: clamp(1rem, 2vw, 2rem);
	--section-y: clamp(4rem, 8vw, 7rem);
	/* Barra más compacta: logos sin padding en el archivo */
	--header-bar-h: 90px;

	--radius: 4px;
	--shadow: 0 24px 60px -32px rgba(36, 50, 99, .35);

	--ease: cubic-bezier(.2, .8, .2, 1);
	--dur:  .55s;
}

/* Sin desbordamiento horizontal (grids / pre / tablas accidentales) */
html {
	overflow-x: clip;
}
.site-main {
	min-width: 0;
}

/* Reset suave */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--ff-body);
	font-size: var(--fs-body);
	line-height: 1.6;
	color: var(--c-text);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

a {
	color: inherit;
	text-decoration: none;
	transition: color .25s var(--ease), background .25s var(--ease);
}
a:hover { color: var(--c-azul); }

h1, h2, h3, h4 {
	font-family: var(--ff-display);
	font-weight: 600;
	line-height: 1.12;
	letter-spacing: .01em;
	margin: 0 0 .55em;
	color: var(--c-azul-d);
	text-transform: uppercase;
	text-wrap: balance;
	hyphens: none;
}
h1 { font-size: var(--fs-h1); font-weight: 700; line-height: 1.1; }
h2 { font-size: var(--fs-h2); line-height: 1.12; }
h3 { font-size: var(--fs-h3); line-height: 1.15; }

p { margin: 0 0 1em; color: var(--c-text-2); }

::selection { background: var(--c-amarillo); color: var(--c-azul-d); }

/* Layout helpers */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 clamp(1.2rem, 4vw, 2.5rem);
}
.container.wide { max-width: var(--container-wide); }
.section { padding: var(--section-y) 0; }
.section.dark { background: var(--c-azul-d); color: #fff; }
.section.dark h1, .section.dark h2, .section.dark h3 { color: #fff; }
.section.dark p { color: rgba(255,255,255,.78); }
.section.soft { background: var(--c-bg-soft); }
.section-eyebrow {
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .25em;
	text-transform: uppercase;
	font-size: var(--fs-eyebrow);
	color: var(--c-azul);
	display: inline-flex;
	align-items: center;
	gap: .8rem;
	margin: 0 0 1rem;
}
.section-eyebrow::before {
	content: "";
	width: 32px;
	height: 2px;
	background: var(--c-amarillo);
}
.section.dark .section-eyebrow { color: var(--c-amarillo); }

/* Apertura de página: el título usa el ancho del container; solo el cuerpo .lead se acorta para lectura */
.page-hero-intro > .lead {
	max-width: 62ch;
}

.page-hero-intro--center {
	text-align: center;
}
.page-hero-intro--center .section-eyebrow {
	justify-content: center;
}
.page-hero-intro--center > .lead {
	margin-left: auto;
	margin-right: auto;
}

/* Bloques eyebrow + título (no apretar a 60ch: dispara muchos saltos en mayúsculas) */
.page-section-lead {
	max-width: min(44rem, 100%);
}
.page-section-lead > .lead {
	max-width: 62ch;
}
.page-section-lead--center {
	margin-left: auto;
	margin-right: auto;
	margin-bottom: clamp(1.5rem, 3vw, 2rem);
	text-align: center;
}
.page-section-lead--center .section-eyebrow {
	justify-content: center;
}

/* Fila título + CTA (portada y secciones similares) */
.section-heading-row {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 1rem 1.25rem;
	min-width: 0;
}
.section-heading-row > div {
	min-width: 0;
	flex: 1 1 min(28rem, 100%);
}
.section-heading-row > .btn {
	flex-shrink: 0;
	align-self: flex-end;
}
@media (max-width: 640px) {
	.section-heading-row {
		flex-direction: column;
		align-items: stretch;
	}
	.section-heading-row > .btn {
		align-self: stretch;
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 480px) {
	:root {
		--header-bar-h: 76px;
	}
	h1 { line-height: 1.14; }
	h2 { line-height: 1.16; }
}

/* Texto destacado dentro de fondo oscuro evita `.lead { color: gris }` heredando poco contraste */
.section.dark .lead {
	color: rgba(255,255,255, 0.9);
	max-width: 65ch;
}

/* Botones */
.btn {
	display: inline-flex;
	align-items: center;
	gap: .65rem;
	padding: 1rem 1.6rem;
	font-family: var(--ff-display);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-size: .95rem;
	background: var(--c-azul);
	color: #fff;
	border: 1px solid var(--c-azul);
	border-radius: var(--radius);
	cursor: pointer;
	transition: transform .35s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
	will-change: transform;
}
.btn:hover { background: var(--c-amarillo); color: var(--c-azul-d); border-color: var(--c-amarillo); transform: translateY(-2px); }
.btn .arrow { width: 18px; height: 18px; transition: transform .35s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

.btn.ghost { background: transparent; color: inherit; border-color: currentColor; }
.btn.ghost:hover { background: #fff; color: var(--c-azul-d); border-color: #fff; }

/* Header / nav */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	padding-top: env(safe-area-inset-top, 0px);
	backdrop-filter: saturate(140%) blur(10px);
	background: rgba(255,255,255,.92);
	border-bottom: 1px solid var(--c-line);
	/*
	 * `backdrop-filter` en escritorio; en ≤960px se anula más abajo.
	 * El panel móvil es `absolute` respecto a `.nav-shell`, no `fixed` al viewport.
	 */
	overflow: visible;
}
.site-header.invert {
	background: transparent;
	color: #fff;
	border-bottom-color: rgba(255,255,255,.18);
}
.site-header.invert .site-logo svg text,
.site-header.invert .site-logo svg g { color: #fff; }
.nav-shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: var(--header-bar-h);
	padding-block: 0.5rem;
	gap: clamp(0.65rem, 2.5vw, 2rem);
	flex-wrap: nowrap;
	position: relative;
}
.site-logo {
	color: var(--c-azul-d);
	display: inline-flex;
	align-items: center;
	flex: 1 1 auto;
	min-width: 0;
	max-width: 100%;
}
.site-logo svg { color: currentColor; }

/* Logo de marca (Customizer → Identidad → Logo): LOGOCOLOR */
.site-logo .custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}
.site-logo img.custom-logo,
.site-logo .custom-logo-link img {
	height: auto;
	width: auto;
	max-height: clamp(44px, 9vh, 68px);
	max-width: min(340px, 58vw);
	object-fit: contain;
}
.footer-logo .custom-logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 0;
}
.footer-logo .custom-logo-link img,
.footer-logo img.custom-logo,
.footer-logo .footer-brand-logo {
	max-height: 64px;
	max-width: min(260px, 78vw);
	object-fit: contain;
}
.footer-logo.footer-logo--negative {
	display: inline-flex;
	align-items: center;
	line-height: 0;
	color: #fff;
}
.primary-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: clamp(1rem, 2vw, 2.4rem);
	align-items: center;
}
.primary-nav a {
	font-family: var(--ff-display);
	font-weight: 500;
	font-size: 0.95rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	position: relative;
	padding: .5em 0;
}
.primary-nav a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 2px;
	background: var(--c-amarillo);
	transition: width .3s var(--ease);
}
.primary-nav a:hover::after,
.primary-nav .current-menu-item > a::after { width: 100%; }

.nav-cta {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	padding: .8rem 1.2rem;
	background: var(--c-azul-d);
	color: #fff;
	border-radius: var(--radius);
	font-family: var(--ff-display);
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-size: .85rem;
}
.nav-cta:hover { background: var(--c-amarillo); color: var(--c-azul-d); }

.nav-toggle { display: none; }

@media (min-width: 961px) {
	.nav-shell {
		justify-content: space-between;
	}
	.site-logo {
		flex: 0 0 auto;
		max-width: none;
	}
	.primary-nav {
		flex: 1 1 auto;
		min-width: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.primary-nav ul {
		justify-content: center;
		flex-wrap: wrap;
		row-gap: 0.35rem;
		column-gap: clamp(1rem, 2vw, 2.4rem);
	}
	.nav-cta {
		flex-shrink: 0;
	}
}

@media (max-width: 960px) {
	/*
	 * Panel `absolute` bajo `.nav-shell` (no `fixed`): evita huecos raros al redimensionar
	 * escritorio→móvil y fallos de sticky/`--creinsa-header-h` en Chrome/Android (p. ej. Xiaomi).
	 */
	.site-header {
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		background: rgba(255, 255, 255, 0.97);
	}
	.site-header.invert {
		background: rgba(255, 255, 255, 0.97);
		color: var(--c-azul-d);
		border-bottom-color: var(--c-line);
	}

	.site-logo {
		flex: 1 1 auto;
		min-width: 0;
		position: relative;
		z-index: 25;
	}

	.primary-nav {
		position: absolute;
		left: 50%;
		top: calc(100% + 0px);
		z-index: 15;
		width: 100vw;
		max-width: none;
		box-sizing: border-box;
		margin: 0;
		padding: 2rem clamp(1.25rem, 4vw, 2.5rem);
		background: var(--c-azul-d);
		color: #fff;
		transform: translate(-50%, -108%);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition:
			transform 0.45s var(--ease),
			opacity 0.35s var(--ease),
			visibility 0.45s var(--ease);
		max-height: min(82vh, 32rem);
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		box-shadow: 0 28px 56px rgba(17, 20, 24, 0.38);
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	}
	.primary-nav ul {
		flex-direction: column;
		align-items: stretch;
		gap: 1.2rem;
	}
	.primary-nav a {
		color: #fff;
		font-size: clamp(1.15rem, 4vw, 1.4rem);
	}
	.primary-nav a::after {
		background: var(--c-amarillo);
	}
	.menu-open .primary-nav {
		transform: translate(-50%, 0);
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
	}
	.nav-cta {
		display: none;
	}
	body.menu-open .site-header {
		z-index: 99999;
	}
	.nav-toggle {
		display: inline-flex;
		flex-shrink: 0;
		position: relative;
		z-index: 25;
		flex-direction: column;
		justify-content: center;
		gap: 5px;
		width: 44px;
		height: 44px;
		background: transparent;
		border: none;
		cursor: pointer;
	}
	.nav-toggle span {
		display: block;
		width: 24px;
		height: 2px;
		background: currentColor;
		transition: transform .3s var(--ease), opacity .3s var(--ease);
	}
	.menu-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
	.menu-open .nav-toggle span:nth-child(2) { opacity: 0; }
	.menu-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

/* Hero */
.hero {
	position: relative;
	min-height: 100vh;
	color: #fff;
	display: grid;
	align-items: end;
	overflow: hidden;
	isolation: isolate;
}
.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: var(--hero-img);
	background-size: cover;
	background-position: center;
	transform: scale(1.06);
	z-index: -2;
	animation: heroZoom 24s ease-in-out infinite alternate;
}
.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(36,50,99,.55) 0%, rgba(36,50,99,.85) 100%),
		linear-gradient(45deg, rgba(243,204,19,.08), transparent 60%);
	z-index: -1;
}
@keyframes heroZoom {
	from { transform: scale(1.04) translateY(0); }
	to   { transform: scale(1.12) translateY(-1.5%); }
}
.hero .container { padding-top: 8rem; padding-bottom: 6rem; }
.hero-eyebrow {
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .35em;
	text-transform: uppercase;
	font-size: .85rem;
	color: var(--c-amarillo);
	margin-bottom: 1.2rem;
	display: inline-flex;
	align-items: center;
	gap: .8rem;
}
.hero-eyebrow::before {
	content: "";
	width: 40px;
	height: 2px;
	background: var(--c-amarillo);
}
.hero h1 {
	color: #fff;
	max-width: min(36rem, 100%);
	font-size: clamp(1.75rem, 1rem + 5vw, 6.35rem);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -.01em;
	text-wrap: balance;
}
.hero .lead {
	max-width: 52ch;
	font-size: var(--fs-lead);
	color: rgba(255,255,255,.88);
	margin-top: 1.2rem;
}
.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2.4rem;
}
.hero-meta {
	margin-top: 4rem;
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	border-top: 1px solid rgba(255,255,255,.18);
	padding-top: 1.6rem;
}
.hero-meta .num {
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: clamp(2rem, 3.5vw, 3rem);
	line-height: 1;
	color: var(--c-amarillo);
	display: block;
}
.hero-meta .lbl {
	font-size: .85rem;
	color: rgba(255,255,255,.78);
	letter-spacing: .04em;
}

@media (max-width: 960px) {
	.hero {
		min-height: 100svh;
		min-height: 100dvh;
	}
	.hero .container {
		padding-top: clamp(5.25rem, 22vw, 8rem);
		padding-bottom: clamp(2rem, 8vw, 6rem);
	}
}

@media (max-width: 640px) {
	.hero-actions {
		flex-direction: column;
		align-items: stretch;
	}
	.hero-actions .btn {
		justify-content: center;
		width: 100%;
		max-width: 100%;
	}
}

@media (max-width: 480px) {
	.hero-meta {
		margin-top: clamp(2rem, 8vw, 4rem);
		padding-top: 1.25rem;
		gap: 1rem;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.hero-meta .num {
		font-size: clamp(1.65rem, 7vw, 2.35rem);
	}
	.hero-meta .lbl {
		font-size: .72rem;
		line-height: 1.35;
	}
	.hero-eyebrow {
		letter-spacing: .22em;
		font-size: .78rem;
	}
}

/* Bloques home */
.intro-claim {
	max-width: 60ch;
	font-size: clamp(1.4rem, 2.4vw, 2rem);
	line-height: 1.3;
	font-family: var(--ff-display);
	font-weight: 500;
	color: var(--c-azul-d);
	text-transform: uppercase;
}
.intro-claim em { font-style: normal; color: var(--c-azul); }

.steps {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--gap);
	counter-reset: step;
}
.step {
	background: #fff;
	border: 1px solid var(--c-line);
	padding: 2.2rem 1.8rem 2rem;
	position: relative;
	overflow: hidden;
	transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.step::before {
	counter-increment: step;
	content: counter(step, decimal-leading-zero);
	position: absolute;
	top: 1rem;
	right: 1.2rem;
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: 4.5rem;
	color: var(--c-gris);
	line-height: 1;
	transition: color .4s var(--ease);
}
.step:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow);
	border-color: var(--c-azul);
}
.step:hover::before { color: var(--c-amarillo); }
.step h3 { color: var(--c-azul-d); margin: 1rem 0 .5rem; }
.step p { color: var(--c-text-2); }
.step .step-icon {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--c-azul);
	color: #fff;
}
.step .step-link {
	margin-top: 1.4rem;
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-family: var(--ff-display);
	font-weight: 600;
	letter-spacing: .15em;
	text-transform: uppercase;
	font-size: .82rem;
	color: var(--c-azul);
}
.step .step-link::after { content: "→"; transition: transform .25s var(--ease); }
.step:hover .step-link::after { transform: translateX(4px); }

/* Tarjetas de proyecto */
.proyectos-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--gap);
}

/* Portada — evita que una sola tarjeta ocupe todo el ancho y quede ridiculamente alta (4/5 × 100% width) */
.proyectos-grid--home {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 360px));
	justify-content: center;
}
.proyectos-grid--home .card-proyecto {
	aspect-ratio: 3 / 2;
	max-width: 360px;
	width: 100%;
	margin-inline: auto;
}
.card-proyecto {
	position: relative;
	overflow: hidden;
	display: block;
	color: #fff;
	border-radius: var(--radius);
	aspect-ratio: 4/5;
	background: var(--c-azul-d);
}
.card-proyecto img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.04);
	transition: transform 1.2s var(--ease), filter .6s var(--ease);
	filter: brightness(.7) contrast(1.05);
}
.card-proyecto:hover img { transform: scale(1.12); filter: brightness(.55); }
.card-proyecto::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(0deg, rgba(36,50,99,.85) 0%, rgba(36,50,99,0) 65%);
}
.card-proyecto .card-body {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: 1.6rem 1.6rem 1.4rem;
	z-index: 2;
}
.card-proyecto .meta {
	display: inline-flex;
	gap: .6rem;
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .18em;
	text-transform: uppercase;
	font-size: .72rem;
	color: var(--c-amarillo);
}
.card-proyecto h3 {
	color: #fff;
	margin: .4rem 0 0;
	font-size: 1.5rem;
	letter-spacing: 0;
}
.card-proyecto .ubicacion {
	margin-top: .35rem;
	font-size: .9rem;
	color: rgba(255,255,255,.78);
}

@media (max-width: 480px) {
	.card-proyecto .card-body {
		padding: 1.25rem 1.15rem 1.05rem;
	}
	.card-proyecto h3 {
		font-size: 1.28rem;
		line-height: 1.18;
	}
	.card-proyecto .meta {
		font-size: .68rem;
		letter-spacing: .14em;
	}
}

/* Bloque proceso (cómo trabajamos) */
.process {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--gap);
	margin-top: 2rem;
	position: relative;
}
.process .pstep {
	border-top: 2px solid var(--c-amarillo);
	padding-top: 1.4rem;
}
.process .pstep .num {
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: clamp(2.65rem, 5vw, 3.35rem);
	color: var(--c-azul);
	line-height: 1;
	letter-spacing: 0.02em;
	display: inline-block;
}
.process .pstep h3 {
	margin: .8rem 0 .5rem;
	color: var(--c-azul-d);
	font-size: clamp(1.15rem, 2vw, 1.35rem);
}
.process .pstep p {
	color: var(--c-text-2);
	font-size: .98rem;
	line-height: 1.55;
}

/* Proceso en fondo oscuro (#243263): contraste alto (WCAG AA/AAA para tipos grandes) */
.section.dark .process .pstep {
	border-top-color: var(--c-amarillo);
}
.section.dark .process .pstep .num {
	color: var(--c-amarillo);
	font-size: clamp(2.6rem, 5vw, 3.25rem);
	letter-spacing: 0.02em;
}
.section.dark .process .pstep h3 {
	color: #fff;
}
.section.dark .process .pstep p {
	color: rgba(255, 255, 255, 0.9);
	max-width: 36ch;
}

/* Bloque pilares */
.pillars {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--gap);
}
.pillar {
	padding: 2rem;
	border: 1px solid rgba(255,255,255,.18);
	background: rgba(255,255,255,.04);
	transition: background .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.pillar:hover { background: rgba(255,255,255,.09); transform: translateY(-4px); }
.pillar h3 {
	color: #fff;
	font-size: 1.6rem;
	letter-spacing: .04em;
}
.pillar h3 small {
	display: block;
	color: var(--c-amarillo);
	font-size: .8rem;
	letter-spacing: .35em;
	margin-bottom: .8rem;
	font-weight: 500;
}
.pillar p { color: rgba(255,255,255,.78); }

/* CTA grande */
.cta-band {
	background: var(--c-amarillo);
	color: var(--c-azul-d);
	padding: var(--section-y) 0;
	position: relative;
	overflow: visible;
}
.cta-band h2 {
	color: var(--c-azul-d);
	font-size: clamp(1.42rem, 1rem + 2.4vw, 3.35rem);
	line-height: 1.12;
	margin-bottom: 1rem;
	text-wrap: balance;
	min-width: 0;
	overflow-wrap: break-word;
}
.cta-band .container {
	min-width: 0;
}
.cta-band .actions { display: flex; flex-wrap: wrap; gap: 1rem; }
@media (max-width: 560px) {
	.cta-band .actions {
		flex-direction: column;
		align-items: stretch;
	}
	.cta-band .actions .btn {
		width: 100%;
		justify-content: center;
	}
}
.cta-band .btn { background: var(--c-azul-d); color: #fff; border-color: var(--c-azul-d); }
.cta-band__grid.row {
	align-items: center;
}
.cta-band__lead {
	color: var(--c-azul-d);
	opacity: 0.88;
}
.cta-band__actions {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: flex-end;
	min-width: 0;
}
@media (max-width: 760px) {
	.cta-band__actions {
		justify-content: stretch;
		flex-direction: column;
	}
	.cta-band__actions .btn {
		width: 100%;
		justify-content: center;
	}
}
.cta-band .btn:hover { background: #fff; color: var(--c-azul-d); border-color: #fff; }
/* Secundario: contorno oscuro sobre amarillo (el inline azul + .cta-band .btn sólido dejaba texto invisible) */
.cta-band .btn.ghost {
	background: transparent;
	color: var(--c-azul-d);
	border-color: var(--c-azul-d);
	text-shadow: none;
}
.cta-band .btn.ghost:hover {
	background: rgba(36, 50, 99, 0.1);
	color: var(--c-azul-d);
	border-color: var(--c-azul-d);
}

/* Logos clientes */
.clients {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 2rem;
	align-items: center;
	opacity: .8;
}
.clients .client {
	font-family: var(--ff-display);
	font-weight: 600;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--c-text-2);
	text-align: center;
	font-size: .95rem;
	padding: .8rem 0;
	border: 1px solid var(--c-line);
}

/* Servicios layout */
.servicio-block {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
	margin-bottom: 5rem;
}
.servicio-block:nth-child(even) .servicio-img { order: 2; }
.servicio-block .servicio-img { aspect-ratio: 4/3; overflow: hidden; }
.servicio-block .servicio-img img { width: 100%; height: 100%; object-fit: cover; }
.servicio-block ul {
	margin: 1rem 0 1.5rem;
	padding: 0;
	list-style: none;
}
.servicio-block ul li {
	padding: .55rem 0 .55rem 1.6rem;
	border-bottom: 1px solid var(--c-line);
	position: relative;
	color: var(--c-text);
}
.servicio-block ul li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 1.05em;
	width: 12px;
	height: 2px;
	background: var(--c-amarillo);
}

@media (max-width: 760px) {
	.servicio-block { grid-template-columns: 1fr; }
	.servicio-block:nth-child(even) .servicio-img { order: 0; }
}

/* Filtro proyectos */
.filter-bar {
	display: flex;
	flex-wrap: nowrap;
	gap: .6rem;
	margin: 2rem 0 3rem;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	padding-bottom: .35rem;
	overscroll-behavior-x: contain;
}
.filter-bar::-webkit-scrollbar {
	height: 5px;
}
.filter-bar::-webkit-scrollbar-thumb {
	background: var(--c-line);
	border-radius: 999px;
}
.filter-btn {
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .18em;
	text-transform: uppercase;
	font-size: .8rem;
	padding: .65rem 1rem;
	border: 1px solid var(--c-line);
	background: transparent;
	color: var(--c-text);
	cursor: pointer;
	border-radius: var(--radius);
	transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
	flex: 0 0 auto;
}
.filter-btn:hover { border-color: var(--c-azul); color: var(--c-azul); }
.filter-btn.is-active {
	background: var(--c-azul-d);
	color: #fff;
	border-color: var(--c-azul-d);
}

/* Single proyecto */
.project-hero {
	min-height: clamp(240px, 48vh, 70vh);
	min-height: clamp(240px, 48svh, 70vh);
	color: #fff;
	display: grid;
	align-items: end;
	background: var(--c-azul-d);
	position: relative;
	isolation: isolate;
	overflow: hidden;
}
.project-hero img.bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -2;
	filter: brightness(.6);
}
.project-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(36,50,99,.4) 0%, rgba(36,50,99,.85) 100%);
	z-index: -1;
}
.project-hero .container {
	padding-top: clamp(5rem, 14vw, 7rem);
	padding-bottom: clamp(2rem, 5vw, 4rem);
}
.project-hero h1 {
	color: #fff;
	font-size: clamp(1.55rem, 0.9rem + 3.15vw, 4.55rem);
	line-height: 1.1;
	text-wrap: balance;
}
.project-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1.6rem 3rem;
	margin-top: 1.4rem;
	color: rgba(255,255,255,.85);
}
.project-meta .item span:first-child {
	display: block;
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .25em;
	text-transform: uppercase;
	font-size: .72rem;
	color: var(--c-amarillo);
	margin-bottom: .25rem;
}

@media (max-width: 600px) {
	.project-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem 0;
	}
	.project-meta .item {
		max-width: 100%;
	}
	.project-meta .item span:last-child {
		overflow-wrap: anywhere;
	}
}

.project-rrr {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--gap);
}
.project-rrr h3 { font-size: 1.2rem; color: var(--c-azul); letter-spacing: .15em; }

.project-gallery {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--gap);
}
.project-gallery img {
	width: 100%;
	height: auto;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--radius);
}
@media (max-width: 639px) {
	.project-gallery { grid-template-columns: 1fr; }
}

/* —— Conversiones + formularios B2B —— */
.creinsa-notice {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100002;
	padding: 1rem 1.25rem;
	text-align: center;
	font-size: var(--fs-sm);
	font-weight: 600;
	line-height: 1.35;
	box-shadow: 0 12px 32px rgba(17,20,24,.22);
	animation: creinsaSlideDown .45s var(--ease) both;
}
@keyframes creinsaSlideDown {
	from { transform: translateY(-100%); opacity: 0; }
	to { transform: translateY(0); opacity: 1; }
}
.creinsa-notice--success {
	background: var(--c-azul-d);
	color: #fff;
	border-bottom: 3px solid var(--c-amarillo);
}
.creinsa-notice--error {
	background: #4a1414;
	color: #fff;
}
.creinsa-notice a {
	color: var(--c-amarillo);
	text-decoration: underline;
	font-weight: 700;
}
.creinsa-notice a:hover { color: #fff; }

.creinsa-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
}

#contacto-embed-home { scroll-margin-top: calc(var(--header-bar-h) + 18px); }
#formulario-contacto-creinsa { scroll-margin-top: calc(var(--header-bar-h) + 18px); }

.cta-strip { padding: 2.75rem 0; border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06); }
.cta-strip__title {
	max-width: min(40rem, 100%);
	line-height: 1.12;
	text-wrap: balance;
}
.cta-strip--dark {
	background: var(--c-azul-2);
	color: #fff;
}
.cta-strip--dark .cta-strip__title {
	color: #fff;
	font-size: clamp(1.32rem, 0.92rem + 1.85vw, 2.08rem);
	margin: 0 0 .5rem;
	line-height: 1.12;
	max-width: min(40rem, 100%);
	text-wrap: balance;
}
.cta-strip--dark .cta-strip__text {
	color: rgba(255,255,255,.88);
	margin: 0;
	max-width: 46ch;
	font-size: 1.05rem;
}
.cta-strip--light {
	background: var(--c-bg-soft);
	color: var(--c-azul-d);
}
.cta-strip--light .cta-strip__title { color: var(--c-azul-d); }
.cta-strip--light .cta-strip__text { color: var(--c-text-2); }
.cta-strip__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1.75rem;
}
.cta-strip__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .75rem 1rem;
}
.cta-strip__btn-primary { white-space: nowrap; }
.cta-strip--dark .cta-strip__btn-secondary {
	border-color: rgba(255,255,255,.45);
	color: #fff;
}
.cta-strip--dark .cta-strip__btn-secondary:hover {
	background: #fff;
	color: var(--c-azul-d);
	border-color: #fff;
}
.cta-strip__mail {
	font-family: var(--ff-display);
	font-weight: 600;
	font-size: .92rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: inherit;
	opacity: .88;
	padding: .5rem 0;
}
.cta-strip--dark .cta-strip__mail { color: var(--c-amarillo); }
.cta-strip--dark .cta-strip__mail:hover { opacity: 1; color: #fff; }

.embed-contact-layout__intro > h2 {
	text-wrap: balance;
}

.embed-contact-layout--single .btn.ghost {
	color: var(--c-azul-d);
	border-color: var(--c-azul-d);
}

.embed-contact-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(2rem, 6vw, 4rem);
	align-items: start;
}
.embed-contact-layout__intro .section-eyebrow { justify-content: flex-start; }
.embed-contact-points {
	margin: 1.25rem 0 0;
	padding-left: 1.2rem;
	color: var(--c-text);
	max-width: 48ch;
}
.embed-contact-points li { margin-bottom: .45rem; }

.contact-form-card,
.contact-form-pro {
	position: relative;
}

.contact-form-pro--compact .contact-form-pro__lead { display: none; }
.contact-form-pro__title {
	font-size: clamp(1.35rem, 2.4vw, 1.75rem);
	margin: 0 0 .45rem;
	color: var(--c-azul-d);
}
.contact-form-pro__intro {
	margin: 0 0 1.25rem;
	color: var(--c-text-2);
	font-size: 1rem;
	line-height: 1.5;
}
.contact-form-pro__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.1rem 1.25rem;
}
.contact-form-pro--compact .contact-form-pro__grid {
	grid-template-columns: 1fr;
	max-width: 100%;
}
.contact-field label {
	display: block;
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .08em;
	text-transform: uppercase;
	font-size: .74rem;
	margin-bottom: .4rem;
	color: var(--c-azul-d);
}
.contact-field .req { color: #a61c1c; margin-left: 2px; }
.contact-field .opt {
	font-family: var(--ff-body);
	font-weight: 400;
	text-transform: none;
	font-size: .78rem;
	letter-spacing: 0;
	color: var(--c-text-2);
}
.contact-field input,
.contact-field select,
.contact-field textarea {
	width: 100%;
	padding: 0.92rem 1rem;
	border: 1px solid var(--c-line);
	background: #fff;
	font: inherit;
	font-size: 1rem;
	border-radius: var(--radius);
	color: var(--c-text);
	transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
	outline: none;
	border-color: var(--c-azul);
	box-shadow: 0 0 0 4px rgba(37,94,138,.16);
}
.contact-field--full { grid-column: 1 / -1; }
.contact-field__hint {
	display: block;
	margin-top: .4rem;
	font-size: .82rem;
	color: var(--c-text-2);
	line-height: 1.35;
}
.contact-field--check { margin-top: .25rem; }
.contact-check {
	display: flex;
	align-items: flex-start;
	gap: .65rem;
	font-size: .86rem;
	line-height: 1.45;
	color: var(--c-text-2);
	cursor: pointer;
}
.contact-check input {
	width: 1.1rem;
	height: 1.1rem;
	margin-top: .15rem;
	flex-shrink: 0;
	accent-color: var(--c-azul);
}
.contact-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: .25rem;
	gap: 0.35rem;
}
.contact-actions .btn { width: auto; min-width: 220px; }
.contact-form-pro--compact .contact-actions {
	align-items: stretch;
}
.contact-form-pro--compact .contact-actions .btn { width: 100%; justify-content: center; }
.contact-form-pro__footnote {
	margin: .75rem 0 0;
	font-size: .84rem;
	color: var(--c-text-2);
	text-align: center;
}

.contact-form-card {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	padding: clamp(1.25rem, 3vw, 2rem);
	box-shadow: 0 20px 50px -28px rgba(36, 50, 99, .28);
}

.contact-aside__card {
	background: rgba(255,255,255,.65);
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	padding: 1.25rem 1.35rem;
	margin-bottom: 1.25rem;
}
.contact-aside__title {
	font-family: var(--ff-display);
	font-size: 1.05rem;
	color: var(--c-azul-d);
	text-transform: uppercase;
	letter-spacing: .12em;
	margin: 0 0 .4rem;
}
.contact-aside__text { margin: 0; color: var(--c-text); font-size: .95rem; line-height: 1.55; }
.contact-aside__img {
	margin-top: 1rem;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius);
	border: 1px solid var(--c-line);
}
.contact-aside__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.contact-grid.contact-grid--pro {
	align-items: start;
	grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.95fr);
}

.creinsa-mobile-cta {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 99997;
	align-items: center;
	justify-content: center;
	gap: .65rem;
	padding: 0.65rem clamp(12px, 4vw, 20px);
	padding-bottom: max(0.65rem, env(safe-area-inset-bottom));
	background: rgba(36,50,99,.94);
	box-shadow: 0 -8px 36px rgba(17,20,24,.35);
	border-top: 2px solid var(--c-amarillo);
}

.creinsa-mobile-cta__btn.btn {
	flex: 1;
	max-width: 320px;
	margin: 0;
	justify-content: center;
	padding: .85rem 1rem;
}
.creinsa-mobile-cta__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: var(--radius);
	border: 1px solid rgba(255,255,255,.38);
	color: var(--c-amarillo);
	background: rgba(255,255,255,.06);
	transition: background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease);
}
.creinsa-mobile-cta__icon:hover {
	background: var(--c-amarillo);
	color: var(--c-azul-d);
	border-color: var(--c-amarillo);
}

@media (max-width: 900px) {
	body.has-sticky-mobile-cta { padding-bottom: 5.75rem; }
	.creinsa-mobile-cta { display: flex; }
}

/* Botón flotante WhatsApp */
.creinsa-whatsapp-float {
	position: fixed;
	right: max(1rem, env(safe-area-inset-right));
	bottom: max(1rem, env(safe-area-inset-bottom));
	z-index: 99998;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	color: #fff;
	background: #25d366;
	box-shadow: 0 10px 28px rgba(17, 20, 24, .35), 0 2px 8px rgba(17, 20, 24, .2);
	transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.creinsa-whatsapp-float:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 32px rgba(17, 20, 24, .4), 0 4px 10px rgba(17, 20, 24, .22);
	background: #22c35e;
	color: #fff;
}
.creinsa-whatsapp-float:focus-visible {
	outline: 3px solid var(--c-amarillo);
	outline-offset: 3px;
}
.creinsa-whatsapp-float__icon {
	display: block;
	flex-shrink: 0;
	width: 28px;
	height: auto;
	max-height: 32px;
}

@media (max-width: 900px) {
	.creinsa-whatsapp-float {
		bottom: calc(5.75rem + max(0.75rem, env(safe-area-inset-bottom)));
	}
	.embed-contact-layout {
		grid-template-columns: 1fr;
	}
	.embed-contact-layout--single .btn.ghost {
		width: 100%;
		justify-content: center;
	}
	.contact-form-pro__grid {
		grid-template-columns: 1fr;
	}
	.cta-strip__inner {
		flex-direction: column;
		align-items: flex-start;
	}
	.cta-strip__actions { width: 100%; justify-content: flex-start; }
}

/* Contacto */
.contact-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
}
.contact-form { display: grid; gap: 1rem; }
.contact-form label {
	display: block;
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-size: .8rem;
	margin-bottom: .35rem;
	color: var(--c-azul-d);
}
.contact-form input,
.contact-form select,
.contact-form textarea {
	width: 100%;
	padding: .9rem 1rem;
	border: 1px solid var(--c-line);
	background: #fff;
	font: inherit;
	border-radius: var(--radius);
	color: var(--c-text);
	transition: border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
	outline: none;
	border-color: var(--c-azul);
	box-shadow: 0 0 0 4px rgba(37,94,138,.15);
}
.contact-info dt {
	font-family: var(--ff-display);
	font-weight: 500;
	letter-spacing: .25em;
	text-transform: uppercase;
	font-size: .75rem;
	color: var(--c-azul);
	margin-top: 1.2rem;
}
.contact-info dd { margin: .25rem 0 0; font-size: 1.05rem; }

@media (max-width: 760px) {
	.contact-grid { grid-template-columns: 1fr; }
}

/* Footer */
.site-footer {
	background: var(--c-azul-d);
	color: #fff;
	padding: 4rem 0 calc(2rem + env(safe-area-inset-bottom, 0px));
}
.site-footer h4 {
	color: #fff;
	font-family: var(--ff-display);
	font-size: 1rem;
	letter-spacing: .25em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}
.site-footer .grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 2rem;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.site-footer a { color: rgba(255,255,255,.78); overflow-wrap: anywhere; }
.site-footer a:hover { color: var(--c-amarillo); }
.site-footer .legal {
	margin-top: 3rem;
	padding-top: 1.4rem;
	border-top: 1px solid rgba(255,255,255,.18);
	display: flex;
	flex-direction: column;
	gap: 1.35rem;
	font-size: .85rem;
	color: rgba(255,255,255,.7);
}
.site-footer .legal__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: space-between;
	width: 100%;
}
.site-footer .legal__nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem 1.85rem;
}
.site-footer .legal__nav a {
	color: rgba(255,255,255,.88);
	font-size: .86rem;
}
.site-footer .legal__nav a:hover { color: var(--c-amarillo); }

/* Documentos legales (prosa, no titulares en versalitas) */
.legal-document h2 {
	font-family: var(--ff-display);
	text-transform: none;
	font-size: clamp(1.12rem, 1.4vw, 1.28rem);
	letter-spacing: .04em;
	font-weight: 600;
	color: var(--c-azul-d);
	margin-top: 2rem;
	margin-bottom: .55rem;
	line-height: 1.28;
}
.legal-document h2:first-of-type { margin-top: 1.25rem; }
.legal-document p {
	color: var(--c-text-2);
	font-size: 1rem;
	line-height: 1.65;
	max-width: 68ch;
}
.legal-document__note {
	margin: 0 0 1.5rem;
	padding: 1rem 1.15rem;
	background: var(--c-bg-soft);
	border-left: 3px solid var(--c-amarillo);
	color: var(--c-text-2);
	font-size: .95rem;
	line-height: 1.55;
	max-width: 68ch;
}
.legal-document__note em { font-style: italic; }
.legal-document a { color: var(--c-azul); text-decoration: underline; text-underline-offset: .15em; }
.legal-document a:hover { color: var(--c-azul-d); }

@media (max-width: 760px) {
	.site-footer .grid { grid-template-columns: 1fr 1fr; gap: 1.75rem 1.25rem; }
}

@media (max-width: 560px) {
	.site-footer .grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.site-footer .legal__meta {
		flex-direction: column;
		align-items: flex-start;
		gap: .65rem;
	}
	.site-footer .legal__nav {
		flex-direction: column;
		align-items: flex-start;
		gap: .65rem;
	}
}

/* Reveal */
.reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; transition: none; }
	.hero::before { animation: none; }
	.primary-nav { transition: none; }
	.creinsa-notice { animation: none; }
}

/* Utilities */
.entry-content--narrow {
	max-width: 65ch;
}

.text-center { text-align: center; }
@media (max-width: 380px) {
	.btn {
		padding: 0.82rem 1.15rem;
		font-size: 0.86rem;
		letter-spacing: 0.1em;
		gap: 0.5rem;
	}
}
.lead { font-size: var(--fs-lead); color: var(--c-text-2); max-width: 60ch; }
.mt-1 { margin-top: 1rem; } .mt-2 { margin-top: 2rem; } .mt-4 { margin-top: 4rem; }
.row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
@media (max-width: 760px) { .row { grid-template-columns: 1fr; } }
