@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@200;300;400;500;700&family=Playfair+Display:ital,wght@0,300;1,300&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Newsreader:ital,opsz,wght@0,6..72,200..800;1,6..72,200..800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Space+Grotesk:wght@300..700&display=swap");
/* Tema por defecto (Proyectos) */
:root {
	--color-primary: #000000;
	--color-bg-light: #ffffff;
	--color-bg-dark: #0a0a0a;
	--color-accent: #666666;
	--color-brand: #ef3340;
	--color-brand-hover: #d92b37;
	--font-display: "Cormorant Garamond", serif;
	--font-sans: "Inter", sans-serif;
	--font-serif: "Cormorant Garamond", serif;
	--font-Space-Grotesk: "Space Grotesk", sans-serif;
}

/* Override de tema (Servicios / Diario) */
[data-theme="servicios"] {
	--color-primary: #1754cf;
	--color-bg-light: #f6f6f8;
	--color-bg-dark: #111621;
	--color-accent: #1754cf;
	--font-display: "Newsreader", serif;
	--font-sans: "Inter", sans-serif;
	--font-serif: "Newsreader", serif;
}
/* Override de tema (Contacto) */
body.page-template-contacto,
body.page-template-contacto-php {
	--color-primary: #1754cf;
	--color-bg-light: #ffffff;
	--color-bg-dark: #060606;
	--color-accent: #94a3b8;
	--font-display: "Manrope", sans-serif;
	--font-sans: "Manrope", sans-serif;
	--font-serif: "Playfair Display", serif;
}
/* Base */
body {
	background: #ffffff;
	color: #000000;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
/* Utilidades usadas en plantillas */
.hairline-serif {
	font-weight: 200;
	letter-spacing: -0.01em;
	font-family: "Cormorant Garamond", serif;
}
.poetic-narrative {
	line-height: 1.7;
	font-weight: 300;
}
.credits-label {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	color: #666666;
	margin-bottom: 0.5rem;
	font-family: Inter, sans-serif;
}
.credits-value {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-family: Inter, sans-serif;
	margin-bottom: 2rem;
	line-height: 1.625;
}
/* Utilidades usadas en Diario/Servicios */
.hairline-title {
	font-weight: 300;
	letter-spacing: -0.02em;
}
.grain-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 50;
	opacity: 0.03;
	background-image: url(https://lh3.googleusercontent.com/aida-public/AB6AXuD9qqXz8lFPcbrgwLTmrMJ8PVzYX-I31grHkG45a3ZwoJPjVxeETV51TyTZ8yN3wMJoCh8Y_MLw6LFWgwXTqZX3W3kvL9hZjagOnyIDNar0p9zRM8t6UA1RdhVCDAodnw01TZG92JSpaiaqBJ5sHgsAHC2WdWKGmnz1sCblUhbLg37nnrIIN-xZTiR7WMvk5rzovkZkEE8dFWd0B0rLp_SPGDSH9OrsDim4l0EHu9DDbiKNmtvuIgDtbf3g8Am5n54rdKiVsO2d2UQ);
}
.content-column {
	max-width: 720px;
	margin: 0 auto;
}
.pull-quote {
	font-weight: 200;
	font-style: italic;
	line-height: 1.1;
}
/* Tipografía por tema */
[data-theme="servicios"] {
	font-family: "Newsreader", serif;
}
/* Contacto */
body.page-template-contacto,
body.page-template-contacto-php {
	font-family: "Manrope", sans-serif;
	background: var(--color-bg-light);
	color: #1a1a1a;
	transition: background-color 700ms ease, color 700ms ease;
}
.dark body.page-template-contacto,
.dark body.page-template-contacto-php {
	background: var(--color-bg-dark);
	color: #f8f8f8;
}
/* Proyectos (templates/proyectos.php) */
body.page-template-proyectos,
body.page-template-proyectos-php {
	--color-primary: #111111;
	--color-bg-light: #ffffff;
	--color-accent: #8a8a8a;
	--font-serif: "Newsreader", serif;
	--font-sans: "Inter", sans-serif;
	background: var(--color-bg-light);
	color: var(--color-primary);
	font-family: var(--font-serif);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body.page-template-proyectos ::selection,
body.page-template-proyectos-php ::selection {
	background: var(--color-primary);
	color: #ffffff;
}
body.page-template-proyectos ::-moz-selection,
body.page-template-proyectos-php ::-moz-selection {
	background: var(--color-primary);
	color: #ffffff;
}
body.page-template-proyectos .editorial-img-container,
body.page-template-proyectos-php .editorial-img-container {
	overflow: hidden;
	background: #f9fafb;
	aspect-ratio: 4 / 5;
	position: relative;
  width: 100%;
  height: 300px;
}
body.page-template-proyectos .entry-title,
body.page-template-proyectos-php .entry-title {
	font-size: 1.875rem;
	line-height: 1.1;
	font-weight: 100;
	letter-spacing: -0.025em;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
	transition-duration: 500ms;
	font-family: var(--font-serif);
	font-style: italic;
}
@media (min-width: 768px) {
	body.page-template-proyectos .entry-title,
	body.page-template-proyectos-php .entry-title {
		font-size: 3rem;
	}
}
body.page-template-proyectos .category-tag,
body.page-template-proyectos-php .category-tag {
	font-size: 9px;
	letter-spacing: 0.4em;
	font-weight: 300;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: 1.5rem;
	display: block;
}

body.page-template-proyectos .proyectos,
body.page-template-proyectos-php .proyectos {
	display: grid;
	grid-template-columns: 1fr;
	row-gap: 6rem;
	column-gap: 3rem;
	align-items: start;
}

@media (min-width: 681px) {
	body.page-template-proyectos .proyectos,
	body.page-template-proyectos-php .proyectos {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		row-gap: 6rem;
		column-gap: 3rem;
	}
}

@media (min-width: 992px) {
	body.page-template-proyectos .proyectos,
	body.page-template-proyectos-php .proyectos {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		row-gap: 6rem;
		column-gap: 3rem;
	}
}

body.page-template-proyectos .proyecto,
body.page-template-proyectos-php .proyecto {
	transition: opacity 450ms ease, transform 450ms ease;
	will-change: opacity, transform;
	cursor: pointer;
}
@media (min-width: 768px) {
	body.page-template-proyectos .proyecto.is-proyectos-offset,
	body.page-template-proyectos-php .proyecto.is-proyectos-offset {
		margin-top: 12rem;
	}
}

body.page-template-proyectos .proyecto.is-proyectos-hidden,
body.page-template-proyectos-php .proyecto.is-proyectos-hidden {
	opacity: 0;
	transform: translateY(14px);
	pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
	body.page-template-proyectos .proyecto,
	body.page-template-proyectos-php .proyecto {
		transition: none;
	}
}

body.page-template-proyectos .proyecto .editorial-img-container > div,
body.page-template-proyectos-php .proyecto .editorial-img-container > div {
	transform: scale(1);
}
body.page-template-proyectos .proyecto a:hover .editorial-img-container > div,
body.page-template-proyectos-php .proyecto a:hover .editorial-img-container > div {
	transform: scale(1.08);
}
body.page-template-proyectos .read-more,
body.page-template-proyectos-php .read-more {
	font-size: 9px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	border-bottom: 1px solid rgba(17, 17, 17, 0.1);
	padding-bottom: 0.25rem;
	margin-top: 2rem;
	display: inline-block;
	transition: all 500ms;
	font-family: var(--font-sans);
}
body.page-template-proyectos .read-more:hover,
body.page-template-proyectos-php .read-more:hover {
	border-bottom-color: var(--color-brand);
}
body.page-template-proyectos .hairline-title,
body.page-template-proyectos-php .hairline-title {
	font-weight: 100;
	letter-spacing: -0.05em;
	line-height: 0.85;
}
body.page-template-proyectos::-webkit-scrollbar {
	width: 3px;
}
body.page-template-proyectos::-webkit-scrollbar-track {
	background: #fbfaf8;
}
body.page-template-proyectos::-webkit-scrollbar-thumb {
	background: #d1d1d1;
}
body.page-template-proyectos-php::-webkit-scrollbar {
	width: 3px;
}
body.page-template-proyectos-php::-webkit-scrollbar-track {
	background: #fbfaf8;
}
body.page-template-proyectos-php::-webkit-scrollbar-thumb {
	background: #d1d1d1;
}
/* Servicios (templates/servicios.php) */
body.page-template-servicios,
body.page-template-servicios-php {
	--color-primary: #1754cf;
	--color-bg-light: #ffffff;
	--color-bg-dark: #111621;
	--color-accent: #636f88;
	--font-display: "Newsreader", serif;
	--font-sans: "Noto Sans", sans-serif;
	--font-serif: "Newsreader", serif;
	background-color: #fdfbf7;
}
body.page-template-servicios .text-editorial,
body.page-template-servicios-php .text-editorial {
	font-variation-settings: 'opsz' 72;
}
@media (max-width: 767px) {
	#servicios-listado .max-w-sm {
		max-width: 100% !important;
	}
	#servicios-listado img.aspect-\[3\/4\] {
		aspect-ratio: 16 / 9 !important;
		height: auto !important;
		object-position: center !important;
	}
}
body.page-template-proyectos ::selection,
body.page-template-proyectos-php ::selection {
	background: #000000;
	color: #ffffff;
}
body.page-template-proyectos ::-moz-selection,
body.page-template-proyectos-php ::-moz-selection {
	background: #000;
	color: #fff;
}
body.page-template-proyectos .hairline-serif,
body.page-template-proyectos-php .hairline-serif {
	font-family: "Newsreader", serif;
	font-weight: 200;
	font-style: italic;
	letter-spacing: -0.02em;
}
body.page-template-proyectos .small-caps,
body.page-template-proyectos-php .small-caps {
	font-family: "Inter", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	font-size: 0.6rem;
	font-weight: 300;
}
body.page-template-proyectos .project-meta,
body.page-template-proyectos-php .project-meta {
	font-family: "Inter", sans-serif;
	font-size: 0.55rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 300;
}
body.page-template-proyectos .project-container:hover img,
body.page-template-proyectos-php .project-container:hover img {
	opacity: 0.9;
}
body.page-template-proyectos .asymmetric-grid,
body.page-template-proyectos-php .asymmetric-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 6rem 4rem;
}
@media (max-width: 768px) {
	body.page-template-proyectos .asymmetric-grid,
	body.page-template-proyectos-php .asymmetric-grid {
		display: flex;
		flex-direction: column;
		gap: 4rem;
	}
}
body.page-template-proyectos .ultra-fine-border,
body.page-template-proyectos-php .ultra-fine-border {
	border-bottom: 0.5px solid currentColor;
}
.logo-header-invertido {
	filter: brightness(0) invert(1) !important;
}
.cliente-card {
	position: relative;
	background: #000000;
	box-shadow: inset 0 0 0 0.5px rgba(255, 255, 255, 0.5);
	transition: background-color 800ms ease, box-shadow 800ms ease;
}
.cliente-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background-color: transparent;
	background-image: none;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0;
	transform: scale(1);
	transform-origin: center;
	will-change: opacity, transform;
	transition: opacity 800ms ease, transform 800ms ease;
}

