/* OBBI — shell del sitio: header, layout de página, grilla y product card.
   Estética B/N (Henk / Noo.ma); el color lo aportan las fotos. */

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

html { scroll-behavior: smooth; scroll-padding-top: var(--space-6); }

/* Respeta a quien prefiere menos movimiento. */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-mono);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; }

/* === Header === */
.site-header {
  position: relative; /* ancla del dropdown del nav en móvil */
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-7);
  border-bottom: 1px solid var(--color-border);
}
.site-header__brand {
  display: flex;
  align-items: center;
  text-decoration: none;
}
.site-header__brand img {
  height: 22px;
  width: auto;
  display: block;
}
.site-nav { display: flex; align-items: center; gap: var(--space-6); }
.site-nav__links { display: flex; align-items: center; gap: var(--space-6); }
/* Botón hamburguesa: oculto en desktop, visible en móvil (ver breakpoint ≤560). */
.site-nav__toggle {
  display: none;
  align-items: center;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--color-text);
}
.site-nav a {
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-text-secondary);
  transition: color var(--duration-base, 0.2s) var(--ease, ease);
}
.site-nav a:hover,
.site-nav a[aria-current="page"] { color: var(--color-text); }

/* === Contenedor de página === */
.page { max-width: 1280px; margin: 0 auto; padding: var(--space-8) var(--space-7) var(--space-10); }

/* === Breadcrumb (mínimo, 2 niveles) === */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}
.breadcrumb a { text-decoration: none; color: var(--color-text-secondary); transition: color 0.2s ease; }
.breadcrumb a:hover { color: var(--color-text); }
.breadcrumb [aria-current="page"] { color: var(--color-text); }
.breadcrumb__sep { color: var(--color-border); }

/* === Hero de categoría === */
.cat-hero { margin-bottom: var(--space-8); max-width: 52ch; }
.cat-hero__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
}
.cat-hero__intro {
  margin-top: var(--space-4);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.cat-hero__count {
  margin-top: var(--space-3);
  font-size: var(--fs-xs);
  color: var(--color-text-secondary);
}

/* === Grilla === */
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8) var(--space-6);
}
@media (max-width: 900px) { .grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .grid { grid-template-columns: 1fr; } }

/* === Card === */
.card { display: block; text-decoration: none; color: inherit; cursor: pointer; }
.card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-surface);
}
.card__badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 1;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  background: var(--color-white);
  color: var(--color-text);
  border-radius: var(--radius-full);
}
.card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--duration-base, 0.4s) var(--ease, ease);
}
.card:hover .card__media img { transform: scale(1.03); }

.card__body { padding-top: var(--space-4); }
.card__eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}
.card__name {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-tight);
}
.card__price { text-align: left; margin-top: var(--space-3); white-space: nowrap; }
.card__price-list { font-size: var(--fs-sm); font-weight: 700; color: var(--color-text); }
.card__price-cash { font-size: var(--fs-xs); color: var(--color-accent); margin-top: var(--space-1); }
.card__price-cuotas { font-size: var(--fs-xs); color: var(--color-text-secondary); margin-top: var(--space-1); }
.card__price-consult { font-size: var(--fs-sm); }

/* === Ficha de producto === */
.ficha {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--space-8);
  align-items: start;
}
@media (max-width: 900px) {
  .ficha { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* Galería */
.gallery__main {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-surface);
}
.gallery__main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery__thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.gallery__thumb {
  width: 72px;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 1px solid transparent;
  background: var(--color-surface);
  cursor: pointer;
  overflow: hidden;
  transition: border-color var(--duration-base) var(--ease);
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery__thumb:hover { border-color: var(--color-border); }
.gallery__thumb.is-active { border-color: var(--color-text); }

/* Info */
.ficha__eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}
.ficha__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
}
.ficha__desc {
  margin-top: var(--space-4);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.ficha__desc p + p { margin-top: var(--space-4); }

/* Detalles (prosa larga bajo la galería) */
.details {
  margin-top: var(--space-7);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
  display: grid;
  gap: var(--space-7);
  max-width: 70ch;
}
.details__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-tight);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}
.details__body { font-size: var(--fs-sm); line-height: var(--lh-relaxed); color: var(--color-text-secondary); }
.details__body p + p { margin-top: var(--space-4); }

