/* ==========================================================================
   DIVERKION — Estilos WooCommerce
   ========================================================================== */

/* Layout tienda */
/* dk-shop-hero es ahora ancho completo (fuera de dk-wrap) — tiene su propio dk-wrap interno */
.dk-shop-hero {
  background: var(--dk-oat);
  padding-block: clamp(40px, 6vw, 72px) 40px;
  border-bottom: 1.5px solid var(--dk-line);
}
.dk-shop-hero .dk-wrap { text-align: center; }
/* Separación visual entre shop hero y la cuadrícula de productos */
.woocommerce .dk-page { padding-top: 40px; }
.dk-shop-hero__desc { color: var(--dk-muted); max-width: 60ch; margin-inline: auto; }
.dk-page__layout .dk-shop-main { min-width: 0; }
.dk-sidebar { min-width: 0; }

.woocommerce .dk-page { padding-top: 32px; }

/* Barra de orden y resultados */
.woocommerce .woocommerce-result-count { color: var(--dk-muted); font-size: .9rem; margin-top: .6rem; }
.woocommerce .woocommerce-ordering select,
.woocommerce select,
.woocommerce .select2-container .select2-selection {
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-pill);
  padding: .55em 1.1em;
  background: var(--dk-white);
  font-family: var(--dk-font-body);
}

/* ====================== Grid de productos ====================== */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin: 0 0 2rem;
  padding: 0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; display: none !important; }

/* li.product = celda de grid; dk-pcard gestiona toda la visual */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  display: block !important;
}
/* dk-pcard ocupa toda la celda */
.woocommerce ul.products li.product .dk-pcard { height: 100%; }

/* Estrellas */
.woocommerce .star-rating span::before,
.woocommerce p.stars a::before { color: var(--dk-clay); }
.woocommerce .star-rating { margin: 0 auto 10px; color: var(--dk-clay); }

/* Insignia de oferta */
.woocommerce span.onsale {
  background: var(--dk-sale);
  color: var(--dk-white);
  border-radius: var(--dk-radius-pill);
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .04em;
  padding: .4em 1em;
  min-height: 0;
  min-width: 0;
  line-height: 1.4;
  top: 16px; left: 16px;
  margin: 0;
}

/* ====================== Producto individual ====================== */

/* Wrapper de la página de producto — ancho completo sin sidebar */
.single-product .dk-page__layout { display: block; }
.single-product .dk-shop-main { width: 100%; }

/* Grid principal imagen + detalles */
.single-product div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
  float: none !important;
  width: 100% !important;
}

/* Galería: ocupa toda la columna izquierda */
.single-product div.product .woocommerce-product-gallery {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
  grid-column: 1;
}
.single-product .woocommerce-product-gallery .flex-viewport { width: 100% !important; }
/* NO forzar width en las diapositivas: flexslider les pone un width inline calculado;
   si lo pisamos con !important el slider muestra varias a la vez / deja huecos.
   Sólo forzamos ancho completo cuando NO hay slider activo. */
