/* ==========================================================================
   MIMMA TELECOM - woocommerce.css  v1.2.0
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. RESET FLOTANTES DE WC (causa #1 de grid roto)
   -------------------------------------------------------------------------- */
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; content: none !important; }
.woocommerce ul.products li.product { float: none !important; clear: none !important; }

/* --------------------------------------------------------------------------
   2. FONDO — aplasta cualquier herencia del tema anterior
   -------------------------------------------------------------------------- */
body.woocommerce,
body.woocommerce-page,
body.post-type-archive-product,
body.tax-product_cat,
body.single-product,
body.woocommerce-cart,
body.woocommerce-checkout {
  background: var(--navy) !important;
  background-image: none !important;
}
/* Eliminar el fondo con "MIMMA" gigante del tema anterior */
body.woocommerce::before,
body.woocommerce-page::before,
body.post-type-archive-product::before,
body.tax-product_cat::before { display: none !important; }

/* --------------------------------------------------------------------------
   3. WOO PAGE LAYOUT
   -------------------------------------------------------------------------- */
.woo-page {
  min-height: 100vh;
  padding-top: var(--nav-h);
  background: var(--navy);
}
.woo-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 40px 5vw 80px;
}

/* --------------------------------------------------------------------------
   4. CABECERA TIENDA — titulo + busqueda + filtros + orden
   -------------------------------------------------------------------------- */
.shop-header {
  margin-bottom: 40px;
}
.shop-header-top {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.shop-title {
  font-family: 'Syne', sans-serif !important;
  font-size: clamp(1.8rem, 4vw, 2.4rem) !important;
  font-weight: 800 !important;
  color: var(--white) !important;
  margin: 0 !important;
  line-height: 1.1 !important;
}
.shop-count {
  color: var(--gray);
  font-size: .84rem;
}

/* Barra de busqueda */
.shop-search-bar { margin-bottom: 20px; }
.shop-search-form {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--card-border);
  border-radius: 50px;
  overflow: hidden;
  transition: border-color .2s;
  max-width: 560px;
}
.shop-search-form:focus-within { border-color: var(--cyan); }
.shop-search-icon {
  padding: 0 14px;
  color: var(--gray);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.shop-search-input {
  flex: 1;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  color: var(--white) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .95rem !important;
  padding: 12px 0 !important;
}
.shop-search-input::placeholder { color: var(--gray) !important; }
.shop-search-btn {
  background: var(--cyan);
  color: var(--navy);
  border: none;
  padding: 12px 22px;
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: .85rem;
  cursor: pointer;
  transition: background .2s;
  flex-shrink: 0;
}
.shop-search-btn:hover { background: var(--cyan2); }

/* Filtro categorias */
.shop-cat-filter {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 50px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--card-border);
  color: var(--gray);
  font-size: .82rem;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s, border-color .2s, color .2s;
  white-space: nowrap;
}
.cat-pill:hover { border-color: rgba(0,195,255,0.4); color: var(--white); }
.cat-pill.active { background: rgba(0,195,255,0.12); border-color: var(--cyan); color: var(--cyan); }
.cat-count {
  background: rgba(255,255,255,0.1);
  border-radius: 50px;
  padding: 1px 7px;
  font-size: .72rem;
}
.cat-pill.active .cat-count { background: rgba(0,195,255,0.2); }

/* Ordenar */
.shop-sort-bar { display: flex; justify-content: flex-end; }
.shop-sort-bar .woocommerce-ordering { margin: 0; }
.woocommerce-ordering select {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid var(--card-border) !important;
  color: var(--white) !important;
  border-radius: 8px !important;
  padding: 8px 14px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: .86rem !important;
  outline: none !important;
  cursor: pointer;
}

/* Ocultar el breadcrumb nativo de WC (usamos los category pills) */
.woocommerce-breadcrumb { display: none !important; }
/* Ocultar resultado count nativo (lo mostramos en shop-count) */
.woo-wrap > .woocommerce-result-count { display: none; }
.shop-products .woocommerce-result-count { display: none; }

/* --------------------------------------------------------------------------
   5. PRODUCTOS DESTACADOS MIMMA
   -------------------------------------------------------------------------- */
