@import url('hwm-patterns.css');

/* Catálogo corporativo · páginas productos/index y productos/*/productos/
   Paleta: #38b6ff · #ffde59 · #000000 · #ffffff
   (Banner y botones heredan estilos globales de styles.css) */

.catalog-ui {
  background: #ffffff;
}

/* ---------- HormiMax fijo al lado del catálogo de productos ---------- */
.catalog-ui .catalog-hormimax {
  position: fixed;
  top: 50%;
  left: clamp(0.25rem, 1vw, 0.75rem);
  z-index: 45;
  width: clamp(220px, 24vw, 380px);
  pointer-events: none;
  user-select: none;
  transform: translateY(-50%);
}

.catalog-ui .catalog-hormimax img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 16px 28px rgba(0, 0, 0, 0.16));
}

.catalog-ui:has(.catalog-hormimax) .section.white {
  padding-left: clamp(1.25rem, 26vw, 22rem);
}

@media (max-width: 1100px) {
  .catalog-ui .catalog-hormimax {
    width: clamp(200px, 22vw, 300px);
  }

  .catalog-ui:has(.catalog-hormimax) .section.white {
    padding-left: clamp(1.25rem, 22vw, 16rem);
  }
}

@media (max-width: 860px) {
  .catalog-ui .catalog-hormimax {
    top: auto;
    bottom: 5.5rem;
    left: 0.25rem;
    width: 160px;
    transform: none;
    opacity: 0.92;
  }

  .catalog-ui:has(.catalog-hormimax) .section.white {
    padding-left: 1.25rem;
  }
}

@media (max-width: 520px) {
  .catalog-ui .catalog-hormimax {
    width: 130px;
    bottom: 4.75rem;
  }
}

/* ---------- Sección catálogo ---------- */
.catalog-ui .section.white {
  padding: 2.75rem 7vw 4rem;
}

.catalog-ui .section.white > .lead {
  max-width: 720px;
  margin: 0 auto 2rem;
  text-align: center;
  font-size: 1rem;
  line-height: 1.65;
  color: #38485a;
}

.catalog-ui .catalogProducts {
  max-width: 1180px;
  margin: 0 auto;
}

/* ---------- Grid categorías ---------- */
.catalog-ui .categoryGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(268px, 1fr));
  gap: 1.25rem;
  max-width: 1280px;
  margin: 0 auto;
}

.catalog-ui .catCard {
  border: 1px solid #d7edf9;
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(15, 50, 80, .06);
  min-height: auto;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.catalog-ui .catCard::before {
  height: 3px;
  background: #38b6ff;
}

.catalog-ui .catCard:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(56, 182, 255, .14);
  border-color: rgba(56, 182, 255, .45);
}

.catalog-ui .catImg {
  height: 176px;
  padding: 0;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid rgba(56, 182, 255, 0.1);
  overflow: hidden;
}

.catalog-ui .catImg img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: cover;
  object-position: center;
  filter: none;
}

.catalog-ui .catBody {
  padding: 1.15rem 1.25rem 1.35rem;
  text-align: left;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.catalog-ui .catBody h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: #000000;
  text-transform: uppercase;
  letter-spacing: -.01em;
}

.catalog-ui .catBody p {
  margin: 0;
  flex: 1;
  font-size: .88rem;
  line-height: 1.55;
  color: #38485a;
}

.catalog-ui .btnSmall {
  margin-top: .5rem;
  align-self: flex-start;
}

/* ---------- Fichas de producto (layout ficha técnica) ---------- */
.catalog-ui .productApartado {
  max-width: 1180px;
  margin: 0 auto 2.5rem;
}

.catalog-ui .productApartado:last-child {
  margin-bottom: 0;
}

.catalog-ui .productBlock--sheet {
  display: block;
  padding: 1.1rem 1.25rem;
  border: 1px solid rgba(56, 182, 255, 0.14);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(15, 50, 80, 0.06);
  background: #ffffff;
}

.catalog-ui .productBlock--sheet:hover {
  box-shadow: 0 4px 18px rgba(56, 182, 255, .1);
}

.catalog-ui .productSheetTitle {
  margin: 0 0 1.5rem;
  font-size: clamp(1.5rem, 3vw, 2.35rem);
  font-weight: 900;
  color: #38b6ff;
  text-transform: none;
  letter-spacing: -.03em;
  line-height: 1.05;
}

.catalog-ui .productSheetGrid {
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  gap: 2rem;
  align-items: start;
}

.catalog-ui .productSheetVisual {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 240px;
  padding: .5rem;
  background: #ffffff;
  border-radius: 10px;
  border: 1px solid rgba(56, 182, 255, 0.1);
}

.catalog-ui .productSheetVisual .imgAnimWrap {
}
  min-height: 220px;
  width: 100%;
}

.catalog-ui .productSheetVisual .imgAnim {
  max-width: 100%;
  max-height: 300px;
}

.catalog-ui .productSheetInfo {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.catalog-ui .productDescTitle,
.catalog-ui .medidasTableTitle {
  margin: 0 0 .75rem;
  font-size: 1.05rem;
  font-weight: 900;
  color: #000000;
  letter-spacing: -.02em;
}

.catalog-ui .productDesc p {
  margin: 0;
  font-size: .95rem;
  line-height: 1.65;
  color: #38485a;
}

/* Tabla de medidas · estilo corporativo */
.catalog-ui .medidasTableGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
}

