/* ════════════════════════════════════════════════════════════════════════
   HOREKA — Paginas internas (productos, categoria, soluciones, etc.)
   ════════════════════════════════════════════════════════════════════════ */

/* ── Reveal direccional (animacion de entrada al scroll) ───────────────── */
[data-reveal][data-reveal-dir] {
  opacity: 0;
  transition: opacity 900ms cubic-bezier(0.2, 0.7, 0.2, 1),
              transform 900ms cubic-bezier(0.2, 0.7, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: transform, opacity;
}
[data-reveal][data-reveal-dir="from-left"]  { transform: translateX(-120px); }
[data-reveal][data-reveal-dir="from-right"] { transform: translateX(120px); }
[data-reveal][data-reveal-dir="from-bottom"]{ transform: translateY(60px); }
[data-reveal][data-reveal-dir="fade-up"]    { transform: translateY(24px); }

[data-reveal][data-reveal-dir].is-visible {
  opacity: 1;
  transform: translate(0, 0);
}
/* Movil: desplazamientos mas sutiles para que no haya overflow horizontal
   visible ni sensacion de viewport "encogiendo" durante el scroll. */
@media (max-width: 720px) {
  [data-reveal][data-reveal-dir="from-left"]  { transform: translateX(-40px); }
  [data-reveal][data-reveal-dir="from-right"] { transform: translateX(40px); }
  [data-reveal][data-reveal-dir="from-bottom"]{ transform: translateY(30px); }
  [data-reveal][data-reveal-dir="fade-up"]    { transform: translateY(18px); }
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal][data-reveal-dir] { transform: none; transition: none; opacity: 1; }
}

/* ── Catalogo editorial (productos.html) ───────────────────────────────── */
.catalog-intro {
  max-width: 880px;
  padding: var(--sp-6) 0 var(--sp-4);
}
.catalog-intro h1 {
  margin-top: var(--sp-3);
  font-size: clamp(2.2rem, 4.6vw, 3.75rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
}
.catalog-intro .lead {
  margin-top: var(--sp-5);
  max-width: 60ch;
}
.catalog-jump {
  margin-top: var(--sp-7);
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
  background: var(--c-ice);
  border-radius: var(--r-pill);
}
.catalog-jump a {
  display: inline-flex;
  align-items: center;
  padding: 10px 22px;
  border-radius: var(--r-pill);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-text-soft);
  transition: color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.catalog-jump a:hover {
  color: var(--c-text);
}
.catalog-jump a.is-active {
  background: var(--c-white);
  color: var(--c-text);
  box-shadow: var(--sh-sm);
}
.catalog-jump--hover a:hover {
  background: var(--c-white);
  color: var(--c-text);
  box-shadow: var(--sh-sm);
}

/* ── Solucion — bloque editorial 'Oportunidad' ─────────────────────────── */
.sol-oportunidad {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.sol-oportunidad h3 {
  margin-top: var(--sp-3);
  font-size: var(--fs-2xl);
  color: var(--c-text);
}
.sol-oportunidad p {
  margin-top: var(--sp-4);
  color: var(--c-text-soft);
}
.sol-oportunidad__btns {
  margin-top: var(--sp-6);
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  justify-content: center;
}
.res-empty {
  margin-top: var(--sp-6);
  padding: var(--sp-7);
  text-align: center;
  border: 1px dashed var(--c-border);
  border-radius: var(--r-lg);
  color: var(--c-text-soft);
  font-size: var(--fs-sm);
}

.catalog-cat {
  padding: var(--sp-10) 0;
  border-top: 1px solid var(--c-border);
}
.catalog-cat--alt {
  background: var(--c-warm-white);
}
.catalog-cat__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--sp-6);
  margin-bottom: var(--sp-8);
  flex-wrap: wrap;
}
.catalog-cat__title {
  margin-top: var(--sp-3);
  font-size: clamp(1.875rem, 3vw, 2.75rem);
  letter-spacing: -0.025em;
}
.catalog-cat__desc {
  margin-top: var(--sp-4);
  max-width: 60ch;
  color: var(--c-text-soft);
  font-size: var(--fs-md);
}
.catalog-cat__count {
  text-align: right;
  border-left: 2px solid var(--c-ice-blue);
  padding-left: var(--sp-5);
}
.catalog-cat__count-num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 4vw, 3.75rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--c-text);
}
.catalog-cat__count-lbl {
  display: block;
  margin-top: 6px;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--c-text-soft);
  font-weight: 600;
}

