/* ==========================================================================
   Vértice Commerce 2 — core/layout.css
   Fundación de layout del MOTOR: contenedores, grillas utilitarias,
   espaciado de secciones, cabeceras de página/sección, breadcrumbs, prosa,
   listados de blog/búsqueda, estados vacíos, 404 y comentarios. Porta la
   mecánica de layout.css + secciones 4 de theme.css de v1, reescrita con
   prefijo vc- y SOLO tokens semánticos.

   Breakpoints del contrato: 640px / 880px / 1100px, mobile-first (min-width).

   Convención: los contenedores de grilla anulan el clearfix que WooCommerce
   inyecta (::before/::after con content) — sin eso, el clearfix se vuelve un
   ítem fantasma de la grilla y desalinea la primera fila.
   ========================================================================== */

/* ------------------------------ Contenedores --------------------------- */
.vc-container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.vc-container--narrow { max-width: var(--container-narrow); }

/* ------------------------------ Secciones ------------------------------ */
/* .vc-section: bloque de página interior (page/single/archive/404).
   .vc-sec: sección de la home (front-page.php + template-parts/home/*). */
.vc-section,
.vc-sec { padding-block: clamp(var(--sp-7), 7vw, var(--sp-9)); }

/* Título de sección suelto (related.php / up-sells.php). */
.vc-section__title {
	font-size: var(--fs-h2);
	margin-bottom: var(--sp-5);
}

/* ------------------------------ Grillas utilitarias -------------------- */
.vc-grid {
	display: grid;
	gap: clamp(var(--sp-4), 2.5vw, var(--sp-5));
}
/* Anula el clearfix de WooCommerce (ver cabecera). */
.vc-grid::before,
.vc-grid::after { content: none; }

/* Mobile-first: 1 columna por defecto; las variantes abren columnas en los
   breakpoints del contrato. --4 arranca en 2 columnas (aprendizaje de v1:
   las grillas de producto a 1 columna en phones desperdician la pantalla). */
.vc-grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }

@media (min-width: 640px) {
	.vc-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.vc-grid--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.vc-grid--4 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 880px) {
	.vc-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1100px) {
	.vc-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* ------------------------------ Cabecera de sección -------------------- */
/* header.vc-sec-head (+ --row con acción a la derecha) — template-parts/home. */
.vc-sec-head {
	max-width: 60ch;
	margin-bottom: clamp(var(--sp-5), 4vw, var(--sp-7));
}
.vc-sec-head__title { font-size: var(--fs-h2); }
.vc-sec-head__lead {
	margin-top: var(--sp-2);
	color: var(--ink-2);
}
.vc-sec-head__action {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	margin-top: var(--sp-3);
	font-size: var(--fs-sm);
	font-weight: 500;
}
.vc-sec-head__action svg { width: 16px; height: 16px; flex: none; }

@media (min-width: 640px) {
	.vc-sec-head--row {
		display: flex;
		max-width: none;
		align-items: baseline;
		justify-content: space-between;
		gap: var(--sp-4);
	}
	.vc-sec-head--row .vc-sec-head__action { margin-top: 0; flex: none; }
}

/* ------------------------------ Kicker --------------------------------- */
/* span.vc-kicker (hero.php). Sentence-case con regla previa. */
.vc-kicker {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--accent-strong);
}
.vc-kicker::before {
	content: "";
	width: 1.75rem;
	height: 2px;
	background: currentColor;
	border-radius: var(--radius-pill);
}

/* ------------------------------ Cabecera de página --------------------- */
.vc-page-head {
	max-width: 60ch;
	margin-bottom: clamp(var(--sp-5), 4vw, var(--sp-7));
}
.vc-page-head--wide { max-width: none; }
.vc-page-head__kicker { display: block; margin-bottom: var(--sp-3); }
.vc-page-head__title { font-size: var(--fs-h1); }
.vc-page-head__desc { margin-top: var(--sp-3); color: var(--ink-2); }
.vc-page-head__search { margin-top: var(--sp-4); max-width: 420px; }
.vc-page-head--wide .vc-page-head__search { max-width: 480px; }

/* ------------------------------ Breadcrumbs ---------------------------- */
/* nav.vc-breadcrumbs > .vc-container > span.vc-breadcrumbs__item + __sep
   (inc/template-tags.php / inc/woocommerce.php). */