.cliente-card--has-bg::before {
	background-image: linear-gradient(rgba(0, 0, 0, 0.38), rgba(0, 0, 0, 0.38)), var(--cliente-hover-bg, none);
}

.cliente-card--has-bg:hover::before {
	opacity: 1;
	transform: scale(1.06);
}
.cliente-card:hover {
	background: #000000;
	box-shadow: inset 0 0 0 0.5px rgba(17, 19, 24, 0.08);
}
header {
	transition: background-color 500ms ease, color 500ms ease;
}
header.header--default {
	color: #000000;
	mix-blend-mode: normal;
}

header.header--default,
header.header--default a,
header.header--default .widget-cabecera ul.menu a {
	color: #000000 !important;
}
header.header--default .widget-cabecera figure.wp-block-image,
header.header--default .widget-cabecera .open-menu img {
	filter: brightness(0) invert(0) !important;
}

header.header--front {
	color: #ffffff;
}

header.header--front,
header.header--front a,
header.header--front .widget-cabecera ul.menu a {
	color: #ffffff;
}

header.is-scrolled {
	background: rgba(255, 255, 255, 0.96);
	color: #000000;
	mix-blend-mode: normal !important;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
header.is-scrolled:not([data-home-header]) {
	background: #ffffff;
}
header.is-scrolled,
header.is-scrolled a,
header.is-scrolled .widget-cabecera ul.menu a {
	color: #000000 !important;
}
header.is-scrolled .widget-cabecera figure.wp-block-image,
header.is-scrolled .widget-cabecera .open-menu img {
	filter: brightness(0) invert(0) !important;
}
/* Header: menú mobile (wp_nav_menu) con el mismo estilo del bloque hardcodeado */
@media (max-width: 879px) {
	header.is-mobile-menu-open {
		mix-blend-mode: normal !important;
	}
	header nav[data-mobile-menu] > div:not(.menu-menu-prinicipal-container) {
		display: none !important;
	}
	header nav[data-mobile-menu] .menu-menu-prinicipal-container {
		background: rgba(0, 0, 0, 0.8) !important;
		backdrop-filter: blur(12px) !important;
		-webkit-backdrop-filter: blur(12px) !important;
		border-radius: 0.75rem !important;
		padding: 1.5rem !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 1rem !important;
	}
	header nav[data-mobile-menu] .menu-menu-prinicipal-container ul.menu {
		list-style: none !important;
		margin: 0 !important;
		padding: 0 !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 1rem !important;
	}
	header nav[data-mobile-menu] .menu-menu-prinicipal-container ul.menu li {
		margin: 0 !important;
	}
	header nav[data-mobile-menu] .menu-menu-prinicipal-container ul.menu a {
		display: block !important;
		color: #ffffff !important;
		text-decoration: none !important;
		font-size: 11px !important;
		font-weight: 800 !important;
		letter-spacing: 0.3em !important;
		text-transform: uppercase !important;
		transition: opacity 200ms ease !important;
	}
	header nav[data-mobile-menu] .menu-menu-prinicipal-container ul.menu a:hover {
		opacity: 0.7 !important;
	}
}
/* Header widgets (widget-cabecera): igualar estilos del header */
header .widget-cabecera {
	flex: 1;
	width: 100%;
	position: relative;
}
header .widget-cabecera ~ div,
header .widget-cabecera ~ nav:not([data-mobile-menu]),
header .widget-cabecera ~ button {
	display: none !important;
}
header .widget-cabecera .wp-block-columns {
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: nowrap;
	margin: 0;
	width: 100%;
}
header .widget-cabecera .wp-block-columns > .wp-block-column:first-child {
	flex: 0 0 auto;
}
header .widget-cabecera .wp-block-columns > .wp-block-column:last-child {
	flex: 1 1 auto;
	min-width: 0;
}
header .widget-cabecera .wp-block-column {
	margin: 0;
}
header .widget-cabecera figure.wp-block-image {
	margin: 0;
	filter: none;
}
header.header--front .widget-cabecera figure.wp-block-image,
header.header--front .widget-cabecera .open-menu img {
	filter: invert(1);
}
header .widget-cabecera .wp-block-group {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 2.5rem;
	flex-wrap: nowrap;
}
header .widget-cabecera ul.menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: none;
	gap: 2rem;
	flex-wrap: nowrap;
}
header .widget-cabecera ul.menu li {
	margin: 0;
}
header .widget-cabecera ul.menu a {
	color: inherit;
	text-decoration: none;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	white-space: nowrap;
	transition: opacity 200ms ease;
}
header .widget-cabecera ul.menu a:hover {
	opacity: 0.5;
}
header .widget-cabecera .open-menu {
	display: block;
	margin: 0;
	cursor: pointer;
}
header .widget-cabecera .open-menu img {
	width: 24px;
	height: 24px;
	object-fit: contain;
	display: block;
}
@media (max-width: 879px) {
	header .widget-cabecera .wp-block-columns {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
    gap: unset !important;
	}
	header .widget-cabecera .wp-block-columns.is-layout-flex,
	header .widget-cabecera .wp-block-columns.wp-block-columns-is-layout-flex {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
	}
	header .widget-cabecera .wp-block-columns > .wp-block-column {
		flex: 0 0 50% !important;
		flex-basis: 50% !important;
		max-width: 50% !important;
		width: 50% !important;
		min-width: 0 !important;
	}
	header .widget-cabecera .wp-block-columns > .wp-block-column:first-child {
		display: flex;
		justify-content: flex-start;
	}
	header .widget-cabecera .wp-block-columns > .wp-block-column:last-child {
		display: flex;
		justify-content: flex-end;
	}
}
@media (max-width: 879px) {
	header .widget-cabecera.is-menu-open ul.menu {
		display: flex;
		flex-direction: column;
		gap: 1rem;
		position: absolute;
		top: calc(100% + 0.75rem);
		left: 0;
		right: 0;
		background: rgba(0, 0, 0, 0.8);
		backdrop-filter: blur(12px);
		-webkit-backdrop-filter: blur(12px);
		border-radius: 0.75rem;
		padding: 1.5rem;
	}
	header .widget-cabecera.is-menu-open ul.menu a:hover {
		opacity: 0.7;
	}
}
@media (min-width: 880px) {
	header .widget-cabecera ul.menu {
		display: flex;
		align-items: center;
	}
	header .widget-cabecera .open-menu {
		display: none;
	}
}
/* Footer widgets: dar estilo al HTML del widget (Gutenberg columns + nav menus) */
footer .widget-footer {
	max-width: 80rem;
	margin-left: auto;
	margin-right: auto;
}
footer .widget-footer .wp-block-columns {
	display: grid !important;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: start;
	margin: 0;
}
@media (min-width: 768px) {
	footer .widget-footer .wp-block-columns {
		grid-template-columns: 2fr 1fr 1fr;
		gap: 6rem;
	}
}
footer .widget-footer .wp-block-column {
	margin: 0;
}
footer .widget-footer h2.wp-block-heading {
	font-size: 2.25rem;
	line-height: 1.2;
	font-weight: 200;
	letter-spacing: -0.02em;
	margin: 0 0 1.5rem;
}
footer .widget-footer p {
	font-size: 0.875rem;
	font-weight: 400;
	opacity: 0.6;
	line-height: 1.8;
	margin: 0;
	max-width: 520px;
}
footer .widget-footer .widgettitle {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.4em;
	font-weight: 700;
	margin: 0 0 1rem;
	opacity: 0.4;
}
footer .widget-footer ul.menu {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.875rem;
	font-weight: 200;
	opacity: 0.7;
}
footer .widget-footer ul.menu li {
	margin: 0 0 0.5rem;
	color: #000;
	font-weight: 300;
}
footer .widget-footer ul.menu li:last-child {
	margin-bottom: 0;
}
footer .widget-footer ul.menu a {
	color: inherit;
	text-decoration: none;
	transition: color 200ms ease, opacity 200ms ease;
}
footer .widget-footer ul.menu a:hover {
	opacity: 0.7;
	color: var(--color-brand);
}
.serif-title {
	font-family: "Playfair Display", serif;
	font-weight: 300;
}
.hairline-input {
	border: 0;
	border-bottom: 1px solid #f3f4f6;
	background: transparent !important;
	padding-top: 2rem;
	padding-bottom: 2rem;
	padding-left: 0;
	padding-right: 0;
	width: 100%;
	outline: none;
	transition: all 700ms ease;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.45em;
	font-weight: 300;
}
textarea.hairline-input,
select.hairline-input {
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent !important;
  border-color: #6b7280;
  border-width: 1px;
  border-radius: 0px;
  padding-top: 0.5rem;
  padding-right: 0.75rem;
  padding-bottom: 0.5rem;
  padding-left: 0.75rem;
  font-size: 1rem;
  line-height: 1.5rem;
  --tw-shadow: 0 0 #0000;
}
textarea.hairline-input {
  height: 150px;
}
.hairline-input::placeholder {
	color: #e5e7eb;
}
.hairline-input:focus {
	border-bottom-color: rgba(0, 0, 0, 0.3);
}
.dark .hairline-input {
	border-bottom-color: #18181b;
}
.dark .hairline-input::placeholder {
	color: #27272a;
}
.dark .hairline-input:focus {
	border-bottom-color: rgba(255, 255, 255, 0.3);
}
#form-contacto .wpcf7-not-valid-tip {
  font-size: 9px;
  width: 100%;
  border-top: 1px solid #dc3232;
  padding-top: 3px;
  text-align: center;
  text-transform: uppercase;
  margin-top: -17px;
  z-index: 5;
  padding-bottom: 6px;
  position: relative;
}
.nav-link {
	font-size: 8px;
	text-transform: uppercase;
	letter-spacing: 0.45em;
	opacity: 0.3;
	transition: opacity 500ms ease;
}
.nav-link:hover {
	opacity: 1;
	color: var(--color-brand);
}
.dot-pattern {
	background-image: radial-gradient(circle, #e5e7eb 0.5px, transparent 0.5px);
	background-size: 40px 40px;
}
.dark .dot-pattern {
	background-image: radial-gradient(circle, #1a1a1a 0.5px, transparent 0.5px);
}

html {
	scroll-behavior: smooth;
}

/* Nosotros (templates/nosotros.php) */

body.page-template-nosotros,
body.page-template-nosotros-php {
	--color-primary: #000000;
	--color-bg-light: #ffffff;
	--color-bg-dark: #0a0a0a;
	--color-accent: rgba(0, 0, 0, 0.15);
	--font-sans: "Inter", sans-serif;
	--font-serif: "Playfair Display", serif;
	--font-display: "Playfair Display", serif;
	--grain: url(https://lh3.googleusercontent.com/aida-public/AB6AXuAOBBDVejPw3yQa27huPZMrj9xvLBIoT2k0vmPOAhyQ8E7qgzR63bfuh-PPkBtRK6GheuwgPWv7urn1dbBLkNGjLH6emyNuhLcVABwpbT63nV0oqbDfSDlkV4v5c4SBFn7yQRioqk0rKh3UYVXR-TSQ-FeHIkpMin5Vs__izRNmWCWt4Dm1jcuWfPBcyH2WDEJTi1YEuzDesgQZ2JdcWROUGtDAU-4_1q1yYtaGI2Xt8wESzRAh6ThDf1QMnxbypBk5bI_3NRk0DGM);
	background: var(--color-bg-light);
	color: #000;
	overflow-x: hidden;
}

body.page-template-nosotros ::selection,
body.page-template-nosotros-php ::selection {
	background: rgba(0, 0, 0, 0.03);
	color: #000;
}

body.page-template-nosotros .grain-overlay,
body.page-template-nosotros-php .grain-overlay {
	opacity: 0.02;
	background-image: var(--grain);
}

body.page-template-nosotros .hairline-text,
body.page-template-nosotros-php .hairline-text {
	font-weight: 100;
	letter-spacing: 0.15em;
}

body.page-template-nosotros .hairline-title,
body.page-template-nosotros-php .hairline-title {
	font-weight: 100;
	letter-spacing: 0.4em;
	text-transform: uppercase;
}

body.page-template-nosotros .editorial-grid,
body.page-template-nosotros-php .editorial-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 1.5rem;
}

body.page-template-nosotros .border-hairline,
body.page-template-nosotros-php .border-hairline {
	border-color: rgba(0, 0, 0, 0.06);
}

body.page-template-nosotros-php .nosotros-philosophy-section {
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
}

body.page-template-nosotros .nosotros-philosophy-grid,
body.page-template-nosotros-php .nosotros-philosophy-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}

body.page-template-nosotros .nosotros-philosophy-label,
body.page-template-nosotros-php .nosotros-philosophy-label {
	margin: 0;
	font-size: 15px;
	font-weight: 300;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: #818181;
}

body.page-template-nosotros .nosotros-philosophy-copy,
body.page-template-nosotros-php .nosotros-philosophy-copy {
	max-width: 52rem;
	font-size: 22px;
	line-height: 1.05;
	font-weight: 400;
	letter-spacing: -0.04em;
	color: rgba(17, 19, 24, 0.96);
}

body.page-template-nosotros .nosotros-philosophy-copy p,
body.page-template-nosotros-php .nosotros-philosophy-copy p {
	margin: 0;
	font: inherit;
	color: inherit;
	line-height: inherit;
	letter-spacing: inherit;
	font-weight: inherit;
}

body.page-template-nosotros .nosotros-media-frame,
body.page-template-nosotros-php .nosotros-media-frame {
	position: relative;
	overflow: hidden;
	aspect-ratio: 21 / 14;
	background: #0f0f10;
}

body.page-template-nosotros .nosotros-media-asset,
body.page-template-nosotros-php .nosotros-media-asset {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

@media (min-width: 992px) {
	body.page-template-nosotros .nosotros-philosophy-grid,
	body.page-template-nosotros-php .nosotros-philosophy-grid {
		grid-template-columns: minmax(180px, 0.48fr) minmax(0, 1fr);
		gap: 4rem;
	}

	body.page-template-nosotros .nosotros-philosophy-copy-wrap,
	body.page-template-nosotros-php .nosotros-philosophy-copy-wrap {
		padding-right: 1rem;
	}
}

@media (max-width: 767px) {
	body.page-template-nosotros-php .nosotros-philosophy-section {
		padding-top: 1.25rem;
		padding-bottom: 1.25rem;
	}

	body.page-template-nosotros .nosotros-media-frame,
	body.page-template-nosotros-php .nosotros-media-frame {
		aspect-ratio: 4 / 5;
	}
}

/* Contenido del editor (the_content) */
.editorial-content {
	font-weight: 200;
	letter-spacing: -0.01em;
}

.editorial-content > *:first-child {
	margin-top: 0;
}

.editorial-content > *:last-child {
	margin-bottom: 0;
}

.editorial-content p,
.editorial-content ul,
.editorial-content ol,
.editorial-content blockquote {
	margin: 0 0 1.75rem;
}

.editorial-content p {
	font-size: 1.05rem;
	line-height: 2.1;
	font-weight: 200;
	color: rgba(17, 19, 24, 0.72);
}

@media (min-width: 768px) {
	.editorial-content p {
		font-size: 1.125rem;
	}
}

.editorial-content h2,
.editorial-content h3,
.editorial-content h4 {
	font-family: var(--font-display);
	font-weight: 200;
	letter-spacing: -0.02em;
	color: rgba(17, 19, 24, 0.92);
	margin: 3rem 0 1rem;
}

.editorial-content h2 {
	font-size: 1.75rem;
	line-height: 1.2;
}

.editorial-content h3 {
	font-size: 1.25rem;
	line-height: 1.3;
}

.editorial-content h4 {
	font-size: 1.1rem;
	line-height: 1.35;
}

.editorial-content a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid rgba(17, 17, 17, 0.18);
	padding-bottom: 2px;
	transition: border-color 300ms ease, opacity 300ms ease;
}

.editorial-content a:hover {
	border-bottom-color: var(--color-brand);
	opacity: 0.9;
}

.editorial-content ul,
.editorial-content ol {
	padding-left: 1.25rem;
	color: rgba(17, 19, 24, 0.72);
}

.editorial-content li {
	margin: 0.5rem 0;
}

.editorial-content strong {
	font-weight: 500;
	color: rgba(17, 19, 24, 0.9);
}

.editorial-content em {
	font-style: italic;
}

.editorial-content blockquote {
	margin: 3rem 0;
	padding-left: 1.25rem;
	border-left: 1px solid rgba(17, 17, 17, 0.12);
	font-family: var(--font-display);
	font-weight: 200;
	font-style: italic;
	font-size: 1.5rem;
	line-height: 1.25;
	color: rgba(17, 19, 24, 0.9);
}

@media (min-width: 768px) {
	.editorial-content blockquote {
		font-size: 2rem;
	}
}

.editorial-content figure {
	margin: 2.25rem 0;
}

.editorial-content img {
	max-width: 100%;
	height: auto;
	display: block;
}

.editorial-content hr {
	border: 0;
	border-top: 1px solid rgba(17, 17, 17, 0.1);
	margin: 3rem 0;
}

/* Slider (Galería ACF) */
.crea-slider {
	position: relative;
}

.crea-slider-track {
	height: 100%;
	display: flex;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.crea-slider-track::-webkit-scrollbar {
	display: none;
}

.crea-slider-slide {
	flex: 0 0 100%;
	height: 100%;
	scroll-snap-align: start;
}

/* Variante: carrusel de tarjetas (Home) */
.crea-slider--cards .crea-slider-track {
	gap: 1.5rem;
	padding: 0 1.5rem;
	scroll-padding-left: 1.5rem;
}

.crea-slider--cards .crea-slider-slide {
	flex-basis: 88%;
}

@media (min-width: 768px) {
	.crea-slider--cards .crea-slider-slide {
		flex-basis: 48%;
	}
}

@media (min-width: 1024px) {
	.crea-slider--cards .crea-slider-slide {
		flex-basis: 38%;
	}
}

.crea-slider-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(0, 0, 0, 0.25);
	color: #fff;
	backdrop-filter: blur(8px);
	transition: opacity 300ms ease, background 300ms ease;
}

.crea-slider-btn:hover {
	background: var(--color-brand);
	border-color: var(--color-brand);
}

.crea-slider-btn[disabled] {
	opacity: 0.25;
	cursor: default;
}

.crea-slider-btn--prev {
	left: 16px;
}

.crea-slider-btn--next {
	right: 16px;
}

@media (max-width: 640px) {
	.crea-slider-btn--prev {
		left: 10px;
	}
	.crea-slider-btn--next {
		right: 10px;
	}
}

/* Botón flotante: Volver arriba */
.crea-scroll-top {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 60;
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: rgba(255, 255, 255, 0.85);
	color: rgba(0, 0, 0, 0.9);
	backdrop-filter: blur(10px);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
	transition: transform 250ms ease, opacity 250ms ease, background 250ms ease;
}

.crea-scroll-top:hover {
	transform: translateY(-2px);
	background: var(--color-brand);
	border-color: var(--color-brand);
	color: #fff;
}

/* Home: CTA final */
.front-cta-section {
	background: #ffffff;
}

.front-cta-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 1rem;
	align-items: start;
}