/* Precio (ficha) */
.price { margin-top: var(--space-5); }
.price__list { font-size: var(--fs-lg); font-weight: 700; }
.price__cash { font-size: var(--fs-sm); color: var(--color-accent); margin-top: var(--space-2); }
.price__cuotas { font-size: var(--fs-xs); color: var(--color-text-secondary); margin-top: var(--space-1); }

/* Selector de variante */
.variants { margin-top: var(--space-5); }
.variants__label {
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}
.variants__opts { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.variant {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--color-text);
  padding: var(--space-2) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: border-color var(--duration-base) var(--ease), background var(--duration-base) var(--ease);
}
.variant:hover { border-color: var(--color-text); }
.variant.is-active { background: var(--color-text); color: var(--color-bg); border-color: var(--color-text); }

/* Specs */
.specs { margin-top: var(--space-5); border-top: 1px solid var(--color-border); }
.specs__row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--fs-sm);
}
.specs__row dt { color: var(--color-text-secondary); }
.specs__row dd { text-align: right; }

.ficha__nota {
  margin-top: var(--space-4);
  font-size: var(--fs-xs);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}

/* Botón */
.btn {
  display: inline-block;
  margin-top: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  padding: var(--space-4) var(--space-6);
  cursor: pointer;
  border: 1px solid var(--color-text);
  transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}
.btn--primary { background: var(--color-text); color: var(--color-bg); }
.btn--primary:hover { background: var(--color-bg); color: var(--color-text); }

.ficha__feedback {
  margin-top: var(--space-3);
  font-size: var(--fs-xs);
  color: var(--color-accent);
  min-height: 1em;
}

/* === Estado vacío === */
.empty { font-size: var(--fs-sm); color: var(--color-text-secondary); padding: var(--space-8) 0; }
.empty--error { color: var(--color-accent); }

/* ============================================================
   LANDING
   ============================================================ */

/* === Hero === */
.hero {
  position: relative;
  height: 78vh;
  min-height: 480px;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero__overlay {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-6);
  color: var(--color-white);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.45));
}
.hero__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-3xl);
  line-height: var(--lh-tight);
  max-width: 18ch;
}
.hero__sub {
  margin-top: var(--space-5);
  font-size: var(--fs-md);
  letter-spacing: 0.02em;
  max-width: 46ch;
}
.hero__cta {
  display: inline-block;
  margin-top: var(--space-6);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-text);
  background: var(--color-white);
  padding: var(--space-4) var(--space-7);
  transition: opacity var(--duration-base) var(--ease);
}
.hero__cta:hover { opacity: 0.85; }
@media (max-width: 560px) {
  .hero { height: 70vh; }
  .hero__title { font-size: var(--fs-xl); }
}

/* === Secciones de la home === */
.home-section {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-9) var(--space-7);
}
.home-section__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-lg);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-7);
}

/* === Grilla de categorías === */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 900px) { .cat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .cat-grid { grid-template-columns: 1fr; } }

.cat-card { display: block; text-decoration: none; color: inherit; }
.cat-card__media {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--color-surface);
}
.cat-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--duration-base) var(--ease);
}
.cat-card:hover .cat-card__media img { transform: scale(1.03); }
.cat-card__name {
  margin-top: var(--space-3);
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
}

/* === Bloque servicio (a medida) === */
.service {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: center;
}
.service__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-surface);
}
.service__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.service__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
}
.service__text {
  margin-top: var(--space-4);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
  max-width: 48ch;
}
.service__cta { margin-top: var(--space-6); }
@media (max-width: 720px) {
  .service { grid-template-columns: 1fr; gap: var(--space-6); }
}
/* Banner de servicio dentro de la grilla de catálogo (necesita separación del grid). */
.cat-service:not(:empty) { margin-top: var(--space-9); }

/* === Instagram / "en sus espacios" === */
.ig-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-7);
}
.ig-head .home-section__title { margin-bottom: 0; }
.ig-head__link {
  font-size: var(--fs-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-text-secondary);
  transition: color var(--duration-base) var(--ease);
}
.ig-head__link:hover { color: var(--color-text); }
.ig-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-3);
}
@media (max-width: 900px) { .ig-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .ig-grid { grid-template-columns: repeat(2, 1fr); } }
.ig-cell {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--color-surface);
  display: block;
}
.ig-cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--duration-base) var(--ease);
}
.ig-cell:hover img { transform: scale(1.05); }