.single-product .woocommerce-product-gallery:not(:has(.flex-viewport)) .woocommerce-product-gallery__image {
  width: 100% !important;
}
.single-product .woocommerce-product-gallery__image img,
.single-product .woocommerce-product-gallery__image a img {
  width: 100% !important;
  height: auto;
  max-height: 520px;
  object-fit: contain;
  border-radius: var(--dk-radius);
  background: #fff;
  display: block;
}
/* Miniaturas bajo la imagen principal */
.single-product .woocommerce-product-gallery .flex-control-thumbs {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  padding: 0;
  list-style: none;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs li {
  flex: 0 0 auto;
  width: 70px;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs img {
  border-radius: var(--dk-radius-sm);
  aspect-ratio: 1;
  object-fit: cover;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.2s;
}
.single-product .woocommerce-product-gallery .flex-control-thumbs .flex-active { border-color: var(--dk-brand); }

/* WooCommerce pone la galería ENTERA en opacity:0 hasta que el JS de flexslider/zoom
   termina de inicializar. Si ese JS falla o tarda, la imagen grande queda invisible
   (las miniaturas sí se ven). Forzamos SÓLO el contenedor a visible — dejamos que
   flexslider gestione qué diapositiva se muestra (no forzar todas las imgs, o se
   ven varias a la vez). */
.single-product .woocommerce-product-gallery {
  opacity: 1 !important;
}
/* Si flexslider NO se inicializó (no hay .flex-viewport): mostrar sólo la 1ª imagen
   para que las demás no se apilen ni queden lado a lado. */
.single-product .woocommerce-product-gallery:not(:has(.flex-viewport)) .woocommerce-product-gallery__image:nth-child(n+2) {
  display: none !important;
}
.single-product .woocommerce-product-gallery .flex-viewport { min-height: 200px; }

/* Lupa (zoom icon) */
.single-product .woocommerce-product-gallery .woocommerce-product-gallery__trigger {
  top: 12px; right: 12px;
}

/* Columna de detalles del producto */
.single-product div.product .summary {
  float: none !important;
  width: 100% !important;
  grid-column: 2;
  padding-top: 0;
}
.single-product div.product .product_title {
  font-family: var(--dk-font-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  margin-bottom: .4rem;
  line-height: 1.2;
}
.single-product div.product p.price,
.single-product div.product span.price {
  color: var(--dk-brand-dark);
  font-weight: 800;
  font-size: 1.8rem;
  display: block;
  margin-bottom: .6rem;
}
.single-product div.product p.price del,
.single-product div.product span.price del { color: var(--dk-muted); font-weight: 400; font-size: 1.1rem; }
.single-product .dk-product-badge {
  display: inline-flex; align-items: center; gap: .5em;
  background: var(--dk-pastel-mint); color: #3a8a5a;
  border-radius: var(--dk-radius-pill);
  padding: .45em 1em; font-weight: 600; font-size: .88rem;
  margin: .4rem 0 1.2rem;
}
.single-product .quantity input.qty {
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-sm);
  padding: .7em .9em; width: 72px; text-align: center;
  font-family: var(--dk-font-body);
  font-size: 1rem;
}
.single-product div.product form.cart {
  display: flex; gap: 12px; align-items: center;
  margin: 1.4rem 0; flex-wrap: wrap;
}
.single-product div.product .single_add_to_cart_button {
  padding: .95em 2.2em;
  font-size: 1rem;
}

/* Meta (SKU, categorías, etiquetas) */
.single-product div.product .product_meta { margin-top: 1.2rem; font-size: .88rem; color: var(--dk-muted); }
.single-product div.product .product_meta a { color: var(--dk-brand-dark); }

/* Tabs descripción / reseñas */
.woocommerce-tabs { margin-top: 2.5rem; }
.single-product div.product .woocommerce-tabs { grid-column: 1 / -1; }

/* Tabs */
.woocommerce-tabs ul.tabs { border: none !important; padding: 0 !important; display: flex; gap: 8px; flex-wrap: wrap; }
.woocommerce-tabs ul.tabs::before { border: none !important; }
.woocommerce-tabs ul.tabs li {
  background: var(--dk-oat) !important;
  border: none !important;
  border-radius: var(--dk-radius-pill) !important;
  margin: 0 !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.tabs li.active { background: var(--dk-clay) !important; }
.woocommerce-tabs ul.tabs li.active a { color: var(--dk-white) !important; }
.woocommerce-tabs ul.tabs li a { font-weight: 700; padding: .7em 1.4em !important; }

/* Productos relacionados */
.related.products > h2, .upsells > h2 { font-family: var(--dk-font-display); margin-top: 2rem; }

/* ====================== Carrito ====================== */
.woocommerce table.shop_table {
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  overflow: hidden;
  border-collapse: separate;
}
.woocommerce table.shop_table th { background: var(--dk-oat); font-family: var(--dk-font-body); }
.woocommerce-cart table.cart img { border-radius: var(--dk-radius-sm); width: 72px; }
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 14px 24px 24px;
}
.woocommerce .cart_totals h2, .woocommerce-checkout h3 { font-family: var(--dk-font-display); margin-top: 0; }

/* ====================== Checkout / Formularios ====================== */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce #add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment { border-radius: var(--dk-radius-sm); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  border: 1.5px solid var(--dk-line);
  padding: .8em 1em;
  font-family: var(--dk-font-body);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { outline: none; border-color: var(--dk-clay); }
.woocommerce-checkout #payment { background: var(--dk-oat); border-radius: var(--dk-radius); }

/* Avisos */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-top-color: var(--dk-sage) !important;
  border-radius: var(--dk-radius-sm);
  background: var(--dk-oat);
}
.woocommerce-message::before { color: var(--dk-sage-dark); }

/* ====================== Tarjetas de blog ====================== */
.dk-posts { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--dk-gap); }
.dk-card {
  background: var(--dk-white); border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius); overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .3s var(--dk-ease), box-shadow .3s var(--dk-ease);
}
.dk-card:hover { transform: translateY(-5px); box-shadow: var(--dk-shadow); }
.dk-card__media { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--dk-oat); }
.dk-card__media img { width: 100%; height: 100%; object-fit: cover; }
.dk-card__body { padding: 22px; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.dk-card__cat { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--dk-clay); }
.dk-card__title { font-size: 1.25rem; margin: 0; }
.dk-card__title a { color: var(--dk-charcoal); }
.dk-card__title a:hover { color: var(--dk-wood); }
.dk-card__excerpt { color: var(--dk-muted); font-size: .95rem; margin: 0; }
.dk-card__more { font-weight: 700; margin-top: auto; }
.dk-card--row { flex-direction: row; align-items: center; }
.dk-card--row .dk-card__media { flex: 0 0 120px; aspect-ratio: 1/1; }