.vc-breadcrumbs {
	padding-top: clamp(var(--sp-4), 3vw, var(--sp-5));
	font-size: var(--fs-sm);
	color: var(--ink-3);
}
.vc-breadcrumbs .vc-container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--sp-2);
}
.vc-breadcrumbs a { color: var(--ink-2); }
.vc-breadcrumbs a:hover { color: var(--brand-strong); }
.vc-breadcrumbs__sep { color: var(--line); }
.vc-breadcrumbs__item[aria-current="page"] {
	color: var(--ink);
	font-weight: 500;
}

/* ------------------------------ Prosa (contenido) ---------------------- */
/* GOTCHA DOCUMENTADO (fix del gotcha de v1): la medida de lectura (68ch) se
   aplica SOLO a los hijos DIRECTOS de .vc-prose. En v1 el selector de prosa
   era descendiente (afectaba a TODO <p> anidado) y estrangulaba párrafos
   dentro de columnas, galerías y bloques anidados del editor. Con `>` los
   bloques compuestos administran su propio ancho. */
.vc-prose { line-height: var(--lh-body); color: var(--ink); }
.vc-prose > * + * { margin-top: var(--sp-4); }
.vc-prose > p,
.vc-prose > ul,
.vc-prose > ol { max-width: 68ch; }
.vc-prose h2,
.vc-prose h3,
.vc-prose h4 { margin-top: var(--sp-6); margin-bottom: var(--sp-2); }
.vc-prose h2 { font-size: var(--fs-h2); }
.vc-prose h3 { font-size: var(--fs-h3); }
.vc-prose ul,
.vc-prose ol { padding-left: 1.4rem; }
.vc-prose li + li { margin-top: var(--sp-1); }
.vc-prose a {
	color: var(--brand-strong);
	text-decoration: underline;
	text-underline-offset: 0.18em;
	text-decoration-thickness: 1px;
}
.vc-prose a:hover { color: var(--brand); }
/* Cita: convención tipográfica de regla izquierda, en hairline NEUTRO (la
   capa de diseño decide si la acentúa). */
.vc-prose blockquote {
	margin-inline: 0;
	padding: var(--sp-3) var(--sp-5);
	border-left: var(--border-w) solid var(--line);
	background: var(--surface-2);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	color: var(--ink-2);
}
.vc-prose img,
.vc-prose figure { border-radius: var(--radius-lg); overflow: hidden; }
.vc-prose figure figcaption {
	margin-top: var(--sp-2);
	font-size: var(--fs-sm);
	color: var(--ink-3);
	text-align: center;
}
.vc-prose code {
	font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
	font-size: 0.9em;
	background: var(--surface-2);
	padding: 0.15em 0.4em;
	border-radius: var(--radius-sm);
}
.vc-prose pre {
	background: var(--surface-inverse);
	color: var(--surface);
	padding: var(--sp-4);
	border-radius: var(--radius-md);
	overflow-x: auto;
}
.vc-prose pre code { background: none; color: inherit; padding: 0; }
.vc-prose hr {
	border: 0;
	border-top: var(--border-w) solid var(--line);
	margin-block: var(--sp-6);
}
.vc-prose table { width: 100%; font-size: var(--fs-sm); }
.vc-prose th,
.vc-prose td {
	padding: var(--sp-2) var(--sp-3);
	border: var(--border-w) solid var(--line);
	text-align: left;
}
.vc-prose th { background: var(--surface-2); font-weight: 600; }

/* ------------------------------ Entrada (single/page) ------------------ */
.vc-entry__media {
	margin-bottom: clamp(var(--sp-5), 4vw, var(--sp-6));
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--surface-2);
}
.vc-entry__media img { width: 100%; height: auto; }

.vc-entry-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	margin-top: var(--sp-3);
	font-size: var(--fs-sm);
	color: var(--ink-3);
}
.vc-entry-meta__item { display: inline-flex; align-items: center; }
.vc-entry-meta__item + .vc-entry-meta__item::before {
	content: "\00b7";
	margin-right: var(--sp-3);
	color: var(--line);
}

.vc-entry-footer {
	margin-top: var(--sp-6);
	padding-top: var(--sp-4);
	border-top: var(--border-w) solid var(--line);
	font-size: var(--fs-sm);
	color: var(--ink-2);
}
.vc-entry-footer__group + .vc-entry-footer__group { margin-top: var(--sp-2); }
.vc-entry-footer__label { font-weight: 500; color: var(--ink); }

/* Nav entre entradas (the_post_navigation → nav.vc-postnav). */
.vc-postnav {
	margin-top: var(--sp-7);
	padding-top: var(--sp-5);
	border-top: var(--border-w) solid var(--line);
}
.vc-postnav .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-4);
	justify-content: space-between;
}
.vc-postnav .nav-next { text-align: right; margin-left: auto; }
.vc-postnav a { display: inline-flex; flex-direction: column; gap: var(--sp-1); }
.vc-postnav__label {
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-3);
}
.vc-postnav__title {
	font-family: var(--font-display);
	font-weight: 500;
	color: var(--ink);
}