/* === Sobre nosotros === */
.about {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: start;
}
.about__media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--color-surface);
  position: sticky;
  top: var(--space-7);
}
.about__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.about__eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}
.about__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-5);
}
.about__body p.about__lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-normal);
  color: var(--color-text);
  margin-bottom: var(--space-5);
  max-width: 42ch;
}
.about__body p {
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
  max-width: 52ch;
}
.about__body p + p { margin-top: var(--space-4); }
/* sobreCuerpo también viene del WYSIWYG de Directus: si alguna vez incluye
   títulos o listas, que usen la display y el mismo marcador que el resto. */
.about__prose h2,
.about__prose h3 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-tight);
  margin-top: var(--space-6);
  margin-bottom: var(--space-4);
}
.about__prose ul { list-style: none; margin-top: var(--space-3); padding-left: 0; }
.about__prose li {
  position: relative;
  padding-left: var(--space-5);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.about__prose li + li { margin-top: var(--space-2); }
.about__prose li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-text-secondary);
}
.about__cta { margin-top: var(--space-6); }
@media (max-width: 720px) {
  .about { grid-template-columns: 1fr; gap: var(--space-6); }
  .about__media { position: static; top: auto; }
}

/* === Páginas de texto legal (garantía, etc.) === */
.legal { max-width: 64ch; }
.legal__eyebrow {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}
.legal__title {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-5);
}
.legal__lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-normal);
  color: var(--color-text);
  margin-bottom: var(--space-5);
}
.legal p {
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.legal p + p { margin-top: var(--space-4); }
.legal p strong { color: var(--color-text); font-weight: 700; }
.legal__section {
  margin-top: var(--space-7);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}
.legal__heading {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-4);
}
.legal__list {
  list-style: none;
  margin-top: var(--space-3);
}
.legal__list li {
  position: relative;
  padding-left: var(--space-5);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.legal__list li + li { margin-top: var(--space-2); }
.legal__list li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-text-secondary);
}
.legal__cta { margin-top: var(--space-6); }

/* El cuerpo viene del WYSIWYG de Directus como HTML plano (h2/h3/p/ul/li/strong),
   sin las clases .legal__*. Replicamos acá la misma tipografía que el resto del
   sitio para que los títulos usen la display y no hereden la mono del body. */
.legal__prose p {
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.legal__prose p + p,
.legal__prose ul,
.legal__prose p + h2,
.legal__prose p + h3 { margin-top: var(--space-4); }
.legal__prose p strong { color: var(--color-text); font-weight: 700; }
.legal__prose h2,
.legal__prose h3 {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-md);
  line-height: var(--lh-tight);
  margin-top: var(--space-6);
  margin-bottom: var(--space-4);
}
.legal__prose ul {
  list-style: none;
  margin-top: var(--space-3);
  padding-left: 0;
}
.legal__prose li {
  position: relative;
  padding-left: var(--space-5);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-text-secondary);
}
.legal__prose li + li { margin-top: var(--space-2); }
.legal__prose li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-text-secondary);
}

/* ============================================================
   FOOTER (compartido por todas las páginas)
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-9);
}
.site-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-7);
  display: flex;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
}
.site-footer__brand {
  display: inline-flex;
  text-decoration: none;
}
.site-footer__brand img {
  height: 28px;
  width: auto;
  display: block;
}
.site-footer__cols {
  display: flex;
  gap: var(--space-9);
  flex-wrap: wrap;
}
.site-footer__col { display: flex; flex-direction: column; gap: var(--space-3); }
.site-footer__head {
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}
.site-footer__col a {
  font-size: var(--fs-sm);
  text-decoration: none;
  color: var(--color-text);
  transition: color var(--duration-base) var(--ease);
}
.site-footer__col a:hover { color: var(--color-accent); }
.site-footer__legal {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-5) var(--space-7) var(--space-7);
  font-size: var(--fs-xs);
  color: var(--color-text-secondary);
}

/* === Carrito en el nav === */
.site-nav__cart { position: relative; display: inline-flex; align-items: center; color: var(--color-text); }
.site-nav__cart:hover { color: var(--color-text-secondary); }
.site-nav__count {
  position: absolute;
  top: -6px;
  right: -8px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  line-height: 1;
  font-weight: 500;
  color: var(--color-bg);
  background: var(--color-accent);
  border-radius: var(--radius-full);
}
.site-nav__count[hidden] { display: none; }