/* Paginación */
.woocommerce nav.woocommerce-pagination ul,
.navigation .nav-links { display: flex; gap: 8px; justify-content: center; border: none; }
.woocommerce nav.woocommerce-pagination ul li,
.navigation .nav-links a, .navigation .nav-links span {
  border: 1px solid var(--dk-line) !important;
  border-radius: var(--dk-radius-pill);
  overflow: hidden;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { padding: .6em 1em; }
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--dk-clay); color: #fff; }

/* ====================== Páginas WC en page.php — quitar caja de artículo ====================== */
.woocommerce-cart .dk-article,
.woocommerce-checkout .dk-article,
.woocommerce-account .dk-article {
  max-width: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
/* entry-content tiene max-width: 72ch (para artículos de blog) — anularlo en páginas WC */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content {
  max-width: none !important;
}
.woocommerce-cart .dk-page-title,
.woocommerce-checkout .dk-page-title,
.woocommerce-account .dk-page-title { margin-bottom: 1.5rem; }

/* ====================== Mi Cuenta ====================== */
.woocommerce-account .dk-page__layout { display: block; }

/* Aviso "revisa el spam" en Mi cuenta / login */
.dk-account-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--dk-brand-soft);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 14px 18px;
  margin-bottom: 1.5rem;
  color: var(--dk-charcoal);
  font-size: .92rem;
  line-height: 1.5;
}
.dk-account-note svg { flex: 0 0 auto; color: var(--dk-brand-dark); margin-top: 2px; }

/* Grid 2 columnas: nav lateral LEFT + contenido RIGHT.
   SOLO con sesión iniciada (cuando existe la navegación). En la página de
   login/registro NO hay navegación → no aplicamos el grid, o el bloque
   Acceder/Registrarse quedaría aplastado en la columna de 220px. */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 0 40px;
  align-items: start;
}

/* Notices wrapper → fila completa; si está vacía, desaparece (evita fila fantasma) */
.woocommerce-account .woocommerce > .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
}
.woocommerce-account .woocommerce > .woocommerce-notices-wrapper:empty {
  display: none;
}

