/* ============================================================
   EDIFICIO ÉLFICO — tema.css
   Migrado de styles.css + adiciones WordPress y accesibilidad
   ============================================================ */

:root {
	--ink:       #1a1815;
	--ink-soft:  #4a4640;
	--paper:     #f4efe6;
	--paper-warm:#ede5d4;
	--accent:    #7a3b1f;
	--line:      #c9bfae;
	--serif:     "Fraunces", Georgia, serif;
	--mono:      "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
	font-family: var(--serif);
	font-weight: 400;
	color: var(--ink);
	background: var(--paper);
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
}

/* ── Skip to content (WCAG AA) ──────────────────────────────── */
.skip-to-content {
	position: absolute;
	top: -100%;
	left: 1.5rem;
	z-index: 1000;
	background: var(--ink);
	color: var(--paper);
	padding: 0.75rem 1.5rem;
	font-family: var(--mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	text-decoration: none;
	transition: top 0.2s;
}
.skip-to-content:focus { top: 1rem; }

/* ── Focus rings (WCAG AA) ───────────────────────────────────── */
*:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}
*:focus:not(:focus-visible) { outline: none; }

/* ── WordPress admin bar offset ─────────────────────────────── */
.admin-bar nav { top: 32px; }
@media screen and (max-width: 782px) {
	.admin-bar nav { top: 46px; }
}

/* ── NAV ─────────────────────────────────────────────────────── */
nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.5rem 3rem;
	background: rgba(244, 239, 230, 0.92);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--line);
}

.logo {
	font-family: var(--serif);
	font-weight: 500;
	font-size: 1.05rem;
	letter-spacing: 0.02em;
	font-variation-settings: "opsz" 144;
	text-decoration: none;
	color: var(--ink);
}
.logo em { font-style: italic; font-weight: 400; }

nav ul {
	list-style: none;
	display: flex;
	gap: 2.5rem;
}

nav a.nav-link {
	font-family: var(--mono);
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--ink);
	text-decoration: none;
	padding-bottom: 2px;
	border-bottom: 1px solid transparent;
	transition: border-color 0.2s;
}
nav a.nav-link:hover,
nav a.nav-link.active {
	border-bottom-color: var(--accent);
}

/* ── Tipografía base ──────────────────────────────────────────── */
h1 {
	font-family: var(--serif);
	font-weight: 300;
	font-size: clamp(3rem, 7vw, 6rem);
	line-height: 0.95;
	letter-spacing: -0.02em;
	margin-bottom: 2rem;
	font-variation-settings: "opsz" 144;
}
h1 em { font-style: italic; font-weight: 400; }

h2 {
	font-family: var(--serif);
	font-weight: 300;
	font-size: clamp(2.2rem, 4vw, 3.5rem);
	line-height: 1;
	letter-spacing: -0.015em;
	font-variation-settings: "opsz" 144;
}
h2 em { font-style: italic; }

h3 {
	font-family: var(--serif);
	font-weight: 400;
	font-size: 1.35rem;
	line-height: 1.2;
	font-variation-settings: "opsz" 96;
}
h3 em { font-style: italic; }

.eyebrow {
	font-family: var(--mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--accent);
	margin-bottom: 2rem;
	display: block;
}

.section-label {
	font-family: var(--mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--accent);
}

.lead {
	font-size: 1.15rem;
	line-height: 1.55;
	color: var(--ink-soft);
	margin-bottom: 2.5rem;
	max-width: 460px;
}

.cta {
	display: inline-block;
	font-family: var(--mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--ink);
	text-decoration: none;
	padding: 0.9rem 1.6rem;
	border: 1px solid var(--ink);
	transition: background 0.2s, color 0.2s;
	cursor: pointer;
}
.cta:hover { background: var(--ink); color: var(--paper); }

/* ── Imágenes en bloques (sustituyen a placeholders del HTML) ── */
.hero-image img,
.servicio-img img,
.preview-card-img img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ── Placeholder (solo visible cuando no hay imagen asignada) ── */
.placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 2rem;
	color: var(--ink-soft);
}
.placeholder-tag {
	font-family: var(--mono);
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--accent);
	margin-bottom: 1rem;
}
.placeholder-caption {
	font-family: var(--serif);
	font-style: italic;
	font-size: 0.95rem;
	max-width: 320px;
	line-height: 1.4;
}

