/* ============================================================
   SINGLE PRODUCT — Compra Tu Panel
   ============================================================ */

/* ── Notices de WooCommerce ──────────────────────────────────── */
.ctp-wc-notices { background: #FFFFFF; }
.ctp-wc-notices .ctp-wrap { padding-top: 0; padding-bottom: 0; }
.ctp-wc-notices .woocommerce-message,
.ctp-wc-notices .woocommerce-error,
.ctp-wc-notices .woocommerce-info {
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  border-radius: 8px;
  margin: 0.75rem 0;
  padding: 0.75rem 1rem;
  list-style: none;
}

/* ── Breadcrumb ──────────────────────────────────────────────── */
.ctp-breadcrumb {
  background: #FFFFFF;
  border-bottom: 1px solid #E4E4E7;
}
.ctp-breadcrumb .ctp-wrap {
  display:     flex;
  align-items: center;
  gap:         0.375rem;
  flex-wrap:   wrap;
  padding-top:    0.875rem;
  padding-bottom: 0.875rem;
  font-family: 'Inter', sans-serif;
  font-size:   0.75rem;
  font-weight: 500;
  color:       #A1A1AA;
}
.ctp-breadcrumb__item {
  color:           #A1A1AA;
  text-decoration: none;
  transition:      color 0.15s ease;
  white-space:     nowrap;
  max-width:       200px;
  overflow:        hidden;
  text-overflow:   ellipsis;
}
.ctp-breadcrumb__item:hover          { color: #18181B; }
.ctp-breadcrumb__item--current       { color: #18181B; }
.ctp-breadcrumb__sep                 { color: #D4D4D8; flex-shrink: 0; line-height: 1; }

/* ── Neutralizar columnas de WooCommerce ─────────────────────── */
.woocommerce .ctp-product__gallery,
.woocommerce-page .ctp-product__gallery,
.woocommerce .ctp-product__details,
.woocommerce-page .ctp-product__details {
  float:     none !important;
  width:     100% !important;
  max-width: none !important;
  clear:     none !important;
  padding:   0 !important;
  margin:    0 !important;
}

/* ── Sección principal ────────────────────────────────────────── */
.ctp-product {
  background:     #F8F9FA;
  padding-top:    2.5rem;
  padding-bottom: 2.5rem;
}
@media (min-width: 1024px) {
  .ctp-product { padding-top: 4rem; padding-bottom: 4rem; }
}
.ctp-product__grid {
  display:               grid !important;
  grid-template-columns: 1fr !important;
  gap:                   2.5rem !important;
}
@media (min-width: 1024px) {
  .ctp-product__grid {
    grid-template-columns: 1fr 1fr !important;
    gap:                   4rem !important;
    align-items:           start !important;
  }
}

/* ── Galería ─────────────────────────────────────────────────── */
.ctp-product__gallery {
  display:   flex;
  flex-direction: column;
  gap:       1rem;
  min-width: 0; /* Evita que el grid expanda la columna */
  width:     100%;
}

.ctp-product__main-image {
  position:      relative;
  aspect-ratio:  4 / 4;  /* = 1/1 en todos los tamaños */
  width:         100%;
  background:    #FFFFFF;
  border-radius: 16px;
  border:        1px solid #E4E4E7;
  overflow:      hidden;
}

/* Ambas imágenes se superponen exactamente */
.ctp-product__main-img {
  position:   absolute;
  inset:      0;
  width:      100% !important;
  height:     100% !important;
  max-width:  none !important;
  object-fit: cover;
  display:    block;
}

/* Imagen actual — siempre visible debajo */
.ctp-product__main-img--current {
  z-index: 1;
  opacity: 1;
}

/* Imagen siguiente — encima, invisible hasta el crossfade */
.ctp-product__main-img--next {
  z-index:    2;
  opacity:    0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

/* Al cargar la imagen nueva: fade in suave */
.ctp-product__main-img--next.is-visible {
  opacity: 1;
}

/* ── Splide thumbnail slider ─────────────────────────────── */
.ctp-thumbs-splide {
  position:   relative;
  width:      100%;
  box-sizing: border-box;
  /* padding lateral para que las arrows no tapen los thumbs */
  padding:    0 38px;
}

/* Track: no recorta los thumbs */
.ctp-thumbs-splide .splide__track {
  overflow: hidden;
}

/* Slide = thumbnail */
.ctp-product__thumb {
  width:         72px !important;
  height:        72px !important;
  border-radius: 10px;
  border:        2px solid #E4E4E7;
  overflow:      hidden;
  background:    #FFFFFF;
  cursor:        pointer;
  box-sizing:    border-box;
  transition:    border-color 0.15s ease;
  list-style:    none;
  padding:       0;
  display:       block;
}
.ctp-product__thumb img       { width: 100%; height: 100%; object-fit: cover; display: block; pointer-events: none; }
.ctp-product__thumb:hover     { border-color: #A1A1AA; }
.ctp-product__thumb.is-active { border-color: #18181B; box-shadow: 0 0 0 1px #18181B; }

/* Arrows de Splide — dentro del .splide (position: relative) */
.ctp-thumbs-splide .splide__arrow {
  position:        absolute !important;
  top:             50% !important;
  width:           28px !important;
  height:          28px !important;
  border-radius:   50% !important;
  border:          1px solid #E4E4E7 !important;
  background:      #FFFFFF !important;
  opacity:         1 !important;
  display:         flex !important;
  align-items:     center !important;
  justify-content: center !important;
  padding:         0 !important;
  cursor:          pointer !important;
  transition:      background 0.15s ease, border-color 0.15s ease !important;
}
/* Prev: izquierda · centrado verticalmente */
.ctp-thumbs-splide .splide__arrow--prev {
  left:      0 !important;
  right:     auto !important;
  transform: translateY(-50%) !important;
}
/* Next: derecha · centrado verticalmente */
.ctp-thumbs-splide .splide__arrow--next {
  right:     0 !important;
  left:      auto !important;
  transform: translateY(-50%) !important;
}
/* SVG: prev apunta izquierda, next apunta derecha */
.ctp-thumbs-splide .splide__arrow svg {
  fill:   #52525B !important;
  width:  12px !important;
  height: 12px !important;
}
.ctp-thumbs-splide .splide__arrow--prev svg {
  transform: scaleX(-1) !important; /* voltear para apuntar ← */
}
.ctp-thumbs-splide .splide__arrow--next svg {
  transform: scaleX(1) !important;  /* dirección natural → */
}
.ctp-thumbs-splide .splide__arrow:hover {
  background:   #F4F4F5 !important;
  border-color: #A1A1AA !important;
}
.ctp-thumbs-splide .splide__arrow:disabled {
  opacity:        0.3 !important;
  cursor:         default !important;
  pointer-events: none !important;
}

/* ── Detalles ─────────────────────────────────────────────────── */
.ctp-product__details { display: flex; flex-direction: column; min-width: 0; width: 100%; }

.ctp-product__cat {
  display:         inline-block;
  font-family:     'Inter', sans-serif;
  font-size:       0.6875rem;
  font-weight:     600;
  color:           #10B981;
  text-transform:  uppercase;
  letter-spacing:  0.06em;
  text-decoration: none;
  margin-bottom:   0.5rem;
  transition:      color 0.15s ease;
}
.ctp-product__cat:hover { color: #059669; }

.ctp-product__title {
  font-family:    'Inter', sans-serif;
  font-size:      clamp(1.5rem, 2.8vw, 2.125rem);
  font-weight:    600;
  color:          #18181B;
  letter-spacing: -0.025em;
  line-height:    1.2;
  margin:         0 0 0.875rem;
}

/* Stock */
.ctp-product__stock {
  display:     flex;
  align-items: center;
  gap:         0.375rem;
  font-family: 'Inter', sans-serif;
  font-size:   0.8125rem;
  font-weight: 500;
  margin-bottom: 1.125rem;
}
.ctp-product__stock--instock    { color: #10B981; }
.ctp-product__stock--outofstock { color: #EF4444; }
.ctp-product__stock--onbackorder { color: #F59E0B; }

/* Precio */
.ctp-product__price-wrap { margin-bottom: 1.125rem; }
.ctp-product__price {
  font-family:    'Inter', sans-serif;
  font-size:      2rem;
  font-weight:    700;
  color:          #18181B;
  letter-spacing: -0.03em;
  line-height:    1;
}
.ctp-product__price .woocommerce-Price-amount {
  font-size:   inherit;
  font-weight: inherit;
  color:       inherit;
}
.ctp-product__price ins  { text-decoration: none; }
.ctp-product__price del  { opacity: 0.4; font-size: 1.25rem; margin-right: 0.5rem; font-weight: 500; }
.ctp-product__price-note {
  font-family:  'Inter', sans-serif;
  font-size:    0.75rem;
  color:        #A1A1AA;
  margin:       0.375rem 0 0;
}

/* Descripción corta */
.ctp-product__short-desc {
  font-family:   'Inter', sans-serif;
  font-size:     0.9375rem;
  color:         #71717A;
  line-height:   1.65;
  margin-bottom: 1.25rem;
}
.ctp-product__short-desc p { margin: 0; }

/* Divisor */
.ctp-product__divider {
  height:        1px;
  background:    #E4E4E7;
  margin-bottom: 1.375rem;
}

/* ── Formulario WooCommerce ───────────────────────────────────── */
.ctp-product__form { margin-bottom: 1.5rem; }

/* Ocultar tabla nativa de variaciones (la reemplaza el JS con pills) */
.ctp-product__form table.variations { display: none !important; }

/* Ocultar info de variación individual y shipping */
.ctp-product__form .woocommerce-variation-description  { display: none; }
.ctp-product__form .woocommerce-variation-availability { display: none; }
.ctp-product__form .woocommerce-variation-price        { display: none; }
.ctp-product__form .shipping-calculator-button         { display: none; }
.ctp-product__form .woocommerce-shipping-calculator    { display: none; }
.ctp-product__form p.stock                             { display: none; }

/* Variation pills (creados por JS) */
.ctp-variation-group { margin-bottom: 1.125rem; }
.ctp-variation-group__label {
  font-family:   'Inter', sans-serif;
  font-size:     0.8125rem;
  font-weight:   600;
  color:         #18181B;
  margin-bottom: 0.625rem;
}
.ctp-variation-pills {
  display:   flex;
  flex-wrap: wrap;
  gap:       0.5rem;
}
.ctp-variation-pill {
  font-family:  'Inter', sans-serif;
  font-size:    0.875rem;
  font-weight:  500;
  color:        #52525B;
  background:   #FFFFFF;
  border:       1px solid #E4E4E7;
  border-radius: 9999px;
  padding:      0.5rem 1.125rem;
  cursor:       pointer;
  transition:   all 0.15s ease;
  line-height:  1;
}
.ctp-variation-pill:hover:not(:disabled) {
  border-color: #A1A1AA;
  color:        #18181B;
}
.ctp-variation-pill.is-selected {
  border-color: #18181B;
  color:        #18181B;
  background:   #F4F4F5;
  font-weight:  600;
  box-shadow:   0 0 0 1px #18181B;
}
.ctp-variation-pill:disabled {
  opacity:         0.4;
  cursor:          not-allowed;
  text-decoration: line-through;
}

/* Reset variaciones */
.ctp-product__form .reset_variations {
  display:         inline-flex;
  font-family:     'Inter', sans-serif;
  font-size:       0.75rem;
  color:           #A1A1AA;
  text-decoration: none;
  margin-top:      0.5rem;
  gap:             0.25rem;
  transition:      color 0.15s ease;
}
.ctp-product__form .reset_variations:hover { color: #18181B; }

/* Layout del single_variation_wrap y form.cart */
.ctp-product__form .woocommerce-variation-add-to-cart,
.ctp-product__form form.cart:not(.variations_form) {
  display:     flex;
  gap:         0.75rem;
  align-items: center;
  flex-wrap:   wrap;
  margin-top:  0;
}

/* Ocultar el input qty nativo (lo reemplaza el JS) */
.ctp-product__form .quantity { position: relative; }
.ctp-product__form input.qty { display: none; }

/* UI de cantidad personalizada (inyectada por JS) */
.ctp-qty-wrap {
  display:       flex;
  align-items:   center;
  border:        1px solid #E4E4E7;
  border-radius: 9999px;
  height:        3.25rem;
  background:    #FFFFFF;
  padding:       0 0.375rem;
  gap:           0;
  flex-shrink:   0;
}
.ctp-qty-wrap__btn {
  width:           2.5rem;
  height:          2.5rem;
  border-radius:   50%;
  border:          none;
  background:      transparent;
  color:           #52525B;
  font-size:       1.125rem;
  font-weight:     500;
  line-height:     1;
  cursor:          pointer;
  display:         flex;
  align-items:     center;
  justify-content: center;
  transition:      background 0.15s ease, color 0.15s ease;
  flex-shrink:     0;
}
.ctp-qty-wrap__btn:hover { background: #F4F4F5; color: #18181B; }
.ctp-qty-wrap__val {
  font-family: 'Inter', sans-serif;
  font-size:   0.875rem;
  font-weight: 700;
  color:       #18181B;
  min-width:   2rem;
  text-align:  center;
}

/* Botón add to cart */
.ctp-product__form .single_add_to_cart_button,
.ctp-product__form button[name="add-to-cart"] {
  font-family:     'Inter', sans-serif !important;
  font-size:       0.9375rem !important;
  font-weight:     600 !important;
  color:           #FFFFFF !important;
  background:      #18181B !important;
  border:          none !important;
  border-radius:   9999px !important;
  padding:         0 1.75rem !important;
  height:          3.25rem !important;
  cursor:          pointer !important;
  display:         flex !important;
  align-items:     center !important;
  justify-content: center !important;
  gap:             0.5rem !important;
  flex:            1 !important;
  min-width:       0 !important;
  transition:      background 0.15s ease, box-shadow 0.15s ease !important;
  box-shadow:      0 8px 30px rgba(0, 0, 0, 0.12) !important;
  text-decoration: none !important;
  line-height:     1 !important;
}
.ctp-product__form .single_add_to_cart_button:hover,
.ctp-product__form button[name="add-to-cart"]:hover {
  background:  #27272A !important;
  color:       #FFFFFF !important;
  box-shadow:  0 8px 30px rgba(0, 0, 0, 0.18) !important;
}
.ctp-product__form .single_add_to_cart_button.loading,
.ctp-product__form .single_add_to_cart_button[disabled] {
  opacity:        0.6 !important;
  pointer-events: none !important;
  box-shadow:     none !important;
}
.ctp-product__form .single_add_to_cart_button.added {
  background: #10B981 !important;
  box-shadow: 0 8px 30px rgba(16, 185, 129, 0.25) !important;
}

/* Read more / View product (para productos sin stock o externos) */
.ctp-product__form .product_type_external.button,
.ctp-product__form a.button {
  font-family:     'Inter', sans-serif !important;
  font-size:       0.9375rem !important;
  font-weight:     600 !important;
  color:           #FFFFFF !important;
  background:      #18181B !important;
  border:          none !important;
  border-radius:   9999px !important;
  padding:         0.875rem 1.75rem !important;
  cursor:          pointer !important;
  text-decoration: none !important;
  display:         inline-flex !important;
  align-items:     center !important;
}

/* ── Highlights ───────────────────────────────────────────────── */
.ctp-product__features {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   0.75rem;
  margin-top:            0.25rem;
}
.ctp-product__feature {
  display:     flex;
  align-items: flex-start;
  gap:         0.75rem;
  background:  #FFFFFF;
  border:      1px solid #F4F4F5;
  border-radius: 12px;
  padding:     0.875rem;
}
.ctp-product__feature iconify-icon { color: #10B981; flex-shrink: 0; margin-top: 1px; }
.ctp-product__feature-title {
  font-family: 'Inter', sans-serif;
  font-size:   0.8125rem;
  font-weight: 600;
  color:       #18181B;
  margin:      0;
}
.ctp-product__feature-sub {
  font-family: 'Inter', sans-serif;
  font-size:   0.6875rem;
  color:       #A1A1AA;
  margin:      0.125rem 0 0;
}

/* ── Sección Info: Descripción + Specs ────────────────────────── */
.ctp-product__info {
  background:  #FFFFFF;
  border-top:  1px solid #E4E4E7;
  padding:     4rem 0;
}
.ctp-product__info-grid {
  display:               grid;
  grid-template-columns: 1fr;
  gap:                   3rem;
}
@media (min-width: 1024px) {
  .ctp-product__info-grid {
    grid-template-columns: 7fr 5fr;
    gap:                   4rem;
    align-items:           start;
  }
}

/* Descripción larga */
.ctp-product__info-title {
  font-family:    'Inter', sans-serif;
  font-size:      1.375rem;
  font-weight:    600;
  color:          #18181B;
  letter-spacing: -0.02em;
  margin:         0 0 1.5rem;
}
.ctp-product__description-body {
  font-family: 'Inter', sans-serif;
  font-size:   0.9375rem;
  color:       #52525B;
  line-height: 1.75;
}
.ctp-product__description-body p             { margin: 0 0 1rem; }
.ctp-product__description-body p:last-child  { margin-bottom: 0; }
.ctp-product__description-body h2,
.ctp-product__description-body h3 {
  font-size:      1.0625rem;
  font-weight:    600;
  color:          #18181B;
  letter-spacing: -0.015em;
  margin:         1.75rem 0 0.75rem;
}
.ctp-product__description-body ul {
  list-style: none;
  padding:    0;
  margin:     0.75rem 0;
  display:    flex;
  flex-direction: column;
  gap:        0.5rem;
}
.ctp-product__description-body ul li {
  display:     flex;
  align-items: flex-start;
  gap:         0.5rem;
  padding-left: 1.125rem;
  position:    relative;
}
.ctp-product__description-body ul li::before {
  content:       '';
  width:         5px;
  height:        5px;
  background:    #10B981;
  border-radius: 50%;
  position:      absolute;
  left:          0;
  top:           0.55rem;
  flex-shrink:   0;
}
.ctp-product__description-body strong { color: #18181B; font-weight: 600; }

/* Specs box */
.ctp-product__specs-wrap { display: flex; flex-direction: column; gap: 1rem; }
.ctp-product__specs {
  background:    #F8F9FA;
  border:        1px solid #E4E4E7;
  border-radius: 16px;
  padding:       1.5rem;
}
.ctp-product__specs-title {
  font-family:    'Inter', sans-serif;
  font-size:      1rem;
  font-weight:    600;
  color:          #18181B;
  letter-spacing: -0.015em;
  margin:         0 0 1.25rem;
}
.ctp-product__specs-list {
  display:        flex;
  flex-direction: column;
  margin:         0;
}
.ctp-product__spec-row {
  display:         flex;
  justify-content: space-between;
  align-items:     baseline;
  gap:             1rem;
  padding:         0.75rem 0;
  border-bottom:   1px solid #E4E4E7;
  font-family:     'Inter', sans-serif;
  font-size:       0.8125rem;
}
.ctp-product__spec-row:last-child { border-bottom: none; padding-bottom: 0; }
.ctp-product__spec-row dt { color: #71717A; flex-shrink: 0; }
.ctp-product__spec-row dd { font-weight: 600; color: #18181B; margin: 0; text-align: right; }

/* PDF button */
.ctp-product__pdf-btn {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             0.5rem;
  width:           100%;
  padding:         0.75rem 1.25rem;
  border-radius:   9999px;
  border:          1px solid #E4E4E7;
  background:      #FFFFFF;
  font-family:     'Inter', sans-serif;
  font-size:       0.875rem;
  font-weight:     500;
  color:           #18181B;
  text-decoration: none;
  transition:      background 0.15s ease, border-color 0.15s ease;
  box-sizing:      border-box;
}
.ctp-product__pdf-btn:hover {
  background:   #F4F4F5;
  border-color: #A1A1AA;
  color:        #18181B;
}