.mimma-featured-section {
  margin-bottom: 48px;
  padding: 32px;
  background: linear-gradient(135deg, rgba(0,195,255,0.05), rgba(30,109,200,0.07));
  border: 1px solid rgba(0,195,255,0.18);
  border-radius: var(--radius);
}
.mimma-featured-header {
  margin-bottom: 24px;
}
.section-title-sm {
  font-family: 'Syne', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--white);
  margin: 4px 0 0;
}
.mimma-featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}
.mimma-product-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(0,195,255,0.15);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .3s, border-color .3s;
}
.mimma-product-card:hover { transform: translateY(-4px); border-color: rgba(0,195,255,0.4); }
.mimma-product-img {
  position: relative;
  height: 160px;
  overflow: hidden;
  background: rgba(0,195,255,0.04);
}
.mimma-product-img .product-thumb { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.mimma-product-card:hover .product-thumb { transform: scale(1.05); }
.product-thumb-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.product-thumb-placeholder img { width: 80px; opacity: .5; }
.mimma-sale-badge { position: absolute; top: 10px; left: 10px; background: var(--cyan); color: var(--navy); font-size: .65rem; font-weight: 800; padding: 3px 9px; border-radius: 50px; text-transform: uppercase; letter-spacing: .05em; }
.mimma-product-info { padding: 16px; }
.mimma-product-info h3 { font-family: 'Syne',sans-serif; font-size: .95rem; font-weight: 700; margin-bottom: 8px; }
.mimma-product-info h3 a { color: var(--white); text-decoration: none; }
.mimma-product-info h3 a:hover { color: var(--cyan); }
.mimma-product-price { color: var(--cyan); font-family: 'Syne',sans-serif; font-weight: 800; font-size: 1.1rem; margin-bottom: 12px; }
.mimma-product-price del { color: var(--gray); font-weight: 400; font-size: .85rem; margin-right: 4px; }
.mimma-add-btn {
  display: block; text-align: center; width: 100%;
  background: rgba(0,195,255,0.1); border: 1px solid rgba(0,195,255,0.3);
  color: var(--cyan); font-family: 'Syne',sans-serif; font-weight: 700;
  font-size: .84rem; padding: 9px; border-radius: 8px; text-decoration: none;
  transition: background .2s; cursor: pointer;
}
.mimma-add-btn:hover { background: rgba(0,195,255,0.22); color: var(--cyan); }

/* Divisor entre featured y todos */
.shop-divider {
  display: flex; align-items: center; gap: 16px;
  margin: 32px 0 28px; color: var(--gray); font-size: .84rem;
}
.shop-divider::before, .shop-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--card-border);
}

/* --------------------------------------------------------------------------
   6. LAYOUT CON SIDEBAR
   -------------------------------------------------------------------------- */
.shop-content-wrap {
  display: flex;
  gap: 32px;
  align-items: flex-start;
}
.shop-sidebar {
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: calc(var(--nav-h) + 20px);
}
.shop-products.full-width { flex: 1; min-width: 0; }
.shop-products.with-sidebar { flex: 1; min-width: 0; }

/* --------------------------------------------------------------------------
   7. SIDEBAR WIDGETS (compatibilidad con plugins de filtros)
   -------------------------------------------------------------------------- */
.woo-widget {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: 20px;
  margin-bottom: 20px;
}
.woo-widget-title {
  font-family: 'Syne', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--card-border);
}

/* -- Iconos de plugins sidebar (Dashicons, FontAwesome, etc.) -- */
.woo-widget .dashicons,
.woo-widget [class*="dashicons-"],
.woo-widget .fa, .woo-widget [class*="fa-"],
.woo-widget .woofc-icon,
.woo-widget .widget-icon,
.sidebar-icon { color: var(--cyan) !important; }

/* YITH / JetWooBuilder / WooCommerce Sidebar filters */
.woo-widget .widget_product_categories ul,
.woo-widget .wc-layered-nav-term ul,
.woo-widget ul.product-categories { list-style: none; padding: 0; margin: 0; }

.woo-widget .widget_product_categories li,
.woo-widget ul.product-categories li {
  border-bottom: 1px solid rgba(0,195,255,0.07);
  padding: 7px 0;
}
.woo-widget .widget_product_categories li:last-child,
.woo-widget ul.product-categories li:last-child { border: none; }