/* ------------------------------ Tarjeta de entrada --------------------- */
/* template-parts/post-card.php. */
.vc-post-card { display: flex; flex-direction: column; }
.vc-post-card__media {
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-radius: var(--radius-card);
	background: var(--surface-2);
	border: var(--border-w) solid var(--line);
}
.vc-post-card__media img { width: 100%; height: 100%; object-fit: cover; }
.vc-post-card__body {
	padding-top: var(--sp-3);
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}
.vc-post-card__cat {
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-3);
}
.vc-post-card__cat a { color: inherit; }
.vc-post-card__cat a:hover { color: var(--brand-strong); }
.vc-post-card__title {
	font-size: var(--fs-h3);
	font-weight: 500;
	line-height: var(--lh-snug);
}
.vc-post-card__title a { color: var(--ink); }
.vc-post-card__title a:hover { color: var(--brand-strong); }
.vc-post-card__excerpt { color: var(--ink-2); font-size: var(--fs-sm); }

.vc-readmore {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	margin-top: var(--sp-1);
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--brand);
}
.vc-readmore:hover { color: var(--brand-strong); }
.vc-readmore__ico { display: inline-grid; place-items: center; }
.vc-readmore__ico svg { width: 16px; height: 16px; }

/* ------------------------------ Resultados de búsqueda ----------------- */
/* search.php: vidriera de productos + bloque "en el sitio". */
.vc-search-results { display: flex; flex-direction: column; gap: var(--sp-5); }
.vc-search-item {
	display: grid;
	gap: var(--sp-4);
	padding-bottom: var(--sp-5);
	border-bottom: var(--border-w) solid var(--line);
}
@media (min-width: 640px) {
	.vc-search-item { grid-template-columns: 160px minmax(0, 1fr); align-items: start; }
}
.vc-search-item__media {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--radius-md);
	background: var(--surface-2);
	border: var(--border-w) solid var(--line);
}
.vc-search-item__media img { width: 100%; height: 100%; object-fit: cover; }
.vc-search-item__body { display: flex; flex-direction: column; gap: var(--sp-1); min-width: 0; }
.vc-search-item__type {
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-3);
}
.vc-search-item__title { font-size: var(--fs-h3); font-weight: 500; line-height: var(--lh-snug); }
.vc-search-item__title a { color: var(--ink); }
.vc-search-item__title a:hover { color: var(--brand-strong); }
.vc-search-item__excerpt { color: var(--ink-2); font-size: var(--fs-sm); }

.vc-results__section + .vc-results__section {
	margin-top: clamp(var(--sp-6), 6vw, var(--sp-8));
	padding-top: clamp(var(--sp-5), 5vw, var(--sp-7));
	border-top: var(--border-w) solid var(--line);
}
.vc-results__heading {
	font-size: var(--fs-h3);
	font-weight: 500;
	margin-bottom: var(--sp-4);
}
.vc-results__heading--secondary { color: var(--ink-2); }
.vc-results__count {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 400;
	color: var(--ink-3);
	margin-left: var(--sp-1);
}
.vc-results__note { margin-bottom: var(--sp-4); color: var(--ink-2); font-size: var(--fs-sm); }
.vc-results__note-cta { margin-bottom: var(--sp-5); }
.vc-results__shop-link { display: flex; justify-content: center; margin-top: var(--sp-5); }

/* ------------------------------ Estado vacío --------------------------- */
.vc-empty {
	max-width: 48ch;
	margin-inline: auto;
	padding-block: clamp(var(--sp-6), 6vw, var(--sp-8));
	text-align: center;
}
.vc-empty__title { font-size: var(--fs-h2); }
.vc-empty__text { margin-top: var(--sp-3); color: var(--ink-2); }
.vc-empty__action,
.vc-empty .vc-btn { margin-top: var(--sp-5); }
.vc-empty__chips { justify-content: center; margin-top: var(--sp-4); }

/* ------------------------------ 404 ------------------------------------ */
.vc-404 { text-align: center; }
.vc-404__code {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(5rem, 18vw, 11rem);
	line-height: 0.9;
	letter-spacing: -0.02em;
	color: var(--line);
}
.vc-404__title { font-size: var(--fs-h1); margin-top: var(--sp-1); }
.vc-404__text { margin-top: var(--sp-3); color: var(--ink-2); }
.vc-404__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	justify-content: center;
	margin-top: var(--sp-5);
}
.vc-404__search { margin-top: var(--sp-7); max-width: 460px; margin-inline: auto; }
.vc-404__search-label { margin-bottom: var(--sp-2); font-size: var(--fs-sm); color: var(--ink-3); }

