/* =========================================================
   PRODUCTOS RELACIONADOS SEINTO
   Estilo acorde a ficha de producto
   Responsive + optimizado CLS
   ========================================================= */

:root {
  --dc-primary: #ec2324;
  --dc-primary-hover: #c91517;
  --dc-whatsapp: #20bf5a;
  --dc-whatsapp-hover: #159947;
  --dc-text: #111827;
  --dc-muted: #6b7280;
  --dc-soft: #f6f7f9;
  --dc-surface: #ffffff;
  --dc-border: #e5e7eb;
  --dc-border-strong: #d1d5db;
  --dc-success-soft: #eafff1;
  --dc-success-border: #b7f7cf;
  --dc-success-text: #0f7a37;
  --dc-radius-sm: 10px;
  --dc-radius-md: 14px;
  --dc-radius-lg: 20px;
  --dc-shadow-sm: 0 4px 14px rgba(15, 23, 42, .06);
  --dc-shadow-md: 0 12px 35px rgba(15, 23, 42, .10);
  --dc-transition: .16s ease;
}

/* =========================
   CONTENEDOR GENERAL
   ========================= */

#vo-relacionados {
  display: block;
  scroll-margin-top: 120px;
}

.prseinto-related-groups {
  margin-top: 34px;
  width: 100%;
}

#prseinto-groups {
  display: grid;
  gap: 14px;
}

.prseinto-group {
  border: 1px solid var(--dc-border);
  border-radius: var(--dc-radius-lg);
  background: var(--dc-surface);
  overflow: hidden;
  box-shadow: var(--dc-shadow-sm);
  content-visibility: auto;
  contain-intrinsic-size: 1px 900px;
}

/* =========================
   CABECERA ACORDEÓN
   ========================= */

.prseinto-group > h4,
.prseinto-acc-trigger {
  margin: 0 !important;
  min-height: 64px;
  padding: 16px 20px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: linear-gradient(180deg, #ffffff, #fafafa) !important;
  color: var(--dc-text);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  cursor: pointer;
  user-select: none;
  position: relative;
  font-size: clamp(17px, 1.8vw, 21px);
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: -.02em;
}

.prseinto-group > h4 span:first-child,
.prseinto-acc-trigger span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.prseinto-group > h4:hover,
.prseinto-acc-trigger:hover {
  background: #fff !important;
}

.prseinto-group .prse-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(236, 35, 36, .08);
  border: 1px solid rgba(236, 35, 36, .18);
  color: var(--dc-primary);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
}

/* Flecha acordeón */
.prseinto-group > h4::after,
.prseinto-acc-trigger::after {
  content: "";
  flex: 0 0 auto;
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--dc-text);
  border-bottom: 2px solid var(--dc-text);
  transform: rotate(45deg);
  transition: transform var(--dc-transition), opacity var(--dc-transition);
  opacity: .65;
  margin-left: 4px;
}

.prseinto-group.is-open > h4::after,
.prseinto-group.is-open .prseinto-acc-trigger::after {
  transform: rotate(-135deg);
  opacity: 1;
}

/* =========================
   CUERPO ACORDEÓN
   ========================= */

.prseinto-collapse {
  overflow: hidden;
  max-height: 0;
  transition: max-height .24s ease;
  border-top: 1px solid transparent;
}

.prseinto-group.is-open .prseinto-collapse {
  max-height: 9999px;
  border-top-color: var(--dc-border);
}

/* =========================
   GRID
   ========================= */

.prseinto-related-groups .prse-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 0 !important;
  padding: 18px !important;
}

/* Anula Bootstrap dentro del grid */
.prseinto-related-groups .prse-grid > [class^="col-"],
.prseinto-related-groups .prse-grid > [class*=" col-"] {
  padding: 0 !important;
  margin: 0 !important;
  width: auto !important;
  max-width: none !important;
  flex: initial !important;
}

/* =========================
   CARD PRODUCTO
   ========================= */

.prseinto-related-groups .product-miniature,
.prseinto-related-groups .xt-card {
  height: 100%;
  margin: 0 !important;
}

.prseinto-related-groups .xt-card__inner {
  height: 100%;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--dc-surface);
  border: 1px solid var(--dc-border);
  border-radius: 18px;
  overflow: hidden;
  margin: 0;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .07);
  transition: border-color var(--dc-transition), box-shadow var(--dc-transition);
}

.prseinto-related-groups .xt-card__inner:hover {
  border-color: rgba(236, 35, 36, .32);
  box-shadow: 0 14px 34px rgba(15, 23, 42, .11);
}

/* =========================
   IMAGEN
   ========================= */

.prseinto-related-groups .xt-card__media {
  position: relative;
  background: var(--dc-soft);
  border-bottom: 1px solid var(--dc-border);
}

.prseinto-related-groups .xt-card__thumb {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: var(--dc-soft);
  overflow: hidden;
}

.prseinto-related-groups .xt-card__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  padding: 12px;
  background: var(--dc-soft) !important;
}

/* =========================
   BODY
   ========================= */

.prseinto-related-groups .xt-card__body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  padding: 15px;
}

.prseinto-related-groups .xt-card__title {
  min-height: 42px;
  margin: 0 0 8px;
  color: var(--dc-text);
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.22;
  letter-spacing: -.02em;
}

.prseinto-related-groups .xt-card__title-link {
  color: var(--dc-text);
  text-decoration: none;
}

.prseinto-related-groups .xt-card__title-link:hover {
  color: var(--dc-primary);
}

.prseinto-related-groups .xt-card__subtitle {
  min-height: 54px;
  margin: 0 0 10px;
  color: var(--dc-muted);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.4;
}