.woo-widget .widget_product_categories a,
.woo-widget ul.product-categories a { color: var(--gray); text-decoration: none; font-size: .88rem; transition: color .2s; display: flex; align-items: center; gap: 8px; }
.woo-widget .widget_product_categories a:hover,
.woo-widget ul.product-categories a:hover { color: var(--cyan); }
.woo-widget .widget_product_categories .count,
.woo-widget ul.product-categories .count { background: rgba(0,195,255,0.1); border-radius: 50px; padding: 1px 7px; font-size: .72rem; color: var(--gray); margin-left: auto; }

/* Price filter slider */
.woo-widget .price_slider_wrapper .ui-slider { background: rgba(255,255,255,0.1); height: 4px; border-radius: 4px; border: none; margin: 10px 0; }
.woo-widget .price_slider_wrapper .ui-slider-range { background: var(--cyan); height: 4px; border-radius: 4px; }
.woo-widget .price_slider_wrapper .ui-slider-handle { background: var(--cyan); border: 2px solid var(--navy); width: 16px; height: 16px; border-radius: 50%; top: -6px; margin-left: -8px; cursor: pointer; }
.woo-widget .price_slider_amount { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.woo-widget .price_slider_amount .button { background: rgba(0,195,255,0.1) !important; border: 1px solid rgba(0,195,255,0.3) !important; color: var(--cyan) !important; border-radius: 6px !important; padding: 6px 14px !important; font-size: .82rem !important; font-family: 'Syne',sans-serif !important; font-weight: 700 !important; box-shadow: none !important; cursor: pointer; }
.woo-widget .price_slider_amount .button:hover { background: rgba(0,195,255,0.2) !important; }
.woo-widget .price_slider_amount .price_label { color: var(--gray); font-size: .82rem; }

/* Rating filter */
.woo-widget .wc-layered-nav-rating a { color: var(--gray); text-decoration: none; font-size: .88rem; transition: color .2s; }
.woo-widget .wc-layered-nav-rating a:hover { color: var(--cyan); }

/* Search widget */
.woo-widget .widget_product_search form { display: flex; gap: 8px; }
.woo-widget .widget_product_search input[type="search"] { flex: 1; background: rgba(255,255,255,0.05) !important; border: 1px solid var(--card-border) !important; color: var(--white) !important; border-radius: 8px !important; padding: 9px 12px !important; outline: none !important; font-size: .88rem !important; }
.woo-widget .widget_product_search button { background: var(--cyan) !important; border: none !important; color: var(--navy) !important; border-radius: 8px !important; padding: 9px 14px !important; cursor: pointer !important; font-size: .88rem !important; }

/* --------------------------------------------------------------------------
   8. GRID DE PRODUCTOS (loop WC) — Tarjetas bonitas
   -------------------------------------------------------------------------- */
.woo-wrap ul.products,
.shop-products ul.products {
  display: grid !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 48px !important;
  gap: 22px !important;
}
/* 3 columnas default, 2 con sidebar */
.shop-products.full-width ul.products { grid-template-columns: repeat(3, 1fr) !important; }
.shop-products.with-sidebar ul.products { grid-template-columns: repeat(2, 1fr) !important; }
/* Fallback cuando woocommerce.php no aplica clases */
.woo-wrap > .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }

/* Tarjeta */
.woo-wrap ul.products li.product,
.shop-products ul.products li.product {
  float: none !important; clear: none !important;
  width: auto !important; margin: 0 !important;
  background: var(--card-bg) !important;
  border: 1px solid var(--card-border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease !important;
  position: relative !important;
}
.woo-wrap ul.products li.product:hover,
.shop-products ul.products li.product:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(0,195,255,0.45) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.3), 0 0 0 1px rgba(0,195,255,0.1) !important;
}

/* Borde superior cyan en hover */
.woo-wrap ul.products li.product::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity: 0; transition: opacity .3s; z-index: 1;
}
.woo-wrap ul.products li.product:hover::before { opacity: 1 !important; }

/* Imagen */
.woo-wrap ul.products li.product a.woocommerce-loop-product__link,
.shop-products ul.products li.product a.woocommerce-loop-product__link {
  display: block;
  overflow: hidden;
}
.woo-wrap ul.products li.product img,
.shop-products ul.products li.product img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform .4s ease !important;
}
.woo-wrap ul.products li.product:hover img { transform: scale(1.06) !important; }