/* Grid editorial: 3 columnas en escritorio, 1 grande + 2 chicas en patrones */
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
@media (max-width: 1100px) {
  .catalog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .catalog-grid { grid-template-columns: 1fr; }
}

/* Card individual */
.catalog-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: transparent;
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform var(--t-base);
}
.catalog-card:hover {
  transform: translateY(-4px);
}
.catalog-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  display: grid;
  place-items: center;
  overflow: hidden;
  transition: border-color var(--t-base), box-shadow var(--t-base);
}
.catalog-cat--alt .catalog-card__media {
  background: var(--c-white);
}
.catalog-card:hover .catalog-card__media {
  border-color: var(--c-graphite);
  box-shadow: var(--sh-lg);
}
.catalog-card__media img {
  width: 78%;
  height: 78%;
  object-fit: contain;
  mix-blend-mode: multiply;
  transition: transform 700ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.catalog-card:hover .catalog-card__media img {
  transform: scale(1.05);
}
.catalog-card__code {
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--c-text);
  background: var(--c-white);
  padding: 5px 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--c-border);
  z-index: 2;
}
.catalog-card__body {
  padding: var(--sp-5) var(--sp-2) 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.catalog-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--c-text);
}
.catalog-card__meta {
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  letter-spacing: 0.01em;
}
.catalog-card__cta {
  margin-top: var(--sp-3);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ice-blue-dark);
}
.catalog-card__cta span {
  transition: transform var(--t-fast);
}
.catalog-card:hover .catalog-card__cta span {
  transform: translateX(4px);
}

@media (max-width: 720px) {
  .catalog-cat { padding: var(--sp-9) 0; }
  .catalog-cat__count { text-align: left; border-left: 2px solid var(--c-ice-blue); }
}


/* ── Page hero (banda superior comun) ──────────────────────────────────── */
.page-hero {
  background:
    radial-gradient(900px 500px at 100% -10%, rgba(232,199,102,0.15), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(95,175,196,0.16), transparent 60%),
    var(--c-warm-white);
  padding: var(--sp-9) 0 var(--sp-7);
  border-bottom: 1px solid var(--c-border);
}
.page-hero__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--sp-7);
  align-items: end;
}
.page-hero h1 {
  font-size: clamp(2rem, 4.4vw, 3.5rem);
  letter-spacing: -0.03em;
  margin-top: var(--sp-3);
}
.page-hero p { margin-top: var(--sp-4); max-width: 60ch; font-size: var(--fs-md); }
.page-hero__meta {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.page-hero__meta-row {
  display: flex;
  justify-content: space-between;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--c-border);
  font-size: var(--fs-sm);
}
.page-hero__meta-row span:first-child { color: var(--c-text-soft); }
.page-hero__meta-row span:last-child { font-weight: 600; }
@media (max-width: 880px) {
  .page-hero__inner { grid-template-columns: 1fr; }
}

/* ── Productos: layout con filtros ─────────────────────────────────────── */
.shop {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-7);
}
.shop__aside {
  position: sticky;
  top: calc(var(--header-h) + var(--sp-4));
  align-self: start;
  padding: var(--sp-5);
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.shop__aside h3 {
  font-size: var(--fs-base);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-family: var(--font-body);
  margin-bottom: var(--sp-3);
}
.shop__group { padding: var(--sp-3) 0; border-bottom: 1px solid var(--c-border); }
.shop__group:last-child { border-bottom: 0; }
.shop__group h4 {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--c-text-soft);
  margin-bottom: var(--sp-3);
}
.shop__pills { display: flex; flex-wrap: wrap; gap: 6px; }
.shop__results-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
}
.shop__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
@media (max-width: 1100px) { .shop__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 980px) {
  .shop { grid-template-columns: 1fr; }
  .shop__aside { position: static; }
}
@media (max-width: 600px) { .shop__grid { grid-template-columns: 1fr; } }

.shop__help {
  margin-top: var(--sp-8);
  padding: var(--sp-6);
  background: var(--c-graphite);
  color: var(--c-warm-white);
  border-radius: var(--r-lg);
  text-align: center;
}
.shop__help h3 { color: var(--c-warm-white); }
.shop__help p { color: var(--c-warm-white); margin: var(--sp-3) auto; max-width: 50ch; }
.shop__empty {
  padding: var(--sp-8);
  text-align: center;
  border: 1px dashed var(--c-border);
  border-radius: var(--r-lg);
  color: var(--c-text-soft);
}

/* ── Categoria — Pestañas pill ─────────────────────────────────────────── */
.tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: var(--c-ice);
  border-radius: var(--r-pill);
  margin-bottom: var(--sp-7);
  flex-wrap: wrap;
}
.tab {
  padding: 10px 22px;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-text-soft);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.tab:hover { color: var(--c-text); }
