/* ============================================================
   IV TECH LATAM — WooCommerce Dark Theme Overrides
   Cubre: Shop, Producto, Carrito, Checkout, Mi Cuenta
   ============================================================ */

/* ── VARIABLES — IV Tech dark palette (hardcoded para evitar conflictos con Blocksy) */
:root {
  --ivt-bg:         #050e1f;
  --ivt-bg2:        #0a1a33;
  --ivt-bg3:        #0d2040;
  --ivt-accent:     #00d4ff;
  --ivt-accent-dim: rgba(0,212,255,.12);
  --ivt-text:       #f5f3ee;
  --ivt-text-m:     #c8c5be;
  --ivt-text-s:     #8a877e;
  --ivt-border:     rgba(0,212,255,.12);
  --ivt-radius:     12px;
  --ivt-shadow:     0 4px 24px rgba(0,0,0,.4);
  --ivt-shadow-h:   0 12px 48px rgba(0,212,255,.15);
}

/* ══════════════════════════════════════════════════════════
   BOTONES WOOCOMMERCE
══════════════════════════════════════════════════════════ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button.alt,
.woocommerce a.button.alt {
  background: var(--ivt-accent) !important;
  color: var(--ivt-bg) !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  padding: 11px 20px !important;
  letter-spacing: .02em !important;
  border: none !important;
  transition: background .2s, transform .15s, box-shadow .2s !important;
  box-shadow: none !important;
  text-transform: none !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .button.alt:hover {
  background: #00a8cc !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(0,212,255,.2) !important;
  color: var(--ivt-bg) !important;
}

/* ══════════════════════════════════════════════════════════
   SHOP — GRID DE PRODUCTOS
══════════════════════════════════════════════════════════ */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  margin: 0 !important;
  list-style: none !important;
  padding: 0 !important;
}

@media (max-width: 900px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
}
@media (max-width: 576px) {
  .woocommerce ul.products { grid-template-columns: 1fr !important; gap: 14px !important; }
}

/* Imagen del producto */




/* Imagen wrapper */


/* Título del producto */


/* Precio */






/* Botón agregar al carrito */


/* Badge Oferta */
.woocommerce span.onsale {
  background: #ef4444 !important;
  color: #fff !important;
  border-radius: 6px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  padding: 3px 10px !important;
  top: 12px !important;
  left: 12px !important;
  min-height: unset !important;
  min-width: unset !important;
  line-height: 1.6 !important;
  border: none !important;
}

/* Breadcrumbs */
.woocommerce-breadcrumb,
.ivt-breadcrumb {
  font-size: 13px !important;
  color: var(--ivt-text-s) !important;
  background: transparent !important;
  padding: 16px 0 !important;
  margin: 0 !important;
}

.woocommerce-breadcrumb a,
.ivt-breadcrumb a {
  color: var(--ivt-text-m) !important;
}

.woocommerce-breadcrumb a:hover,
.ivt-breadcrumb a:hover {
  color: var(--ivt-accent) !important;
}

/* ══════════════════════════════════════════════════════════
   PÁGINA DE PRODUCTO INDIVIDUAL
══════════════════════════════════════════════════════════ */
.woocommerce div.product {
  background: var(--ivt-bg) !important;
}

.woocommerce div.product .woocommerce-product-gallery {
  border: 1px solid var(--ivt-border);
  border-radius: var(--ivt-radius);
  overflow: hidden;
  background: var(--ivt-bg2);
}

.woocommerce div.product .woocommerce-product-gallery img {
  background: var(--ivt-bg2);
}

.woocommerce div.product .summary .product_title {
  font-size: clamp(1.5rem, 3vw, 2rem) !important;
  font-weight: 800 !important;
  color: var(--ivt-text) !important;
  line-height: 1.2 !important;
  margin-bottom: 12px !important;
}

.woocommerce div.product .summary .price {
  font-size: 2rem !important;
  font-weight: 800 !important;
  color: var(--ivt-accent) !important;
  margin-bottom: 16px !important;
}

.woocommerce div.product .summary .woocommerce-product-details__short-description {
  color: var(--ivt-text-m) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  margin-bottom: 24px !important;
  border-top: 1px solid var(--ivt-border) !important;
  padding-top: 20px !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
  font-size: 15px !important;
  padding: 14px 32px !important;
  width: 100% !important;
  border-radius: 10px !important;
}

/* Stock */
.woocommerce div.product .stock {
  color: #10b981 !important;
  font-weight: 600 !important;
  font-size: 13px !important;
}

.woocommerce div.product .out-of-stock {
  color: #ef4444 !important;
}