/* Info: titulo + precio + boton */
.woo-wrap ul.products li.product .product-info-wrap,
.shop-products ul.products li.product .product-info-wrap { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; }

/* Titulo */
.woo-wrap ul.products li.product .woocommerce-loop-product__title,
.shop-products ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Syne', sans-serif !important;
  font-size: .98rem !important;
  font-weight: 700 !important;
  color: var(--white) !important;
  margin-bottom: 8px !important;
  line-height: 1.35 !important;
  padding: 16px 18px 0 !important;
}

/* Precio */
.woo-wrap ul.products li.product .price,
.shop-products ul.products li.product .price {
  color: var(--cyan) !important;
  font-family: 'Syne', sans-serif !important;
  font-weight: 800 !important;
  font-size: 1.1rem !important;
  display: block !important;
  padding: 4px 18px 12px !important;
  margin: 0 !important;
}
.woo-wrap ul.products li.product .price del,
.shop-products ul.products li.product .price del {
  color: var(--gray) !important;
  font-weight: 400 !important;
  font-size: .82rem !important;
  margin-right: 5px !important;
}

/* Boton agregar */
.woo-wrap ul.products li.product .button,
.shop-products ul.products li.product .button,
.woocommerce ul.products li.product .button {
  display: block !important;
  margin: auto 18px 18px !important;
  width: calc(100% - 36px) !important;
  text-align: center !important;
  background: rgba(0,195,255,0.1) !important;
  border: 1px solid rgba(0,195,255,0.28) !important;
  color: var(--cyan) !important;
  font-family: 'Syne', sans-serif !important;
  font-weight: 700 !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-size: .86rem !important;
  transition: background .2s !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.woo-wrap ul.products li.product .button:hover,
.shop-products ul.products li.product .button:hover {
  background: rgba(0,195,255,0.22) !important;
  transform: none !important;
  box-shadow: none !important;
}
.woo-wrap ul.products li.product .button.added,
.shop-products ul.products li.product .button.added { background: rgba(0,195,255,0.25) !important; border-color: var(--cyan) !important; }

/* Badge "En oferta" */
.woo-wrap .onsale, .shop-products .onsale {
  background: var(--cyan) !important; color: var(--navy) !important;
  font-family: 'Syne',sans-serif !important; font-weight: 800 !important;
  border-radius: 50px !important; padding: 3px 10px !important;
  font-size: .65rem !important; text-transform: uppercase !important;
  min-height: auto !important; min-width: auto !important;
  line-height: 1.4 !important;
}

/* Sin productos */
.woocommerce-info {
  background: rgba(0,195,255,0.07) !important;
  border: none !important;
  border-left: 3px solid var(--cyan) !important;
  color: var(--white) !important;
  padding: 16px 20px !important;
  border-radius: 0 8px 8px 0 !important;
  font-size: .95rem !important;
}
.woocommerce-info::before { display: none !important; }
.woocommerce-info a { color: var(--cyan) !important; }

/* --------------------------------------------------------------------------
   9. PRODUCTO INDIVIDUAL
   -------------------------------------------------------------------------- */
.woo-wrap div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 48px !important;
  align-items: start !important;
}
.woo-wrap div.product .woocommerce-product-gallery { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--card-border); }
.woo-wrap div.product h1.product_title { font-family: 'Syne',sans-serif !important; font-size: clamp(1.5rem,3vw,2rem) !important; font-weight: 800 !important; color: var(--white) !important; margin-bottom: 10px !important; }
.woo-wrap div.product p.price { color: var(--cyan) !important; font-size: 1.7rem !important; font-weight: 800 !important; font-family: 'Syne',sans-serif !important; margin-bottom: 18px !important; }
.woo-wrap div.product .woocommerce-product-details__short-description { color: var(--gray); line-height: 1.65; margin-bottom: 22px; }
.woo-wrap div.product .cart .qty { background: rgba(255,255,255,0.05) !important; border: 1px solid var(--card-border) !important; color: var(--white) !important; border-radius: 8px !important; padding: 10px !important; width: 72px !important; text-align: center !important; }
.woo-wrap div.product form.cart .button { background: linear-gradient(135deg, var(--cyan), var(--blue-mid)) !important; color: var(--navy) !important; font-family: 'Syne',sans-serif !important; font-weight: 700 !important; border-radius: 50px !important; border: none !important; padding: 13px 32px !important; box-shadow: 0 6px 24px rgba(0,195,255,0.22) !important; transition: transform .2s, box-shadow .2s !important; }
.woo-wrap div.product form.cart .button:hover { transform: translateY(-2px) !important; box-shadow: 0 10px 28px rgba(0,195,255,0.35) !important; }