.tab.is-active {
  color: var(--c-text);
  background: var(--c-white);
  box-shadow: var(--sh-sm);
}
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

/* ── Categoria — Cards estilo compare (replicado de home) ─────────────── */
.cat-compare {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-6);
}
.cat-compare .compare__card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.cat-compare .compare__card:hover {
  border-color: var(--c-graphite);
  transform: translateY(-3px);
  box-shadow: var(--sh-md);
}
.cat-compare .compare__icon {
  width: 56px;
  height: 56px;
  border-radius: var(--r-md);
  background: var(--c-ice);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  margin: 0 auto;
}
.cat-compare .compare__icon img {
  width: 32px;
  height: 32px;
  display: block;
}
.cat-compare .compare__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--c-text);
  margin: 0;
}
.cat-compare .compare__text {
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  line-height: 1.55;
  margin: 0;
}
@media (max-width: 1024px) { .cat-compare { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .cat-compare { grid-template-columns: 1fr; } }

/* ── Ficha de producto v2 (editorial) ──────────────────────────────────── */

/* Compatibilidad con las fichas generadas actualmente. */
.product-page {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
  gap: var(--sp-9);
  align-items: start;
}

.product-page__gallery {
  position: sticky;
  top: calc(var(--header-h) + var(--sp-5));
  display: grid;
  gap: var(--sp-4);
}

.product-page__main-img {
  min-height: 460px;
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  padding: var(--sp-9);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.7), rgba(243,246,246,0.55)),
    var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
}

.product-page__main-img img {
  width: 100%;
  height: 100%;
  max-width: 560px;
  max-height: 560px;
  object-fit: contain;
  mix-blend-mode: multiply;
}

.product-gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp-3);
}

.product-gallery__item {
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  padding: 10px;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
}

.product-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}

.product-page__info {
  min-width: 0;
  padding-top: var(--sp-2);
}

.product-page__info h1 {
  margin-top: var(--sp-3);
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.08;
}

.product-page__info h2 {
  line-height: 1.2;
}

.product-page__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: var(--sp-4);
}

.product-page__specs {
  margin-top: var(--sp-4);
  display: grid;
  border-top: 1px solid var(--c-border);
}

.product-page__specs .spec-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.72fr) minmax(0, 1fr);
  gap: var(--sp-4);
  padding: 14px 0;
  border-bottom: 1px solid var(--c-border);
}

.product-page__specs dt {
  color: var(--c-text-soft);
  font-size: var(--fs-sm);
}

.product-page__specs dd {
  margin: 0;
  color: var(--c-text);
  font-weight: 700;
  text-align: right;
}

.product-page .cta-final__btns {
  justify-content: flex-start;
}

@media (max-width: 1100px) {
  .product-page {
    grid-template-columns: minmax(0, 1fr);
    gap: var(--sp-6);
  }

  .product-page__gallery {
    position: static;
  }

  .product-page__main-img {
    min-height: auto;
    aspect-ratio: 4 / 3;
    padding: var(--sp-7);
  }

  .product-page__main-img img {
    max-width: 100%;
    max-height: 100%;
  }

  /* Bloque de info como contenedor real cuando va debajo de la imagen */
  .product-page__info {
    background: var(--c-white);
    border: 1px solid var(--c-border);
    border-radius: var(--r-xl);
    padding: var(--sp-7);
  }
}

@media (max-width: 640px) {
  .product-page {
    gap: var(--sp-5);
  }

  .product-page__main-img {
    aspect-ratio: 4 / 3;
    padding: var(--sp-5);
    border-radius: var(--r-lg);
  }

  .product-page__main-img img {
    max-width: 100%;
    max-height: 100%;
  }

  .product-page__info {
    padding: var(--sp-5);
    border-radius: var(--r-lg);
  }

  .product-page__info h1 {
    font-size: clamp(1.5rem, 6vw, 1.875rem);
    line-height: 1.15;
  }

  .product-page__info h2 {
    font-size: var(--fs-lg) !important;
  }

  .product-gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--sp-2);
  }

  .product-page__specs .spec-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }

  .product-page__specs dd {
    text-align: left;
  }

  .product-page .cta-final__btns,
  .cta-final__btns {
    flex-direction: column;
    align-items: stretch;
    gap: var(--sp-3);
  }

  .product-page .cta-final__btns .btn,
  .cta-final__btns .btn {
    width: 100%;
    min-width: 0;
    white-space: normal;
  }
}