/* Anular float/width de WooCommerce (30%/70%) dentro de nuestro grid */
.woocommerce-account .woocommerce > .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce > .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Nav lateral sticky */
.woocommerce-account .woocommerce-MyAccount-navigation {
  grid-column: 1;
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 10px;
  position: sticky;
  top: 88px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
/* Sobreescribir el color naranja de entry-content a con mayor especificidad */
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: .6em 1em;
  border-radius: var(--dk-radius-pill);
  font-weight: 700;
  font-size: .9rem;
  color: var(--dk-charcoal) !important;
  text-decoration: none !important;
  transition: background .2s, color .2s;
  white-space: nowrap;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--dk-oat);
  color: var(--dk-brand-dark) !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--dk-brand);
  color: #fff !important;
  text-decoration: none !important;
}

/* Contenido principal */
.woocommerce-account .woocommerce-MyAccount-content { grid-column: 2; min-width: 0; }
.woocommerce-account .woocommerce-MyAccount-content h2 { font-family: var(--dk-font-display); margin-bottom: 1rem; }

/* Tabla de pedidos en Mi Cuenta */
.woocommerce-orders-table,
.woocommerce-table--order-details {
  width: 100%;
  border-collapse: collapse;
  font-size: .94rem;
}
.woocommerce-orders-table th,
.woocommerce-table--order-details th {
  background: var(--dk-oat);
  font-weight: 700;
  padding: .7em 1em;
  text-align: left;
  border-bottom: 1px solid var(--dk-line);
}
.woocommerce-orders-table td,
.woocommerce-table--order-details td {
  padding: .7em 1em;
  border-bottom: 1px solid var(--dk-line);
  vertical-align: middle;
}
.woocommerce-orders-table mark.order-status {
  background: var(--dk-oat);
  color: var(--dk-charcoal);
  font-size: .8rem;
  font-weight: 700;
  padding: .3em .8em;
  border-radius: var(--dk-radius-pill);
  letter-spacing: .04em;
}

/* Formulario de Mi Cuenta (editar datos) */
.woocommerce-EditAccountForm .woocommerce-form-row { margin-bottom: 1rem; }
.woocommerce-EditAccountForm label { display: block; font-weight: 700; font-size: .88rem; margin-bottom: .4rem; }

/* Login / Registro / Dirección — flex 2 columnas (más robusto que grid para 3 ítems) */
.woocommerce-account .u-columns,
.woocommerce-account .col2-set {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0 !important;
  overflow: visible !important;
  text-align: left;
}
/* Párrafo intro (dentro del wrapper) ocupa ancho completo */
.woocommerce-account .u-columns > p,
.woocommerce-account .col2-set > p {
  flex: 0 0 100% !important;
  width: 100% !important;
  margin-bottom: 1rem !important;
  text-align: left !important;
}
/* Columna izquierda (facturación) */
.woocommerce-account .u-columns .col-1,
.woocommerce-account .col2-set .col-1 {
  flex: 0 0 calc(50% - 20px) !important;
  width: calc(50% - 20px) !important;
  max-width: calc(50% - 20px) !important;
  float: none !important;
  margin: 0 40px 0 0 !important;
  text-align: left !important;
  box-sizing: border-box;
}
/* Columna derecha (envío) */
.woocommerce-account .u-columns .col-2,
.woocommerce-account .col2-set .col-2 {
  flex: 0 0 calc(50% - 20px) !important;
  width: calc(50% - 20px) !important;
  max-width: calc(50% - 20px) !important;
  float: none !important;
  margin: 0 !important;
  text-align: left !important;
  box-sizing: border-box;
}
.woocommerce-form__label-for-checkbox { display: flex; align-items: center; gap: 8px; font-size: .9rem; }

/* ====================== Formulario de Registro (plugin User Registration) ====================== */
/* Quitar la caja/borde propios del plugin: ya vamos dentro de la tarjeta de la página */
.ur-frontend-form,
.user-registration .ur-frontend-form {
  max-width: 560px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}