/* === Página: Mi consulta === */
.consulta__title { font-size: var(--fs-lg); font-weight: 400; margin-bottom: var(--space-6); }
.consulta__list-wrap { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--color-border); }
.consulta__item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border);
}
.consulta__thumb {
  width: 72px;
  height: 72px;
  object-fit: cover;
  background: var(--color-surface);
  flex-shrink: 0;
}
.consulta__info { flex: 1; min-width: 0; }
.consulta__name { font-size: var(--fs-sm); font-weight: 500; }
.consulta__variant { color: var(--color-text-secondary); font-weight: 400; }
.consulta__cash { font-size: var(--fs-sm); color: var(--color-accent); margin-top: var(--space-1); }
.consulta__list { font-size: var(--fs-xs); color: var(--color-text-secondary); margin-top: var(--space-1); }
.consulta__remove {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  transition: color var(--duration-base) var(--ease);
}
.consulta__remove:hover { color: var(--color-accent); }
.consulta__totals { margin-top: var(--space-5); text-align: right; }
.consulta__total-cash { font-size: var(--fs-md); font-weight: 700; }
.consulta__total-list { font-size: var(--fs-xs); color: var(--color-text-secondary); margin-top: var(--space-1); }
.consulta__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-6); }
.consulta__nota { margin-top: var(--space-4); font-size: var(--fs-xs); color: var(--color-text-secondary); line-height: var(--lh-relaxed); }

/* Header de la lista de consulta: título + vaciar */
.consulta__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-6); }
.consulta__head .consulta__title { margin-bottom: 0; }
.consulta__clear-all {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  transition: color var(--duration-base) var(--ease);
}
.consulta__clear-all:hover { color: var(--color-accent); }

/* Estado vacío de la consulta */
.consulta__empty {
  text-align: center;
  padding: var(--space-9) var(--space-5);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}
.consulta__empty svg { color: var(--color-text-secondary); margin-bottom: var(--space-4); }
.consulta__empty-title { font-size: var(--fs-md); font-weight: 500; margin-bottom: var(--space-2); }
.consulta__empty-text {
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  max-width: 32ch;
  margin: 0 auto var(--space-6);
  line-height: var(--lh-relaxed);
}

/* === Repaso responsive (paso 12): padding horizontal y nav en móvil === */
/* En pantallas chicas el padding de space-7 (48px) come demasiado ancho útil.
   Se reduce a space-5 (24px) en los contenedores principales y se aprieta el nav
   (3 links + carrito) para que no desborde a scroll horizontal. */
@media (max-width: 560px) {
  .site-header { padding: var(--space-4) var(--space-5); gap: var(--space-4); }
  /* Layout móvil: [☰] [logo] ……… [carrito].
     `display: contents` disuelve el <nav> para que toggle/carrito sean items directos
     del header y se puedan reordenar junto al logo. */
  .site-nav { display: contents; }
  .site-nav__toggle { display: inline-flex; order: -2; }
  .site-header__brand { order: -1; }
  .site-nav__cart { margin-left: auto; }
  .site-nav__links {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    display: none;
    z-index: 20;
  }
  .site-nav__links.is-open { display: flex; }
  .site-nav__links a {
    padding: var(--space-4) var(--space-5);
    border-top: 1px solid var(--color-border);
  }
  .page { padding: var(--space-6) var(--space-5) var(--space-8); }
  .home-section { padding: var(--space-7) var(--space-5); }
  .site-footer__inner { padding: var(--space-7) var(--space-5); }
  .site-footer__legal { padding: var(--space-5) var(--space-5) var(--space-6); }
  /* Consulta: el CTA de WhatsApp ocupa todo el ancho para ser pulgar-friendly. */
  .consulta__actions { flex-direction: column; }
  .consulta__actions .btn { width: 100%; }
  .consulta__empty { padding: var(--space-8) var(--space-4); }
}