/* Hero del producto: galeria sticky + info al lado */
.product-hero {
  padding: var(--sp-9) 0 var(--sp-10);
}
.product-hero .breadcrumb {
  margin-bottom: var(--sp-7);
}
.product-hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: var(--sp-9);
  align-items: start;
}
@media (max-width: 980px) {
  .product-hero__layout { grid-template-columns: 1fr; gap: var(--sp-7); }
}

.product-hero__visual {
  position: sticky;
  top: calc(72px + var(--sp-5));
}
@media (max-width: 980px) {
  .product-hero__visual { position: static; }
}

.product-hero__gallery {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.product-hero__main {
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  padding: var(--sp-9);
  overflow: hidden;
}
.product-hero__main img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
  transition: transform 700ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.product-hero__main:hover img { transform: scale(1.04); }

.product-hero__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
}
.product-hero__thumb {
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-warm-white);
  aspect-ratio: 1;
  padding: 8px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: border-color var(--t-fast), transform var(--t-fast);
}
.product-hero__thumb:hover { transform: translateY(-2px); }
.product-hero__thumb img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}
.product-hero__thumb.is-active { border-color: var(--c-graphite); }

/* Info derecha */
.product-hero__info {
  padding-top: var(--sp-3);
}
.product-hero__cat {
  font-size: var(--fs-xs);
  color: var(--c-ice-blue-dark);
}
.product-hero__title {
  margin-top: var(--sp-3);
  font-size: clamp(1.875rem, 3.4vw, 2.75rem);
  letter-spacing: -0.025em;
  line-height: 1.1;
}
.product-hero__lead {
  margin-top: var(--sp-5);
  font-size: var(--fs-md);
  color: var(--c-text-soft);
  max-width: 56ch;
  line-height: 1.65;
}
.product-hero__tags {
  margin-top: var(--sp-5);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.product-hero__tag {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: var(--c-ice);
  color: var(--c-text);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1px solid var(--c-border);
}
.product-hero__tag--code {
  background: var(--c-graphite);
  color: var(--c-warm-white);
  border-color: var(--c-graphite);
  letter-spacing: 0.14em;
}
.product-hero__tag--accent {
  background: rgba(95,175,196,0.16);
  color: var(--c-ice-blue-dark);
  border-color: rgba(95,175,196,0.45);
}

.product-hero__quick {
  margin-top: var(--sp-7);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
.product-hero__quick-item .lbl {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--c-text-soft);
  font-weight: 600;
}
.product-hero__quick-item .val {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 6px;
  color: var(--c-text);
}

.product-hero__actions {
  margin-top: var(--sp-6);
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

.product-hero__trust {
  margin-top: var(--sp-6);
  display: grid;
  gap: 10px;
}
.product-hero__trust li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  font-weight: 500;
}
.product-hero__trust svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  color: var(--c-ice-blue-dark);
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Beneficios */
.prod-benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}
@media (max-width: 880px) { .prod-benefits { grid-template-columns: 1fr; } }
.prod-benefit {
  position: relative;
  padding: var(--sp-3) 0 var(--sp-3) var(--sp-5);
  border-left: 2px solid var(--c-ice-blue);
}
.prod-benefit__num {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-ice-blue-dark);
}
.prod-benefit h3 {
  margin: var(--sp-3) 0 var(--sp-3);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--c-text);
}
.prod-benefit p {
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  line-height: 1.6;
}

/* Ficha tecnica — tabla editorial */
.prod-specs {
  border-top: 1px solid var(--c-border);
}
.prod-specs__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.prod-specs__table tr {
  border-bottom: 1px solid var(--c-border);
  transition: background var(--t-fast);
}
.prod-specs__table tr:hover {
  background: var(--c-warm-white);
}
.prod-specs__table th,
.prod-specs__table td {
  text-align: left;
  padding: var(--sp-4) var(--sp-3);
  vertical-align: top;
}
.prod-specs__table th {
  font-weight: 500;
  color: var(--c-text-soft);
  width: 38%;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: var(--fs-xs);
}
.prod-specs__table td {
  font-weight: 600;
  color: var(--c-text);
  font-family: var(--font-display);
  letter-spacing: -0.005em;
}

/* Ideal para */
.prod-ideal {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
}
@media (max-width: 720px) { .prod-ideal { grid-template-columns: repeat(2, 1fr); } }
.prod-ideal__item {
  padding: var(--sp-5) var(--sp-4);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-align: center;
  color: var(--c-text);
  transition: border-color var(--t-fast), transform var(--t-fast);
}
.prod-ideal__item:hover {
  border-color: var(--c-graphite);
  transform: translateY(-2px);
}