.prseinto-related-groups .xt-card__subtitle .muted {
  display: block;
  margin-top: 4px;
  color: #9ca3af;
  font-weight: 500;
}

/* =========================
   BADGE GARANTÍA
   ========================= */

.prseinto-related-groups .xt-card__badge {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--dc-success-soft);
  border: 1px solid var(--dc-success-border);
  color: var(--dc-success-text);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  margin: 0 0 10px;
}

.prseinto-related-groups .xt-card__badge svg {
  width: 15px;
  height: 15px;
  flex: 0 0 auto;
}

/* =========================
   PILLS REF / OEM
   ========================= */

.prseinto-related-groups .xt-card__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 0 0 12px;
}

.prseinto-related-groups .xt-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  max-width: 100%;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--dc-soft);
  border: 1px solid var(--dc-border);
  color: var(--dc-text);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.prseinto-related-groups .xt-pill b {
  font-weight: 900;
  margin-right: 3px;
}

/* =========================
   PRECIO
   ========================= */

.prseinto-related-groups .xt-card__price {
  margin-top: auto;
  color: #000;
  font-size: 23px;
  font-weight: 950;
  line-height: 1.1;
  letter-spacing: -.03em;
}

.prseinto-related-groups .xt-card__iva {
  margin: 3px 0 12px;
  color: var(--dc-muted);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.35;
}

/* =========================
   ACCIONES
   ========================= */

.prseinto-related-groups .xt-card__actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px;
  gap: 10px;
  align-items: stretch;
}

.prseinto-related-groups .xt-btn-wa,
.prseinto-related-groups .xt-btn-cart,
.prseinto-related-groups .btn-consultar {
  min-height: 48px;
  border: 0 !important;
  border-radius: 12px;
  color: #fff !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: 900;
  line-height: 1.1;
  transition: background-color var(--dc-transition), box-shadow var(--dc-transition), opacity var(--dc-transition);
}

.prseinto-related-groups .xt-btn-wa {
  gap: 8px;
  padding: 11px 14px;
  background: var(--dc-whatsapp);
  font-size: 14px;
  box-shadow: 0 10px 20px rgba(32, 191, 90, .18);
}

.prseinto-related-groups .xt-btn-wa:hover {
  background: var(--dc-whatsapp-hover);
  color: #fff !important;
  box-shadow: 0 14px 26px rgba(32, 191, 90, .24);
}

.prseinto-related-groups .xt-btn-cart {
  width: 52px;
  padding: 0;
  background: var(--dc-primary);
  box-shadow: 0 10px 20px rgba(236, 35, 36, .18);
}

.prseinto-related-groups .xt-btn-cart:hover {
  background: var(--dc-primary-hover);
  color: #fff !important;
  box-shadow: 0 14px 26px rgba(236, 35, 36, .24);
}

.prseinto-related-groups .xt-btn-cart i,
.prseinto-related-groups .xt-btn-wa i {
  font-size: 20px;
  line-height: 1;
}

.prseinto-related-groups .btn-consultar {
  width: 100%;
  margin-top: auto;
  padding: 12px 16px;
  background: var(--dc-primary) !important;
  font-size: 15px;
  box-shadow: 0 10px 20px rgba(236, 35, 36, .18);
}

.prseinto-related-groups .btn-consultar:hover {
  background: var(--dc-primary-hover) !important;
  color: #fff !important;
  box-shadow: 0 14px 26px rgba(236, 35, 36, .24);
}

/* =========================
   LIMPIEZA BOOTSTRAP / THEME
   ========================= */

.prseinto-related-groups .thumbnail-container,
.prseinto-related-groups .product-description,
.prseinto-related-groups .product-meta {
  width: auto !important;
  height: auto !important;
  min-height: 0;
}

.prseinto-related-groups .product-title a,
.prseinto-related-groups a {
  outline-offset: 3px;
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 1400px) {
  .prseinto-related-groups .prse-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1199px) {
  .prseinto-related-groups .prse-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .prseinto-related-groups {
    margin-top: 26px;
  }

  .prseinto-related-groups .prse-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 16px !important;
  }

  .prseinto-group > h4,
  .prseinto-acc-trigger {
    min-height: 58px;
    padding: 14px 16px !important;
  }
}

@media (max-width: 575px) {
  .prseinto-related-groups {
    margin-top: 22px;
  }

  .prseinto-related-groups .prse-grid {
    grid-template-columns: 1fr;
    padding: 14px !important;
  }

  .prseinto-group {
    border-radius: 16px;
  }

  .prseinto-group > h4,
  .prseinto-acc-trigger {
    min-height: 56px;
    font-size: 16px;
    padding: 13px 14px !important;
  }

  .prseinto-group .prse-badge {
    min-width: 30px;
    min-height: 26px;
    font-size: 12px;
  }

  .prseinto-related-groups .xt-card__body {
    padding: 14px;
  }

  .prseinto-related-groups .xt-card__title {
    min-height: auto;
    font-size: 16px;
  }

  .prseinto-related-groups .xt-card__subtitle {
    min-height: auto;
  }

  .prseinto-related-groups .xt-card__actions {
    grid-template-columns: 1fr 50px;
  }

  .prseinto-related-groups .xt-btn-wa,
  .prseinto-related-groups .xt-btn-cart,
  .prseinto-related-groups .btn-consultar {
    min-height: 46px;
  }

  .prseinto-related-groups .xt-btn-wa {
    font-size: 13px;
  }

  .prseinto-related-groups .xt-btn-cart {
    width: 50px;
  }
}