/* =========================================================
   PRODUCT PAGE – product-style.css
   Necxus · Sintonía con main.css + nx-header/footer
   FHD/2K/4K first: diseñado para hasta 1800px+
   (VERSIÓN AISLADA: Cero conflictos globales)
   ========================================================= */

/* =========================================================
   LAYOUT BASE
   ========================================================= */

.nx-product-page {
  width: 100%;
  max-width: 1800px;
  margin: 0 auto;
  padding: 20px 60px 60px 60px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

@media (max-width: 1400px) {
  .nx-product-page {
    padding: 0 32px 48px;
  }
}

@media (max-width: 1024px) {
  .nx-product-page {
    padding: 0 20px 40px;
  }
}

@media (max-width: 767px) {
  .nx-product-page {
    padding: 0 16px 32px;
  }
}

/* =========================================================
   LAYOUT PRINCIPAL 2 COLUMNAS
   ========================================================= */

.nx-product-main-layout {
  display: block;
}

/* El lower-col es siempre full width debajo del grid */
.nx-product-lower-col {
  width: 100%;
}

.nx-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 16px 0;
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
}

/* Aislado para no afectar enlaces globales */
.nx-product-page .nx-breadcrumb a {
  color: var(--nx-color-text-darks2);
  text-decoration: none;
}

.nx-product-page .nx-breadcrumb a:hover {
  color: var(--nx-color-accent);
  text-decoration: underline;
}

.nx-breadcrumb__sep {
  color: var(--nx-color-muted);
  font-size: var(--nx-font-xs);
}

.nx-breadcrumb__current {
  color: var(--nx-color-text-darks);
  font-weight: 600;
}

/* =========================================================
   GRILLA PRINCIPAL
   mobile   → 1 col
   tablet   → galería | compra (50/50)
   desktop  → galería grande | panel compra fijo
   FHD+     → galería ocupa el espacio sobrante, panel = 460px
   ========================================================= */

.nx-product-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: start;
}

@media (min-width: 768px) {
  .nx-product-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
}

@media (min-width: 1024px) {
  .nx-product-grid {
    grid-template-columns: 1fr 420px;
    gap: 40px;
  }
}

@media (min-width: 1400px) {
  .nx-product-grid {
    grid-template-columns: 1fr 460px;
    gap: 56px;
  }
}

@media (min-width: 1600px) {
  .nx-product-grid {
    grid-template-columns: 1fr 650px;
    gap: 64px;
  }
}

/* =========================================================
   GALERÍA
   ========================================================= */

.nx-product-gallery {
  position: sticky;
  top: 90px;
}

@media (max-width: 767px) {
  .nx-product-gallery {
    position: static;
  }
}

/* ---- Inner: thumbs izquierda + visor derecha ---- */

.nx-product-gallery__inner {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

/* ---- Thumbnails verticales (columna izquierda) ---- */

.nx-product-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .nx-product-gallery__inner {
    flex-direction: column-reverse;
  }

  .nx-product-gallery__thumbs {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

.nx-product-gallery__thumb {
  width: 72px;
  height: 72px;
  border-radius: var(--nx-radius-sm);
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  border: 2px solid transparent;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  flex-shrink: 0;
  padding: 0;
  position: relative;
}

.nx-product-gallery__thumb:hover,
.nx-product-gallery__thumb.is-active {
  border-color: var(--nx-color-accent);
  box-shadow: 0 0 0 1px var(--nx-color-accent);
}

/* Aislado */
.nx-product-page .nx-product-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 5px;
  box-sizing: border-box;
  display: block;
}

/* Aislado */
.nx-product-page .nx-product-gallery__thumb--video img {
  object-fit: cover;
  padding: 0;
}

.nx-thumb-play-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.38);
  pointer-events: none;
  border-radius: calc(var(--nx-radius-sm) - 2px);
}

/* Aislado */
.nx-product-page .nx-thumb-play-icon svg {
  width: 28px;
  height: 28px;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.6));
}

@media (min-width: 1400px) {
  .nx-product-gallery__thumb {
    width: 80px;
    height: 80px;
  }
}

/* ---- Visor principal (imagen o video) ---- */

.nx-product-gallery__main {
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  border-radius: var(--nx-radius-md);
  overflow: hidden;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex: 1;
  min-width: 0;
}

/* Aislado */
.nx-product-page .nx-product-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  box-sizing: border-box;
  transition: transform 0.35s ease;
  display: block;
}



/* Aislado */
.nx-product-page .nx-product-gallery__main iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: var(--nx-radius-md);
}

.nx-gallery-img   { display: block; }
.nx-gallery-video { display: none;  }

.nx-product-gallery__main.is-video .nx-gallery-img   { display: none;  }
.nx-product-gallery__main.is-video .nx-gallery-video { display: block; }

/* =========================================================
   COLUMNA DE COMPRA
   ========================================================= */

.nx-product-buy {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* ---- Encabezado ---- */

.nx-product-header__brand {
  font-size: var(--nx-font-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--nx-color-accent);
  margin: 0 0 6px;
}

.nx-product-header__title {
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--nx-color-text-darks);
  margin: 0 0 10px;
    text-transform: capitalize;

}