/* ── Ficha de producto (legacy — selectores antiguos) ──────────────────── */
.product {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--sp-8);
  align-items: start;
}
@media (max-width: 980px) { .product { grid-template-columns: 1fr; } }

.product__head h1 {
  font-size: clamp(1.875rem, 3.4vw, 2.5rem);
  letter-spacing: -0.02em;
  margin-top: var(--sp-2);
}
.product__cat { color: var(--c-text-soft); font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }
.product__tags { display: flex; gap: 8px; flex-wrap: wrap; margin: var(--sp-4) 0; }
.product__lead { font-size: var(--fs-md); color: var(--c-text-soft); max-width: 60ch; margin-top: var(--sp-3); }
.product__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin: var(--sp-6) 0; }

.product__quick {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.product__quick__item .lbl {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--c-text-soft);
  font-weight: 600;
}
.product__quick__item .val {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 4px;
  color: var(--c-text);
}

.product__section { margin-top: var(--sp-8); }
.product__section h2 { font-size: var(--fs-2xl); }

.benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-5);
}
.benefit {
  padding: var(--sp-5);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
}
.benefit__num {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--c-ice-blue-dark);
  line-height: 1;
}
.benefit h4 { margin: var(--sp-3) 0 var(--sp-2); font-size: var(--fs-md); }
.benefit p { font-size: var(--fs-sm); line-height: 1.55; }
@media (max-width: 720px) { .benefits { grid-template-columns: 1fr; } }

.ideal-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}
.ideal {
  padding: var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  text-align: center;
  font-size: var(--fs-sm);
  font-weight: 600;
  background: var(--c-warm-white);
}
@media (max-width: 720px) { .ideal-grid { grid-template-columns: repeat(2,1fr); } }

/* ── Soluciones index ──────────────────────────────────────────────────── */
.sols-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.sol-big {
  position: relative;
  padding: var(--sp-7);
  border-radius: var(--r-lg);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  min-height: 320px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  transition: transform var(--t-base), border-color var(--t-base);
}
.sol-big:hover { transform: translateY(-4px); border-color: var(--c-graphite); }
.sol-big::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 100% 0%, rgba(232,199,102,0.18), transparent 55%);
  opacity: 0;
  transition: opacity var(--t-base);
}
.sol-big:hover::before { opacity: 1; }
.sol-big > * { position: relative; z-index: 2; }
.sol-big__num {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--c-ice);
  line-height: 1;
}
.sol-big__icon {
  width: 88px;
  height: 88px;
  object-fit: contain;
  margin-top: var(--sp-4);
}
.sol-big h3 { font-size: var(--fs-xl); margin-top: var(--sp-4); }
.sol-big p { font-size: var(--fs-sm); color: var(--c-text-soft); margin-top: var(--sp-2); line-height: 1.55; }
.sol-big__cta {
  margin-top: var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sol-big__cta::after { content: "→"; transition: transform var(--t-fast); }
.sol-big:hover .sol-big__cta::after { transform: translateX(4px); }
@media (max-width: 880px) { .sols-grid { grid-template-columns: 1fr; } }

/* ── Recursos ──────────────────────────────────────────────────────────── */
.res-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: var(--sp-6);
}
.res-list { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--sp-4); }
.res-list .res-card__media { aspect-ratio: 1 / 1; }
@media (max-width: 880px) { .res-list { grid-template-columns: 1fr; } }

.article-hero {
  padding: var(--sp-8) 0 var(--sp-7);
  background:
    radial-gradient(900px 520px at 90% -10%, rgba(95,175,196,0.16), transparent 58%),
    var(--c-white);
  border-bottom: 1px solid var(--c-border);
}
.article-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: var(--sp-8);
  align-items: end;
}
.article-hero h1 {
  max-width: 14ch;
}
.article-hero .lead {
  margin-top: var(--sp-5);
}
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: var(--sp-5);
}
.article-meta .tag {
  background: var(--c-white);
}
.article-hero__media {
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid var(--c-border);
  background: var(--c-ice);
  box-shadow: var(--sh-md);
  aspect-ratio: 1 / 1.08;
}
.article-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.article-page {
  padding: var(--sp-9) 0;
}
.article-body {
  max-width: 860px;
  margin: 0 auto;
}
.article-body h2 {
  font-size: clamp(1.55rem, 2.4vw, 2.2rem);
  margin: var(--sp-8) 0 var(--sp-3);
}
.article-body p {
  font-size: var(--fs-md);
  line-height: 1.8;
  margin-top: var(--sp-4);
}
.article-body ul {
  display: grid;
  gap: 10px;
  margin-top: var(--sp-4);
}
.article-body li {
  position: relative;
  padding-left: 28px;
  color: var(--c-text-soft);
  font-size: var(--fs-md);
  line-height: 1.65;
}
.article-body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 10px;
  height: 10px;
  border-radius: var(--r-pill);
  background: var(--c-ice-blue);
}
.article-callout {
  margin: var(--sp-8) 0;
  padding: var(--sp-6);
  border-radius: var(--r-lg);
  background: var(--c-graphite);
  color: var(--c-warm-white);
}
.article-callout p,
.article-callout h2 {
  color: var(--c-warm-white);
}
.article-actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-top: var(--sp-5);
}
.article-source {
  margin-top: var(--sp-7);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--c-border);
  font-size: var(--fs-sm);
}
.article-source a {
  color: var(--c-ice-blue-dark);
  font-weight: 700;
}
@media (max-width: 860px) {
  .article-hero__grid {
    grid-template-columns: 1fr;
  }
  .article-hero h1 {
    max-width: 100%;
  }
}