.ur-frontend-form .ur-form-row { margin-bottom: 0 !important; }
.ur-frontend-form .ur-form-row,
.ur-frontend-form .ur-form-grid { display: block !important; }
.ur-frontend-form .ur-field-item,
.ur-frontend-form .field-label,
.ur-frontend-form .ur-field {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 0 1.1rem !important;
}
/* Etiquetas */
.ur-frontend-form label,
.ur-frontend-form .label {
  display: block !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
  color: var(--dk-charcoal) !important;
  margin-bottom: .45rem !important;
}
.ur-frontend-form label .required { color: var(--dk-sale); }
/* Campos de texto, email, password */
.ur-frontend-form input[type="text"],
.ur-frontend-form input[type="email"],
.ur-frontend-form input[type="password"],
.ur-frontend-form input[type="tel"],
.ur-frontend-form input[type="number"],
.ur-frontend-form textarea,
.ur-frontend-form select {
  width: 100% !important;
  border: 1.5px solid var(--dk-line) !important;
  border-radius: var(--dk-radius-pill) !important;
  padding: .8em 1.1em !important;
  font-family: var(--dk-font-body) !important;
  font-size: 1rem !important;
  background: var(--dk-white) !important;
  box-sizing: border-box;
}
.ur-frontend-form textarea { border-radius: var(--dk-radius) !important; }
.ur-frontend-form input:focus,
.ur-frontend-form textarea:focus,
.ur-frontend-form select:focus {
  outline: none !important;
  border-color: var(--dk-brand) !important;
}
/* Contenedor del campo password con icono de ojo */
.ur-frontend-form .ur-input-type-password,
.ur-frontend-form .ur-input-type-user_confirm_password { position: relative; }
.ur-frontend-form .password-input-group,
.ur-frontend-form .ur-field input[type="password"] ~ .show-password-input,
.ur-frontend-form .show-password-input { line-height: 1; }
/* Botón submit con estilo de marca */
.ur-frontend-form .ur-submit-button,
.ur-frontend-form button[type="submit"],
.ur-frontend-form .ur-submit-button:hover {
  background: var(--dk-brand) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--dk-radius-pill) !important;
  font-weight: 700 !important;
  font-family: var(--dk-font-body) !important;
  padding: .9em 2.4em !important;
  font-size: 1rem !important;
  cursor: pointer;
  transition: background .2s, transform .15s;
}
.ur-frontend-form .ur-submit-button:hover { background: var(--dk-brand-dark) !important; transform: translateY(-1px); }
.ur-frontend-form .ur-button-container { margin-top: .5rem !important; }

/* ====================== Carrito vacío ====================== */
.woocommerce-cart .cart-empty {
  text-align: center;
  padding: 48px 24px;
  background: var(--dk-oat);
  border-radius: var(--dk-radius);
  font-size: 1.1rem;
  color: var(--dk-muted);
}
.woocommerce-cart .return-to-shop { text-align: center; margin-top: 1.2rem; }

/* ====================== Carrito — mejoras ====================== */

/* Tabla principal */
.woocommerce-cart table.cart { width: 100%; border-spacing: 0; }
.woocommerce-cart table.cart thead th {
  background: var(--dk-oat);
  padding: 12px 14px;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--dk-muted);
  border-bottom: 1.5px solid var(--dk-line);
  white-space: nowrap;
}
/* Columnas fijas: Remove y Thumbnail */
.woocommerce-cart table.cart td.product-remove,
.woocommerce-cart table.cart th.product-remove { width: 48px; padding-inline: 8px; text-align: center; }
.woocommerce-cart table.cart td.product-thumbnail,
.woocommerce-cart table.cart th.product-thumbnail { width: 88px; padding-inline: 10px; }
/* Columnas de precio, cantidad y subtotal */
.woocommerce-cart table.cart td.product-price,
.woocommerce-cart table.cart td.product-subtotal { white-space: nowrap; width: 90px; text-align: right; }
.woocommerce-cart table.cart th.product-price,
.woocommerce-cart table.cart th.product-subtotal { width: 90px; text-align: right; }
.woocommerce-cart table.cart td.product-quantity { width: 120px; text-align: center; }
.woocommerce-cart table.cart th.product-quantity { width: 120px; text-align: center; }
/* Imagen */
.woocommerce-cart table.cart .product-thumbnail img {
  border-radius: var(--dk-radius-sm);
  width: 68px; height: 68px;
  object-fit: cover;
  display: block;
}
.woocommerce-cart table.cart td { vertical-align: middle; padding: 14px 12px; }
.woocommerce-cart table.cart .product-name a { font-weight: 700; color: var(--dk-charcoal); }
.woocommerce-cart table.cart .product-name a:hover { color: var(--dk-brand-dark); }
.woocommerce-cart table.cart .product-remove a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--dk-oat);
  color: var(--dk-muted) !important;
  font-size: 1rem;
  font-weight: 700;
  transition: background .2s, color .2s;
}
.woocommerce-cart table.cart .product-remove a:hover { background: #FDE8E4; color: var(--dk-sale) !important; }
.woocommerce-cart .actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 12px 0; }
.woocommerce-cart .coupon { display: flex; gap: 8px; align-items: center; }
.woocommerce-cart .coupon label { font-weight: 700; font-size: .9rem; color: var(--dk-muted); }
.woocommerce-cart .coupon input[type="text"] {
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-pill);
  padding: .65em 1.1em;
  font-family: var(--dk-font-body);
  font-size: .9rem;
  width: 140px;
}
.woocommerce-cart .coupon input:focus { outline: none; border-color: var(--dk-brand); }
.woocommerce-cart #calc_shipping_state { max-width: 240px; }