/* ── Hero ─────────────────────────────────────────────────────── */
.hero {
	min-height: 100vh;
	padding: 8rem 3rem 4rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: end;
}
.hero-text { max-width: 540px; }
.hero-image {
	aspect-ratio: 4/5;
	background: var(--paper-warm);
	border: 1px solid var(--line);
	position: relative;
	overflow: hidden;
}

/* ── Intro ────────────────────────────────────────────────────── */
.intro {
	padding: 6rem 3rem;
	border-top: 1px solid var(--line);
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 4rem;
}
.intro-text {
	font-family: var(--serif);
	font-size: 1.6rem;
	line-height: 1.4;
	font-weight: 300;
	max-width: 720px;
	font-variation-settings: "opsz" 96;
}
.intro-text em { font-style: italic; }

/* ── Preview de servicios (Home) ─────────────────────────────── */
.servicios-preview {
	padding: 6rem 3rem;
	border-top: 1px solid var(--line);
}
.preview-header {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 4rem;
	margin-bottom: 4rem;
}
.preview-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem;
}
.preview-card {
	text-decoration: none;
	color: var(--ink);
	display: block;
	transition: opacity 0.2s;
}
.preview-card:hover { opacity: 0.75; }
.preview-card-img {
	aspect-ratio: 4/3;
	background: var(--paper-warm);
	border: 1px solid var(--line);
	position: relative;
	margin-bottom: 1.5rem;
	overflow: hidden;
}
.preview-card-num {
	font-family: var(--mono);
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	color: var(--accent);
	margin-bottom: 0.5rem;
}

/* ── Cabecera de página (servicios, contacto) ────────────────── */
.page-header {
	padding: 10rem 3rem 5rem;
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 4rem;
	align-items: end;
	border-bottom: 1px solid var(--line);
}
.page-header h1 {
	font-size: clamp(2.8rem, 5.5vw, 5rem);
	margin-bottom: 0;
}
.page-header .lead {
	margin-bottom: 0;
	max-width: 640px;
	font-size: 1.25rem;
}

/* ── Servicios (página) ──────────────────────────────────────── */
.servicios-list { padding: 0; }
.servicio {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	padding: 5rem 3rem;
	border-bottom: 1px solid var(--line);
	align-items: center;
}
.servicio.imagen-izquierda .servicio-img { order: -1; }
.servicio-num {
	font-family: var(--mono);
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	color: var(--accent);
	margin-bottom: 1.5rem;
}
.servicio h2 {
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	line-height: 1.05;
	margin-bottom: 1.5rem;
}
.servicio p {
	font-size: 1.05rem;
	line-height: 1.6;
	color: var(--ink-soft);
	margin-bottom: 1.2rem;
	max-width: 460px;
}
.servicio-meta {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--line);
	font-family: var(--mono);
	font-size: 0.78rem;
	line-height: 1.8;
	color: var(--ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}
.servicio-meta strong { color: var(--ink); font-weight: 500; }
.servicio-img {
	aspect-ratio: 5/4;
	background: var(--paper-warm);
	border: 1px solid var(--line);
	position: relative;
	overflow: hidden;
}

/* ── Ficha del espacio ───────────────────────────────────────── */
.espacio {
	padding: 6rem 3rem;
	border-top: 1px solid var(--line);
	background: var(--paper-warm);
}
.espacio-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
}
.espacio-data { list-style: none; }
.espacio-data li {
	display: flex;
	justify-content: space-between;
	padding: 1.2rem 0;
	border-top: 1px solid var(--line);
	font-family: var(--mono);
	font-size: 0.85rem;
}
.espacio-data li:last-child { border-bottom: 1px solid var(--line); }
.espacio-data .key {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--ink-soft);
}
.espacio-data .val {
	color: var(--ink);
	font-weight: 500;
	text-align: right;
}