/* ── Contacto ──────────────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--sp-9);
  align-items: start;
}
.contact-info { display: flex; flex-direction: column; gap: var(--sp-5); }
.contact-info__item {
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--c-border);
}
.contact-info__lbl {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--c-text-soft);
  margin-bottom: 6px;
  font-weight: 600;
}
.contact-info__val {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.015em;
}
.contact-form {
  padding: var(--sp-7);
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-form__row { grid-template-columns: 1fr; }
}

/* ── Nosotros ──────────────────────────────────────────────────────────── */
.empresa-section {
  background:
    radial-gradient(circle at 92% -12%, rgba(95, 175, 196, 0.18), transparent 46%),
    var(--c-graphite);
}
.empresa-section .section__title h2 {
  color: var(--c-warm-white);
}
.empresa-section > .container > .section__head .eyebrow {
  color: var(--c-vanilla);
}
.empresa-section .about-intro .eyebrow {
  color: var(--c-ice-blue-soft);
}
.nosotros-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-7);
}
.about-intro,
.value-card {
  position: relative;
  padding: var(--sp-3) 0 var(--sp-3) var(--sp-5);
  background: transparent;
  border: 0;
  border-left: 2px solid var(--c-ice-blue);
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
}
.about-intro {
  width: 100%;
  padding-left: 0;
  border-left: 0;
}
.about-intro:hover,
.value-card:hover {
  transform: none;
  background: transparent;
}
.about-intro h3 {
  margin: var(--sp-3) 0 var(--sp-4);
  font-size: clamp(1.75rem, 2.4vw, 2.35rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--c-warm-white);
}
.about-intro p:last-child {
  max-width: 76ch;
  font-size: var(--fs-base);
  line-height: 1.7;
  color: rgba(250, 250, 247, 0.82);
}
.value-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  height: auto;
  padding: 0;
  margin-bottom: var(--sp-2);
  border-radius: 0;
  background: transparent;
  color: var(--c-warm-white);
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
}
.value-card h4 {
  margin-bottom: var(--sp-3);
  font-size: clamp(1.25rem, 1.8vw, 1.55rem);
  letter-spacing: -0.02em;
  color: var(--c-warm-white);
}
.value-card p {
  font-size: var(--fs-base);
  line-height: 1.7;
  color: rgba(250, 250, 247, 0.82);
}
@media (max-width: 880px) { .nosotros-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .nosotros-grid { grid-template-columns: 1fr; } }