/* ------------------------------ Banda CTA ------------------------------ */
/* aside.vc-cta-band (page-templates/page-about.php). */
.vc-cta-band__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-4);
	padding: clamp(var(--sp-5), 4vw, var(--sp-7));
	background: var(--surface-2);
	border-radius: var(--radius-card);
}
.vc-cta-band__text { max-width: 46ch; }
.vc-cta-band__actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); }

/* ------------------------------ Comentarios ---------------------------- */
/* comments.php + comment_form() (clases del core de WP). */
.vc-comments {
	margin-top: clamp(var(--sp-6), 6vw, var(--sp-8));
	padding-top: var(--sp-6);
	border-top: var(--border-w) solid var(--line);
}
.vc-comments__title { font-size: var(--fs-h3); margin-bottom: var(--sp-5); }
.vc-comments__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}
.vc-comments__list .children {
	list-style: none;
	margin: var(--sp-4) 0 0;
	padding-left: clamp(var(--sp-3), 4vw, var(--sp-6));
	border-left: var(--border-w) solid var(--line);
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
}
.vc-comments__list .comment-body { display: flex; flex-direction: column; gap: var(--sp-2); }
.vc-comments__list .comment-author {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-weight: 500;
}
.vc-comments__list .comment-author .avatar { border-radius: var(--radius-pill); }
.vc-comments__list .comment-author .fn { font-style: normal; color: var(--ink); }
.vc-comments__list .comment-author .says { display: none; }
.vc-comments__list .comment-metadata { font-size: var(--fs-xs); color: var(--ink-3); }
.vc-comments__list .comment-metadata a { color: inherit; }
.vc-comments__list .comment-content > * + * { margin-top: var(--sp-3); }
.vc-comments__list .reply { font-size: var(--fs-sm); }
.vc-comments__list .comment-reply-link { font-weight: 500; }
.vc-comments__closed { margin-top: var(--sp-4); color: var(--ink-3); font-size: var(--fs-sm); }

.comment-respond {
	margin-top: var(--sp-7);
	padding: clamp(var(--sp-4), 4vw, var(--sp-6));
	background: var(--surface-2);
	border: var(--border-w) solid var(--line);
	border-radius: var(--radius-card);
}
.comment-respond .comment-reply-title { font-size: var(--fs-h3); margin-bottom: var(--sp-2); }
.comment-respond .comment-reply-title small { margin-left: var(--sp-2); font-size: var(--fs-sm); font-weight: 400; }
.vc-comment-form__notes { font-size: var(--fs-sm); margin-bottom: var(--sp-4); color: var(--ink-2); }
.comment-form-author,
.comment-form-email,
.comment-form-url,
.vc-comment-form__field {
	display: flex;
	flex-direction: column;
	gap: var(--sp-1);
	margin-bottom: var(--sp-4);
}
.comment-form label { font-size: var(--fs-sm); font-weight: 500; color: var(--ink-2); }
/* Los inputs del comment_form del core no llevan clase vc-: se estilan por
   elemento, con la misma receta que .vc-input (core/components.css). */
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: var(--sp-3) var(--sp-3);
	background: var(--surface);
	color: var(--ink);
	border: var(--border-w) solid var(--line);
	border-radius: var(--radius-md);
}
/* Fix theme.css:316: el anillo global :focus-visible queda intacto; acá solo
   se suma el borde activo (nunca outline:none). */
.comment-form input:focus-visible,
.comment-form textarea:focus-visible { border-color: var(--brand); }
/* Autor/email a 2 columnas: grid en el padre (los <p> que imprime
   comment_form() son hijos directos). El patrón inline-flex + width:calc no
   cierra nunca: 100% + márgenes + el whitespace entre <p> siempre desborda. */
@media (min-width: 640px) {
	.comment-form {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 0 var(--sp-4);
	}
	.comment-form > * { grid-column: 1 / -1; }
	.comment-form-author { grid-column: 1; }
	.comment-form-email { grid-column: 2; }
}
.comment-form .form-submit { margin-top: var(--sp-2); }
.comment-form .comment-form-cookies-consent {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-2);
	font-size: var(--fs-sm);
	color: var(--ink-2);
}
.comment-form .comment-form-cookies-consent label { font-weight: 400; }