/* ====================== Carrito — layout 2 columnas ====================== */
/* Tabla izquierda · Totales fijos a la derecha */
.woocommerce-cart .woocommerce {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 0 40px;
  align-items: start;
}
.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
}
/* Notices vacíos → sin fila fantasma */
.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper:empty {
  display: none;
}
.woocommerce-cart .woocommerce > form.woocommerce-cart-form {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}
.woocommerce-cart .woocommerce > .cart-collaterals {
  grid-column: 2;
  grid-row: 1;
  padding-top: 0 !important;
  margin-top: 0 !important;
}
/* Anular float/margin nativo de WC */
.woocommerce-cart .cart-collaterals .cart_totals {
  float: none !important;
  width: 100% !important;
  margin-top: 0 !important;
  position: sticky;
  top: 88px;
}
/* Divs vacíos que WC Payments / Stripe añade ANTES de cart_totals como placeholder */
.woocommerce-cart .cart-collaterals > div:empty,
.woocommerce-cart .cart-collaterals > section:empty {
  display: none !important;
}

/* Totales del carrito */
.woocommerce .cart_totals h2 { font-size: 1.35rem; margin: 0 0 1rem; }
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td { padding: .7em 0; border-bottom: 1px solid var(--dk-line); }
.woocommerce .cart_totals .order-total td,
.woocommerce .cart_totals .order-total th { font-weight: 800; font-size: 1.1rem; color: var(--dk-charcoal); }
.woocommerce .wc-proceed-to-checkout { margin-top: 1rem; }
.woocommerce .wc-proceed-to-checkout a.checkout-button { width: 100%; display: block; text-align: center; padding: 1em 2em; font-size: 1.05rem; }

/* ====================== Checkout mejorado ====================== */
/* Grid 2 columnas: datos facturación LEFT · resumen pedido RIGHT */
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 0 48px;
  align-items: start;
}
/* Elementos previos (GPay, aviso cupón) → ancho completo */
.woocommerce-checkout form.checkout > *:not(#customer_details):not(#order_review_heading):not(#order_review) {
  grid-column: 1 / -1;
}
/* Datos de cliente: columna izquierda */
.woocommerce-checkout #customer_details {
  grid-column: 1;
  display: block;
}
.woocommerce-checkout .col-1,
.woocommerce-checkout .col-2 { width: 100% !important; float: none !important; padding: 0 !important; }
/* Encabezado resumen: columna derecha */
.woocommerce-checkout #order_review_heading {
  grid-column: 2;
  margin-top: 0;
  font-family: var(--dk-font-display);
  font-size: 1.35rem;
}
/* Caja de resumen: columna derecha, sticky */
.woocommerce-checkout #order_review {
  grid-column: 2;
  position: sticky;
  top: 88px;
}
.woocommerce-checkout .form-row { margin-bottom: 1rem; }
.woocommerce-checkout .form-row label { display: block; font-weight: 700; font-size: .88rem; margin-bottom: .4rem; }
.woocommerce-checkout #payment { border-radius: var(--dk-radius); }
.woocommerce-checkout #payment ul.payment_methods { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.woocommerce-checkout #payment ul.payment_methods li { padding: 12px 16px; background: var(--dk-white); border: 1.5px solid var(--dk-line); border-radius: var(--dk-radius-sm); }
.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method input:checked ~ label { color: var(--dk-brand-dark); }
.woocommerce-checkout #payment .place-order { padding: 1.2rem; }
.woocommerce-checkout #payment #place_order { width: 100%; font-size: 1.1rem; padding: 1em; }