/* Tabs */
.woo-wrap div.product .woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--card-border) !important; background: none !important; padding: 0 !important; margin-bottom: 0 !important; }
.woo-wrap div.product .woocommerce-tabs ul.tabs::before { border: none !important; }
.woo-wrap div.product .woocommerce-tabs ul.tabs li { background: none !important; border: none !important; margin: 0 !important; }
.woo-wrap div.product .woocommerce-tabs ul.tabs li a { color: var(--gray) !important; font-weight: 600 !important; padding: 12px 20px !important; }
.woo-wrap div.product .woocommerce-tabs ul.tabs li.active a { color: var(--cyan) !important; }
.woo-wrap div.product .woocommerce-tabs ul.tabs li.active { border-bottom: 2px solid var(--cyan) !important; margin-bottom: -1px !important; }
.woo-wrap div.product .woocommerce-tabs .panel { background: var(--card-bg) !important; border: 1px solid var(--card-border) !important; border-top: none !important; border-radius: 0 0 var(--radius) var(--radius) !important; padding: 24px !important; color: var(--gray) !important; }

/* Rating */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--cyan) !important; }

/* --------------------------------------------------------------------------
   10. CARRITO
   -------------------------------------------------------------------------- */
.woo-wrap table.shop_table { background: var(--card-bg) !important; border: 1px solid var(--card-border) !important; border-radius: var(--radius) !important; border-collapse: separate !important; border-spacing: 0 !important; overflow: hidden !important; width: 100% !important; }
.woo-wrap table.shop_table th { background: rgba(255,255,255,0.04) !important; color: var(--gray) !important; font-size: .76rem !important; text-transform: uppercase !important; letter-spacing: .07em !important; padding: 14px 18px !important; border-bottom: 1px solid var(--card-border) !important; font-family: 'Syne',sans-serif !important; font-weight: 700 !important; }
.woo-wrap table.shop_table td { padding: 16px 18px !important; border-bottom: 1px solid rgba(0,195,255,0.06) !important; color: var(--white) !important; vertical-align: middle !important; }
.woo-wrap table.shop_table td a { color: var(--white) !important; text-decoration: none !important; }
.woo-wrap table.shop_table td a:hover { color: var(--cyan) !important; }
.woo-wrap table.shop_table .product-thumbnail img { width: 64px !important; height: 64px !important; object-fit: cover !important; border-radius: 8px !important; }
.woo-wrap .cart_totals { background: var(--card-bg) !important; border: 1px solid var(--card-border) !important; border-radius: var(--radius) !important; padding: 28px !important; margin-top: 28px !important; }
.woo-wrap .cart_totals h2 { font-size: 1.2rem !important; margin-bottom: 18px !important; color: var(--white) !important; }
.woo-wrap .cart_totals table th, .woo-wrap .cart_totals table td { color: var(--white) !important; padding: 10px 0 !important; border-bottom: 1px solid rgba(0,195,255,0.07) !important; }
.woo-wrap .wc-proceed-to-checkout a, .woo-wrap .checkout-button {
  background: linear-gradient(135deg, var(--cyan), var(--blue-mid)) !important;
  color: var(--navy) !important; font-family: 'Syne',sans-serif !important;
  font-weight: 700 !important; border-radius: 50px !important;
  padding: 14px 32px !important; display: block !important;
  text-align: center !important; text-decoration: none !important;
  margin-top: 18px !important; font-size: 1rem !important;
  border: none !important; transition: transform .2s, box-shadow .2s !important;
  box-shadow: 0 6px 22px rgba(0,195,255,0.2) !important;
}
.woo-wrap .wc-proceed-to-checkout a:hover { transform: translateY(-2px) !important; box-shadow: 0 10px 28px rgba(0,195,255,0.32) !important; }
.woo-wrap button[name="update_cart"] { background: rgba(255,255,255,0.05) !important; border: 1px solid var(--card-border) !important; color: var(--gray) !important; border-radius: 8px !important; padding: 10px 18px !important; cursor: pointer !important; transition: border-color .2s !important; font-family: 'DM Sans',sans-serif !important; }
.woo-wrap button[name="update_cart"]:hover { border-color: var(--cyan) !important; color: var(--white) !important; }

