/* Product Page */
.main {
  margin-top: 0; /* El espacio viene de main--with-header-space */
}

@media (max-width: 768px) {
  .main {
    margin-top: 0;
  }
}

.product {
  padding: var(--spacing-xs) 0; /* Mínimo padding */
  overflow-x: hidden;
}

.product__breadcrumb {
  margin-bottom: var(--spacing-xs);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.product__breadcrumb a {
  color: var(--color-primary);
  transition: color var(--transition-base);
}

.product__breadcrumb a:hover {
  color: #FF5722;
}

.product__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg); /* Reducido de 2xl */
  align-items: start; /* Alinear arriba */
}

/* Gallery */
.product__gallery {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm); /* Reducido de lg */
  overflow: hidden;
}

.product__main {
  position: relative;
  width: 100%;
  max-height: 400px; /* Limitar altura máxima */
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  overflow: hidden;
  z-index: 1;
}

.product__main-image {
  width: 100%;
  height: auto;
  max-height: 400px; /* Limitar altura */
  object-fit: contain;
  background: #ffffff;
}

.product__discount-badge {
  position: absolute;
  top: var(--spacing-lg);
  right: var(--spacing-lg);
  background: var(--color-danger);
  color: white;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  font-weight: bold;
  font-size: var(--font-size-lg);
  z-index: 10;
}

.product__video-section {
  width: 100%;
  margin-top: var(--spacing-sm); /* Reducido de lg */
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.product__video {
  width: 100%;
  height: auto;
  background: var(--color-bg);
}

.product__thumbnails {
  display: grid;
  grid-template-columns: repeat(5, 70px); /* Reducido de 80px */
  gap: var(--spacing-sm); /* Reducido de md */
  padding: var(--spacing-xs) 0; /* Reducido de md */
}

.product__gallery-img {
  width: 70px; /* Reducido de 80px */
  height: 70px;
  object-fit: contain;
  background: #ffffff;
  border-radius: var(--radius-md);
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color var(--transition-base);
  flex-shrink: 0;
}

.product__gallery-img:hover {
  border-color: var(--color-primary);
}

/* Info */
.product__info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm); /* Reducido de lg */
}

.product__title {
  font-size: var(--font-size-xl); /* Reducido de 2xl */
  margin: 0;
  line-height: 1.2;
}

.product__rating {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm); /* Reducido de md */
  font-size: var(--font-size-sm); /* Reducido de base */
}

.product__stars {
  font-weight: 600;
}

.product__reviews {
  color: var(--color-text-secondary);
}

.product__price-section {
  background: var(--color-bg-secondary);
  padding: var(--spacing-md); /* Reducido de lg */
  border-radius: var(--radius-lg);
}

.product__price {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.product__price-current {
  font-size: var(--font-size-3xl);
  font-weight: bold;
  color: var(--color-primary);
}

.product__price-original {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  text-decoration: line-through;
}

.product__savings {
  background: var(--color-success);
  color: white;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.product__description {
  font-size: var(--font-size-sm); /* Reducido de base */
  line-height: 1.6; /* Reducido de 1.8 */
  color: var(--color-text-secondary);
}

.product__specs {
  background: var(--color-bg-secondary);
  padding: var(--spacing-md); /* Reducido de lg */
  border-radius: var(--radius-lg);
}

.product__specs h3 {
  margin-bottom: var(--spacing-sm); /* Reducido de md */
  font-size: var(--font-size-base);
}

.product__spec {
  display: flex;
  justify-content: space-between;
  padding: var(--spacing-xs) 0; /* Reducido de sm */
  border-bottom: 1px solid var(--color-border);
  font-size: var(--font-size-sm);
}

.product__spec:last-child {
  border-bottom: none;
}

.product__spec-label {
  font-weight: 600;
  color: var(--color-text-secondary);
}

.product__spec-value {
  color: var(--color-text);
}

.product__shipping {
  background: var(--color-bg-secondary);
  padding: var(--spacing-md); /* Reducido de lg */
  border-radius: var(--radius-lg);
}

.product__shipping h3 {
  margin-bottom: var(--spacing-sm); /* Reducido de md */
  font-size: var(--font-size-base);
}

.product__shipping p {
  margin: 0;
  font-size: var(--font-size-sm); /* Reducido de base */
}

.product__stock {
  padding: var(--spacing-md); /* Reducido de lg */
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
}

.product__stock-status {
  margin: 0;
  font-weight: 600;
  font-size: var(--font-size-sm); /* Reducido de base */
}

.product__stock-status.in-stock {
  color: var(--color-success);
}

.product__stock-status.out-of-stock {
  color: var(--color-danger);
}

.product__actions {
  display: flex;
  gap: var(--spacing-md);
}

.btn--large {
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--font-size-base);
  flex: 1;
}

.btn--large:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.product__badge {
  text-align: center;
  padding: var(--spacing-lg);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-lg);
  font-weight: 600;
}

.product__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
  padding: 16px;
  background: #1a1a2e;
  border-radius: 12px;
}

.product__tag {
  display: inline-block;
  padding: 6px 12px;
  background: #4CAF50;
  color: white;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 500;
}

.product__error {
  text-align: center;
  padding: var(--spacing-2xl);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
}

.product__error h2 {
  margin-bottom: var(--spacing-md);
}

.product__error p {
  margin-bottom: var(--spacing-lg);
  color: var(--color-text-secondary);
}