/* ====================== Pedido recibido ====================== */
.woocommerce-thankyou-order-received { font-size: 1.1rem; font-weight: 700; color: var(--dk-success); margin-bottom: 1.2rem; }
.woocommerce-order-overview { list-style: none; padding: 0; margin: 0 0 2rem; display: flex; flex-wrap: wrap; gap: 12px; }
.woocommerce-order-overview li {
  background: var(--dk-oat);
  border-radius: var(--dk-radius-sm);
  padding: 12px 18px;
  font-size: .9rem;
  font-weight: 600;
}
.woocommerce-order-overview li strong { display: block; color: var(--dk-charcoal); font-size: 1rem; }

/* ====================== Avisos WC mejorados ====================== */
.woocommerce-message {
  border-top-color: var(--dk-success) !important;
  background: #F0FAF4 !important;
  border-radius: var(--dk-radius-sm);
}
.woocommerce-message::before { color: var(--dk-success) !important; }
.woocommerce-error { border-top-color: var(--dk-sale) !important; background: #FEF2F0 !important; }
.woocommerce-info { border-top-color: var(--dk-brand) !important; background: var(--dk-brand-soft) !important; }

/* ====================== Responsive ====================== */
@media (max-width: 900px) {
  .single-product div.product {
    grid-template-columns: 1fr !important;
    gap: 28px;
  }
  .single-product div.product .woocommerce-product-gallery { grid-column: 1; }
  .single-product div.product .summary { grid-column: 1; }
  .single-product div.product .woocommerce-tabs { grid-column: 1; }
  .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); gap: 14px; }
  /* Checkout: una columna en tablet */
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
  }
  .woocommerce-checkout form.checkout > * { grid-column: 1 !important; }
  .woocommerce-checkout #order_review { position: static; }
  /* Mi Cuenta: una columna en tablet */
  .woocommerce-account .woocommerce { grid-template-columns: 1fr; }
  .woocommerce-account .woocommerce-MyAccount-navigation { position: static; grid-column: 1; }
  .woocommerce-account .woocommerce-MyAccount-navigation ul { flex-direction: row; flex-wrap: wrap; }
  .woocommerce-account .woocommerce-MyAccount-content { grid-column: 1; }
  .woocommerce-account .u-columns,
  .woocommerce-account .col2-set { flex-direction: column; }
  .woocommerce-account .u-columns .col-1,
  .woocommerce-account .u-columns .col-2,
  .woocommerce-account .col2-set .col-1,
  .woocommerce-account .col2-set .col-2 {
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 1.5rem !important;
  }
}
@media (max-width: 760px) {
  .woocommerce-cart .woocommerce {
    grid-template-columns: 1fr;
  }
  .woocommerce-cart .woocommerce > form.woocommerce-cart-form,
  .woocommerce-cart .woocommerce > .cart-collaterals {
    grid-column: 1;
  }
  .woocommerce-cart .woocommerce > .cart-collaterals {
    position: static;
    margin-top: 2rem;
  }
}
@media (max-width: 560px) {
  .woocommerce ul.products { grid-template-columns: 1fr 1fr; gap: 12px; }
  .single-product div.product .product_title { font-size: 1.5rem; }
  .woocommerce-cart table.cart td.product-thumbnail { display: none; }
  .woocommerce-MyAccount-navigation ul { flex-direction: column; }
  .woocommerce-cart .coupon { flex-direction: column; align-items: flex-start; }
  .woocommerce-cart .coupon input[type="text"] { width: 100%; }
}