@media (min-width: 1024px) {
  .nx-product-header__title {
    font-size: 1.45rem;
  }
}

@media (min-width: 1400px) {
  .nx-product-header__title {
    font-size: 1.55rem;
  }
}

.nx-product-header__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
}

.nx-rating {
  display: flex;
  align-items: center;
  gap: 5px;
}

.nx-rating__stars {
  color: #f59e0b;
  font-size: 14px;
  letter-spacing: -1px;
  font-size: var(  --nx-font-m);
}

.nx-rating__value {
  font-weight: 700;
  color: var(--nx-color-text-darks);
}

.nx-rating__count {
  color: var(--nx-color-text-darks2);
}

.nx-product-header__sku {
  color: var(--nx-color-text-darks2);
}

/* ---- Precio ---- */

.nx-price-box {
  background: var(--nx-color-bg-s);
  border-radius: var(--nx-radius-md);
  padding: 20px;
  border: 1px solid var(--nx-border-light);
}

.nx-price-box__badge {
  display: inline-block;
  background: var(--nx-color-accent);
  color: var(--nx-color-bg-w);
  font-size: var(--nx-font-xs);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0.5px;
  padding: 4px 8px;
  border-radius: var(--nx-radius-sm);
  margin-bottom: 10px;
}

.nx-price-box__label {
  font-size: var(--nx-font-xs);
  font-weight: 600;
  text-transform: uppercase;
  color: var(--nx-color-text-darks2);
  margin: 0 0 4px;
}

.nx-price-box__main {
  font-size: 2.3rem;
  font-weight: 700;
  color: var(--nx-text-dark);
  letter-spacing: -0.5px;
  line-height: 1.1;
  margin: 0;
}

.nx-price-box__original {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 6px 0 0;
}

.nx-price-box__list {
    font-size: var( --nx-font-sm);
  text-decoration: line-through;
  color: var(--nx-color-text-textcomment);
  min-height: var(--nx-font-sm);
}

.nx-price-box__off {
  font-size: var(--nx-font-g);
  font-weight: 800;
  color: var(--nx-color-background-v);
  background-color: var(--nx-color-background-vs);
  padding: 3px 6px;
  border-radius: var(--nx-radius-sm);
  margin-left: 8px;
}
.nx-price-box-ps__off{
  font-size: var(--nx-font-m);
  font-weight: 800;
  color: var(--nx-color-background-v);
  background-color: var(--nx-color-background-vs);
  padding: 3px 6px;
  border-radius: var(--nx-radius-sm);
  margin-left: 8px;
}

.nx-price-box__usd {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
  margin: 6px 0 0;
}

/* ---- Cuotas ---- */

.nx-cuotas-box {
  background: var(--nx-color-bg-s);
  border-radius: var(--nx-radius-md);
  padding: 16px 20px;
  border: 1px solid var(--nx-border-light);
}