.front-cta-media {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: auto;
	align-self: start;
	aspect-ratio: 1 / 1;
	background-color: #d9d3cf;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.front-cta-media-overlay {
	position: absolute;
	inset: 0;
	background: rgba(17, 19, 24, 0.6);
	transition: opacity 500ms ease;
	pointer-events: none;
	z-index: 1;
}

.front-cta-media-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	gap: 1rem;
	height: 100%;
	padding: 2.5rem;
	color: #ffffff;
	font-weight: 300;
}

.front-cta-kicker {
	color: #ffffff;
	text-decoration: none;
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.35em;
	border-bottom: 1px solid rgba(255, 255, 255, 0.45);
	padding-bottom: 0.5rem;
	transition: opacity 300ms ease, border-color 300ms ease;
}

.front-cta-kicker:hover {
	opacity: 0.75;
	border-color: rgba(255, 255, 255, 0.75);
}

.front-cta-addresses {
	max-width: 28rem;
	font-family: var(--font-sans);
	font-size: 0.9rem;
	line-height: 1.8;
	font-weight: 300;
}

.front-cta-addresses p {
	margin: 0;
}

.front-cta-addresses p + p {
	margin-top: 1.5rem;
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	line-height: 1.9;
	color: rgba(255, 255, 255, 0.88);
}