/* Tabs del producto */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 48px !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  background: transparent !important;
  border-bottom: 1px solid var(--ivt-border) !important;
  padding: 0 !important;
  margin: 0 0 32px !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent !important;
  border: none !important;
  margin: 0 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: var(--ivt-text-s) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 12px 20px !important;
  border-bottom: 2px solid transparent !important;
  transition: color .2s, border-color .2s !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--ivt-accent) !important;
  border-bottom-color: var(--ivt-accent) !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
  color: var(--ivt-text-m) !important;
  line-height: 1.7 !important;
}

/* Productos relacionados */
.related.products h2,
.upsells.products h2 {
  color: var(--ivt-text) !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  margin-bottom: 24px !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid var(--ivt-border) !important;
}

/* ══════════════════════════════════════════════════════════
   CARRITO
══════════════════════════════════════════════════════════ */
.woocommerce-cart table.cart {
  background: transparent !important;
  border: none !important;
}

.woocommerce-cart table.cart td,
.woocommerce-cart table.cart th {
  border: none !important;
  border-bottom: 1px solid var(--ivt-border) !important;
  padding: 16px 12px !important;
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
  vertical-align: middle !important;
}

.woocommerce-cart table.cart thead th {
  color: var(--ivt-text-s) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  background: var(--ivt-bg3) !important;
}

.woocommerce-cart .cart_totals {
  background: var(--ivt-bg2) !important;
  border: 1px solid var(--ivt-border) !important;
  border-radius: var(--ivt-radius) !important;
  padding: 24px !important;
}

.woocommerce-cart .cart_totals h2 {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--ivt-text) !important;
  margin-bottom: 20px !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid var(--ivt-border) !important;
}

.woocommerce-cart .cart_totals table {
  background: transparent !important;
  border: none !important;
}

.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  border: none !important;
  border-bottom: 1px solid var(--ivt-border-s, rgba(255,255,255,.06)) !important;
  padding: 12px 0 !important;
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
}

.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
  color: var(--ivt-text) !important;
  font-weight: 700 !important;
  font-size: 18px !important;
}

.woocommerce .wc-proceed-to-checkout a.checkout-button {
  font-size: 15px !important;
  padding: 14px !important;
  border-radius: 10px !important;
  width: 100% !important;
}

/* Cupón */
.woocommerce-cart .coupon input[type="text"] {
  background: var(--ivt-bg3) !important;
  border: 1.5px solid var(--ivt-border) !important;
  color: var(--ivt-text) !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-size: 13px !important;
}

/* ══════════════════════════════════════════════════════════
   CHECKOUT
══════════════════════════════════════════════════════════ */
.woocommerce-checkout {
  background: var(--ivt-bg) !important;
}

.woocommerce-checkout h3,
.woocommerce-checkout legend {
  color: var(--ivt-text) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  margin-bottom: 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--ivt-border) !important;
}

/* Campos del formulario */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--ivt-bg3) !important;
  border: 1.5px solid var(--ivt-border) !important;
  color: var(--ivt-text) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  transition: border-color .2s !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--ivt-accent) !important;
  box-shadow: 0 0 0 3px rgba(0,212,255,.15) !important;
  outline: none !important;
}

.woocommerce form .form-row label {
  color: var(--ivt-text-m) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}

.woocommerce form .form-row .required { color: var(--ivt-accent) !important; }

/* Order review en checkout */
.woocommerce-checkout #order_review {
  background: var(--ivt-bg2) !important;
  border: 1px solid var(--ivt-border) !important;
  border-radius: var(--ivt-radius) !important;
  padding: 28px !important;
}

.woocommerce-checkout #order_review table {
  background: transparent !important;
  border: none !important;
}

.woocommerce-checkout #order_review table th,
.woocommerce-checkout #order_review table td {
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,.05) !important;
  padding: 12px 0 !important;
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
}

.woocommerce-checkout #order_review .order-total th,
.woocommerce-checkout #order_review .order-total td {
  color: var(--ivt-text) !important;
  font-weight: 800 !important;
  font-size: 20px !important;
}

#place_order {
  width: 100% !important;
  font-size: 15px !important;
  padding: 16px !important;
  border-radius: 10px !important;
  margin-top: 24px !important;
}

/* Métodos de pago */
.woocommerce-checkout #payment {
  background: var(--ivt-bg2) !important;
  border: 1px solid var(--ivt-border) !important;
  border-radius: var(--ivt-radius) !important;
}