.nx-cuotas-box__title {
  font-size: var(--nx-font-m2);
  font-weight: 700;
  color: var(--nx-color-text-darks);
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Aislado */
.nx-product-page .nx-cuotas-box__title svg {
  flex-shrink: 0;
}

.nx-cuotas-list {
  list-style: none;
  padding: 0;
  margin: 0 0 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Aislado */
.nx-product-page .nx-cuotas-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: #fff;
  border-radius: var(--nx-radius-sm);
  border: 1px solid var(--nx-border-light);
  font-size: var(--nx-font-m2);
}

.nx-cuotas-list__plan {
  font-weight: 700;
  color: var(--nx-color-text-darks);
}

.nx-cuotas-list__total {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
}

.nx-cuotas-note {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
  margin: 0;
  font-style: italic;
}

/* ---- CTAs ---- */

.nx-product-ctas {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.nx-btn-buy {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 24px;
  background: var(--nx-color-button-b);
  color: #fff;
  border: none;
  border-radius: var(--nx-radius-md);
  font-size: var(--nx-font-m);
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.1s ease;
  width: 100%;
  box-sizing: border-box;
}

.nx-btn-buy:hover {
  background: var(--nx-color-button-bd);
}

.nx-btn-buy:active {
  transform: scale(0.98);
}

.nx-btn-secondary-action {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 24px;
  background: #fff;
  color: var(--nx-color-text-darks);
  border: 1.5px solid var(--nx-border-light);
  border-radius: var(--nx-radius-md);
  font-size: var(--nx-font-m);
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.2s ease, background 0.15s ease;
  width: 100%;
  box-sizing: border-box;
}

.nx-btn-secondary-action:hover {
  border-color: var(--nx-color-accent);
  background: var(--nx-color-background-cs, #e8fff4);
}

/* ---- Envíos ---- */

.nx-shipping-box {
  background: var(--nx-color-background-cs, #e8fff4);
  border-radius: var(--nx-radius-md);
  padding: 16px 20px;
  border: 1px solid #bce8f7;
}

.nx-shipping-box__title {
  font-size: var(--nx-font-m2);
  font-weight: 700;
  color: var(--nx-color-text-darks);
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nx-shipping-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Aislado */
.nx-product-page .nx-shipping-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

.nx-shipping-list__icon {
  flex-shrink: 0;
  margin-top: 1px;
}

.nx-shipping-list__price {
  font-weight: 700;
  color: var(--nx-color-background-v);
}

.nx-shipping-list__eta {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
  display: block;
}

/* ---- Trust bar ---- */

.nx-trust-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.nx-trust-bar__item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: var(--nx-color-background-vs);
  border-radius: var(--nx-radius-sm);
  font-size: var(--nx-font-sm);
  font-weight: 600;
  color: #1a6b3c;
   flex: 1 1 auto;     /* 👈 antes era flex: 1 */
  min-width: max-content; /* 👈 evita que se rompa en 2 líneas */
}

/* =========================================================
   LOWER: secciones continuas + nav ancla sticky
   ========================================================= */

.nx-product-lower {
  margin-top: 40px;
}

/* ---- Nav ancla ---- */

.nx-section-nav {
  top: 105px; /* altura del header del site */
  z-index: 100;
  background: #fff;
  border-bottom: 2px solid var(--nx-border-light);
  display: flex;
  gap: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.nx-section-nav::-webkit-scrollbar { display: none; }

.nx-section-nav__btn {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  padding: 14px 24px;
  font-size: var(--nx-font-m2);
  font-weight: 600;
  color: var(--nx-color-text-darks2);
  cursor: pointer;
  white-space: nowrap;
  margin-bottom: -2px;
  transition: color 0.15s ease, border-color 0.15s ease;
  font-family: var(--nx-font-base);
}

.nx-section-nav__btn:hover {
  color: var(--nx-color-text-darks);
}

.nx-section-nav__btn.is-active {
  color: var(--nx-color-accent);
  border-bottom-color: var(--nx-color-accent);
}

/* ---- Secciones continuas ---- */

.nx-product-section {
  padding: 40px 0;
  border-bottom: 1px solid var(--nx-border-light);
}

.nx-product-section:last-child {
  border-bottom: none;
  padding-bottom: 60px;
}

.nx-product-section__title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--nx-color-text-darks);
  margin: 0 0 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--nx-border-light);
}

/* ---- Descripción ---- */

/* Aislado */
.nx-product-page .nx-product-description p {
  font-size: var(--nx-font-m);
  line-height: 1.8;
  color: var(--nx-color-text-darks);
  margin: 0 0 16px;
}

/* ---- Specs ---- */

.nx-specs-table {
  width: 100%;
  border-collapse: collapse;
}

/* Aislado */
.nx-product-page .nx-specs-table caption {
  text-align: left;
  font-weight: 700;
  font-size: var(--nx-font-m2);
  padding: 0 0 14px;
  color: var(--nx-color-text-darks);
}

/* Aislado */
.nx-product-page .nx-specs-table tr {
  border-bottom: 1px solid var(--nx-border-light);
}

.nx-product-page .nx-specs-table tr:last-child {
  border-bottom: none;
}

.nx-product-page .nx-specs-table th {
  width: 34%;
  padding: 13px 16px;
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  text-align: left;
  font-weight: 600;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

.nx-product-page .nx-specs-table td {
  padding: 13px 16px;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

/* ---- FAQs ---- */
.nx-faq-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  max-width: 860px;
}

@media (min-width: 900px) {
  .nx-faq-list {
    grid-template-columns: 1fr 1fr;
    max-width: 100%;
    align-items: start; /* cards de distinta altura no se estiran */
  }
}

.nx-faq-item {
  border: 1px solid var(--nx-border-light);
  border-radius: var(--nx-radius-md);
  overflow: hidden;
}

/* Aislado */
.nx-product-page .nx-faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  font-size: var(--nx-font-m2);
  font-weight: 600;
  color: var(--nx-color-text-darks);
  cursor: pointer;
  list-style: none;
  gap: 12px;
  background: var(--nx-surface-1, #fff);
  transition: background 0.15s ease;
}

.nx-product-page .nx-faq-item summary::-webkit-details-marker {
  display: none;
}

.nx-product-page .nx-faq-item summary:hover {
  background: var(--nx-surface-2, var(--nx-color-bg-s));
}

.nx-product-page .nx-faq-item[open] summary {
  background: var(--nx-color-background-cs, #e8fff4);
  color: var(--nx-color-accent);
  border-bottom: 1px solid #bce8f7;
}

.nx-faq-item__icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--nx-color-background-c, #ccc); /* Agregar fallback si falta la var */
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  transition: transform 0.2s ease;
}

.nx-product-page .nx-faq-item[open] .nx-faq-item__icon {
  transform: rotate(45deg);
}

.nx-faq-item__body {
  padding: 16px 20px;
  font-size: var(--nx-font-m2);
  line-height: 1.7;
  color: var(--nx-color-text-darks);
  background: var(--nx-surface-1, #fff);
}

/* ---- Reseñas ---- */

.nx-reviews-summary {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 24px;
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  border-radius: var(--nx-radius-md);
  margin-bottom: 20px;
  flex-wrap: wrap;
  max-width: 860px;
}

.nx-reviews-summary__score {
  text-align: center;
  flex-shrink: 0;
}

.nx-reviews-summary__number {
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1;
  color: var(--nx-color-text-darks);
}

.nx-reviews-summary__stars {
  font-size: 22px;
  color: #f59e0b;
  letter-spacing: -1px;
  display: block;
}

.nx-reviews-summary__total {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
  margin-top: 4px;
}

.nx-reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 1200px) {
  .nx-reviews-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.nx-review-card {
  border: 1px solid var(--nx-border-light);
  border-radius: var(--nx-radius-md);
  padding: 18px 20px;
  background: var(--nx-surface-1, #fff);
}

.nx-review-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.nx-review-card__author {
  font-weight: 700;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

.nx-review-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
}

.nx-review-card__stars {
  color: #f59e0b;
  font-size: 14px;
  letter-spacing: -1px;
}

.nx-review-card__date {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
}

.nx-review-card__body {
  font-size: var(--nx-font-m2);
  line-height: 1.65;
  color: var(--nx-color-text-darks);
  margin: 0;
}

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

.nx-warranty-bar {
  background: var(--nx-color-bg-s);
  border: 1px solid var(--nx-border-light);
  border-radius: var(--nx-radius-md);
  padding: 24px 28px;
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
}

.nx-warranty-bar__title {
  font-size: var(--nx-font-m);
  font-weight: 700;
  color: var(--nx-color-text-darks);
  margin: 0 0 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nx-warranty-bar__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Aislado */
.nx-product-page .nx-warranty-bar__list li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

.nx-product-page .nx-warranty-bar__list li::before {
  content: "✓";
  color: var(--nx-color-background-v);
  font-weight: 700;
  flex-shrink: 0;
}

/* =========================================================
   MOBILE
   ========================================================= */

@media (max-width: 767px) {
  .nx-price-box__main {
    font-size: 1.9rem;
  }

  .nx-section-nav__btn {
    padding: 12px 14px;
    font-size: var(--nx-font-xs);
  }

  .nx-trust-bar__item {
    flex: 1 1 100%;
  }
}

/* -------- ENVÍOS (UX HUMANA Y LIMPIA) -------- */
.nx-delivery-human {
  background: var(--nx-surface-2, var(--nx-color-bg-s)); /* Fondo suave, no invasivo */
  border-radius: var(--nx-radius-md);
  padding: 20px;
  margin-bottom: 24px;
}

.nx-delivery-human__header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  padding-bottom: 16px;
}

.nx-delivery-human__icon {
  font-size: 1.2rem;
  line-height: 1;
}

.nx-delivery-human__sentence {
  margin: 0;
  font-size: var(--nx-font-m);
  color: var(--nx-color-text-darks);
}

/* El truco mágico: Un <select> invisible sobre texto visible */
.nx-delivery-human__select-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--nx-active-color);
  font-weight: 700;
  cursor: pointer;
}

.nx-product-page .nx-delivery-human__select-wrap select {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  appearance: none;
}

.nx-delivery-human__selected {
  border-bottom: 1px dashed var(--nx-active-color);
  transition: opacity 0.2s;
}

.nx-delivery-human__select-wrap:hover .nx-delivery-human__selected {
  opacity: 0.8;
}

/* Opciones de entrega (lista) */
.nx-delivery-human__options {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.nx-product-page .nx-delivery-human__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.nx-delivery-human__icon-sm {
  font-size: 1.1rem;
  line-height: 1.2;
}

.nx-delivery-human__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.nx-delivery-human__title {
  font-size: var(--nx-font-m2);
  color: var(--nx-color-text-darks);
}

.nx-delivery-human__price {
  font-size: var(--nx-font-m2);
  font-weight: 700;
  color: var(--nx-text-dark);
}

/* -------- WIDGET DE PAGOS (Oculto por defecto UX / Visible IA) -------- */
.nx-payments-widget {
  margin-bottom: 24px;
}

.nx-payments-details {
  background: var(--nx-surface-1, #fff);
  border: 1px solid var(--nx-border-light);
  border-radius: var(--nx-radius-md);
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

.nx-payments-details:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.04);
}

/* El botón (Summary) */
.nx-product-page .nx-payments-summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  cursor: pointer;
  list-style: none; /* Oculta flecha nativa */
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  transition: background 0.2s ease;
}

.nx-product-page .nx-payments-summary::-webkit-details-marker {
  display: none; /* Oculta flecha nativa en navegadores viejos */
}

.nx-payments-summary__left {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: var(--nx-font-m2);
  color: var(--nx-color-accent); 
}

.nx-payments-summary__icon {
  color: var(--nx-color-accent);
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
}

/* Gira la flecha y agrega borde cuando está abierto */
.nx-product-page .nx-payments-details[open] .nx-payments-summary__icon {
  transform: rotate(180deg);
}

.nx-product-page .nx-payments-details[open] .nx-payments-summary {
  border-bottom: 1px solid var(--nx-border-light);
}

/* Contenido interno */
.nx-payments-content {
  padding: 16px 20px;
  animation: nxFadeIn 0.3s ease;
}

.nx-payments-list {
  list-style: none;
  padding: 0;
  margin: 0 0 12px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.nx-product-page .nx-payments-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--nx-surface-2, var(--nx-color-bg-s));
  border-radius: var(--nx-radius-sm);
  font-size: var(--nx-font-m2);
}

.nx-payments-list__plan {
  color: var(--nx-color-text-darks);
}

.nx-payments-list__plan strong {
  font-weight: 700;
  color: var(--nx-text-dark);
}

.nx-payments-list__total {
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
}

.nx-payments-note {
  margin: 0;
  font-size: var(--nx-font-xs);
  color: var(--nx-color-text-darks2);
  font-style: italic;
}

/* -------- BOTÓN DISPARADOR -------- */
.nx-payments-trigger {
  margin-bottom: 24px;
}

.nx-product-page .nx-btn-open-modal {
  display: flex;
  align-items: center;
  width: 100%;
  background: var(--nx-surface-1, #fff);
  border: 1px solid var(--nx-border-light);
  padding: 16px 20px;
  border-radius: var(--nx-radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
}

.nx-product-page .nx-btn-open-modal:hover {
  border-color: var(--nx-color-accent);
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.nx-btn-open-modal__icon {
  color: var(--nx-color-accent);
  margin-right: 12px;
  display: flex;
}

.nx-btn-open-modal__text {
  flex: 1;
  text-align: left;
  font-size: var(--nx-font-m2);
  font-weight: 600;
  color: var(--nx-color-text-darks);
}

.nx-btn-open-modal__arrow {
  font-size: 1.5rem;
  color: var(--nx-color-muted);
  line-height: 1;
}

/* -------- ESTRUCTURA DEL MODAL -------- */
.nx-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  z-index: 99999;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 16px;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.nx-modal-overlay[hidden] {
  display: none !important;
  opacity: 0;
}

.nx-modal-box {
  background: var(--nx-color-bg-w, #fff);
  width: 100%;
  max-width: 1200px;
  max-height: 90vh;
  border-radius: 15px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
  animation: nxSlideUp 0.3s ease;
}

@keyframes nxSlideUp {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.nx-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid var(--nx-border-light);
}

.nx-modal-title {
  margin: 0;
  font-size: 1.2rem;
  color: var(--nx-color-text-dark);
}

.nx-product-page .nx-modal-close {
  background: transparent;
  border: none;
  color: var(--nx-color-text-darks2);
  cursor: pointer;
  padding: 4px;
  display: flex;
  transition: color 0.2s;
}

.nx-product-page .nx-modal-close:hover {
  color: var(--nx-color-background-r, #ff3541);
}

.nx-modal-body {
  padding: 0;
  overflow-y: auto; /* Permite scrollear si el contenido es muy largo */
}

/* Reutilizamos los estilos de los bloques del mensaje anterior */
.nx-payment-block { padding: 24px; border-bottom: 1px solid var(--nx-border-light); }
.nx-payment-block:last-child { border-bottom: none; }
.nx-payment-block__title { margin: 0 0 8px 0; font-size: var(--nx-font-m); color: var(--nx-color-accent); font-weight: 700; }
.nx-payment-block__desc { margin: 0 0 12px 0; font-size: var(--nx-font-sm); color: var(--nx-color-text-darks2); line-height: 1.5; }
.nx-payment-block__price-main { font-size: 1.8rem; font-weight: 800; color: var(--nx-text-dark); margin-bottom: 4px; }
.nx-payment-block__price-sub { font-size: var(--nx-font-xs); color: var(--nx-color-text-darks2); display: flex; gap: 6px; }
.nx-payments-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.nx-product-page .nx-payments-list li { background: var(--nx-surface-2, var(--nx-color-bg-s)); border-radius: var(--nx-radius-sm); padding: 12px 16px; }
.nx-payments-list__row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.nx-payments-list__plan { font-size: var(--nx-font-m2); color: var(--nx-color-text-darks); }
.nx-payments-list__plan strong { color: var(--nx-text-dark); }
.nx-payments-list__total { font-size: var(--nx-font-sm); font-weight: 400; color: var(--nx-color-text-darks2); padding-left: 10px; }
.nx-payments-list__tax { font-size: var(--nx-font-xs); color: var(--nx-color-text-textcomment); }

.nx-payment-block--calculator { background: var(--nx-color-background-vs, #f0fdf4); }
.nx-mixed-calculator { display: flex; flex-direction: column; gap: 12px; margin-top: 16px; }
.nx-mixed-input-group { display: flex; flex-direction: column; gap: 6px; }
.nx-mixed-label { font-size: var(--nx-font-sm); font-weight: 600; color: var(--nx-color-text-darks); }
.nx-mixed-input-wrapper { position: relative; display: flex; align-items: center; }
.nx-mixed-currency { position: absolute; left: 12px; color: var(--nx-color-text-darks2); font-weight: 600; }
.nx-product-page .nx-mixed-input { width: 100%; padding: 12px 12px 12px 28px; border: 1px solid var(--nx-border-light); border-radius: var(--nx-radius-sm); font-size: var(--nx-font-m); outline: none; }
.nx-product-page .nx-mixed-input:focus { border-color: var(--nx-active-color); }
.nx-product-page .nx-btn-calc-mixed { background: #fff; border: 1px solid var(--nx-active-color); color: var(--nx-active-color); font-weight: 600; padding: 12px; border-radius: var(--nx-radius-sm); cursor: pointer; transition: all 0.2s; }
.nx-product-page .nx-btn-calc-mixed:hover { background: var(--nx-active-color); color: #fff; }

/* -------- CALCULADOR MIXTO AVANZADO -------- */
.nx-mixed-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}

.nx-mixed-card {
  background: var(--nx-surface-1, #fff);
  border: 2px solid var(--nx-border-light);
  border-radius: var(--nx-radius-sm);
  padding: 16px;
  transition: all 0.2s ease;
}

/* Tarjeta Activa (La que el usuario está escribiendo) */
.nx-mixed-card.is-active {
  border-color: var(--nx-active-color);
  background: var(--nx-color-background-vs, #f0fdf4);
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.nx-mixed-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.nx-mixed-card__header label {
  font-size: var(--nx-font-m2);
  font-weight: 700;
  color: var(--nx-color-text-darks);
}

.nx-mixed-percent {
  font-size: var(--nx-font-xs);
  font-weight: 700;
  color: #fff;
  background: var(--nx-color-background-v);
  padding: 4px 8px;
  border-radius: 20px;
}

.nx-mixed-card:not(.is-active) .nx-mixed-percent {
  background: var(--nx-color-muted);
}

.nx-mixed-card__body {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 8px;
}

.nx-mixed-currency {
  position: absolute;
  left: 12px;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--nx-color-text-darks2);
}

.nx-product-page .nx-mixed-input {
  width: 100%;
  padding: 14px 14px 14px 32px;
  border: 1px solid var(--nx-border-light);
  border-radius: var(--nx-radius-sm);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--nx-text-dark);
  outline: none;
  background: var(--nx-surface-1, #fff);
}

.nx-product-page .nx-mixed-input:focus {
  border-color: var(--nx-active-color);
}

.nx-mixed-card__footer {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  font-style: italic;
}

.nx-mixed-card.is-active .nx-mixed-card__footer {
  color: var(--nx-active-color);
  font-weight: 600;
}

/* -------- TOGGLE DEL CALCULADOR MIXTO -------- */
.nx-payment-block--mixed-toggle {
  background: var(--nx-surface-2, #f9f9f9);
  padding: 16px 24px; /* Un poco más compacto */
}

.nx-mixed-details {
  width: 100%;
}

.nx-product-page .nx-mixed-summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  list-style: none;
}

.nx-product-page .nx-mixed-summary::-webkit-details-marker {
  display: none;
}

.nx-mixed-summary__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.nx-mixed-summary__text strong {
  font-size: var(--nx-font-m2);
  color: var(--nx-text-dark);
}

.nx-mixed-summary__text span {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
}

.nx-mixed-summary__btn {
  font-size: var(--nx-font-sm);
  font-weight: 700;
  color: var(--nx-active-color);
  background: #fff;
  border: 1px solid var(--nx-border-light);
  padding: 8px 16px;
  border-radius: 20px;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  gap: 6px;
}

.nx-product-page .nx-mixed-summary:hover .nx-mixed-summary__btn {
  border-color: var(--nx-active-color);
  background: var(--nx-color-background-vs, #e8fff4);
}

/* Cambia el botón a "-" cuando está abierto */
.nx-product-page .nx-mixed-details[open] .nx-mixed-summary__btn span {
  transform: rotate(45deg);
  display: inline-block;
}

.nx-mixed-details-content {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px dashed var(--nx-border-light);
  animation: nxFadeIn 0.3s ease;
}

/* -------- TARJETAS ACEPTADAS -------- */
.nx-payment-cards-accepted {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.nx-badge-card {
  background: var(--nx-surface-2, #f5f5f5);
  border: 1px solid var(--nx-border-light);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--nx-color-text-darks);
  letter-spacing: 0.5px;
}

.nx-payment-cards-note {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  margin: 0 0 16px 0;
  background: var(--nx-color-background-vs, #f0fdf4);
  padding: 8px 12px;
  border-radius: var(--nx-radius-sm);
  border-left: 3px solid var(--nx-color-background-v);
}

/* -------- FOOTER DEL CALCULADOR -------- */
.nx-mixed-card__footer {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 8px;
}

.nx-mixed-footer-main {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  font-style: italic;
}

.nx-mixed-card.is-active .nx-mixed-footer-main {
  color: var(--nx-active-color);
  font-weight: 600;
}

.nx-mixed-footer-total {
  font-size: var(--nx-font-sm);
  font-weight: 700;
  color: var(--nx-text-dark);
  background: #fff;
  padding: 6px 10px;
  border-radius: 4px;
  border: 1px dashed var(--nx-border-light);
  margin-top: 4px;
}

.nx-mixed-card.is-active .nx-mixed-footer-total {
  display: none; /* No mostramos "Total mixto" en la tarjeta que se usa como base */
}

/* -------- TARJETAS ACEPTADAS (CON IMÁGENES) -------- */
.nx-payment-cards-accepted {
  display: flex;
  align-items: center;
  gap: 6px; /* Reemplaza tu margin-right: 2px dándole un respiro más moderno */
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.nx-product-page .nx-payment-card-img {
  width: 31px; /* El ancho exacto que venías usando */
  height: auto;
  display: block;
  object-fit: contain;
  border-radius: 2px; /* Suaviza apenitas los bordes de la imagen */
}

.nx-payment-cards-note {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  margin: 0 0 16px 0;
  background: var(--nx-color-background-vs, #f0fdf4);
  padding: 8px 12px;
  border-radius: var(--nx-radius-sm);
  border-left: 3px solid var(--nx-color-background-v);
}

/* -------- TITULO + TARJETAS EN UNA LINEA (UX Compacta) -------- */

.nx-payment-block__title-row {
  display: flex;
  justify-content: space-between; /* Empuja título a izq y tarjetas a der */
  align-items: center; /* Alineación vertical perfecta */
  margin-bottom: 12px; /* Espacio antes de la nota verde */
  flex-wrap: wrap; /* Por seguridad en celus muy viejos */
  gap: 10px;
}

/* Sacamos el margin-bottom al título porque ahora lo maneja el contenedor row */
.nx-product-page .nx-payment-block__title {
  margin: 0;
  font-size: var(--nx-font-m);
  color: var(--nx-color-accent);
  font-weight: 700;
}

.nx-payment-cards-accepted {
  display: flex;
  align-items: center;
  gap: 4px; /* Espacio compacto entre logos */
  margin: 0; /* Sacamos márgenes previos */
}

.nx-product-page .nx-payment-card-img {
  width: 31px; /* Tu ancho exacto */
  height: auto;
  display: block;
  object-fit: contain;
}

.nx-payment-cards-note {
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  margin: 0 0 16px 0; /* Espacio antes del listado de cuotas */
  background: var(--nx-color-background-vs, #f0fdf4);
  padding: 8px 12px;
  border-radius: var(--nx-radius-sm);
  border-left: 3px solid var(--nx-color-background-v);
}

/* -------- CAJA VERDE: TEXTO + TARJETAS EN LÍNEA -------- */
.nx-payment-cards-note {
  display: flex;
  align-items: center; /* Centra todo verticalmente */
  justify-content: space-between; /* Texto a la izq, tarjetas a la der */
  gap: 16px; /* Espacio mínimo entre el texto y las tarjetas */
  
  font-size: var(--nx-font-sm);
  color: var(--nx-color-text-darks2);
  margin: 0 0 16px 0;
  background: var(--nx-color-background-vs, #f0fdf4);
  padding: 10px 14px;
  border-radius: var(--nx-radius-sm);
  border-left: 3px solid var(--nx-color-background-v);
}

.nx-payment-cards-note p {
  margin: 0;
  flex: 1; /* El texto ocupa todo el espacio libre disponible */
  line-height: 1.4;
}

.nx-payment-cards-accepted {
  display: flex;
  align-items: center;
  gap: 4px; /* Separación entre cada tarjetita */
  margin: 0; 
  flex-shrink: 0; /* Evita que los logos se achiquen o deformen si el texto es muy largo */
}

.nx-product-page .nx-payment-card-img {
  width: 31px; /* El tamaño que vos definiste */
  height: auto;
  display: block;
  object-fit: contain;
  border-radius: 2px;
}

/* Ajuste preventivo para celulares muy chiquitos (ej: iPhone SE) */
@media (max-width: 480px) {
  .nx-payment-cards-note {
    flex-direction: column; /* Si no entra todo a lo ancho, lo apila prolijo */
    align-items: flex-start;
    gap: 10px;
  }
}

/* =========================================================
   HIGHLIGHTS – chips horizontales con íconos
   ========================================================= */

.nx-buy-highlights {
  padding-bottom: 16px;
  border-bottom: 1px solid var(--nx-border-light);
}

.nx-buy-highlights__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.nx-highlight-chip {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 14px;
  background: var(--nx-surface-2);
  border: 1px solid transparent;
  border-radius: var(--nx-radius-sm);
  font-size: var(--nx-font-m);
  color: var(--nx-color-text-darks);
  flex: 1;
  min-width: 130px;
}

.nx-highlight-chip svg {
  flex-shrink: 0;
  color: var(--nx-color-text-darks2);
}

.nx-highlight-chip strong {
  color: var(--nx-color-text-darks);
}

.nx-buy-highlights__link {
  font-size: 13px;
  color: var(--nx-active-color, #037FFF);
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.nx-buy-highlights__link:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* =========================================================
   ENVÍO COMPACTO
   ========================================================= */

.nx-delivery-compact {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 0;
  border-top: 1px solid var(--nx-border-light);
  border-bottom: 1px solid var(--nx-border-light);
}

.nx-delivery-compact__row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--nx-font-m);
  color: var(--nx-color-text-darks);
  line-height: 1.5;
}

.nx-delivery-compact__icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

.nx-delivery-compact__text {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}

.nx-delivery-compact__change {
  color: var(--nx-color-button-bd);
  font-weight: 600;
  cursor: pointer;
  font-size: var(--nx-font-m);
   position: relative;
  display: inline-block;
}
/* El select invisible arriba del texto */
.nx-delivery-compact__change .nx-zone-select {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}
.nx-delivery-compact__price {
  font-weight: 700;
  color: var(--nx-color-text-darks);
}

/* Ocultar el select real, mostrar solo el span */
.nx-delivery-human__select-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  font-size: var(--nx-font-m);
}

.nx-delivery-human__select-wrap select {
  position: absolute;
  inset: 0;
  width: 100%;
  cursor: pointer;
  font-size: inherit;
}
@keyframes nx-glow {
  0% { 
    box-shadow: 0 0 0 0 rgba(var(--nx-highlight-rgb), 0.8); 
    outline: 2px solid var(--nx-highlight-color);
    outline-offset: 12px; /* MAGIA: Empuja la línea 12px hacia afuera */
  }
  50% { 
    box-shadow: 0 0 15px 4px rgba(var(--nx-highlight-rgb), 0.4); 
    outline: 2px solid var(--nx-highlight-color);
    outline-offset: 12px; /* Mantenemos la misma distancia */
  }
  100% { 
    box-shadow: 0 0 0 0 transparent; 
    outline: 2px solid transparent; /* Se vuelve invisible suavemente */
    outline-offset: 12px;
  }
}

.nx-product-section.is-highlighted {
  animation: nx-glow 2s ease-out forwards;
  border-radius: 8px; /* Opcional: suaviza las esquinas del fondo si lo tuviera */
}

.nx-price-row {
  display: flex;
  align-items: baseline; /* Alinea los dos textos perfectamente por su base */
  flex-wrap: wrap; /* Evita que se rompa el diseño en pantallas de celulares muy chicos */
}

.nx-price-row .nx-price-box__usd {
  margin-top: 0; /* Reseteamos el margin-top de 6px que traía la clase original para que no quede desalineado */
}

.nx-btn-shoppingcart{
  display: flex;
  align-items: center;
  width: 100%;
  background: var(--nx-surface-1, #fff);
  border: 1px solid var(--nx-border-light);
  padding: 16px 20px;
  border-radius: var(--nx-radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
    justify-content: center;
    font-size: var(--nx-font-m);
}
.nx-btn-shoppingcart:hover{
  border-color: var(--nx-color-accent);
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.nx-zone-select {
    border: none;
    background: transparent;
    font-weight: 600;
    cursor: pointer;
}

.nx-badge-sin-interes {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    color: #1a7f4b;
    background: #e6f4ed;
    border: 1px solid #a8d5bc;
    border-radius: 4px;
    padding: 1px 6px;
    margin-left: 6px;
    vertical-align: middle;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

/* ── Imagen principal clickeable ── */
.nx-gallery-img {
  cursor: zoom-in;
  transition: transform 0.2s ease;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* ── Zoom hover (solo desktop) ── */
@media (hover: hover) and (pointer: fine) {
  .nx-product-gallery__main {
    overflow: hidden;
  }

}

/* ── Lightbox ── */
.nx-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.92);
  align-items: center;
  justify-content: center;
  cursor: zoom-out;
  padding: 16px;
}
.nx-lightbox.is-open {
  display: flex;
}
.nx-lightbox img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  pointer-events: none;
  user-select: none;
}
.nx-lightbox__close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  color: #fff;
  font-size: 32px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 8px;
  opacity: 0.8;
}
.nx-lightbox__close:hover { opacity: 1; }

.nx-gallery-img {
  cursor: zoom-in;
}

.nx-components-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
}

.nx-component-card {
    display: block;
    background: #fff;
    border-radius: 10px;
    padding: 12px;
    text-decoration: none;
    color: inherit;
    transition: 0.2s ease;
}

.nx-component-card:hover {
    box-shadow: 0 6px 18px rgba(0,0,0,0.08);
    transform: translateY(-2px);
}

.nx-component-card img {
    width: 100%;
    height: auto;
    margin-bottom: 8px;
}

.nx-component-card__name {
    font-size: 13px;
    font-weight: 600;
    display: block;
}

.nx-component-card__qty {
    font-size: 12px;
    color: #666;
}
.nx-btn-notify {
    background: var(--nx-color-background-n);
    color: #fff;
    border: none;
}

.nx-btn-notify:hover {
    opacity: 0.9;
    background: var(--nx-color-background-n);
}

.heroPausedPublication {
    width: 100%;
    background: #FFF4E5; /* fondo suave tipo warning */
    border-bottom: 1px solid #FFD8A8;
    padding: 12px 16px;
    display: flex;
    justify-content: center;
}

.heroPausedPublication p {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 500;
    color: #8A5A00; /* marrón/naranja oscuro */
}

.heroPausedPublication svg {
    flex-shrink: 0;
}
.textstock{
  color: var(--nx-color-background-v);
}

#favort {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  width: 36px;
  height: 36px;
  cursor: pointer;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.2));
  transition: transform 0.15s ease, filter 0.15s ease;
}

#favort:hover {
  transform: scale(1.15);
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.3));
}