/* --------------------------------------------------------------------------
   11. CHECKOUT
   -------------------------------------------------------------------------- */
.woo-wrap .woocommerce-checkout { display: grid; grid-template-columns: 3fr 2fr; gap: 40px; align-items: start; }
.woo-wrap .woocommerce-billing-fields h3,
.woo-wrap #order_review_heading { font-size: 1.1rem !important; margin-bottom: 18px !important; padding-bottom: 10px !important; border-bottom: 1px solid var(--card-border) !important; color: var(--white) !important; }
.woo-wrap .woocommerce-checkout .form-row label { color: var(--gray) !important; font-size: .82rem !important; margin-bottom: 5px !important; display: block !important; }
.woo-wrap .woocommerce-checkout .form-row input,
.woo-wrap .woocommerce-checkout .form-row select,
.woo-wrap .woocommerce-checkout .form-row textarea { width: 100% !important; background: rgba(255,255,255,0.05) !important; border: 1px solid var(--card-border) !important; color: var(--white) !important; border-radius: 9px !important; padding: 11px 13px !important; font-family: 'DM Sans',sans-serif !important; outline: none !important; transition: border-color .2s !important; }
.woo-wrap .woocommerce-checkout .form-row input:focus { border-color: var(--cyan) !important; }
.woo-wrap #order_review { background: var(--card-bg) !important; border: 1px solid var(--card-border) !important; border-radius: var(--radius) !important; padding: 28px !important; }
.woo-wrap #payment { background: rgba(255,255,255,0.03) !important; border-radius: 8px !important; padding: 20px !important; margin-top: 20px !important; }
.woo-wrap #payment .place-order .button { background: linear-gradient(135deg, var(--cyan), var(--blue-mid)) !important; color: var(--navy) !important; font-family: 'Syne',sans-serif !important; font-weight: 700 !important; border-radius: 50px !important; width: 100% !important; padding: 14px !important; font-size: 1rem !important; border: none !important; }
.woo-wrap #payment ul.wc_payment_methods { list-style: none !important; padding: 0 !important; }
.woo-wrap #payment ul.wc_payment_methods li { padding: 12px 0 !important; border-bottom: 1px solid rgba(0,195,255,0.07) !important; color: var(--white) !important; }
.woo-wrap #payment .payment_box { background: rgba(255,255,255,0.03) !important; border: 1px solid rgba(0,195,255,0.1) !important; border-radius: 8px !important; padding: 12px !important; color: var(--gray) !important; margin-top: 8px !important; }

/* --------------------------------------------------------------------------
   12. PAGINACION
   -------------------------------------------------------------------------- */
.woo-wrap nav.woocommerce-pagination ul { display: flex !important; gap: 8px !important; list-style: none !important; padding: 0 !important; justify-content: center !important; flex-wrap: wrap !important; }
.woo-wrap nav.woocommerce-pagination ul li a,
.woo-wrap nav.woocommerce-pagination ul li span { background: var(--card-bg) !important; border: 1px solid var(--card-border) !important; color: var(--gray) !important; border-radius: 8px !important; padding: 8px 14px !important; text-decoration: none !important; transition: border-color .2s, color .2s !important; display: block !important; }
.woo-wrap nav.woocommerce-pagination ul li span.current,
.woo-wrap nav.woocommerce-pagination ul li a:hover { border-color: var(--cyan) !important; color: var(--cyan) !important; }

/* --------------------------------------------------------------------------
   13. NOTIFICACIONES
   -------------------------------------------------------------------------- */