.mvf,
.mvf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
}
.mvf__block {
  position: relative;
  grid-column: span 1;
  padding: var(--sp-6);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  background: var(--c-white);
  overflow: hidden;
  transition: border-color var(--t-base), transform var(--t-base), box-shadow var(--t-base);
}
.mvf__block::before {
  content: "— " var(--mvf-num);
  display: block;
  margin-bottom: var(--sp-4);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-ice-blue-dark);
}
.mvf__block:hover {
  transform: translateY(-4px);
  border-color: var(--c-graphite);
  box-shadow: var(--sh-md);
}
.mvf__block h3 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-bottom: var(--sp-3);
  color: var(--c-text);
}
.mvf__block p,
.mvf__block li {
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  line-height: 1.6;
  text-align: left;
}
.mvf__block ul {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  width: 100%;
  margin-top: var(--sp-2);
}
.mvf__block li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-text);
  line-height: 1.25;
}
.mvf__block li svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  color: var(--c-ice-blue-dark);
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body[data-nav="nosotros"] [data-reveal][data-reveal-dir="fade-up"] {
  opacity: 0;
  transform: translateY(72px);
  transition: opacity 1050ms cubic-bezier(0.16, 0.9, 0.2, 1),
              transform 1050ms cubic-bezier(0.16, 0.9, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
body[data-nav="nosotros"] [data-reveal][data-reveal-dir="fade-up"].is-visible {
  opacity: 1;
  transform: translateY(0);
}
body[data-nav="nosotros"] .mvf__block[data-reveal][data-reveal-dir="fade-up"].is-visible:hover {
  transform: translateY(-3px);
}

/* ── Reveal en la seccion oscura "Empresa / Que hace Horeka" ───────────── */
body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir] {
  opacity: 0;
  transition: opacity 950ms cubic-bezier(0.16, 0.9, 0.2, 1),
              transform 950ms cubic-bezier(0.16, 0.9, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="from-left"]  { transform: translateX(-80px); }
body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="from-right"] { transform: translateX(80px); }
body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="fade-up"]    { transform: translateY(36px); }
body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir].is-visible {
  opacity: 1;
  transform: translate(0, 0);
}
/* Movil: reducir el desplazamiento en la seccion oscura de nosotros */
@media (max-width: 720px) {
  body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="from-left"]  { transform: translateX(-30px); }
  body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="from-right"] { transform: translateX(30px); }
  body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir="fade-up"]    { transform: translateY(24px); }
}

/* Barra azul izquierda con animacion de "crecimiento" al revelarse */
body[data-nav="nosotros"] .empresa-section .value-card {
  border-left: 2px solid transparent;
  background-image: linear-gradient(var(--c-ice-blue), var(--c-ice-blue));
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 2px 0%;
  transition: background-size 700ms cubic-bezier(0.16, 0.9, 0.2, 1) 240ms,
              transform var(--t-base);
}
body[data-nav="nosotros"] .empresa-section .value-card.is-visible {
  background-size: 2px 100%;
}
body[data-nav="nosotros"] .empresa-section .value-card:hover {
  transform: translateY(-3px);
}

/* Numero "01/02/03" con micro entrada */
body[data-nav="nosotros"] .empresa-section .value-card__icon {
  display: inline-block;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 600ms cubic-bezier(0.16, 0.9, 0.2, 1) 480ms,
              transform 600ms cubic-bezier(0.16, 0.9, 0.2, 1) 480ms;
}
body[data-nav="nosotros"] .empresa-section .value-card.is-visible .value-card__icon {
  opacity: 1;
  transform: translateY(0);
}
.markets-section {
  overflow: hidden;
}
body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir] {
  opacity: 0;
  transition: opacity 900ms cubic-bezier(0.2, 0.7, 0.2, 1),
              transform 900ms cubic-bezier(0.2, 0.7, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir="from-left"] {
  transform: translateX(-120px);
}
body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir="from-right"] {
  transform: translateX(120px);
}
body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir="fade-up"] {
  transform: translateY(24px);
}
body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir].is-visible {
  opacity: 1;
  transform: translate(0, 0);
}
body[data-nav="nosotros"] .markets-section .sol-card[data-reveal][data-reveal-dir].is-visible:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  body[data-nav="nosotros"] [data-reveal][data-reveal-dir="fade-up"],
  body[data-nav="nosotros"] .markets-section [data-reveal][data-reveal-dir],
  body[data-nav="nosotros"] .empresa-section [data-reveal][data-reveal-dir],
  body[data-nav="nosotros"] .empresa-section .value-card,
  body[data-nav="nosotros"] .empresa-section .value-card__icon {
    opacity: 1;
    transform: none;
    transition: none;
    background-size: 2px 100%;
  }
}

.giros-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
}
.giros-grid .sol-card {
  min-height: 360px;
}
.giros-grid .sol-card__body {
  height: auto;
  min-height: 170px;
  padding: var(--sp-5);
}
@media (max-width: 1100px) { .giros-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .giros-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .giros-grid { grid-template-columns: 1fr; } }

body[data-nav="nosotros"] .cta-final__btns {
  margin-top: var(--sp-5);
  gap: var(--sp-5);
}

@media (max-width: 1100px) {
  .mvf,
  .mvf-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .mvf,
  .mvf-grid {
    grid-template-columns: 1fr;
  }
  .mvf__block {
    padding: var(--sp-5);
  }
}