.front-cta-panel {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2.5rem 2rem;
}

.front-cta-panel-inner {
	width: 100%;
	max-width: 36rem;
	margin: 0 auto;
}

.front-cta-title {
	margin: 0;
	font-size: 1.5rem;
	text-align: center;
	line-height: 0.95;
	font-weight: 300;
	color: rgba(17, 19, 24, 0.95);
}

.front-cta-copy {
	margin: 1.5rem 0 0;
	font-family: var(--font-sans);
	font-size: 12px;
	text-align: center;
	line-height: 1.9;
	font-weight: 300;
	color: rgba(17, 19, 24, 0.58);
}

.front-cta-form {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-top: 2.75rem;
	border-bottom: 1px solid rgba(17, 19, 24, 0.18);
	padding-bottom: 0.35rem;
}

.front-cta-input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: transparent;
	padding: 0.85rem 0;
	font-family: var(--font-sans);
	font-size: 0.7rem;
	font-weight: 400;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: #111318;
	outline: none;
	width: 100%;
	box-shadow: none;
}

.front-cta-input::placeholder {
	color: rgba(17, 19, 24, 0.35);
}

.front-cta-submit {
	width: 2.75rem;
	height: 2.75rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 0;
	background: transparent;
	color: #111318;
	cursor: pointer;
	transition: transform 250ms ease, opacity 250ms ease;
}