.woocommerce-message { background: rgba(0,195,255,0.07) !important; border-top: 3px solid var(--cyan) !important; color: var(--white) !important; padding: 14px 18px !important; border-radius: 0 0 8px 8px !important; margin-bottom: 24px !important; }
.woocommerce-message a { color: var(--cyan) !important; }
.woocommerce-error { background: rgba(255,60,60,0.07) !important; border-top: 3px solid #ff5555 !important; color: var(--white) !important; padding: 14px 18px !important; }

/* --------------------------------------------------------------------------
   14. RESPONSIVE WC
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .shop-products.full-width ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .shop-products.with-sidebar ul.products { grid-template-columns: 1fr !important; }
  .woo-wrap div.product { grid-template-columns: 1fr !important; }
  .woo-wrap .woocommerce-checkout { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .shop-content-wrap { flex-direction: column; }
  .shop-sidebar { width: 100%; position: static; }
  .shop-products.full-width ul.products,
  .shop-products.with-sidebar ul.products,
  .woo-wrap > .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .mimma-featured-grid { grid-template-columns: repeat(2,1fr); }
  .woo-wrap .woocommerce-checkout { grid-template-columns: 1fr; }
  .woo-wrap { padding: 28px 4vw 60px; }
}
@media (max-width: 480px) {
  .shop-products ul.products { grid-template-columns: 1fr !important; }
  .mimma-featured-grid { grid-template-columns: 1fr; }
  .shop-search-form { border-radius: 10px; }
}

/* --------------------------------------------------------------------------
   15. MINI-CART PLUGIN (side cart / floating cart)
   El plugin muestra "Your Cart" con fondo blanco — lo oscurecemos
   -------------------------------------------------------------------------- */

/* Contenedor principal del mini-cart */
.woo-fly-cart, .woo-fly-cart-inner,
.woosq-popup, .woo-cart-popup,
[class*="side-cart"], [class*="fly-cart"],
[class*="mini-cart-"], .cart-popup-wrap,
.woo-cart-drawer, .cart-drawer,
.wc-side-cart { 
  background: var(--navy2) !important;
  color: var(--white) !important;
  border-left: 1px solid var(--card-border) !important;
}

/* Titulo "Your Cart" */
.woo-fly-cart .cart-title,
[class*="side-cart"] .cart-title,
[class*="fly-cart"] h2,
[class*="fly-cart"] h3,
.cart-popup-wrap h2,
.cart-popup-wrap h3 {
  background: var(--navy) !important;
  color: var(--white) !important;
  border-bottom: 1px solid var(--card-border) !important;
  font-family: 'Syne', sans-serif !important;
  font-weight: 700 !important;
  padding: 18px 20px !important;
}

/* Items del carrito en el mini-cart */
.woo-fly-cart .cart_list li,
[class*="side-cart"] .cart_list li,
.cart-popup-wrap .cart_list li {
  border-bottom: 1px solid rgba(0,195,255,0.08) !important;
  padding: 14px 20px !important;
  background: transparent !important;
}

/* Nombre del producto */
.woo-fly-cart .cart_list .product-name a,
[class*="side-cart"] .cart_list .product-name,
.cart-popup-wrap .product-name a {
  color: var(--white) !important;
  font-weight: 600 !important;
}

/* Precio */
.woo-fly-cart .cart_list .amount,
[class*="side-cart"] .amount,
.cart-popup-wrap .amount {
  color: var(--cyan) !important;
  font-family: 'Syne', sans-serif !important;
  font-weight: 700 !important;
}

/* Total / Subtotal */
.woo-fly-cart .total,
[class*="side-cart"] .total,
.cart-popup-wrap .total {
  background: rgba(0,195,255,0.05) !important;
  border-top: 1px solid var(--card-border) !important;
  color: var(--white) !important;
  padding: 14px 20px !important;
}
.woo-fly-cart .total strong,
[class*="side-cart"] .total strong { color: var(--cyan) !important; }

/* Botones del mini-cart */
.woo-fly-cart .buttons a,
[class*="side-cart"] .buttons a,
.cart-popup-wrap .buttons a {
  font-family: 'Syne', sans-serif !important;
  font-weight: 700 !important;
  border-radius: 8px !important;
  padding: 10px 18px !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: transform .2s !important;
  margin: 4px !important;
}

/* "View Cart" */
.woo-fly-cart .buttons .button:first-child,
[class*="side-cart"] .buttons .button:first-child {
  background: rgba(0,195,255,0.1) !important;
  border: 1px solid rgba(0,195,255,0.3) !important;
  color: var(--cyan) !important;
}

/* "Checkout" */
.woo-fly-cart .buttons .checkout,
[class*="side-cart"] .buttons .checkout,
.cart-popup-wrap .buttons .checkout {
  background: linear-gradient(135deg, var(--cyan), var(--blue-mid)) !important;
  color: var(--navy) !important;
  border: none !important;
}

/* Icono de carrito flotante / burbuja */
.woo-fly-cart-btn,
[class*="cart-icon-btn"],
[class*="fly-cart-btn"],
.woo-cart-float-btn {
  background: var(--cyan) !important;
  color: var(--navy) !important;
  border-radius: 50% !important;
}

/* Badge contador */
.woo-fly-cart-btn .count,
[class*="cart-count"],
.cart-count-badge {
  background: var(--navy) !important;
  color: var(--cyan) !important;
  border: 1px solid var(--cyan) !important;
  font-family: 'Syne', sans-serif !important;
  font-weight: 800 !important;
}

/* Savings text */
[class*="savings"], .cart-savings {
  color: var(--cyan) !important;
  font-weight: 600 !important;
}

/* Texto informativo */
.woo-fly-cart p, [class*="side-cart"] p,
.cart-popup-wrap p {
  color: var(--gray) !important;
  font-size: .85rem !important;
}

/* Separador / overlay al abrir */
.woo-fly-cart-overlay,
[class*="cart-overlay"],
.cart-drawer-overlay {
  background: rgba(0,0,0,0.5) !important;
  backdrop-filter: blur(4px) !important;
}

/* Imagen del producto en mini-cart */
.woo-fly-cart .cart_list img,
[class*="side-cart"] .cart_list img,
.cart-popup-wrap .cart_list img {
  border-radius: 8px !important;
  border: 1px solid var(--card-border) !important;
}

/* Quitar la X de cierre blanca sobre fondo blanco */
.woo-fly-cart .close,
[class*="side-cart"] .close,
.cart-popup-wrap .close {
  color: var(--gray) !important;
  background: transparent !important;
}
.woo-fly-cart .close:hover,
[class*="side-cart"] .close:hover { color: var(--white) !important; }

/* ─ Estilos especificos del plugin "WooCommerce Side Cart" (imagen 2) ─ */
.woo-side-cart-wrapper,
.woo-side-cart { background: var(--navy2) !important; }

.woo-side-cart .woo-side-cart-header {
  background: var(--navy) !important;
  color: var(--white) !important;
  border-bottom: 1px solid var(--card-border) !important;
}

.woo-side-cart .woo-side-cart-footer {
  background: rgba(0,0,0,0.2) !important;
  border-top: 1px solid var(--card-border) !important;
}

.woo-side-cart .product-item { border-bottom: 1px solid rgba(0,195,255,0.07) !important; }
.woo-side-cart .product-item .product-name { color: var(--white) !important; font-weight: 600 !important; }
.woo-side-cart .product-item .product-price { color: var(--cyan) !important; font-weight: 700 !important; }
.woo-side-cart .product-item .product-quantity { color: var(--gray) !important; }
.woo-side-cart .product-item .product-remove { color: var(--gray) !important; }
.woo-side-cart .product-item .product-remove:hover { color: #ff5555 !important; }

.woo-side-cart .cart-subtotal { color: var(--white) !important; }
.woo-side-cart .cart-subtotal .amount { color: var(--cyan) !important; font-weight: 800 !important; font-family: 'Syne', sans-serif !important; }

.woo-side-cart .btn-checkout {
  background: linear-gradient(135deg, var(--cyan), var(--blue-mid)) !important;
  color: var(--navy) !important; font-weight: 700 !important;
  border-radius: 50px !important; border: none !important;
}
.woo-side-cart .btn-view-cart {
  background: rgba(0,195,255,0.1) !important;
  border: 1px solid rgba(0,195,255,0.3) !important;
  color: var(--cyan) !important;
  border-radius: 50px !important;
}

/* Iconos del plugin sidebar que no cargan: forzar visibilidad */
.woo-widget .widget-title::before,
.woo-widget [class*="icon"]::before,
.woo-widget svg,
.woo-widget img.icon { display: inline-block !important; visibility: visible !important; opacity: 1 !important; }

/* Si usa font-icons (dashicons no cargan en front sin enqueue): fallback */
.widget_woocommerce_layered_nav .woofc-icon::before { content: '◆'; font-size: .7em; color: var(--cyan); }
.widget_price_filter .woofc-icon::before { content: '$'; color: var(--cyan); }