/* ── Soporte ───────────────────────────────────────────────────────────── */
.process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
  counter-reset: step;
}
.process__step {
  position: relative;
  padding: var(--sp-5);
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  counter-increment: step;
}
.process__step::before {
  content: counter(step, decimal-leading-zero);
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--c-ice-blue);
  display: block;
  margin-bottom: var(--sp-3);
}
.process__step h4 { font-size: var(--fs-md); }
.process__step p { font-size: var(--fs-sm); margin-top: 6px; line-height: 1.55; }
@media (max-width: 880px) { .process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .process { grid-template-columns: 1fr; } }

/* ── Contacto ──────────────────────────────────────────────────────────── */
.contacto-card {
  text-decoration: none;
  cursor: pointer;
}
.contacto-card:hover {
  border-color: var(--c-graphite);
}
.contacto-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-ice-blue-dark);
}
.contacto-card__cta::after {
  content: "→";
  transition: transform var(--t-fast);
}
.contacto-card:hover .contacto-card__cta::after {
  transform: translateX(4px);
}

.contacto-form-desc {
  margin-top: var(--sp-4);
  font-size: var(--fs-md);
  color: var(--c-text-soft);
  max-width: 60ch;
}

.contacto-form {
  max-width: 880px;
  margin: 0 auto;
  padding: var(--sp-7);
  background: var(--c-warm-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.contacto-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
.contacto-form__actions {
  display: flex;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}
.contacto-form__actions .btn {
  flex: 1 1 auto;
  min-width: 220px;
}
@media (max-width: 720px) {
  .contacto-form { padding: var(--sp-5); }
  .contacto-form__row { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════════════
   SOLUCION (solucion.html) — Hero, Stats, Insight, Casos
   ════════════════════════════════════════════════════════════════════════ */

/* ── Hero tematico ─────────────────────────────────────────────────────── */
.sol-hero-section {
  padding: var(--sp-9) 0 var(--sp-8);
  background: linear-gradient(135deg, var(--c-warm-white) 0%, var(--c-ice) 100%);
}
.sol-hero {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--sp-9);
  align-items: center;
}
.sol-hero__copy h1 {
  margin-top: var(--sp-3);
  font-size: clamp(2.4rem, 5vw, 3.75rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
}
.sol-hero__copy .lead {
  margin-top: var(--sp-5);
  max-width: 56ch;
}
.sol-hero__visual {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-lg);
}
.sol-hero__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Stats del hero */
.sol-hero__stats {
  margin-top: var(--sp-7);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--c-border);
}
.sol-hero__stat-num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.4vw, var(--fs-2xl));
  color: var(--c-ice-blue-dark);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.sol-hero__stat-lbl {
  margin-top: var(--sp-2);
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
  line-height: 1.45;
}

@media (max-width: 1024px) {
  .sol-hero { grid-template-columns: 1fr; gap: var(--sp-6); }
  .sol-hero__visual { max-width: 640px; }
}
@media (max-width: 600px) {
  .sol-hero__stats { grid-template-columns: 1fr; gap: var(--sp-5); }
}

/* ── Bloque Insight ────────────────────────────────────────────────────── */
.sol-insight {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}
.sol-insight h2 {
  margin-top: var(--sp-3);
  font-size: clamp(1.6rem, 3vw, var(--fs-2xl));
}
.sol-insight__desc {
  margin-top: var(--sp-5);
  font-size: var(--fs-md);
  color: var(--c-text-soft);
  line-height: 1.6;
}
.sol-insight__fuente {
  margin-top: var(--sp-6);
  font-size: var(--fs-xs);
  color: var(--c-text-soft);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.sol-insight__fuente a {
  color: var(--c-ice-blue-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
  margin-left: 6px;
}
.sol-insight__fuente a:hover { color: var(--c-text); }

/* ── Casos de uso ──────────────────────────────────────────────────────── */
.sol-casos {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: repeat(3, 1fr);
  margin-top: var(--sp-6);
}
.sol-casos[data-cols="2"] {
  grid-template-columns: repeat(2, 1fr);
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}
.sol-caso {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
}
.sol-caso:hover {
  transform: translateY(-3px);
  border-color: var(--c-graphite);
  box-shadow: var(--sh-md);
}
.sol-caso__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--c-ice);
}
.sol-caso__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-base);
}
.sol-caso:hover .sol-caso__media img {
  transform: scale(1.04);
}
.sol-caso__body {
  padding: var(--sp-5);
}
.sol-caso__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--c-text);
}
.sol-caso__desc {
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--c-text-soft);
  line-height: 1.55;
}

@media (max-width: 1024px) {
  .sol-casos { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .sol-casos,
  .sol-casos[data-cols="2"] { grid-template-columns: 1fr; }
}