.front-cta-submit:hover {
	transform: translateX(3px);
	opacity: 0.8;
}

@media (min-width: 1024px) {
	.front-cta-grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}

	.front-cta-panel {
		height: 100%;
	}

	.front-cta-panel {
		padding: 4rem;
	}
	}

@media (max-width: 767px) {
	.front-cta-section {
		padding: 3rem 1rem;
	}

	.front-cta-grid {
		grid-template-columns: minmax(0, 1fr);
		gap: 1rem;
	}

	.front-cta-media {
		order: 1;
	}

	.front-cta-panel {
		order: 2;
		height: 100%;
	}

	.front-cta-panel {
		min-height: auto;
	}

	.front-cta-media-content,
	.front-cta-panel {
		padding: 2rem 1.5rem;
	}

	.front-cta-title {
		max-width: 100%;
	}
}

.dark .crea-scroll-top {
	border-color: rgba(255, 255, 255, 0.16);
	background: rgba(0, 0, 0, 0.45);
	color: rgba(255, 255, 255, 0.92);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

@media (max-width: 640px) {
	.crea-scroll-top {
		right: 14px;
		bottom: 14px;
		width: 44px;
		height: 44px;
	}
}

/* Fondo global muy sutil */
/* body {
	background-color: #ffffff;
	background-image: linear-gradient(rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.98)), url("../img/fondo-todo.jpg") !important;
	background-size: cover !important;
	background-position: center top !important;
	background-repeat: no-repeat !important;
	background-attachment: fixed !important;
} */

.dark body,
.dark body.page-template-contacto,
.dark body.page-template-contacto-php {
	background-image: linear-gradient(rgba(6, 6, 6, 0.88), rgba(6, 6, 6, 0.88)), url("../img/fondo-todo.jpg") !important;
}

@media (max-width: 991px) {
	body {
		background-attachment: scroll !important;
	}
}

.logo-footer img {
	filter: invert(1) !important;
}
.logo-footer {
	margin-bottom: 15px;
}

/* Tipografia global unificada */
:root,
[data-theme="servicios"],
body.page-template-contacto,
body.page-template-contacto-php,
body.page-template-proyectos,
body.page-template-proyectos-php,
body.page-template-servicios,
body.page-template-servicios-php,
body.page-template-nosotros,
body.page-template-nosotros-php {
	--font-display: "Inter", sans-serif;
	--font-sans: "Inter", sans-serif;
	--font-serif: "Inter", sans-serif;
}

/* body,
body *:not(.material-symbols-outlined) {
	font-family: "Inter", sans-serif !important;
}*/
.wpcf7-form-control-wrap {
	width: calc( 100% - 2.75rem );
}


h1,
h2,
h3,
h4,
h5,
h6{
	font-family: var(--font-Space-Grotesk)!important;
	font-weight: 500 !important;
}
body{
	font-family: "Inter", sans-serif !important;
	font-weight: 300;
}


.item-img.item-img--swap {
	position: relative;
}

.item-img.item-img--swap img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: opacity 600ms ease, transform 600ms ease;
	will-change: opacity, transform;
}

.item-img.item-img--swap .item-img__main {
	opacity: 1;
}

.item-img.item-img--swap .item-img__hover {
	opacity: 0;
}

@media (hover: hover) and (pointer: fine) {
	article:hover .item-img.item-img--swap .item-img__main {
		opacity: 0;
		transform: scale(1.03);
	}
	article:hover .item-img.item-img--swap .item-img__hover {
		opacity: 1;
		transform: scale(1.03);
	}
}

article.is-img-swapped .item-img.item-img--swap .item-img__main {
	opacity: 0;
	transform: scale(1.03);
}

article.is-img-swapped .item-img.item-img--swap .item-img__hover {
	opacity: 1;
	transform: scale(1.03);
}