.catalog-ui .medidasCol {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  min-width: 0;
}

.catalog-ui .medidasHead {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: .65rem .75rem;
  background: #38b6ff;
  color: #ffffff;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-align: center;
  border-radius: 10px;
}

.catalog-ui .medidasCell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.25rem;
  padding: .75rem .85rem;
  background: #ffffff;
  color: #000000;
  font-size: .82rem;
  font-weight: 800;
  line-height: 1.35;
  text-align: center;
  text-transform: uppercase;
  border: 2px solid #ffde59;
  border-radius: 10px;
}

.catalog-ui .medidasTableFrame {
  padding: 0;
  background: #ffffff;
  border-radius: 10px;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.catalog-ui .medidasTableFrame .imgAnimWrap {
  min-height: auto;
  width: auto;
  padding: 0;
}

.catalog-ui .medidasTableFrame .specTable {
  width: auto;
  max-width: min(100%, 600px);
  max-height: 380px;
  height: auto;
  object-fit: contain;
  filter: none;
}

.catalog-ui .imgAnimWrap--spec {
  cursor: zoom-in;
}

/* Layout legacy (si queda en alguna página) */
.catalog-ui .productBlock {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  align-items: center;
  gap: 0;
  margin-bottom: 0;
  border: 1px solid #d7edf9;
  border-radius: 10px;
  box-shadow: 0 2px 12px rgba(15, 50, 80, .06);
  overflow: hidden;
}

.catalog-ui .productBlock::before {
  display: none;
}

.catalog-ui .productBlock:hover {
  transform: none;
  box-shadow: 0 4px 18px rgba(56, 182, 255, .1);
}

.catalog-ui .productContent {
  padding: 2rem 2.25rem;
  background: #ffffff;
}

.catalog-ui .productContent h3 {
  margin: 0 0 .75rem;
  font-size: clamp(1.15rem, 2vw, 1.55rem);
  font-weight: 800;
  color: #000000;
  text-transform: none;
  letter-spacing: -.02em;
  line-height: 1.25;
}

.catalog-ui .productContent p {
  margin: 0;
  font-size: .95rem;
  line-height: 1.65;
  color: #38485a;
}

.catalog-ui .productBlock--spec {
  border-color: #e8f4fc;
}

.catalog-ui .productBlock--spec .productContent {
  background: #f8fcff;
}

.catalog-ui .productBlock--spec .productContent h3 {
  color: #38b6ff;
  font-size: clamp(1rem, 1.8vw, 1.25rem);
}

.catalog-ui .productVisual {
  min-height: 260px;
  padding: 1.5rem 1.75rem;
  background: #ffffff;
  border-left: 1px solid #edf4f8;
  display: flex;
  align-items: center;
  justify-content: center;
}

.catalog-ui .productBlock--spec .productVisual {
  background: #f8fcff;
}

.catalog-ui .imgAnimWrap {
  min-height: 220px;
  width: 100%;
}

.catalog-ui .imgAnim {
  width: auto;
  height: auto;
  max-width: min(100%, 480px);
  max-height: 460px;
  object-fit: contain;
  filter: drop-shadow(0 6px 14px rgba(0, 0, 0, .08));
}

.catalog-ui .imgAnimWrap:hover .imgAnim:not(.is-reset) {
  transform: scale(1.08);
}

.catalog-ui .specTable {
  max-width: min(100%, 600px);
  max-height: 380px;
}

/* ---------- Sección relacionados ---------- */
.catalog-ui .section.gray {
  padding: 2.5rem 7vw;
  background: #f3f8fc;
  border-top: 1px solid #d7edf9;
}

.catalog-ui .section.gray h2 {
  font-size: clamp(1.35rem, 2.5vw, 1.85rem);
  margin-bottom: .5rem;
}

.catalog-ui .related a {
  background: #ffffff;
  border: 1px solid #38b6ff;
  color: #000000;
  border-radius: 6px;
  box-shadow: none;
  font-size: .78rem;
  font-weight: 700;
  padding: .6rem 1rem;
}

.catalog-ui .related a:hover {
  background: #38b6ff;
  color: #000000;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .catalog-ui .productBlock {
    grid-template-columns: 1fr;
  }

  .catalog-ui .productSheetGrid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .catalog-ui .productSheetVisual {
    min-height: auto;
  }

  .catalog-ui .medidasTableGrid {
    grid-template-columns: 1fr;
  }

  .catalog-ui .productVisual {
    border-left: 0;
    border-top: 1px solid #edf4f8;
    min-height: 220px;
  }

  .catalog-ui .productContent {
    padding: 1.5rem 1.25rem;
  }
}

@media (max-width: 680px) {
  .catalog-ui .categoryGrid {
    grid-template-columns: 1fr;
  }

  .catalog-ui .wixBanner {
    padding: 2.5rem 1.25rem;
  }

  .catalog-ui .section.white {
    padding: 2rem 1.25rem 3rem;
  }
}