/* ── Contacto — formulario ───────────────────────────────────── */
.contacto-form-wrapper { padding: 5rem 3rem 6rem; }

/* CF7: resetear estilos y aplicar los del tema */
.wpcf7-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	max-width: 800px;
}
.wpcf7-form .half   { /* CF7 groups */  }
.wpcf7-form p { display: contents; }

/* Campos genéricos del tema (fallback sin CF7 y CF7 override) */
.wpcf7-form label,
.field label {
	font-family: var(--mono);
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--ink-soft);
	margin-bottom: 0.6rem;
	display: block;
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea,
.field input,
.field select,
.field textarea {
	font-family: var(--serif);
	font-size: 1.05rem;
	color: var(--ink);
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--line);
	padding: 0.6rem 0;
	outline: none;
	transition: border-color 0.2s;
	width: 100%;
}
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus,
.field input:focus,
.field select:focus,
.field textarea:focus {
	border-bottom-color: var(--accent);
}
.wpcf7-form textarea,
.field textarea {
	resize: vertical;
	min-height: 100px;
}
.wpcf7-form select,
.field select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%231a1815' fill='none' stroke-width='1'/></svg>");
	background-repeat: no-repeat;
	background-position: right 0.4rem center;
}
.wpcf7-form input[type="submit"],
.field button[type="submit"] {
	font-family: var(--mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--paper);
	background: var(--ink);
	border: none;
	padding: 1rem 2.2rem;
	cursor: pointer;
	margin-top: 1rem;
	transition: background 0.2s;
	grid-column: 1 / -1;
	justify-self: start;
}
.wpcf7-form input[type="submit"]:hover,
.field button[type="submit"]:hover {
	background: var(--accent);
}

/* CF7 mensajes de respuesta (ya tienen role="alert") */
.wpcf7-response-output {
	font-family: var(--mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 1rem 1.5rem;
	margin-top: 1.5rem;
	border: 1px solid var(--line);
	grid-column: 1 / -1;
}
.wpcf7-mail-sent-ok { border-color: #2d6a4f; color: #2d6a4f; }
.wpcf7-validation-errors { border-color: var(--accent); color: var(--accent); }

/* CF7: full-width fields */
.wpcf7-form .field-full,
.wpcf7-form br { display: none; } /* ocultar <br> que inserta CF7 */

/* ── Contacto — datos extra ──────────────────────────────────── */
.contacto-extra {
	padding: 5rem 3rem;
	border-top: 1px solid var(--line);
	background: var(--paper-warm);
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 4rem;
}
.contacto-extra-data {
	font-family: var(--mono);
	font-size: 0.9rem;
	line-height: 2;
	color: var(--ink);
}
.contacto-extra-data .label-mono {
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--ink-soft);
	font-size: 0.72rem;
	display: block;
	margin-top: 1.5rem;
}
.contacto-extra-data .label-mono:first-child { margin-top: 0; }

/* ── Footer ──────────────────────────────────────────────────── */
footer {
	padding: 3rem;
	border-top: 1px solid var(--line);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--mono);
	font-size: 0.75rem;
	color: var(--ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
footer a {
	color: var(--ink-soft);
	text-decoration: none;
	margin-left: 2rem;
}
footer a:hover { color: var(--accent); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 860px) {
	nav { padding: 1rem 1.5rem; }
	nav ul { gap: 1.2rem; }

	.hero,
	.intro,
	.servicios-preview,
	.servicios-list,
	.servicio,
	.page-header,
	.espacio,
	.contacto-form-wrapper,
	.contacto-extra,
	footer {
		padding-left: 1.5rem;
		padding-right: 1.5rem;
	}

	.hero { grid-template-columns: 1fr; padding-top: 6rem; gap: 3rem; }

	.intro,
	.preview-header,
	.preview-grid,
	.page-header,
	.servicio,
	.espacio-grid,
	.contacto-extra {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.servicio.imagen-izquierda .servicio-img { order: 0; }

	.wpcf7-form { grid-template-columns: 1fr; gap: 1.5rem; }

	footer { flex-direction: column; gap: 1rem; text-align: center; }
	footer a { margin: 0 0.8rem; }
}