.woocommerce-checkout #payment ul.payment_methods {
  border-bottom: 1px solid var(--ivt-border) !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
  color: var(--ivt-text-m) !important;
  border-bottom: 1px solid var(--ivt-border-s, rgba(255,255,255,.06)) !important;
}

.woocommerce-checkout #payment ul.payment_methods li label {
  color: var(--ivt-text) !important;
}

.woocommerce-checkout #payment div.payment_box {
  background: var(--ivt-bg3) !important;
  color: var(--ivt-text-m) !important;
  border-top: 1px solid var(--ivt-border) !important;
}

/* ══════════════════════════════════════════════════════════
   MI CUENTA
══════════════════════════════════════════════════════════ */
.woocommerce-account .woocommerce-MyAccount-navigation {
  background: var(--ivt-bg2) !important;
  border: 1px solid var(--ivt-border) !important;
  border-radius: var(--ivt-radius) !important;
  padding: 8px !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 10px 14px !important;
  display: block !important;
  border-radius: 8px !important;
  transition: all .15s !important;
  text-decoration: none !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--ivt-accent) !important;
  color: var(--ivt-bg) !important;
}

.woocommerce-account .woocommerce-MyAccount-content {
  color: var(--ivt-text-m) !important;
}

.woocommerce-account .woocommerce-MyAccount-content table {
  background: transparent !important;
  border: 1px solid var(--ivt-border) !important;
  border-radius: var(--ivt-radius) !important;
  overflow: hidden !important;
}

.woocommerce-account .woocommerce-MyAccount-content table th {
  background: var(--ivt-bg3) !important;
  color: var(--ivt-text-s) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  padding: 12px 16px !important;
  border: none !important;
}

.woocommerce-account .woocommerce-MyAccount-content table td {
  padding: 14px 16px !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,.04) !important;
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
}

/* ══════════════════════════════════════════════════════════
   MENSAJES / NOTICES
══════════════════════════════════════════════════════════ */
.woocommerce-message {
  background: rgba(0,212,255,.08) !important;
  border-top-color: var(--ivt-accent) !important;
  color: var(--ivt-text) !important;
}

.woocommerce-info {
  background: rgba(59,130,246,.08) !important;
  border-top-color: #3b82f6 !important;
  color: var(--ivt-text-m) !important;
}

.woocommerce-error {
  background: rgba(239,68,68,.08) !important;
  border-top-color: #ef4444 !important;
  color: var(--ivt-text) !important;
}

/* ══════════════════════════════════════════════════════════
   RATINGS
══════════════════════════════════════════════════════════ */
.woocommerce .star-rating span,
.woocommerce .star-rating::before {
  color: #fbbf24 !important;
}

/* ══════════════════════════════════════════════════════════
   CATEGORÍAS EN SHOP
══════════════════════════════════════════════════════════ */
.woocommerce ul.products li.product-category {
  background: var(--ivt-bg2) !important;
  border-color: var(--ivt-border) !important;
}



.woocommerce ul.products li.product-category h2 {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--ivt-text) !important;
}

.woocommerce ul.products li.product-category h2 mark {
  background: transparent !important;
  color: var(--ivt-text-s) !important;
  font-size: 13px !important;
}

/* ══════════════════════════════════════════════════════════
   FILTROS Y WIDGETS DE SIDEBAR
══════════════════════════════════════════════════════════ */
.widget_product_categories ul,
.widget_layered_nav ul {
  list-style: none !important;
  padding: 0 !important;
}

.widget_product_categories ul li a,
.widget_layered_nav ul li a {
  color: var(--ivt-text-m) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  transition: color .15s !important;
}

.widget_product_categories ul li a:hover,
.widget_layered_nav ul li a:hover {
  color: var(--ivt-accent) !important;
}

.widget_product_categories ul li.current-cat > a {
  color: var(--ivt-accent) !important;
  font-weight: 700 !important;
}

/* Price filter slider */
.woocommerce .price_slider_wrapper .ui-slider {
  background: var(--ivt-bg3) !important;
}

.woocommerce .price_slider_wrapper .ui-slider .ui-slider-range {
  background: var(--ivt-accent) !important;
}

.woocommerce .price_slider_wrapper .ui-slider .ui-slider-handle {
  background: var(--ivt-accent) !important;
  border-color: var(--ivt-accent) !important;
}

.woocommerce .price_slider_amount .button {
  background: transparent !important;
  color: var(--ivt-accent) !important;
  border: 1px solid var(--ivt-border) !important;
  font-size: 12px !important;
  padding: 6px 14px !important;
}