/* Responsive */
@media (max-width: 1024px) {
  .product__content {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
}

@media (max-width: 768px) {
  .product__title {
    font-size: var(--font-size-xl);
  }

  .product__price-current {
    font-size: var(--font-size-2xl);
  }

  .product__actions {
    flex-direction: column;
  }

  .btn--large {
    flex: 1;
  }
}

@media (max-width: 480px) {
  .product {
    padding: var(--spacing-lg) 0;
  }

  .product__gallery {
    max-width: 100%;
  }

  .product__main {
    max-width: 100%;
    width: 100%;
  }

  .product__main-image {
    max-width: 100%;
    height: auto;
  }

  .product__thumbnails {
    grid-template-columns: repeat(4, 60px);
  }

  .product__gallery-img {
    width: 60px;
    height: 60px;
  }

  .product__price-current {
    font-size: var(--font-size-xl);
  }
}


/* =====================================================
   MODO MAYORISTA - Precios Lista/Mayorista (Diseño Compacto)
   ===================================================== */

/* Contenedor principal del precio mayorista compacto */
.product__price--wholesale-compact {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

/* Comparación de precios en línea horizontal */
.product__price-comparison {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}

/* Cada item de precio (Lista y Mayorista) */
.product__price-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.product__price-item .product__price-value {
  font-size: var(--font-size-2xl);
  font-weight: bold;
}

.product__price-item .product__price-label {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Precio Lista - más tenue */
.product__price-item--list .product__price-value {
  color: var(--color-text-secondary);
  opacity: 0.7;
}

/* Precio Mayorista - destacado */
.product__price-item--wholesale .product__price-value {
  color: var(--color-success);
  font-size: var(--font-size-3xl);
}

.product__price-item--wholesale .product__price-label {
  color: var(--color-success);
}

/* Flecha entre precios */
.product__price-arrow {
  font-size: var(--font-size-xl);
  color: var(--color-text-secondary);
  opacity: 0.5;
}

/* Footer con ahorro y condiciones */
.product__wholesale-footer {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  padding-top: var(--spacing-sm);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.product__wholesale-separator {
  color: var(--color-text-secondary);
  opacity: 0.5;
}

.product__wholesale-conditions {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

/* Responsive para móviles */
@media (max-width: 480px) {
  .product__price-comparison {
    gap: var(--spacing-md);
  }
  
  .product__price-item .product__price-value {
    font-size: var(--font-size-xl);
  }
  
  .product__price-item--wholesale .product__price-value {
    font-size: var(--font-size-2xl);
  }
  
  .product__wholesale-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-xs);
  }
  
  .product__wholesale-separator {
    display: none;
  }
}

/* Precios en modo mayorista (diseño anterior - mantener compatibilidad) */
.product__price--wholesale {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.product__price-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.product__price-row .product__price-label {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  min-width: 120px;
}

.product__price-list-value {
  font-size: var(--font-size-lg);
  color: var(--color-text);
  opacity: 0.8;
}

.product__price-row--highlight {
  background: rgba(76, 175, 80, 0.1);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-success);
}

.product__price-row--highlight .product__price-label {
  color: var(--color-success);
  font-weight: 600;
}

.product__price-wholesale-value {
  font-size: var(--font-size-2xl);
  font-weight: bold;
  color: var(--color-success);
}

.product__price--wholesale .product__savings {
  margin-top: var(--spacing-xs);
}

.product__wholesale-footer {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-md);
  padding: var(--spacing-sm) var(--spacing-md);
  background: rgba(76, 175, 80, 0.08);
  border-radius: var(--radius-md);
}

.product__wholesale-footer .product__savings {
  background: transparent;
  color: var(--color-success);
  padding: 0;
  font-weight: 600;
  font-size: var(--font-size-sm);
}

.product__wholesale-separator {
  color: var(--color-text-secondary);
  opacity: 0.5;
}

.product__wholesale-footer .product__wholesale-conditions {
  background: transparent;
  border: none;
  padding: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.product__wholesale-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-sm);
}

.product__wholesale-conditions {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: rgba(255, 152, 0, 0.1);
  border-radius: var(--radius-sm);
  border-left: 3px solid #ff9800;
}

.product__wholesale-note {
  margin-top: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  background: rgba(76, 175, 80, 0.1);
  border-left: 3px solid var(--color-success);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

/* Card en modo mayorista */
.card__price--wholesale {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.card__price-list,
.card__price-wholesale {
  display: flex;
  align-items: center;
  gap: 6px;
}

.card__price-label {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}

.card__price-value {
  font-size: 0.9rem;
  font-weight: 600;
}

.card__price-highlight {
  color: var(--color-success) !important;
  font-size: 1rem !important;
}

.card__price-wholesale .card__price-label {
  color: var(--color-success);
}


/* ========== STOCK BADGES ========== */
.stock-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.375rem 0.75rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.stock-badge--out {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.stock-badge--low {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.3);
}

/* Card stock badge */
.card__stock-badge {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 10;
}

/* Product page stock badge */
.product__stock-badge {
  margin-bottom: 1rem;
}

/* Disabled state for out of stock products */
.card--out-of-stock {
  opacity: 0.7;
}

.card--out-of-stock .card__image {
  filter: grayscale(30%);
}

.card--out-of-stock .card__add-btn {
  background: var(--color-text-secondary);
  cursor: not-allowed;
  pointer-events: none;
}

.product--out-of-stock .product__add-btn {
  background: var(--color-text-secondary);
  cursor: not-allowed;
}

.product--out-of-stock .product__add-btn::after {
  content: 'Sin Stock';
}