/* ══════════════════════════════════════════════════════════
   MOBILE WOOCOMMERCE
══════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
  .woocommerce div.product .summary .product_title { font-size: 1.4rem !important; }
  .woocommerce div.product .summary .price { font-size: 1.5rem !important; }
  .woocommerce-cart table.cart td,
  .woocommerce-cart table.cart th { padding: 10px 6px !important; font-size: 12px !important; }
  .woocommerce form.checkout { padding: 0 !important; }
  .woocommerce-checkout #order_review { padding: 16px !important; }
  .woocommerce-account .woocommerce-MyAccount-navigation { margin-bottom: 24px !important; }
}

/* ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
   DARK BACKGROUND â TODAS LAS PÃGINAS WOO
   (body no recibe ivt-dark-mode en WC, asÃ­ que lo forzamos aquÃ­)
ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ */
body.woocommerce,
body.woocommerce-page,
body.single-product,
body.tax-product_cat,
body.archive.woocommerce {
  background-color: #050e1f !important;
  color: #f5f3ee !important;
}

/* Blocksy/WordPress content wrappers */
body.woocommerce .site,
body.woocommerce-page .site,
body.single-product .site,
body.woocommerce #page,
body.woocommerce-page #page,
body.single-product #page,
body.woocommerce main,
body.woocommerce-page main,
body.single-product main,
body.woocommerce .site-content,
body.woocommerce-page .site-content,
body.single-product .site-content,
body.woocommerce .ct-container,
body.woocommerce-page .ct-container,
body.single-product .ct-container,
body.woocommerce .ct-main-container,
body.woocommerce-page .ct-main-container,
body.single-product .ct-main-container,
body.woocommerce .entry-content,
body.woocommerce-page .entry-content,
body.single-product .entry-content {
  background-color: #050e1f !important;
}

/* Headings */
body.woocommerce h1, body.woocommerce h2, body.woocommerce h3, body.woocommerce h4,
body.woocommerce-page h1, body.woocommerce-page h2, body.woocommerce-page h3,
body.single-product h1, body.single-product h2, body.single-product h3 {
  color: #f5f3ee !important;
}

/* Shop page title */
body.woocommerce .page-title,
body.woocommerce-page .page-title,
body.woocommerce .entry-title,
body.woocommerce-page .entry-title {
  color: #f5f3ee !important;
}

/* TÃ­tulo del producto (clase exacta de WooCommerce) */


/* BotÃ³n AÃ±adir al carrito â forzar estilo CTA */




/* Selector de orden */
.woocommerce-ordering select,
.woocommerce form.woocommerce-ordering select {
  background: #0a1a33 !important;
  color: #f5f3ee !important;
  border: 1px solid rgba(0,212,255,.15) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
}

/* Contador de resultados */
.woocommerce-result-count {
  color: #8a877e !important;
}

/* ââ PRODUCTO INDIVIDUAL â TEXTO ââ */
.woocommerce div.product .product_title,
.woocommerce div.product h1.product_title {
  color: #f5f3ee !important;
}

.woocommerce div.product p,
.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce div.product .woocommerce-product-details__short-description p {
  color: #c8c5be !important;
}

/* Tabla de atributos/especificaciones */
.woocommerce div.product .woocommerce-product-attributes {
  background: transparent !important;
  border-collapse: collapse !important;
  border: 1px solid rgba(0,212,255,.12) !important;
  border-radius: 8px !important;
  width: 100% !important;
}

.woocommerce div.product .woocommerce-product-attributes th {
  background: #0a1a33 !important;
  color: #8a877e !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  border: none !important;
  border-bottom: 1px solid rgba(0,212,255,.08) !important;
  padding: 12px 16px !important;
  white-space: nowrap !important;
}

.woocommerce div.product .woocommerce-product-attributes td {
  background: transparent !important;
  color: #c8c5be !important;
  border: none !important;
  border-bottom: 1px solid rgba(0,212,255,.08) !important;
  padding: 12px 16px !important;
}

/* Quantity input */
.woocommerce div.product form.cart .quantity input {
  background: #0a1a33 !important;
  color: #f5f3ee !important;
  border: 1.5px solid rgba(0,212,255,.15) !important;
  border-radius: 8px !important;
  font-size: 15px !important;
  text-align: center !important;
}

/* Breadcrumb */
.woocommerce-breadcrumb,
.ivt-breadcrumb,
body.woocommerce nav.woocommerce-breadcrumb {
  color: #8a877e !important;
  background: transparent !important;
}

.woocommerce-breadcrumb a,
.ivt-breadcrumb a {
  color: #c8c5be !important;
}

.woocommerce-breadcrumb a:hover,
.ivt-breadcrumb a:hover {
  color: #00d4ff !important;
}
