/*
Theme Name: Don Mascota
Theme URI: https://staging.donmascota.es
Author: Yolanda Jiménez
Description: Tema WooCommerce ultraligero 100% a medida para Don Mascota. Sin page builder, sin framework. Optimizado para rendimiento (TTFB y Core Web Vitals).
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: donmascota
WC requires at least: 8.0
WC tested up to: 10.7
*/

/* ============================================================
   1. TOKENS DE MARCA
   ============================================================ */
:root{
  --dm-teal:#00b0a0;
  --dm-teal-dark:#019486;
  --dm-teal-soft:#e6f7f5;
  --dm-ink:#3f3526;
  --dm-ink-soft:#5d5446;
  --dm-muted:#6d6d6d;
  --dm-bg:#ffffff;
  --dm-soft:#f6f7f7;
  --dm-border:#e6e6e6;
  --dm-sale:#d6453d;
  --dm-ok:#2f9e44;
  --dm-radius:10px;
  --dm-radius-sm:6px;
  --dm-shadow:0 1px 3px rgba(0,0,0,.06),0 6px 18px rgba(0,0,0,.05);
  --dm-wrap:1280px;
  --dm-font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --dm-gap:24px;
}

/* ============================================================
   2. RESET LIGERO
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--dm-font);font-size:16px;line-height:1.6;color:var(--dm-ink);background:var(--dm-bg);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{line-height:1.25;color:var(--dm-ink);margin:0 0 .5em;font-weight:700}
h1{font-size:1.9rem}h2{font-size:1.5rem}h3{font-size:1.15rem}
p{margin:0 0 1em}
a{color:var(--dm-teal-dark);text-decoration:none}
a:hover{color:var(--dm-ink)}
img{max-width:100%;height:auto;display:block}
ul,ol{padding-left:1.1em}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--dm-teal);outline-offset:2px}
.dm-wrap{max-width:var(--dm-wrap);margin:0 auto;padding:0 20px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.dm-skip{position:absolute;left:-9999px}
.dm-skip:focus{left:8px;top:8px;background:#fff;padding:10px 16px;z-index:1000;border-radius:6px;box-shadow:var(--dm-shadow)}

/* ============================================================
   3. BOTONES
   ============================================================ */
.button,.dm-btn,a.button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce-page button.button{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--dm-teal);color:#fff;border:0;border-radius:var(--dm-radius-sm);
  padding:.7em 1.3em;font-size:.95rem;font-weight:600;cursor:pointer;
  line-height:1.2;text-align:center;transition:background .15s ease;text-decoration:none}
.button:hover,.dm-btn:hover,
.woocommerce a.button:hover,.woocommerce button.button:hover,
.woocommerce input.button:hover,.woocommerce #respond input#submit:hover,
.woocommerce button.button.alt:hover{background:var(--dm-teal-dark);color:#fff}
.woocommerce button.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt{background:var(--dm-teal)}
.dm-btn--ghost,.woocommerce a.button.wc-backward{background:#fff;color:var(--dm-ink);border:1px solid var(--dm-border)}
.dm-btn--ghost:hover,.woocommerce a.button.wc-backward:hover{background:var(--dm-soft);color:var(--dm-ink)}
.dm-btn--block{width:100%}

/* ============================================================
   4. CABECERA
   ============================================================ */
.dm-topbar{background:#23262b;color:#fff;font-size:.82rem}
.dm-topbar .dm-wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:16px;position:relative}
.dm-topbar a{color:#fff;opacity:.85}
.dm-topbar a:hover{opacity:1}
.dm-topbar__msg{display:flex;gap:18px;flex-wrap:wrap}

/* Contador cuenta atrás — promo en pastilla amarilla (centro del topbar) */
.dm-topbar__center{position:absolute;left:50%;top:0;bottom:0;transform:translateX(-50%);display:flex;align-items:center;pointer-events:none;z-index:2}
.dm-countdown{
  display:inline-flex;align-items:center;gap:9px;white-space:nowrap;pointer-events:auto;
  background:linear-gradient(180deg,#e8504a,#d6453d);
  color:#fff;border-radius:999px;padding:4px 6px 4px 14px;
  box-shadow:0 0 0 1px rgba(0,0,0,.18),0 2px 12px rgba(214,69,61,.55);
  animation:dm-cd-glow 2.4s ease-in-out infinite;
}
@keyframes dm-cd-glow{
  0%,100%{box-shadow:0 0 0 1px rgba(0,0,0,.18),0 2px 10px rgba(214,69,61,.45)}
  50%    {box-shadow:0 0 0 1px rgba(0,0,0,.18),0 2px 18px rgba(214,69,61,1)}
}
.dm-countdown[hidden]{display:none}
.dm-countdown__text{font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.02em;font-size:.78rem}
.dm-countdown__timer{display:inline-flex;gap:4px}
.dm-countdown__seg{display:inline-flex;flex-direction:column;align-items:center;line-height:1;background:rgba(0,0,0,.28);border-radius:6px;padding:4px 6px;min-width:30px}
.dm-countdown__seg b{font-size:.9rem;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
.dm-countdown__seg i{font-style:normal;font-size:.55rem;text-transform:uppercase;letter-spacing:.03em;color:#fff;opacity:.72;margin-top:3px}
@media(prefers-reduced-motion:reduce){ .dm-countdown{animation:none} }
@media(max-width:1040px){
  .dm-topbar .dm-wrap{flex-wrap:wrap}
  .dm-topbar__center{position:static;transform:none;order:3;flex-basis:100%;justify-content:center;padding:5px 0}
  .dm-countdown{border-radius:10px}
}
@media(max-width:560px){
  .dm-countdown{gap:7px;padding:4px 6px 4px 11px}
  .dm-countdown__text{font-size:.72rem;white-space:normal;text-align:center}
  .dm-countdown__seg{min-width:27px;padding:3px 5px}
}

.dm-header{background:#fff;border-bottom:1px solid var(--dm-border);position:sticky;top:0;z-index:200}
.dm-header__main{display:flex;align-items:center;gap:28px;padding:14px 0}
.dm-logo img{max-height:54px;width:auto}
.dm-search{flex:1;max-width:620px}
.dm-search form{display:flex;border:2px solid var(--dm-teal);border-radius:var(--dm-radius-sm);overflow:hidden}
.dm-search input[type=search]{flex:1;border:0;padding:.65em .9em;font-size:.95rem;outline:0;min-width:0}
.dm-search button{background:var(--dm-teal);border:0;color:#fff;padding:0 1.1em;cursor:pointer;font-weight:600}
.dm-header__tools{display:flex;align-items:center;gap:22px;margin-left:auto}
.dm-tool{display:flex;align-items:center;gap:8px;color:var(--dm-ink);font-size:.85rem;font-weight:600;white-space:nowrap}
.dm-tool small{display:block;font-weight:400;color:var(--dm-muted)}
.dm-tool .dm-ico{width:26px;height:26px;flex:none;stroke:var(--dm-ink);fill:none}
.dm-cart-count{background:var(--dm-teal);color:#fff;border-radius:999px;font-size:.72rem;font-weight:700;padding:1px 7px;margin-left:2px}

/* Navegación de categorías */
.dm-nav{background:#fff;border-bottom:1px solid var(--dm-border)}
.dm-nav__list{display:flex;flex-wrap:wrap;list-style:none;margin:0;padding:0;gap:4px}
.dm-nav__list>li>a{display:flex;align-items:center;gap:8px;padding:14px 16px;font-weight:600;color:var(--dm-ink);font-size:.95rem}
.dm-nav__list>li{position:relative}
/* "Consultas veterinarias": alineado a la derecha del todo, con icono */
.dm-nav__consultas{margin-left:auto}
.dm-nav__consultas>a .dm-nav__qico{flex:none;color:var(--dm-teal)}
.dm-nav__consultas>a:hover .dm-nav__qico{color:var(--dm-teal)}
.dm-nav__list>li>a:hover,.dm-nav__list>li:hover>a{color:var(--dm-teal)}
.dm-nav__list>li:hover>a::after{content:"";position:absolute;left:16px;right:16px;bottom:0;height:3px;background:var(--dm-teal);border-radius:3px 3px 0 0}
/* Submenú nivel 2 — panel desplegable. overflow:visible para permitir fly-out. */
.dm-submenu{position:absolute;top:100%;left:0;min-width:280px;max-width:340px;background:#fff;border:1px solid var(--dm-border);border-radius:0 0 var(--dm-radius) var(--dm-radius);box-shadow:var(--dm-shadow);padding:10px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s ease;z-index:210;overflow:visible}
.dm-submenu__group{position:relative;padding:0;margin:0;list-style:none}
.dm-submenu__head{display:block;font-weight:500;color:var(--dm-ink);padding:9px 32px 9px 14px;border-radius:var(--dm-radius-sm);font-size:.92rem;position:relative}
.dm-submenu__head:hover,
.dm-submenu__group:focus-within>.dm-submenu__head,
.dm-submenu__group.has-grandchildren:hover>.dm-submenu__head{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}

/* Flechita ▸ a la derecha en items con hijos (3er nivel). */
.dm-submenu__group.has-grandchildren>.dm-submenu__head::after{
  content:"";position:absolute;right:14px;top:50%;width:7px;height:7px;
  border-right:2px solid currentColor;border-top:2px solid currentColor;
  transform:translateY(-50%) rotate(45deg);opacity:.55;transition:.15s ease
}
.dm-submenu__group.has-grandchildren:hover>.dm-submenu__head::after,
.dm-submenu__group:focus-within>.dm-submenu__head::after{opacity:1}

/* Sub-panel nivel 3 — fly-out lateral; oculto por defecto, visible en hover/focus. */
.dm-submenu__sub{
  position:absolute;top:-10px;left:calc(100% + 6px);min-width:260px;max-width:320px;
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  box-shadow:var(--dm-shadow);padding:10px;list-style:none;margin:0;
  opacity:0;visibility:hidden;transform:translateX(6px);transition:.15s ease;z-index:220
}
.dm-submenu__group:hover>.dm-submenu__sub,
.dm-submenu__group:focus-within>.dm-submenu__sub{opacity:1;visibility:visible;transform:translateX(0)}
.dm-submenu__sub li{margin:0}
.dm-submenu__sub a{display:block;padding:8px 12px;color:var(--dm-ink-soft);font-size:.88rem;border-radius:var(--dm-radius-sm);font-weight:500}
.dm-submenu__sub a:hover{color:var(--dm-teal-dark);background:var(--dm-teal-soft)}

/* Strip de subcategorías al inicio del archivo de categoría */
.dm-subcats{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 22px;padding:0;list-style:none}
.dm-subcats__item{margin:0}

/* Aviso de alimentación veterinaria (cabecera de categoría) */
.dm-vet-notice{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:#fff8e6;border:1px solid #f0d98c;border-left:4px solid #e0a800;
  border-radius:var(--dm-radius);padding:11px 16px;margin:0 0 22px}
.dm-vet-notice__title{display:flex;align-items:center;gap:8px;
  font-weight:800;font-size:.95rem;color:#8a6d00}
.dm-vet-notice__title svg{flex:none;color:#e0a800}
.dm-vet-notice__btn{flex:none;background:#e0a800;color:#fff;border:0;border-radius:999px;
  padding:7px 22px;font-weight:700;font-size:.85rem;cursor:pointer;transition:.13s ease}
.dm-vet-notice__btn:hover{background:#c8960a}

.dm-vet-modal{border:0;border-radius:14px;padding:0;max-width:560px;width:calc(100% - 32px);
  box-shadow:0 24px 60px rgba(0,0,0,.3);color:var(--dm-ink)}
.dm-vet-modal::backdrop{background:rgba(0,0,0,.5)}
.dm-vet-modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:15px 22px;border-bottom:1px solid var(--dm-border)}
.dm-vet-modal__head h3{margin:0;font-size:1.1rem;color:#8a6d00;display:flex;align-items:center;gap:8px}
.dm-vet-modal__head svg{flex:none;color:#e0a800}
.dm-vet-modal__close{background:none;border:0;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--dm-ink);padding:0 4px}
.dm-vet-modal__close:hover{color:var(--dm-teal-dark)}
.dm-vet-modal__list{margin:0;padding:18px 24px 22px 44px;font-size:.92rem;line-height:1.6}
.dm-vet-modal__list li{margin:8px 0}
.dm-subcat{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--dm-border);border-radius:999px;padding:7px 16px 7px 7px;font-weight:600;font-size:.88rem;color:var(--dm-ink);transition:.13s ease;text-decoration:none}
.dm-subcat:hover{border-color:var(--dm-teal);color:var(--dm-teal-dark);background:var(--dm-teal-soft)}
.dm-subcat__thumb{width:30px;height:30px;border-radius:50%;background:var(--dm-soft);overflow:hidden;flex:none;display:flex;align-items:center;justify-content:center;color:var(--dm-teal-dark)}
.dm-subcat__thumb img{width:100%;height:100%;object-fit:cover}
.dm-subcat__count{margin-left:6px;font-size:.74rem;color:var(--dm-muted);background:var(--dm-soft);border-radius:999px;padding:1px 7px;font-weight:700}
.dm-subcat:hover .dm-subcat__count{background:#fff;color:var(--dm-teal-dark)}
.dm-nav__list>li:hover .dm-submenu{opacity:1;visibility:visible;transform:translateY(0)}
.dm-submenu a{display:block;padding:9px 14px;border-radius:var(--dm-radius-sm);color:var(--dm-ink-soft);font-size:.9rem}
.dm-submenu a:hover{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.dm-nav__cta{margin-left:auto;align-self:center;color:var(--dm-sale)!important}

/* Menú móvil */
.dm-burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.dm-burger span{display:block;width:24px;height:2px;background:var(--dm-ink);margin:5px 0;transition:.2s}
.dm-mobile{display:none}

/* ============================================================
   5. HOME
   ============================================================ */
.dm-section{padding:46px 0}
.dm-section--soft{background:var(--dm-soft)}
.dm-section__head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:26px;gap:16px}
.dm-section__head h2{margin:0;font-size:1.6rem}
.dm-section__head a{font-size:.9rem;font-weight:600}

.dm-hero{position:relative;background:linear-gradient(110deg,var(--dm-teal) 0%,var(--dm-teal-dark) 100%);color:#fff;border-radius:16px;overflow:hidden;margin:24px 0}
.dm-hero__inner{padding:60px 48px;max-width:620px}
.dm-hero h1{color:#fff;font-size:2.4rem;margin-bottom:.3em}
.dm-hero p{font-size:1.1rem;opacity:.95;margin-bottom:1.4em}
.dm-hero .dm-btn{background:#fff;color:var(--dm-teal-dark)}
.dm-hero .dm-btn:hover{background:var(--dm-ink);color:#fff}

.dm-cats{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--dm-gap)}
.dm-cat-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 12px;background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);transition:.15s ease}
.dm-cat-card:hover{border-color:var(--dm-teal);box-shadow:var(--dm-shadow);transform:translateY(-3px)}
.dm-cat-card img{width:84px;height:84px;object-fit:contain;margin-bottom:12px}
.dm-cat-card span{font-weight:700;color:var(--dm-ink);font-size:.95rem}

.dm-usp{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--dm-gap);padding:30px 0}
.dm-usp__item{display:flex;gap:12px;align-items:center;font-size:.9rem;color:var(--dm-ink-soft)}
.dm-usp__item strong{display:block;color:var(--dm-ink)}
.dm-usp svg{width:34px;height:34px;flex:none;stroke:var(--dm-teal);fill:none}

/* Sellos de confianza en la ficha de producto */
.dm-trust{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-wrap:wrap;
  align-items:center;gap:10px 20px}
.dm-trust li{display:flex;align-items:center;gap:8px;font-size:.84rem;font-weight:600;color:var(--dm-ink)}
.dm-trust svg{width:20px;height:20px;flex:none;stroke:var(--dm-teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

.dm-seo{color:var(--dm-muted);font-size:.92rem}
.dm-seo h2{font-size:1.3rem}

/* ============================================================
   6. GRID DE PRODUCTOS / TARJETA
   ============================================================ */
.dm-products,
.woocommerce ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--dm-gap);list-style:none;margin:0;padding:0}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none}
.dm-product,
.woocommerce ul.products li.product{width:auto!important;margin:0!important;text-align:left;float:none!important;
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);overflow:hidden;
  display:flex;flex-direction:column;position:relative;transition:.15s ease}
.dm-product:hover,.woocommerce ul.products li.product:hover{box-shadow:var(--dm-shadow);border-color:#d4d4d4}
.dm-product__media{position:relative;display:block;padding:14px;background:#fff}
.dm-product__media img,
.woocommerce ul.products li.product a img{width:100%;height:200px;object-fit:contain;margin:0}
.dm-badge{position:absolute;top:10px;left:10px;z-index:3;background:var(--dm-sale);color:#fff;font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px}
.dm-badge--draft{background:var(--dm-muted)}
.woocommerce span.onsale{position:absolute;top:10px;left:10px;min-height:auto;min-width:auto;background:var(--dm-sale);border-radius:999px;padding:3px 9px;font-size:.72rem;font-weight:700;margin:0;line-height:1.4}
.dm-product__body,
.woocommerce ul.products li.product .dm-product__body{padding:4px 16px 18px;display:flex;flex-direction:column;flex:1}
.dm-product__brand{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--dm-muted);font-weight:700;margin-bottom:4px}
.dm-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-size:.95rem;font-weight:600;color:var(--dm-ink);padding:0;margin:0 0 8px;line-height:1.35;min-height:2.7em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dm-product__title a{color:inherit}
.dm-product__title a:hover{color:var(--dm-teal-dark)}
.dm-product .price,
.woocommerce ul.products li.product .price{color:var(--dm-ink);font-weight:800;font-size:1.1rem;margin:auto 0 12px;display:block}
.woocommerce ul.products li.product .price del{color:var(--dm-muted);font-weight:400;font-size:.9rem;opacity:.8}
.woocommerce ul.products li.product .price ins{text-decoration:none}
.dm-product .price .dm-perkg,.dm-perkg{display:block;font-size:.78rem;font-weight:600;color:var(--dm-teal-dark);margin-top:2px}
.dm-product__body .button,
.woocommerce ul.products li.product .button{margin-top:auto;width:100%}
.woocommerce ul.products li.product .added_to_cart{width:100%;margin-top:8px}

/* ============================================================
   7. ARCHIVO / TIENDA
   ============================================================ */
.dm-shop{display:grid;grid-template-columns:260px 1fr;gap:36px;padding:34px 0}
.dm-shop__side{font-size:.9rem}
.dm-widget{margin-bottom:26px;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:16px}
.dm-widget h3{font-size:1rem;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--dm-border)}
.dm-widget ul{list-style:none;padding:0;margin:0}
.dm-widget li{margin:0}
.dm-widget li a{display:block;padding:6px 0;color:var(--dm-ink-soft)}
.dm-widget li a:hover{color:var(--dm-teal-dark)}
.dm-shop__head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.woocommerce .woocommerce-result-count{margin:0;color:var(--dm-muted);font-size:.88rem}
.woocommerce .woocommerce-ordering{margin:0}
.woocommerce .woocommerce-ordering select,
.dm-shop select{padding:.5em .8em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);background:#fff;font-family:inherit}
.woocommerce-breadcrumb{font-size:.83rem;color:var(--dm-muted);padding:14px 0}
.woocommerce-breadcrumb a{color:var(--dm-muted)}
.woocommerce-breadcrumb a:hover{color:var(--dm-teal-dark)}
.woocommerce nav.woocommerce-pagination ul{border:0;margin:34px 0 0}
.woocommerce nav.woocommerce-pagination ul li{border:0;margin:0 3px}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);padding:.55em .9em;color:var(--dm-ink)}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover{background:var(--dm-teal);color:#fff;border-color:var(--dm-teal)}
.dm-archive-head{padding:26px 0 6px}
.dm-archive-head h1{margin-bottom:.2em}
.dm-archive-head .term-description{color:var(--dm-muted);font-size:.95rem;max-width:80ch}

/* ============================================================
   8. FICHA DE PRODUCTO
   ============================================================ */
.woocommerce div.product{display:block}
.dm-single{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:48px;padding:30px 0}
.woocommerce div.product div.images,
.woocommerce div.product div.summary{width:auto!important;float:none!important;margin:0!important}
.woocommerce div.product div.images img{border-radius:var(--dm-radius);border:1px solid var(--dm-border)}
.woocommerce div.product .product_title{font-size:24px;margin-bottom:.2em}
.dm-single .dm-product__brand{margin-bottom:10px}
.woocommerce div.product p.price,
.woocommerce div.product span.price{color:var(--dm-ink);font-size:1.7rem;font-weight:800;margin:14px 0}
.woocommerce div.product p.price del{color:var(--dm-muted);font-size:1.1rem;font-weight:400}
.woocommerce div.product p.price ins{text-decoration:none}
.woocommerce div.product form.cart{margin:22px 0;display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.woocommerce div.product form.cart .quantity input{width:72px;padding:.6em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);text-align:center;font-family:inherit}
.woocommerce div.product form.cart .button{padding:.85em 1.8em;font-size:1rem}
.woocommerce .quantity .qty{height:auto}
table.variations{margin:14px 0;border-collapse:collapse}
table.variations td{padding:6px 10px 6px 0;vertical-align:middle}
table.variations label{font-weight:700;margin:0}
table.variations select{padding:.55em .8em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);min-width:180px;background:#fff;font-family:inherit}
.woocommerce-variation-price .price{font-size:1.4rem!important}
.wpc-variation-radios,.variations .value{display:flex;flex-wrap:wrap;gap:8px}
.product_meta{font-size:.85rem;color:var(--dm-muted);margin-top:18px;border-top:1px solid var(--dm-border);padding-top:16px}
.product_meta>span{display:block;margin-bottom:5px}
.product_meta a{color:var(--dm-teal-dark)}
.woocommerce div.product .woocommerce-tabs{padding:36px 0}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0 0 22px;border-bottom:1px solid var(--dm-border);display:flex;gap:6px;flex-wrap:wrap}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{border:0;background:none;border-radius:0;margin:0;padding:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:12px 18px;font-weight:600;color:var(--dm-muted);display:block}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--dm-ink);border-bottom:3px solid var(--dm-teal)}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none}
.woocommerce table.shop_attributes{border:0;font-size:.92rem}
.woocommerce table.shop_attributes th{background:var(--dm-soft);width:220px;padding:10px 14px;border:1px solid var(--dm-border)}
.woocommerce table.shop_attributes td{padding:10px 14px;border:1px solid var(--dm-border);font-style:normal}
.related.products,.upsells.products{border-top:1px solid var(--dm-border);padding-top:36px;margin-top:20px}
.related.products>h2,.upsells.products>h2{font-size:1.4rem;margin-bottom:22px}
@media(min-width:1101px){
  .related.products ul.products{grid-template-columns:repeat(5,1fr)}
}

/* ============================================================
   9. CARRITO / CHECKOUT / CUENTA
   ============================================================ */
/* (Eliminada: añadía padding 30/50 a TODOS los .dm-wrap en cart/checkout/
 * account, incluido el del header → 80px de hueco entre header y nav de
 * categorías. El padding del contenido lo gestiona .dm-page en sección 19.) */
.woocommerce table.shop_table{border:1px solid var(--dm-border);border-radius:var(--dm-radius);border-collapse:separate;border-spacing:0;overflow:hidden}
.woocommerce table.shop_table th{background:var(--dm-soft);padding:14px;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}
.woocommerce table.shop_table td{padding:14px;border-top:1px solid var(--dm-border)}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review,
.woocommerce form.checkout_coupon,
.woocommerce .woocommerce-form-login{border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:24px}
.woocommerce #payment{background:var(--dm-soft);border-radius:var(--dm-radius)}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-account input,.select2-selection{border:1px solid var(--dm-border)!important;border-radius:var(--dm-radius-sm)!important;padding:.7em .85em;font-family:inherit}
.woocommerce form .form-row label{font-weight:600;font-size:.88rem}
.woocommerce-checkout #payment ul.payment_methods{border-bottom:1px solid var(--dm-border)}
.woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;border:1px solid var(--dm-border);border-radius:var(--dm-radius);overflow:hidden}
.woocommerce-MyAccount-navigation li a{display:block;padding:12px 16px;border-bottom:1px solid var(--dm-border);color:var(--dm-ink-soft);font-weight:600}
.woocommerce-MyAccount-navigation li.is-active a{background:var(--dm-teal);color:#fff}
.woocommerce-account .woocommerce-MyAccount-content{padding-left:30px}
.woocommerce .woocommerce-message,.woocommerce-info,.woocommerce-error,.woocommerce-noreviews,p.no-comments{border-top:3px solid var(--dm-teal);background:var(--dm-soft);border-radius:var(--dm-radius-sm);padding:14px 18px;list-style:none}
.woocommerce .woocommerce-error{border-top-color:var(--dm-sale)}
.woocommerce .woocommerce-message::before,.woocommerce-info::before,.woocommerce-error::before{color:var(--dm-teal)}

/* ============================================================
   10. PIE
   ============================================================ */
.dm-footer{background:#23262b;color:#c8cace;font-size:.9rem;margin-top:50px}
.dm-footer a{color:#c8cace}
.dm-footer a:hover{color:#fff}
.dm-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding:48px 0}
.dm-footer h4{color:#fff;font-size:1rem;margin-bottom:16px}
.dm-footer ul{list-style:none;padding:0;margin:0}
.dm-footer li{margin-bottom:9px}
.dm-footer__brand img{height:60px;width:auto;max-width:100%;margin-bottom:14px;filter:brightness(0) invert(1)}
.dm-footer__pay{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.dm-footer__pay span{background:rgba(255,255,255,.1);border-radius:4px;padding:5px 9px;font-size:.72rem;letter-spacing:.04em}
.dm-footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:#8b8e95}

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .dm-cats{grid-template-columns:repeat(3,1fr)}
  .dm-products,.woocommerce ul.products{grid-template-columns:repeat(3,1fr)}
  .dm-usp{grid-template-columns:repeat(2,1fr)}
  .dm-footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .dm-shop{grid-template-columns:1fr}
  .dm-single{grid-template-columns:1fr;gap:26px}
  /* En móvil se oculta el texto del icono, pero NO el contador del carrito */
  .dm-nav,.dm-header__tools .dm-tool span:not(.dm-cart-count){display:none}
  .dm-burger{display:block}
  .dm-header__main{gap:14px}
  .dm-search{order:3;flex-basis:100%;max-width:none}
  .dm-header__main{flex-wrap:wrap}
  /* Contador del carrito como burbuja en la esquina del icono */
  .dm-header__tools .dm-tool[data-dm-cart-toggle]{position:relative}
  .dm-header__tools .dm-tool .dm-cart-count{position:absolute;top:-5px;right:-7px;margin:0;
    min-width:18px;padding:1px 5px;text-align:center;line-height:1.5}
}
@media(max-width:640px){
  h1{font-size:1.5rem}.dm-hero__inner{padding:38px 24px}.dm-hero h1{font-size:1.8rem}
  /* Compra por mascota: 3 columnas compactas que caben en móvil */
  .dm-cats{gap:10px}
  .dm-cats .dm-cat-card{padding:16px 6px;gap:8px}
  .dm-cats .dm-cat-mask{width:64px;height:64px;margin-bottom:8px}
  .dm-cats .dm-cat-card span{font-size:.82rem}
  /* Topbar móvil: ocultar atención, centrar el aviso de envío gratuito */
  .dm-topbar__right{display:none}
  .dm-topbar__msg{flex:1;justify-content:center;text-align:center}
  /* Archivo (categorías raíz y profundas, tienda): título, descripción,
   * contador de resultados y selector de orden centrados en móvil. */
  .woocommerce.archive .woocommerce-products-header__title,
  .woocommerce.archive .page-title{text-align:center}
  .woocommerce.archive .term-description,
  .woocommerce.archive .term-description p{text-align:center}
  .woocommerce.archive .woocommerce-result-count,
  .woocommerce.archive .woocommerce-ordering{text-align:center}
  /* Migas de pan al final, tras la paginación, centradas */
  .woocommerce.archive #dm-main{display:flex;flex-direction:column}
  .woocommerce.archive #dm-main .dm-shop{order:1}
  .woocommerce.archive #dm-main .dm-breadrow{order:9;margin-top:10px}
  .woocommerce.archive .dm-breadrow .woocommerce-breadcrumb{justify-content:center;text-align:center}
  .dm-products,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:14px}
  .dm-product__media img,.woocommerce ul.products li.product a img{height:150px}
  /* Footer móvil: una columna, todo centrado y más compacto */
  .dm-footer{margin-top:36px}
  .dm-footer__top{grid-template-columns:1fr;gap:30px;padding:36px 0;text-align:center}
  .dm-footer__brand img{margin:0 auto 14px;display:block}
  .dm-footer__pay{justify-content:center}
  .dm-footer h4{margin-bottom:12px}
  .dm-footer__bottom{flex-direction:column;align-items:center;text-align:center;gap:8px;padding:16px 0}
  /* Solo productos variables apilan el form (tabla de variación arriba);
   * en simples, cantidad + botón se quedan en la misma fila. */
  .woocommerce div.product.product-type-variable form.cart{flex-direction:column;align-items:stretch}
  /* Categoría / ficha — espaciado más ajustado en móvil */
  .dm-shop{padding:16px 0}
  .dm-shop__head{margin-bottom:14px}
  .dm-breadrow{padding:8px 18px 4px}
  .single-product div.product{gap:18px}
  .single-product .woocommerce-product-gallery{padding:12px}
  .single-product .woocommerce-product-gallery__image img{max-height:320px!important}
  .single-product .product_title{font-size:19px}
  .single-product .summary p.price,
  .single-product .summary span.price,
  .single-product .summary .price{font-size:1.6rem}
  .related.products>h2,.upsells.products>h2{font-size:1.2rem}
  /* En móvil solo 4 productos relacionados (se consultan 5; se oculta el 5º) */
  .related.products ul.products li.product:nth-child(n+5){display:none}
  /* Migas de pan: al final, debajo de los productos relacionados */
  .single-product #dm-main{display:flex;flex-direction:column}
  .single-product #dm-main .dm-woo{order:1}
  .single-product #dm-main .dm-breadrow{order:2;margin-top:8px}
}

/* Móvil: panel desplegable */
.dm-mobile.is-open{display:block;position:fixed;inset:0 auto 0 0;width:min(86vw,360px);background:#fff;z-index:500;box-shadow:var(--dm-shadow);overflow-y:auto;padding:20px}
.dm-mobile__overlay{display:none}
.dm-mobile__overlay.is-open{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:499}
.dm-mobile h4{border-bottom:1px solid var(--dm-border);padding-bottom:12px;margin:0}
.dm-mobile__close{float:right;background:none;border:0;font-size:1.6rem;cursor:pointer;line-height:1;color:var(--dm-ink)}

/* Menú móvil — lista en acordeón con flecha en las categorías con hijos */
.dm-mnav,.dm-mnav__sub{list-style:none;margin:0;padding:0}
.dm-mnav{margin:10px -20px 0}
.dm-mnav__item{border-bottom:1px solid var(--dm-border)}
.dm-mnav__sub{display:none;background:var(--dm-soft)}
.dm-mnav__item.is-open>.dm-mnav__sub{display:block}
.dm-mnav__row{display:flex;align-items:stretch}
.dm-mnav__link{flex:1;min-width:0;display:block;padding:14px 20px;color:var(--dm-ink);font-weight:600;font-size:.95rem;text-decoration:none}
.dm-mnav__link:active{background:var(--dm-teal-soft)}
.dm-mnav__sub .dm-mnav__link{font-weight:500;font-size:.9rem;color:var(--dm-ink-soft);padding-left:34px}
.dm-mnav__sub .dm-mnav__sub .dm-mnav__link{font-size:.86rem;padding-left:48px}
.dm-mnav__toggle{flex:none;width:54px;background:none;border:0;border-left:1px solid var(--dm-border);
  cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--dm-ink-soft)}
.dm-mnav__toggle:active{background:var(--dm-teal-soft)}
.dm-mnav__chev{width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-top:-3px;transition:transform .15s ease}
.dm-mnav__item.is-open>.dm-mnav__row>.dm-mnav__toggle{color:var(--dm-teal-dark)}
.dm-mnav__item.is-open>.dm-mnav__row>.dm-mnav__toggle .dm-mnav__chev{transform:rotate(-135deg);margin-top:3px}

/* Utilidades */
.dm-mt0{margin-top:0}.dm-tc{text-align:center}
.dm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:36px}
@media(max-width:768px){.dm-grid-2{grid-template-columns:1fr}}

/* ============================================================
   12. PULIDO (overrides, cascada posterior gana)
   ============================================================ */

/* --- Ficha de producto: 2 columnas reales (imagen | resumen) --- */
.single-product div.product{display:grid!important;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:48px;align-items:start;position:relative}
.single-product div.product .woocommerce-product-gallery{grid-column:1;float:none;width:auto!important;margin:0;position:relative}
.single-product div.product .summary,
.single-product div.product .entry-summary{grid-column:2;float:none;width:auto!important;margin:0}
.single-product div.product .woocommerce-tabs,
.single-product div.product .related,
.single-product div.product .upsells,
.single-product div.product .woocommerce-product-gallery+.up-sells{grid-column:1/-1}
.single-product .woocommerce-product-gallery__wrapper{margin:0}
.single-product .woocommerce-product-gallery__image img{max-height:540px!important;width:auto!important;max-width:100%;margin:0 auto!important;object-fit:contain;background:#fff}
.single-product .woocommerce-product-gallery{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:24px}
.single-product .flex-control-thumbs{padding:0;margin-top:14px}
/* Badge oferta contenido dentro de la galería */
.single-product div.product>.onsale,
.single-product .woocommerce-product-gallery span.onsale{position:absolute;top:18px;left:18px;right:auto;z-index:5}
@media(max-width:860px){
  .single-product div.product{grid-template-columns:1fr;gap:24px}
  /* En 1 columna, galería y resumen deben apilarse: si conservan
   * grid-column:1 / grid-column:2 el resumen se va a una columna implícita. */
  .single-product div.product .woocommerce-product-gallery,
  .single-product div.product .summary,
  .single-product div.product .entry-summary{grid-column:1/-1}
  .single-product .woocommerce-product-gallery__image img{max-height:380px!important}
}

/* --- Hero más vivo --- */
.dm-hero{background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.18),transparent 45%),linear-gradient(115deg,var(--dm-teal) 0%,var(--dm-teal-dark) 100%)}
.dm-hero__inner{padding:64px 52px;max-width:640px}
.dm-hero h1{font-size:2.55rem;letter-spacing:-.01em}
.dm-hero p{font-size:1.12rem;max-width:46ch}
.dm-hero .dm-btn{padding:.9em 2em;font-size:1.05rem;box-shadow:0 6px 16px rgba(0,0,0,.14)}
.dm-hero::after{content:"🐾";position:absolute;right:6%;bottom:-10px;font-size:9rem;opacity:.10;line-height:1;transform:rotate(-12deg)}

/* --- Tarjetas de categoría: círculo de marca relleno --- */
.dm-cat-card{padding:26px 12px;gap:14px}
.dm-cat-card .dm-cat-ico{width:96px;height:96px;border-radius:50%;background:var(--dm-teal-soft);display:flex;align-items:center;justify-content:center;transition:.15s ease}
.dm-cat-card:hover .dm-cat-ico{background:var(--dm-teal);}
.dm-cat-card:hover .dm-cat-ico svg{stroke:#fff}
.dm-cat-card .dm-cat-ico svg{width:48px;height:48px;stroke:var(--dm-teal-dark);fill:none;stroke-width:1.6;transition:.15s ease}
.dm-cat-card img{width:96px;height:96px;border-radius:50%;object-fit:cover;background:var(--dm-soft)}
.dm-cat-card span{font-size:1rem}

/* --- Marcas como pills compactas --- */
.dm-brandrow{display:flex;flex-wrap:wrap;gap:10px}
.dm-brandrow a{background:#fff;border:1px solid var(--dm-border);border-radius:999px;padding:10px 22px;font-weight:700;font-size:.9rem;color:var(--dm-ink);transition:.15s ease}
.dm-brandrow a:hover{border-color:var(--dm-teal);color:var(--dm-teal-dark);background:var(--dm-teal-soft)}

/* Logotipos de marcas (home) */
.dm-brandlogos{display:grid;grid-template-columns:repeat(6,1fr);gap:22px}
.dm-brandlogo{display:block;aspect-ratio:1;border-radius:50%;overflow:hidden;
  max-width:145px;width:100%;margin:0 auto;transition:.18s ease;background:#fff;
  box-shadow:0 10px 22px rgba(0,0,0,.14),0 2px 5px rgba(0,0,0,.08)}
.dm-brandlogo:hover{transform:translateY(-3px);
  box-shadow:0 15px 30px rgba(0,0,0,.18),0 3px 7px rgba(0,0,0,.1)}
.dm-brandlogo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:900px){.dm-brandlogos{grid-template-columns:repeat(3,1fr);gap:16px}}

/* --- USP más presente --- */
.dm-usp__item{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:16px 18px}
.dm-usp svg{width:30px;height:30px;stroke-width:1.7}
.dm-usp__item strong{font-size:.98rem;margin-bottom:2px}

/* --- Tarjeta producto: respiración y precio --- */
.woocommerce ul.products li.product .dm-product__body,
.dm-product__body{padding:14px 16px 18px}
.dm-product__title{min-height:2.6em;font-size:.92rem}
.dm-product .price,.woocommerce ul.products li.product .price{font-size:1.15rem;margin:6px 0 14px}
.dm-perkg,.price .woocommerce-price-suffix{font-size:.8rem;color:var(--dm-muted);font-weight:600}
li.product .dm-badge{background:var(--dm-sale)}

/* --- Migas: ocultar si quedan vacías / icono suelto --- */
.woocommerce-breadcrumb:empty{display:none}
.dm-woo>.woocommerce-breadcrumb{margin:14px 0 6px}

/* --- Pestaña info adicional: filas legibles --- */
.woocommerce table.shop_attributes tr:nth-child(even) th{background:#fbfbfb}
.single-product .product_meta a{color:var(--dm-teal-dark)}

/* --- Slider de banners (vanilla, sin librería) --- */
.dm-slider{position:relative;margin:24px 0;border-radius:16px;overflow:hidden;aspect-ratio:1600/325;background:var(--dm-soft);box-shadow:var(--dm-shadow)}
.dm-slider__track{position:absolute;inset:0}
.dm-slide{position:absolute;inset:0;opacity:0;transition:opacity .55s ease;display:block;pointer-events:none}
.dm-slide.is-active{opacity:1;pointer-events:auto}
.dm-slide img{width:100%;height:100%;object-fit:cover;display:block}
.dm-slider__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.85);color:var(--dm-ink);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--dm-shadow);transition:.15s ease;z-index:3}
.dm-slider__nav:hover{background:#fff;color:var(--dm-teal-dark)}
.dm-slider__prev{left:14px}.dm-slider__next{right:14px}
.dm-slider__dots{position:absolute;left:0;right:0;bottom:12px;display:flex;justify-content:center;gap:8px;z-index:3}
.dm-dot{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.55);cursor:pointer;padding:0;transition:.18s ease}
.dm-dot:hover{background:rgba(255,255,255,.85)}
.dm-dot.is-active{background:#fff;width:26px;border-radius:6px}
@media(max-width:680px){
  .dm-slider{border-radius:10px;margin:14px 0}
  .dm-slider__nav{width:32px;height:32px;font-size:1.1rem}
  .dm-slider__prev{left:8px}.dm-slider__next{right:8px}
  .dm-slider__dots{bottom:8px}
}
@media(prefers-reduced-motion:reduce){.dm-slide{transition:none}}

/* ============================================================
   13. SIDEBAR DE FILTROS (nativo WooCommerce, diseño a medida)
   ============================================================ */
/* La lateral crece con su contenido y deja al navegador hacer scroll de página
 * (antes era sticky + max-height + overflow-y:auto → la lista de Sabor parecía
 * cortarse al expandir). En móvil el drawer (.is-open) gestiona su propio
 * scroll interno via la media query de abajo. */
.dm-shop__side{align-self:start;padding-right:4px}
.dm-filters__bar{display:none}
.dm-filter{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:18px;margin-bottom:16px}
.dm-filter .dm-widget__title{font-size:1rem;font-weight:700;color:var(--dm-ink);margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid var(--dm-teal-soft);display:flex;align-items:center;gap:8px}
.dm-filter .dm-widget__title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dm-teal)}

/* Listas de atributos (Marca/Sabor/Edad) como filas seleccionables */
.woocommerce-widget-layered-nav-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}
.woocommerce-widget-layered-nav-list__item{margin:0!important;padding:0!important}
.woocommerce-widget-layered-nav-list__item a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--dm-radius-sm);color:var(--dm-ink-soft);font-size:.9rem;line-height:1.3;transition:.13s ease}
.woocommerce-widget-layered-nav-list__item a::before{content:"";flex:none;width:18px;height:18px;border:2px solid var(--dm-border);border-radius:5px;background:#fff;transition:.13s ease}
.woocommerce-widget-layered-nav-list__item a:hover{background:var(--dm-teal-soft);color:var(--dm-ink)}
.woocommerce-widget-layered-nav-list__item a:hover::before{border-color:var(--dm-teal)}
.woocommerce-widget-layered-nav-list__item .count{margin-left:auto;font-size:.78rem;color:var(--dm-muted);background:var(--dm-soft);border-radius:999px;padding:1px 9px;font-weight:600}
.woocommerce-widget-layered-nav-list__item.chosen a{color:var(--dm-teal-dark);font-weight:700;background:var(--dm-teal-soft)}
.woocommerce-widget-layered-nav-list__item.chosen a::before{background:var(--dm-teal);border-color:var(--dm-teal);box-shadow:inset 0 0 0 2px #fff}
.woocommerce-widget-layered-nav-list__item.chosen .count{background:#fff;color:var(--dm-teal-dark)}

/* Filtros activos = chips eliminables */
.dm-filter--active .woocommerce-widget-layered-nav-list{flex-direction:row;flex-wrap:wrap;gap:8px;overflow:visible}
.dm-filter--active .woocommerce-widget-layered-nav-list__item a{background:var(--dm-teal);color:#fff;border-radius:999px;padding:5px 12px 5px 14px;font-size:.82rem;font-weight:600;gap:6px}
.dm-filter--active .woocommerce-widget-layered-nav-list__item a::before{display:none}
.dm-filter--active .woocommerce-widget-layered-nav-list__item a::after{content:"\00d7";font-size:1.05rem;line-height:1;opacity:.85}
.dm-filter--active .woocommerce-widget-layered-nav-list__item a:hover{background:var(--dm-sale);color:#fff}

/* Precio: slider jQuery UI estilizado */
.woocommerce-widget-price-filter .price_slider_wrapper{padding-top:4px}
.price_slider.ui-slider{position:relative;height:6px;background:var(--dm-soft);border-radius:999px;margin:18px 6px 22px}
.price_slider .ui-slider-range{position:absolute;height:100%;background:var(--dm-teal);border-radius:999px}
.price_slider .ui-slider-handle{position:absolute;top:50%;width:20px;height:20px;margin-left:-10px;transform:translateY(-50%);background:#fff;border:3px solid var(--dm-teal);border-radius:50%;cursor:grab;box-shadow:var(--dm-shadow);outline:none;touch-action:none}
.price_slider .ui-slider-handle:active{cursor:grabbing}
.woocommerce-widget-price-filter .price_slider_amount{display:flex;align-items:center;flex-wrap:wrap;gap:10px}
.woocommerce-widget-price-filter .price_slider_amount input{display:none}
.woocommerce-widget-price-filter .price_slider_amount .price_label{order:1;flex:1;font-size:.88rem;color:var(--dm-ink);font-weight:700}
.woocommerce-widget-price-filter .price_slider_amount .button{order:2;padding:.55em 1.2em;font-size:.85rem}
.woocommerce-widget-price-filter .clear{display:block;margin-top:8px;font-size:.8rem;color:var(--dm-muted)}

/* FAB + drawer móvil */
.dm-filters__fab{display:none}
.dm-filters__overlay{display:none}
@media(max-width:900px){
  .dm-shop{grid-template-columns:1fr}
  .dm-shop__side{position:fixed;top:0;left:0;bottom:0;width:min(88vw,360px);height:100vh;height:100dvh;background:#fff;z-index:600;padding:0 16px calc(40px + env(safe-area-inset-bottom));transform:translateX(-105%);transition:transform .25s ease;box-shadow:var(--dm-shadow);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .dm-shop__side.is-open{transform:translateX(0)}
  .dm-filters__bar{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;padding:16px 0;margin-bottom:8px;border-bottom:1px solid var(--dm-border);font-weight:700;font-size:1.05rem;z-index:2}
  .dm-filters__close{background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--dm-ink)}
  .dm-filters__overlay.is-open{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:599}
  .dm-filters__fab{display:inline-flex;align-items:center;gap:8px;position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:400;background:var(--dm-ink);color:#fff;border:0;border-radius:999px;padding:.8em 1.5em;font-weight:700;font-size:.95rem;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.22)}
  .dm-filters__fab svg{stroke:#fff}
  /* En el cajón móvil dejamos crecer el panel en línea (lo gestiona el scroll
   * del cajón) y damos algo más de alto a la lista. */
  .dm-mf__panel{max-height:none}
  .dm-mf__list{max-height:50vh;overflow-y:auto}
}

/* Filtro de precio: barra visual + inputs numéricos sincronizados */
.dm-price__slider{position:relative;height:34px;margin:6px 4px 4px}
.dm-price__track{position:absolute;top:15px;left:0;right:0;height:5px;background:var(--dm-soft);border-radius:999px}
.dm-price__fill{position:absolute;top:15px;height:5px;background:var(--dm-teal);border-radius:999px;left:0;width:100%;will-change:left,width}
.dm-price__r{position:absolute;top:0;left:0;width:100%;height:34px;margin:0;background:none;-webkit-appearance:none;appearance:none;pointer-events:none}
.dm-price__r::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;pointer-events:auto;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--dm-teal);box-shadow:var(--dm-shadow);cursor:grab;margin-top:0}
.dm-price__r::-moz-range-thumb{pointer-events:auto;width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--dm-teal);box-shadow:var(--dm-shadow);cursor:grab}
.dm-price__r::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.08)}
.dm-price__r::-webkit-slider-runnable-track{background:none;height:34px}
.dm-price__r::-moz-range-track{background:none;height:34px}
.dm-price__r:focus-visible::-webkit-slider-thumb{outline:2px solid var(--dm-teal);outline-offset:2px}

.dm-price__inputs{display:flex;gap:10px;margin:14px 0 12px}
.dm-price__input{flex:1;min-width:0;position:relative;background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);padding:6px 10px 6px 12px;display:flex;align-items:baseline;gap:6px;transition:.15s ease}
.dm-price__input:focus-within{border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-price__input>span{font-size:.7rem;color:var(--dm-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700;flex:none}
.dm-price__input>input{flex:1;min-width:0;width:100%;border:0;padding:3px 0;font-size:1rem;font-weight:800;color:var(--dm-ink);background:transparent;outline:0;font-family:inherit;-moz-appearance:textfield}
.dm-price__input>input::-webkit-outer-spin-button,
.dm-price__input>input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.dm-price__input>em{font-style:normal;color:var(--dm-muted);font-weight:700;flex:none}

/* ============================================================
   14. CABECERA CENTRADA, ICONOS DE MASCOTA Y POLISH FILTROS
   ============================================================ */

/* Header: marca | buscador centrado | herramientas */
.dm-header__main{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;padding:14px 0}
.dm-header__brand{display:flex;align-items:center;gap:14px;min-width:0}
.dm-search{justify-self:center;width:100%;max-width:560px;flex:none}
.dm-header__tools{margin-left:0}
@media(max-width:900px){
  .dm-header__main{grid-template-columns:auto 1fr auto;gap:14px}
  .dm-search{grid-column:1/-1;justify-self:stretch;max-width:none;order:3}
}

/* SVG de mascotas como máscara → coloreables con la marca.
 * Estructura: <span class="dm-cat-mask"><span class="dm-cat-mask__ico" style="--ico:url(...)"></span></span> */
.dm-cat-mask{width:96px;height:96px;border-radius:50%;background:var(--dm-teal-soft);display:flex;align-items:center;justify-content:center;transition:.18s ease;margin-bottom:12px}
.dm-cat-mask__ico{display:block;width:60%;height:60%;background-color:var(--dm-teal-dark);
  -webkit-mask:var(--ico) center/contain no-repeat;
          mask:var(--ico) center/contain no-repeat;
  transition:.18s ease}
.dm-cat-card:hover .dm-cat-mask{background:var(--dm-teal);transform:scale(1.04)}
.dm-cat-card:hover .dm-cat-mask__ico{background-color:#fff}

/* Iconos en el menú principal de especies (mini máscara) */
.dm-nav__ico{display:inline-block;width:22px;height:22px;flex:none;vertical-align:middle;
  background-color:var(--dm-teal-dark);
  -webkit-mask:var(--ico) center/contain no-repeat;
          mask:var(--ico) center/contain no-repeat;
  transition:.15s ease}
.dm-nav__list>li:hover .dm-nav__ico,
.dm-nav__list>li>a:hover .dm-nav__ico{background-color:var(--dm-teal)}

/* Widget de filtros como <details> colapsable con chevron animado */
.dm-filter{border:1px solid var(--dm-border);border-radius:var(--dm-radius);background:#fff;
  margin-bottom:14px;padding:0;overflow:hidden;transition:border-color .15s ease}
.dm-filter:hover{border-color:#d4d4d4}
.dm-filter[open]{border-color:#d4d4d4}
.dm-widget__title{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;
  padding:14px 18px;margin:0;font-size:.95rem;font-weight:700;color:var(--dm-ink);
  border-bottom:1px solid transparent;transition:.15s ease;user-select:none;-webkit-user-select:none}
.dm-widget__title::-webkit-details-marker{display:none}
.dm-widget__title::marker{display:none;content:""}
.dm-widget__title::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--dm-teal);flex:none}
.dm-widget__title::after{content:"";margin-left:auto;width:9px;height:9px;border-right:2px solid var(--dm-ink-soft);border-bottom:2px solid var(--dm-ink-soft);transform:rotate(45deg);transition:transform .18s ease;flex:none}
.dm-filter[open] .dm-widget__title::after{transform:rotate(225deg)}
.dm-filter[open] .dm-widget__title{border-bottom-color:var(--dm-border)}
.dm-filter[open] .dm-widget__title:hover{background:var(--dm-teal-soft)}
/* Padding interior del contenido tras la cabecera */
.dm-filter>*:not(.dm-widget__title){padding:14px 18px 16px}
.dm-filter--active>*:not(.dm-widget__title){padding-top:12px}

/* Filtros activos: que la cabecera no haga falta abrir si hay pocos chips */
.dm-filter--active{background:linear-gradient(180deg,#fff,var(--dm-teal-soft))}

/* Listas (Marca/Sabor/Edad): sin padding-left heredado del reset (ul{padding-left:1.1em}) */
.woocommerce-widget-layered-nav-list{padding-left:0!important;list-style:none}

/* Paginación: horizontal, sin viñetas (perdido al desencolar CSS de WC) */
.woocommerce-pagination,
.woocommerce nav.woocommerce-pagination{margin:30px 0 0;text-align:center}
.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul{display:inline-flex;flex-wrap:wrap;gap:6px;list-style:none!important;padding:0!important;margin:0;justify-content:center}
.woocommerce-pagination ul li,
.woocommerce nav.woocommerce-pagination ul li{margin:0;border:0;background:none}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{display:block;min-width:38px;padding:.55em .9em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);color:var(--dm-ink);font-weight:600;background:#fff;transition:.15s ease}
.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li a:hover{background:var(--dm-teal-soft);border-color:var(--dm-teal);color:var(--dm-teal-dark)}
.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--dm-teal);color:#fff;border-color:var(--dm-teal)}
.dm-filter--price .dm-btn--block{width:100%}

/* ============================================================
   14. PULIDO v2 — header centrado · iconos mask · filtros collapsables · paginación
   ============================================================ */

/* --- Header: logo izq | buscador centrado | herramientas der ---
 * Columnas laterales 1fr iguales → el buscador queda centrado respecto
 * al header aunque el logo y las herramientas tengan distinto ancho. */
.dm-header__main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding:14px 0}
.dm-header__brand{display:flex;align-items:center;gap:10px;min-width:0;justify-self:start}
.dm-header__main .dm-search{justify-self:center;width:580px;max-width:100%;flex:none}
.dm-header__main .dm-header__tools{margin-left:0;justify-self:end}
@media(max-width:900px){
  .dm-header__main{grid-template-columns:1fr auto;gap:14px}
  .dm-header__main .dm-search{grid-column:1/-1;justify-self:stretch;width:auto;order:3}
}

/* --- Iconos de categoría con CSS mask (color de marca, no blanco invisible) --- */
.dm-cat-mask{
  width:96px;height:96px;border-radius:50%;background:var(--dm-teal-soft);
  display:flex;align-items:center;justify-content:center;transition:.15s ease;flex:none
}
.dm-cat-mask__ico{
  display:block;width:60px;height:60px;
  background-color:var(--dm-teal-dark);
  -webkit-mask:var(--ico) center/contain no-repeat;
          mask:var(--ico) center/contain no-repeat;
  transition:.15s ease
}
.dm-cat-card:hover .dm-cat-mask{background:var(--dm-teal)}
.dm-cat-card:hover .dm-cat-mask__ico{background-color:#fff}
.dm-cat-mask__ico--paw{
  -webkit-mask:none;mask:none;background-color:var(--dm-teal-dark);
  -webkit-mask-image:radial-gradient(circle,#000 40%,transparent 41%);
          mask-image:radial-gradient(circle,#000 40%,transparent 41%)
}
/* anula la regla antigua de img (ya no se emite) */
.dm-cat-card img{background:transparent}

/* --- Iconos en el menú principal (mismo SVG, tamaño pequeño) --- */
.dm-nav__ico{
  display:inline-block;width:22px;height:22px;flex:none;
  background-color:var(--dm-ink);
  -webkit-mask:var(--ico) center/contain no-repeat;
          mask:var(--ico) center/contain no-repeat;
  vertical-align:middle;transition:.15s ease
}
.dm-nav__list>li:hover>a .dm-nav__ico,
.dm-nav__list>li>a:hover .dm-nav__ico{background-color:var(--dm-teal)}
.dm-mobile .dm-nav__ico{width:24px;height:24px}

/* --- Filtros colapsables <details>/<summary> con chevron animado --- */
.dm-filter{padding:0;overflow:hidden}
.dm-filter>.dm-widget__title{
  list-style:none;cursor:pointer;padding:16px 18px;margin:0;border:0;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-size:1rem;font-weight:700;color:var(--dm-ink);background:#fff;
  transition:background .15s ease
}
.dm-filter>.dm-widget__title::-webkit-details-marker{display:none}
.dm-filter>.dm-widget__title::marker{content:""}
.dm-filter>.dm-widget__title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dm-teal);flex:none}
.dm-filter>.dm-widget__title::after{
  content:"";width:11px;height:11px;flex:none;margin-left:auto;
  border-right:2px solid var(--dm-ink-soft);border-bottom:2px solid var(--dm-ink-soft);
  transform:rotate(45deg);transition:transform .2s ease
}
.dm-filter[open]>.dm-widget__title::after{transform:rotate(-135deg);margin-top:4px}
.dm-filter>*:not(summary){padding:0 18px 18px}
.dm-filter>.dm-widget__title:hover{background:var(--dm-soft)}
.dm-filter[open]>.dm-widget__title{border-bottom:1px solid var(--dm-border)}

/* --- Paginación horizontal limpia (perdimos el reset de WC) --- */
.woocommerce nav.woocommerce-pagination,
.woocommerce-pagination{text-align:center;margin:30px 0}
.woocommerce nav.woocommerce-pagination ul,
.woocommerce-pagination ul{
  display:flex!important;flex-wrap:wrap;justify-content:center;gap:6px;
  list-style:none!important;padding:0!important;margin:0!important
}
.woocommerce nav.woocommerce-pagination ul li,
.woocommerce-pagination ul li{
  list-style:none;border:0;margin:0;padding:0;display:block;background:transparent
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;padding:.55em .9em;border:1px solid var(--dm-border);
  border-radius:var(--dm-radius-sm);color:var(--dm-ink);background:#fff;
  font-weight:600;text-decoration:none;transition:.13s ease
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce-pagination ul li a:hover{background:var(--dm-teal-soft);border-color:var(--dm-teal);color:var(--dm-teal-dark)}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce-pagination ul li span.current{background:var(--dm-teal);color:#fff;border-color:var(--dm-teal)}

/* ============================================================
   15. FIX layout filtros: <li> en flex (count a la derecha) + inputs precio compactos
   ============================================================ */

/* Listas Marca / Sabor / Edad: cada <li> es una fila flex con name + count pill */
.woocommerce-widget-layered-nav-list{
  list-style:none!important;padding:0!important;margin:0!important;
  display:flex;flex-direction:column;gap:1px;max-height:260px;overflow-y:auto
}
.woocommerce-widget-layered-nav-list__item{
  display:flex!important;align-items:center;gap:8px;
  padding:0!important;margin:0!important;border-radius:var(--dm-radius-sm);
  transition:.13s ease
}
.woocommerce-widget-layered-nav-list__item:hover{background:var(--dm-teal-soft)}
.woocommerce-widget-layered-nav-list__item>a{
  flex:1;min-width:0;display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:var(--dm-radius-sm);
  color:var(--dm-ink-soft);font-size:.9rem;line-height:1.3;text-decoration:none;
  transition:.13s ease
}
.woocommerce-widget-layered-nav-list__item>a::before{
  content:"";flex:none;width:16px;height:16px;
  border:2px solid var(--dm-border);border-radius:4px;background:#fff;
  transition:.13s ease
}
.woocommerce-widget-layered-nav-list__item>a:hover{color:var(--dm-ink)}
.woocommerce-widget-layered-nav-list__item>a:hover::before{border-color:var(--dm-teal)}
.woocommerce-widget-layered-nav-list__item>.count{
  flex:none;margin:0 10px 0 auto!important;
  font-size:.74rem;color:var(--dm-muted);background:var(--dm-soft);
  border-radius:999px;padding:2px 9px;font-weight:600;line-height:1.3
}
/* chosen (con filtro aplicado) */
.woocommerce-widget-layered-nav-list__item.chosen{background:var(--dm-teal-soft)}
.woocommerce-widget-layered-nav-list__item.chosen>a{color:var(--dm-teal-dark);font-weight:700}
.woocommerce-widget-layered-nav-list__item.chosen>a::before{
  background:var(--dm-teal);border-color:var(--dm-teal);
  background-image:linear-gradient(45deg,transparent 35%,#fff 35% 45%,transparent 45% 55%,#fff 55% 70%,transparent 70%);
  background-size:14px 14px;background-position:1px 1px;background-repeat:no-repeat
}
.woocommerce-widget-layered-nav-list__item.chosen>.count{background:#fff;color:var(--dm-teal-dark)}

/* Filtros activos (chips) — sin checkbox, con × al final */
.dm-filter--active .woocommerce-widget-layered-nav-list{flex-direction:row;flex-wrap:wrap;gap:6px;max-height:none;overflow:visible}
.dm-filter--active .woocommerce-widget-layered-nav-list__item{padding:0!important;background:none!important}
.dm-filter--active .woocommerce-widget-layered-nav-list__item>a{
  background:var(--dm-teal);color:#fff;border-radius:999px;
  padding:5px 12px 5px 14px;font-size:.8rem;font-weight:600;gap:6px;flex:none
}
.dm-filter--active .woocommerce-widget-layered-nav-list__item>a::before{display:none}
.dm-filter--active .woocommerce-widget-layered-nav-list__item>a::after{content:"\00d7";font-size:1.05rem;line-height:1;opacity:.85;margin-left:2px}
.dm-filter--active .woocommerce-widget-layered-nav-list__item>a:hover{background:var(--dm-sale)}

/* Precio: inputs compactos con label arriba (cabe el número y el €) */
.dm-price__inputs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:14px 0 10px}
.dm-price__input{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  padding:6px 10px 4px;display:block;position:relative;transition:.15s ease
}
.dm-price__input:focus-within{border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-price__input>span{
  display:block;font-size:.62rem;color:var(--dm-muted);
  text-transform:uppercase;letter-spacing:.05em;font-weight:700;margin:0 0 2px
}
.dm-price__input>input{
  display:inline-block;width:60%;max-width:75px;min-width:36px;
  border:0;background:transparent;padding:0;
  font-size:.95rem;font-weight:800;color:var(--dm-ink);
  outline:0;font-family:inherit;-moz-appearance:textfield
}
.dm-price__input>input::-webkit-outer-spin-button,
.dm-price__input>input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.dm-price__input>em{font-style:normal;color:var(--dm-muted);font-weight:700;margin-left:1px}

/* Botón Aplicar más fino */
.dm-filter--price .dm-btn--block{padding:.55em 1em;font-size:.86rem;width:100%}

/* ============================================================
   16. MULTI-SELECT compacto con búsqueda (Marca/Sabor/Edad)
   ============================================================ */
.dm-filters-form{display:flex;flex-direction:column;gap:10px}
.dm-filters__apply{margin-top:6px;padding:.7em 1em!important;font-size:.92rem!important}

.dm-mf{position:relative;background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);transition:.13s ease}
.dm-mf:focus-within{border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-mf__btn{
  display:flex;align-items:center;gap:10px;width:100%;
  background:transparent;border:0;padding:11px 14px;
  cursor:pointer;text-align:left;font-family:inherit;font-size:.92rem;color:var(--dm-ink);
  min-height:44px
}
.dm-mf__label{font-weight:700;flex:none}
.dm-mf__chips{flex:1;display:flex;gap:4px;flex-wrap:wrap;min-width:0;justify-content:flex-end;align-items:center}
.dm-mf__chip{
  background:var(--dm-teal-soft);color:var(--dm-teal-dark);
  font-size:.74rem;padding:2px 9px;border-radius:999px;font-weight:600;
  white-space:nowrap;max-width:110px;overflow:hidden;text-overflow:ellipsis
}
.dm-mf__chip--more{background:var(--dm-teal);color:#fff}
.dm-mf__placeholder{color:var(--dm-muted);font-size:.85rem;font-weight:500}
.dm-mf__caret{flex:none;color:var(--dm-muted);transition:transform .15s ease;font-size:.85rem}
.dm-mf__btn[aria-expanded="true"] .dm-mf__caret{transform:rotate(180deg)}

/* Panel EN LÍNEA (acordeón): al abrirse empuja los siguientes filtros hacia
 * abajo en vez de flotar encima, así todos los filtros quedan siempre visibles
 * (tanto en desktop como en móvil). */
.dm-mf__panel{
  position:static;margin:0;padding:8px 10px 10px;
  border-top:1px solid var(--dm-border);
  background:transparent;box-shadow:none;
  max-height:340px;display:flex;flex-direction:column
}
.dm-mf__panel[hidden]{display:none}
.dm-mf__search{
  width:100%;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  padding:7px 10px;font-size:.85rem;margin-bottom:8px;outline:0;font-family:inherit
}
.dm-mf__search:focus{border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-mf__list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}
.dm-mf__list li{margin:0;padding:0;list-style:none}
.dm-mf__list label{
  display:flex;align-items:center;gap:9px;padding:7px 8px;cursor:pointer;
  border-radius:var(--dm-radius-sm);font-size:.88rem;color:var(--dm-ink-soft);transition:.1s ease
}
.dm-mf__list label:hover{background:var(--dm-teal-soft);color:var(--dm-ink)}
.dm-mf__list input[type="checkbox"]{
  accent-color:var(--dm-teal);width:16px;height:16px;flex:none;margin:0;cursor:pointer
}
.dm-mf__name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dm-mf__count{
  flex:none;font-size:.74rem;color:var(--dm-muted);background:var(--dm-soft);
  border-radius:999px;padding:2px 8px;font-weight:600
}
.dm-mf__list li[hidden]{display:none}

/* ============================================================
   15. MI CUENTA / CARRITO / FINALIZAR COMPRA — diseño dedicado
   ============================================================ */

/* Contenedor común WooCommerce dentro de .dm-wrap */
.dm-woo>.woocommerce{margin:8px 0 40px}
.dm-woo .page-title,
.woocommerce-account .entry-title,
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title{font-size:1.9rem;margin:18px 0 22px}

/* Mensajes WooCommerce (notices) */
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  border:1px solid var(--dm-teal);border-left-width:4px;border-radius:var(--dm-radius);
  background:var(--dm-teal-soft);color:var(--dm-ink);padding:14px 20px;margin:0 0 22px;
  list-style:none;display:flex;align-items:center;gap:14px;font-size:.92rem
}
.woocommerce-error{border-color:var(--dm-sale);background:#fdecea;color:#7a1f1a}
.woocommerce-message .button,.woocommerce-info .button{margin-left:auto}

/* =====================  MI CUENTA  ===================== */

/* Cart / Checkout / Account: la página NO debe limitarse a 860px del .dm-page */
.woocommerce-account .dm-page,
.woocommerce-cart .dm-page,
.woocommerce-checkout .dm-page{max-width:none;margin:0;padding:24px 0 40px}

/* Título grande del header: lo centramos y le damos aire */
.woocommerce-account .dm-page>h1,
.woocommerce-cart .dm-page>h1,
.woocommerce-checkout .dm-page>h1{
  text-align:center;font-size:1.9rem;margin:8px 0 6px;color:var(--dm-ink)
}
.woocommerce-account .dm-page>h1::after,
.woocommerce-cart .dm-page>h1::after,
.woocommerce-checkout .dm-page>h1::after{
  content:"";display:block;width:48px;height:4px;background:var(--dm-teal);border-radius:2px;margin:10px auto 0
}

/* ---------- Mi cuenta — logged-out: dos tarjetas ---------- */
.woocommerce-account:not(.logged-in) .dm-entry::before{
  content:"Accede a tu cuenta o regístrate para gestionar tus pedidos y direcciones de envío.";
  display:block;text-align:center;color:var(--dm-muted);font-size:1rem;margin:0 auto 26px;max-width:560px
}
.woocommerce-account:not(.logged-in) .u-columns#customer_login{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:0 auto;max-width:920px
}
.woocommerce-account:not(.logged-in) #customer_login>div{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  padding:34px 36px 32px;box-shadow:0 1px 3px rgba(0,0,0,.04);
  position:relative;overflow:hidden
}
.woocommerce-account:not(.logged-in) #customer_login>div::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--dm-teal)
}
.woocommerce-account:not(.logged-in) #customer_login .u-column2::before{background:var(--dm-ink)}
.woocommerce-account:not(.logged-in) #customer_login h2{
  font-size:1.35rem;margin:6px 0 22px;color:var(--dm-ink);
  display:flex;align-items:center;gap:10px
}
.woocommerce-account:not(.logged-in) #customer_login h2::before{
  content:"";width:32px;height:32px;border-radius:50%;background:var(--dm-teal-soft);
  -webkit-mask:no-repeat center / 60% url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.8'><circle cx='12' cy='8' r='4'/><path d='M4 21c0-4.4 3.6-7 8-7s8 2.6 8 7'/></svg>");
  background-position:center;background-repeat:no-repeat;background-size:60%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23019184' stroke-width='1.8'><circle cx='12' cy='8' r='4'/><path d='M4 21c0-4.4 3.6-7 8-7s8 2.6 8 7'/></svg>")
}
.woocommerce-account:not(.logged-in) #customer_login .u-column2 h2::before{
  background-color:#efe9dc;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233f3526' stroke-width='1.8'><path d='M16 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/><circle cx='8.5' cy='7' r='4'/><path d='M20 8v6M17 11h6'/></svg>")
}

/* ---- Form rows: labels arriba (block), inputs full width ---- */
.woocommerce-account .woocommerce form .form-row,
.woocommerce-cart .woocommerce form .form-row,
.woocommerce-checkout .woocommerce form .form-row{
  display:block;margin:0 0 14px;padding:0
}
.woocommerce-account .woocommerce form .form-row label,
.woocommerce-account .woocommerce form-row label{
  display:block;font-weight:600;font-size:.84rem;color:var(--dm-ink);margin:0 0 6px
}
.woocommerce-account .woocommerce form .form-row .required{color:var(--dm-sale);text-decoration:none}
.woocommerce-account .woocommerce form .form-row input.input-text,
.woocommerce-account .woocommerce form .form-row .woocommerce-Input,
.woocommerce-account .woocommerce form .form-row input[type="text"],
.woocommerce-account .woocommerce form .form-row input[type="email"],
.woocommerce-account .woocommerce form .form-row input[type="password"],
.woocommerce-account .woocommerce form .form-row textarea{
  width:100%;padding:.75em .9em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--dm-ink);transition:.13s ease;height:auto
}
.woocommerce-account .woocommerce form .form-row input:focus,
.woocommerce-account .woocommerce form .form-row textarea:focus{
  outline:0;border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)
}

/* Quitar el efecto "ojo" raro de algunos navegadores en password */
input[type="password"]::-ms-reveal,
input[type="password"]::-ms-clear,
input[type="password"]::-webkit-credentials-auto-fill-button{display:none!important}

/* Botón "mostrar contraseña" de WooCommerce (.password-input wrapper) */
.woocommerce form .form-row .password-input{position:relative;display:block;width:100%}
.woocommerce form .form-row .password-input input{padding-right:42px}
.woocommerce form .form-row button.show-password-input{
  position:absolute;top:50%;right:10px;transform:translateY(-50%);
  width:28px;height:28px;border:0;background:none;cursor:pointer;padding:0;color:var(--dm-muted);
  display:flex;align-items:center;justify-content:center;border-radius:4px
}
.woocommerce form .form-row button.show-password-input:hover{color:var(--dm-teal-dark);background:var(--dm-teal-soft)}
.woocommerce form .form-row button.show-password-input::before{
  content:"";width:20px;height:20px;display:block;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236d6d6d' stroke-width='1.8'><path d='M2 12s3.5-7 10-7 10 7 10 7-3.5 7-10 7S2 12 2 12z'/><circle cx='12' cy='12' r='3'/></svg>")
}
.woocommerce form .form-row button.show-password-input.display-password::before{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23019184' stroke-width='1.8'><path d='M3 3l18 18M10.6 6.1A10 10 0 0 1 12 6c6.5 0 10 6 10 6a16 16 0 0 1-3.6 4.4M6.6 6.6A16 16 0 0 0 2 12s3.5 6 10 6c1.6 0 3-.3 4.3-.8'/><path d='M9.6 9.6a3 3 0 0 0 4.2 4.2'/></svg>")
}
.woocommerce form .form-row button.show-password-input span{display:none}

/* Borrar cualquier border/padding/background residual del <form> de WC */
.woocommerce-account .woocommerce-form.login,
.woocommerce-account .woocommerce-form.register{
  border:0;padding:0;margin:0;background:transparent;box-shadow:none
}

/* Recuérdame + botón + olvidaste */
.woocommerce-form-login__rememberme{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--dm-ink-soft);font-size:.9rem;margin:0 0 14px}
.woocommerce-form-login__rememberme input{accent-color:var(--dm-teal);width:16px;height:16px;margin:0;cursor:pointer}
.woocommerce-form-login__submit,
.woocommerce-form-register__submit{display:block;width:100%;padding:.9em 1.4em;font-size:1rem;margin:6px 0 0}
.woocommerce-LostPassword{margin:14px 0 0;text-align:center;font-size:.86rem}
.woocommerce-LostPassword a{color:var(--dm-teal-dark);font-weight:600}
.woocommerce-form-register .woocommerce-privacy-policy-text{font-size:.78rem;color:var(--dm-muted);margin:0 0 14px;line-height:1.45}
.woocommerce-form-register .woocommerce-privacy-policy-text p{margin:0}

@media(max-width:760px){
  .woocommerce-account:not(.logged-in) .u-columns#customer_login{grid-template-columns:1fr;gap:18px}
  .woocommerce-account:not(.logged-in) #customer_login>div{padding:28px 24px 26px}
  .woocommerce-account:not(.logged-in) .dm-entry::before{font-size:.95rem;margin-bottom:18px}
}

/* Logged-in: nav + content */
.woocommerce-account.logged-in .woocommerce{
  display:grid;grid-template-columns:240px 1fr;gap:34px;align-items:start
}
.woocommerce-MyAccount-navigation{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);overflow:hidden;position:sticky;top:96px}
.woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0}
.woocommerce-MyAccount-navigation li{border:0;margin:0}
.woocommerce-MyAccount-navigation li a{
  display:flex;align-items:center;gap:10px;padding:13px 18px;color:var(--dm-ink);font-weight:600;font-size:.92rem;
  border-bottom:1px solid var(--dm-border);transition:.13s ease
}
.woocommerce-MyAccount-navigation li:last-child a{border-bottom:0}
.woocommerce-MyAccount-navigation li a:hover{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.woocommerce-MyAccount-navigation li.is-active a{
  background:var(--dm-teal);color:#fff;border-left:4px solid var(--dm-teal-dark);padding-left:14px
}
.woocommerce-MyAccount-content{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  padding:28px 32px;margin:0;min-width:0
}
.woocommerce-MyAccount-content p{margin-bottom:14px}
.woocommerce-MyAccount-content table{margin:0 0 14px}
@media(max-width:860px){
  .woocommerce-account.logged-in .woocommerce{grid-template-columns:1fr;gap:18px}
  .woocommerce-MyAccount-navigation{position:static}
}

/* =====================  CARRITO  ===================== */

/* Cart: la columna derecha (Totales) FIJA a 320px → la izquierda (form con
 * el cart-table) recibe todo el espacio restante y los headers PRECIO /
 * CANTIDAD / SUBTOTAL ya no se truncan. */
.woocommerce-cart .woocommerce{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:30px;align-items:start
}
/* Notices ocupan TODO el ancho; form siempre izquierda, totales siempre derecha
 * (la notice "X se ha añadido al carrito" estaba comiéndose la 1ª celda y los
 * elementos quedaban intercambiados). */
.woocommerce-cart .woocommerce>.woocommerce-notices-wrapper,
.woocommerce-cart .woocommerce>.woocommerce-message,
.woocommerce-cart .woocommerce>.woocommerce-info,
.woocommerce-cart .woocommerce>.woocommerce-error{grid-column:1/-1}
.woocommerce-cart .woocommerce-cart-form{grid-column:1}
.woocommerce-cart .cart-collaterals{grid-column:2}
.woocommerce-cart-form{min-width:0}
.woocommerce-cart-form table.shop_table{
  width:100%;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  border-collapse:separate;border-spacing:0;overflow:hidden;background:#fff
}
.woocommerce-cart-form table.shop_table thead th{
  background:var(--dm-soft);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--dm-ink-soft);
  font-weight:700;padding:14px 16px;text-align:left;border-bottom:1px solid var(--dm-border)
}
.woocommerce-cart-form table.shop_table td{
  padding:18px 16px;border-bottom:1px solid var(--dm-border);vertical-align:middle;font-size:.93rem
}
.woocommerce-cart-form tr:last-child td{border-bottom:0}
/* La columna y la imagen necesitan anchos explícitos. El global
 * img{max-width:100%} hace bucle con la columna auto-size y la imagen
 * acaba renderizándose a 3px → max-width:none aquí lo libera. */
.woocommerce-cart-form .product-thumbnail{width:96px}
.woocommerce-cart-form .product-thumbnail a{display:block}
.woocommerce-cart-form .product-thumbnail img{max-width:none!important;width:78px!important;height:78px!important;object-fit:contain;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);background:#fff;display:block}
.woocommerce-cart-form .product-name a{color:var(--dm-ink);font-weight:600}
.woocommerce-cart-form .product-name a:hover{color:var(--dm-teal-dark)}
.woocommerce-cart-form .product-remove a.remove{
  display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;
  border-radius:50%;background:var(--dm-soft);color:var(--dm-ink)!important;font-size:1.05rem;text-decoration:none;
  transition:.13s ease
}
.woocommerce-cart-form .product-remove a.remove:hover{background:var(--dm-sale);color:#fff!important}
.woocommerce-cart-form .quantity input.qty{
  width:74px;padding:.55em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  text-align:center;font-family:inherit;font-weight:600
}
.woocommerce-cart-form .product-subtotal,.woocommerce-cart-form .product-price{font-weight:700;color:var(--dm-ink)}

/* Fila inferior (cupón + actualizar) */
.woocommerce-cart-form .actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:18px 16px;background:var(--dm-soft);border-top:1px solid var(--dm-border)}
.woocommerce-cart-form .actions .coupon{display:flex;gap:8px;flex:1;min-width:240px}
.woocommerce-cart-form .actions .coupon input{flex:1;padding:.6em .85em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);font-family:inherit}
.woocommerce-cart-form .actions button[name="update_cart"]{background:#fff!important;color:var(--dm-ink)!important;border:1px solid var(--dm-border)!important}
.woocommerce-cart-form .actions button[name="update_cart"]:hover{border-color:var(--dm-teal)!important;color:var(--dm-teal-dark)!important}

/* Cart totals (lateral derecho) */
.woocommerce-cart .cart-collaterals{position:sticky;top:96px;align-self:start;min-width:0}
.woocommerce-cart .cart_totals{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:24px 26px
}
.woocommerce-cart .cart_totals h2{font-size:1.1rem;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--dm-teal-soft);
  display:flex;align-items:center;gap:8px}
.woocommerce-cart .cart_totals h2::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dm-teal)}
.woocommerce-cart .cart_totals table{width:100%;border:0;margin:0 0 18px}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td{padding:10px 0;border:0;border-bottom:1px solid var(--dm-border);font-size:.92rem;background:none}
.woocommerce-cart .cart_totals table tr:last-child th,
.woocommerce-cart .cart_totals table tr:last-child td{border-bottom:0}
.woocommerce-cart .cart_totals .order-total td,
.woocommerce-cart .cart_totals .order-total th{font-size:1.05rem;font-weight:800;color:var(--dm-ink);padding-top:14px}
.woocommerce-cart .wc-proceed-to-checkout{margin:0;padding:0}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button{display:block;text-align:center;font-size:1rem;padding:.85em 1.4em}

@media(max-width:860px){
  .woocommerce-cart .woocommerce{grid-template-columns:1fr}
  /* En 1 columna, formulario y totales deben apilarse (si conservan
   * grid-column:1 / grid-column:2 los totales se van a columna implícita). */
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .cart-collaterals{grid-column:1/-1}
  .woocommerce-cart .cart-collaterals{position:static}
  .woocommerce-cart-form table.shop_table thead{display:none}
  .woocommerce-cart-form table.shop_table tr.cart_item{display:grid;grid-template-columns:78px 1fr auto;gap:8px 14px;padding:14px;border-bottom:1px solid var(--dm-border)}
  .woocommerce-cart-form table.shop_table tr.cart_item td{padding:0;border:0}
  .woocommerce-cart-form .product-remove{grid-column:3;grid-row:1;justify-self:end}
  .woocommerce-cart-form .product-thumbnail{grid-column:1;grid-row:1/4}
  .woocommerce-cart-form .product-name{grid-column:2;grid-row:1}
  .woocommerce-cart-form .product-price{grid-column:2;grid-row:2;color:var(--dm-muted);font-weight:500;font-size:.85rem}
  .woocommerce-cart-form .product-quantity{grid-column:2;grid-row:3}
  .woocommerce-cart-form .product-subtotal{grid-column:3;grid-row:2/4;align-self:end}
}

/* =====================  FINALIZAR COMPRA  ===================== */

.woocommerce-checkout form.checkout{
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);
  grid-template-rows:auto 1fr;gap:0 36px;align-items:start
}
.woocommerce-checkout #customer_details{min-width:0;grid-column:1;grid-row:1/3}
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2{width:auto!important;float:none!important;margin:0 0 22px!important}
.woocommerce-checkout #order_review_heading{font-size:1.1rem;margin:0 0 12px;padding-bottom:12px;border-bottom:2px solid var(--dm-teal-soft);
  display:flex;align-items:center;gap:8px}
.woocommerce-checkout #order_review_heading::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dm-teal)}

/* Bloque resumen + pago a la derecha, sticky */
.woocommerce-checkout #order_review_heading{grid-column:2;grid-row:1}
.woocommerce-checkout #order_review{
  grid-column:2;grid-row:2;align-self:start;
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  padding:22px 24px;position:sticky;top:96px
}
.woocommerce-checkout #order_review table.shop_table{border:0;width:100%;margin:0 0 8px}
/* Miniatura del producto en el resumen del pedido */
.dm-co-item{display:flex;align-items:center;gap:10px}
.dm-co-item__img{flex:none;line-height:0}
.dm-co-item__img img{width:48px;height:48px;object-fit:contain;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);background:#fff;display:block;margin:0}
.dm-co-item__name{flex:1;min-width:0}
.woocommerce-checkout #order_review table th,
.woocommerce-checkout #order_review table td{padding:10px 0;border:0;border-bottom:1px solid var(--dm-border);font-size:.92rem;background:none}
.woocommerce-checkout #order_review table tfoot .order-total td,
.woocommerce-checkout #order_review table tfoot .order-total th{font-size:1.1rem;font-weight:800;padding-top:14px;color:var(--dm-ink)}

/* Datos de facturación: agrupados en card */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  padding:22px 24px 8px;margin-bottom:18px
}
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3{font-size:1.05rem;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--dm-teal-soft);
  display:flex;align-items:center;gap:8px}
.woocommerce-checkout .woocommerce-billing-fields h3::before,
.woocommerce-checkout .woocommerce-shipping-fields h3::before,
.woocommerce-checkout .woocommerce-additional-fields h3::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dm-teal)}

/* Inputs y grilla de campos */
.woocommerce-checkout .form-row{margin:0 0 14px;padding:0}
.woocommerce-checkout .form-row label{display:block;font-weight:600;font-size:.84rem;color:var(--dm-ink);margin-bottom:5px}
.woocommerce-checkout .form-row .required{color:var(--dm-sale);font-weight:600}
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-container .select2-selection--single{
  width:100%;padding:.7em .85em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  font-family:inherit;font-size:.94rem;background:#fff;transition:.13s ease;height:auto
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row textarea:focus,
.woocommerce-checkout .form-row select:focus{border-color:var(--dm-teal);outline:0;box-shadow:0 0 0 3px var(--dm-teal-soft)}
/* Facturación: rejilla de 6 columnas → filas de 2 (span 3), de 3 (span 2)
 * y campos a ancho completo (span 6). El orden de los campos se fija por
 * prioridad en dm_reorder_checkout_fields(). */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper{display:grid;grid-template-columns:repeat(6,1fr);gap:0 14px}
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper{display:grid;grid-template-columns:repeat(6,1fr);gap:0 14px}
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper .form-row-wide,
.woocommerce-checkout .form-row-full,
.woocommerce-checkout #billing_country_field,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #billing_address_2_field,
.woocommerce-checkout #shipping_address_1_field,
.woocommerce-checkout #shipping_address_2_field,
.woocommerce-checkout #order_comments_field,
.woocommerce-checkout #account_password_field,
.woocommerce-checkout #ship-to-different-address{grid-column:1/-1}
/* Facturación — dos por fila */
.woocommerce-checkout #billing_first_name_field,
.woocommerce-checkout #billing_last_name_field,
.woocommerce-checkout #billing_company_field,
.woocommerce-checkout #billing_nif_field,
.woocommerce-checkout #billing_phone_field,
.woocommerce-checkout #billing_email_field{grid-column:span 3}
/* Facturación — fila de tres: CP / población / provincia */
.woocommerce-checkout #billing_postcode_field,
.woocommerce-checkout #billing_city_field,
.woocommerce-checkout #billing_state_field{grid-column:span 2}
/* Orden visual fijo de los campos (robusto ante cualquier orden del HTML) */
.woocommerce-checkout #billing_first_name_field{order:1}
.woocommerce-checkout #billing_last_name_field{order:2}
.woocommerce-checkout #billing_company_field{order:3}
.woocommerce-checkout #billing_nif_field{order:4}
.woocommerce-checkout #billing_phone_field{order:5}
.woocommerce-checkout #billing_email_field{order:6}
.woocommerce-checkout #billing_country_field{order:7}
.woocommerce-checkout #billing_address_1_field{order:8}
.woocommerce-checkout #billing_address_2_field{order:9}
.woocommerce-checkout #billing_postcode_field{order:10}
.woocommerce-checkout #billing_city_field{order:11}
.woocommerce-checkout #billing_state_field{order:12}

/* Envío a otra dirección — mismo grid, anchos y orden que facturación */
.woocommerce-checkout #shipping_first_name_field,
.woocommerce-checkout #shipping_last_name_field,
.woocommerce-checkout #shipping_phone_field,
.woocommerce-checkout #shipping_email_field{grid-column:span 3}
.woocommerce-checkout #shipping_country_field{grid-column:1/-1}
.woocommerce-checkout #shipping_postcode_field,
.woocommerce-checkout #shipping_city_field,
.woocommerce-checkout #shipping_state_field{grid-column:span 2}
.woocommerce-checkout #shipping_first_name_field{order:1}
.woocommerce-checkout #shipping_last_name_field{order:2}
.woocommerce-checkout #shipping_phone_field{order:5}
.woocommerce-checkout #shipping_email_field{order:6}
.woocommerce-checkout #shipping_country_field{order:7}
.woocommerce-checkout #shipping_address_1_field{order:8}
.woocommerce-checkout #shipping_address_2_field{order:9}
.woocommerce-checkout #shipping_postcode_field{order:10}
.woocommerce-checkout #shipping_city_field{order:11}
.woocommerce-checkout #shipping_state_field{order:12}

/* Métodos de pago como tarjetas */
.woocommerce-checkout #payment{background:none;border:0;padding:0;margin-top:14px}
.woocommerce-checkout #payment .payment_methods{list-style:none;margin:0 0 14px;padding:0;border:0;display:flex;flex-direction:column;gap:10px}
.woocommerce-checkout #payment .payment_methods>li{
  background:var(--dm-soft);border:2px solid var(--dm-border);border-radius:var(--dm-radius);padding:14px 16px;list-style:none;transition:.13s ease
}
.woocommerce-checkout #payment .payment_methods>li:hover{border-color:var(--dm-teal-soft)}
.woocommerce-checkout #payment .payment_methods>li.wc_payment_method input[type="radio"]:checked + label,
.woocommerce-checkout #payment .payment_methods>li:has(input[type="radio"]:checked){border-color:var(--dm-teal);background:#fff}
.woocommerce-checkout #payment .payment_methods>li>label{
  display:flex;align-items:center;gap:10px;font-weight:600;color:var(--dm-ink);cursor:pointer;font-size:.95rem;margin:0!important
}
.woocommerce-checkout #payment .payment_methods>li>label img{max-height:22px;margin-left:auto}
.woocommerce-checkout #payment .payment_methods>li>input[type="radio"]{accent-color:var(--dm-teal);width:18px;height:18px;margin:0 4px 0 0;flex:none}
.woocommerce-checkout #payment .payment_box{
  background:#fff;border-top:1px dashed var(--dm-border);margin-top:12px;padding:12px 0 4px;font-size:.85rem;color:var(--dm-muted)
}

/* Política privacidad + términos + botón Realizar pedido */
.woocommerce-checkout .woocommerce-privacy-policy-text{font-size:.78rem;color:var(--dm-muted);margin:14px 0}
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper{margin:8px 0 16px}
.woocommerce-checkout .form-row.place-order{margin:18px 0 0}
.woocommerce-checkout #place_order{width:100%;font-size:1.05rem;padding:.95em 1.4em}

@media(max-width:860px){
  .woocommerce-checkout form.checkout{grid-template-columns:1fr;grid-template-rows:none}
  .woocommerce-checkout #customer_details{grid-column:1;grid-row:auto}
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review{grid-column:1;grid-row:auto}
  .woocommerce-checkout #order_review{position:static}
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper{grid-template-columns:1fr}
  /* En 1 columna, todos los campos a ancho completo (anula los span de escritorio) */
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper>p,
  .woocommerce-checkout .woocommerce-shipping-fields__field-wrapper>p{grid-column:1/-1!important}
}

/* ============================================================
   16. PÁGINA DE CONTACTO
   ============================================================ */
.dm-contact{padding:24px 18px 48px}
.dm-contact__hero{text-align:center;margin:8px auto 28px;max-width:680px}
.dm-contact__hero h1{font-size:2.2rem;margin:0 0 .35em}
.dm-contact__hero p{color:var(--dm-muted);font-size:1.05rem;margin:0}

.dm-contact__notice{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-radius:var(--dm-radius);margin:0 0 24px;font-size:.95rem}
.dm-contact__notice strong{display:block;font-weight:700;margin-bottom:2px}
.dm-contact__notice--ok{background:var(--dm-teal-soft);border:1px solid var(--dm-teal);color:var(--dm-ink)}
.dm-contact__notice--ok svg{stroke:var(--dm-teal-dark);flex:none}
.dm-contact__notice--err{background:#fdecea;border:1px solid var(--dm-sale);color:#7a1f1a}

.dm-contact__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:30px;align-items:start;margin:0 0 36px}

/* Tarjeta info */
.dm-contact__info{background:linear-gradient(180deg,var(--dm-ink) 0%, #2b2519 100%);color:#e9e3d6;border-radius:var(--dm-radius);padding:30px 28px;position:sticky;top:96px}
.dm-contact__info h2{color:#fff;font-size:1.25rem;margin:0 0 22px;display:flex;align-items:center;gap:10px}
.dm-contact__info h2::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--dm-teal)}
.dm-contact__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.dm-contact__list li{display:flex;align-items:flex-start;gap:14px;line-height:1.45}
.dm-contact__ico{flex:none;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--dm-teal);display:flex;align-items:center;justify-content:center}
.dm-contact__ico svg{width:22px;height:22px}
.dm-contact__lbl{display:block;color:#cfc8bd;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:3px}
.dm-contact__list a{color:#fff;font-weight:600}
.dm-contact__list a:hover{color:var(--dm-teal)}
.dm-contact__list li>div{min-width:0}
.dm-contact__list li>div>span:not(.dm-contact__lbl){color:#fff}
.dm-contact__directions{display:inline-block;margin-top:24px;color:var(--dm-teal)!important;font-weight:700;font-size:.92rem;border-bottom:2px solid transparent;transition:.15s ease}
.dm-contact__directions:hover{border-bottom-color:var(--dm-teal);color:#fff!important}

/* Formulario */
.dm-contact__formwrap{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:30px 32px}
.dm-contact__formwrap h2{font-size:1.35rem;margin:0 0 4px;color:var(--dm-ink)}
.dm-contact__sub{color:var(--dm-muted);font-size:.92rem;margin:0 0 22px}
.dm-contact__form{display:flex;flex-direction:column;gap:14px}
.dm-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.dm-field{display:flex;flex-direction:column;gap:6px}
.dm-field>span{font-size:.84rem;font-weight:600;color:var(--dm-ink)}
.dm-field>span>i{font-style:normal;color:var(--dm-sale)}
.dm-field input,.dm-field textarea{
  width:100%;padding:.75em .9em;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--dm-ink);transition:.13s ease;resize:vertical
}
.dm-field input:focus,.dm-field textarea:focus{outline:0;border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-check{display:flex;align-items:flex-start;gap:10px;font-size:.86rem;color:var(--dm-ink-soft);line-height:1.4;margin:6px 0 2px}
.dm-check input{accent-color:var(--dm-teal);width:16px;height:16px;margin:3px 0 0;flex:none}
.dm-check a{color:var(--dm-teal-dark);text-decoration:underline}
.dm-contact__form .dm-btn--block{margin-top:6px;padding:.95em 1.4em;font-size:1rem}

/* Mapa */
.dm-contact__map{border-radius:var(--dm-radius);overflow:hidden;border:1px solid var(--dm-border);box-shadow:0 1px 3px rgba(0,0,0,.04)}
.dm-contact__map iframe{display:block;width:100%}

@media(max-width:860px){
  .dm-contact__grid{grid-template-columns:1fr}
  .dm-contact__info{position:static}
  .dm-contact__formwrap{padding:24px 22px}
  .dm-field-row{grid-template-columns:1fr}
  .dm-contact__hero h1{font-size:1.7rem}
}

/* ============================================================
   17. BREADCRUMB / PRECIO €KG / MARCA EN TITULO / CARD ENTERA
   ============================================================ */

/* Breadcrumb fila — full-width arriba */
.dm-breadrow{padding:12px 18px 6px}

/* Banner de categoría (entre título y descripción) */
.dm-cat-banner{margin:14px 0 20px}
.dm-cat-banner__img{display:block;width:100%;height:auto;border-radius:var(--dm-radius)}

/* Página de marca: banner ancho completo + 3 imágenes en fila */
.dm-brand-banner{margin:14px 0 16px}
.dm-brand-banner__img{display:block;width:100%;height:auto;border-radius:var(--dm-radius)}
.dm-brand-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:0 0 20px}
.dm-brand-imgs__img{display:block;width:100%;height:auto;border-radius:var(--dm-radius)}
.dm-brand-imgs__link{display:block}
.dm-brand-banner__link{display:block}
@media(max-width:640px){.dm-brand-imgs{gap:10px}}

/* ===== Blog: listado de entradas ===== */
.dm-blog{padding:34px 20px 52px}
.dm-blog__head{text-align:center;margin-bottom:30px}
.dm-blog__head h1{font-size:2rem;margin:0 0 8px}
.dm-blog__sub{color:var(--dm-muted);font-size:1rem;margin:0}
.dm-blog__empty{text-align:center;color:var(--dm-muted);padding:46px 0}
.dm-postlist{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.dm-postcard{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.15s ease}
.dm-postcard:hover{box-shadow:var(--dm-shadow);border-color:#d4d4d4;transform:translateY(-3px)}
.dm-postcard__media{display:block;aspect-ratio:16/10;background:var(--dm-teal-soft);overflow:hidden}
.dm-postcard__media img{width:100%;height:100%;object-fit:cover;display:block}
.dm-postcard__ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2.6rem;opacity:.55}
.dm-postcard__body{padding:18px;display:flex;flex-direction:column;gap:9px;flex:1}
.dm-postmeta{font-size:.74rem;color:var(--dm-muted);text-transform:uppercase;letter-spacing:.04em}
.dm-postmeta strong{color:var(--dm-teal-dark)}
.dm-postcard__title{font-size:1.08rem;line-height:1.35;margin:0}
.dm-postcard__title a{color:var(--dm-ink)}
.dm-postcard__title a:hover{color:var(--dm-teal-dark)}
.dm-postcard__excerpt{color:var(--dm-muted);font-size:.9rem;line-height:1.55;margin:0;flex:1}
.dm-postcard__link{align-self:flex-start;margin-top:4px}
@media(max-width:900px){.dm-postlist{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:560px){.dm-postlist{grid-template-columns:1fr}.dm-blog__head h1{font-size:1.6rem}}

/* ===== Blog: entrada individual ===== */
.dm-post{max-width:820px;padding:30px 20px 52px}
.dm-post__head{text-align:center;margin-bottom:22px}
.dm-post__cat{display:inline-block;background:var(--dm-teal-soft);color:var(--dm-teal-dark);
  font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:5px 13px;border-radius:999px;text-decoration:none;margin-bottom:14px}
.dm-post__cat:hover{background:var(--dm-teal);color:#fff}
.dm-post__title{font-size:2.1rem;line-height:1.2;margin:0 0 12px}
.dm-post__meta{color:var(--dm-muted);font-size:.88rem}
.dm-post__sep{margin:0 6px}
.dm-post__cover{margin:0 0 26px;border-radius:var(--dm-radius);overflow:hidden}
.dm-post__cover img{display:block;width:100%;height:auto}
.dm-post__body{font-size:1.02rem}
.dm-post__tags{margin:26px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.dm-post__tags a{background:var(--dm-soft);color:var(--dm-ink-soft);font-size:.8rem;
  padding:5px 12px;border-radius:999px;text-decoration:none}
.dm-post__tags a:hover{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.dm-post__foot{margin:32px 0 0;padding-top:24px;border-top:1px solid var(--dm-border)}
@media(max-width:560px){.dm-post__title{font-size:1.6rem}}

/* ===== Consultas veterinarias ===== */
.dm-consultas-intro{color:var(--dm-muted);font-size:1rem;margin:0 0 22px}
.dm-consultas-h2{font-size:1.4rem;margin:34px 0 18px;padding-bottom:10px;border-bottom:2px solid var(--dm-teal-soft)}
.dm-consulta-note{padding:12px 16px;border-radius:var(--dm-radius-sm);margin:0 0 16px;font-size:.92rem}
.dm-consulta-note--ok{background:var(--dm-teal-soft);color:var(--dm-teal-dark);border:1px solid var(--dm-teal)}
.dm-consulta-note--err{background:#fdecec;color:var(--dm-sale);border:1px solid #f3c0bd}
.dm-consulta-login{background:var(--dm-soft);border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:22px;text-align:center}
.dm-consulta-login p{margin:0 0 12px;color:var(--dm-ink-soft)}
.dm-consulta-add{margin:0}
.dm-consulta-add__btn{display:inline-flex;cursor:pointer;list-style:none}
.dm-consulta-add__btn::-webkit-details-marker{display:none}
.dm-consulta-add[open] .dm-consulta-add__btn{margin-bottom:16px}
.dm-consulta-form{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:20px;max-width:640px}
.dm-consulta-form__row{display:flex;flex-direction:column;gap:6px;margin:0 0 14px}
.dm-consulta-form__row label{font-weight:700;font-size:.9rem}
.dm-consulta-form input,.dm-consulta-form textarea{width:100%;padding:.7em .85em;border:1px solid var(--dm-border);
  border-radius:var(--dm-radius-sm);font-family:inherit;font-size:.95rem;background:#fff}
.dm-consulta-form input:focus,.dm-consulta-form textarea:focus{outline:0;border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-consulta-form__note{font-size:.8rem;color:var(--dm-muted);margin:10px 0 0}
.dm-consultas{display:flex;flex-direction:column;gap:18px}
.dm-consulta{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);padding:22px 24px}
.dm-consulta__title{font-size:1.15rem;margin:0 0 4px}
.dm-consulta__meta{font-size:.8rem;color:var(--dm-muted);margin:0 0 14px}
.dm-consulta__q{margin:0 0 14px}
.dm-consulta__label{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;padding:3px 10px;border-radius:999px;margin-bottom:6px}
.dm-consulta__label--q{background:var(--dm-soft);color:var(--dm-ink-soft)}
.dm-consulta__label--a{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.dm-consulta__q p{margin:0;color:var(--dm-ink-soft)}
.dm-consulta__answer p:first-child{margin-top:0}
.dm-consultas__empty{color:var(--dm-muted);padding:18px 0}
.dm-breadrow .woocommerce-breadcrumb,
.woocommerce-breadcrumb{
  margin:0;color:var(--dm-muted);font-size:.83rem;display:flex;flex-wrap:wrap;align-items:center;gap:2px
}
.dm-breadrow .woocommerce-breadcrumb a,
.woocommerce-breadcrumb a{color:var(--dm-muted);text-decoration:none}
.dm-breadrow .woocommerce-breadcrumb a:hover,
.woocommerce-breadcrumb a:hover{color:var(--dm-teal-dark)}
.dm-breadrow .woocommerce-breadcrumb .sep,
.woocommerce-breadcrumb .sep{opacity:.55;margin:0 4px}
.woocommerce-breadcrumb:empty{display:none}

/* "Desde" antes del precio de variables */
.dm-from{font-size:.78em;font-weight:500;color:var(--dm-muted);margin-right:4px;letter-spacing:.02em;text-transform:uppercase}

/* €/kg debajo del precio. El plugin Unit Price lo envuelve en <small> sin
 * clase, dentro del .price. Paréntesis automáticos vía ::before/::after,
 * color de marca y tamaño menor — destacamos el precio principal. */
.price small,
.dm-product .price small,
.summary .price small,
.woocommerce-variation-price .price small,
.dm-perkg,.unit-price,.wpup-unit-price,.price .woocommerce-price-suffix{
  display:inline-block;margin-left:6px;font-size:.78em;font-weight:600;color:var(--dm-teal-dark);
  letter-spacing:0;text-transform:none;line-height:1.4
}
.price small::before,
.dm-product .price small::before,
.summary .price small::before,
.woocommerce-variation-price .price small::before,
.dm-perkg::before,.unit-price::before,.wpup-unit-price::before,
.price .woocommerce-price-suffix::before{content:"(";opacity:.7;margin-right:1px}
.price small::after,
.dm-product .price small::after,
.summary .price small::after,
.woocommerce-variation-price .price small::after,
.dm-perkg::after,.unit-price::after,.wpup-unit-price::after,
.price .woocommerce-price-suffix::after{content:")";opacity:.7;margin-left:1px}
/* Quitar el <br> que el plugin inyecta antes del <small> para mantenerlos
 * en la misma línea (queda más limpio cuando hay sitio). */
.price br{display:none}

/* Refuerzo del precio principal */
.single-product .summary p.price,
.single-product .summary span.price{color:var(--dm-ink);font-size:1.9rem;font-weight:800;line-height:1.1}
.dm-product .price,.woocommerce ul.products li.product .price{color:var(--dm-ink);font-weight:800}

/* Marca como badge inline a la DERECHA del título en la ficha (estilo Warehouse) */
.single-product .product_title{
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:24px;line-height:1.25
}
.single-product .product_title .dm-title-text{flex:1;min-width:0;display:block}
.single-product .product_title .dm-title-brand{
  flex:none;font-size:.78rem;font-weight:600;text-transform:none;letter-spacing:0;
  color:var(--dm-ink-soft);background:#fff;
  padding:6px 14px;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  text-decoration:none;line-height:1.4;
  transition:.13s ease;align-self:center
}
.single-product .product_title .dm-title-brand:hover{border-color:var(--dm-teal);color:var(--dm-teal-dark);background:#fff}
.single-product .product_title .dm-title-brand--logo{padding:8px 14px;line-height:0}
.single-product .product_title .dm-title-brand--logo img{display:block;height:64px;width:auto;max-width:210px;object-fit:contain}

/* Tarjeta entera clicable (stretched link). Hover invita; el botón "Comprar"
 * tiene mayor z-index para no robarle el clic al stretched-link. */
li.product.dm-product,.dm-product{position:relative;cursor:default}
.dm-product .dm-product__title a,
.dm-product .dm-product__title{position:static}
.dm-product .dm-product__title a::before{
  content:"";position:absolute;inset:0;z-index:1;background:transparent
}
.dm-product__media,
.dm-product__body{position:relative}
.dm-product__body>*{position:relative;z-index:2}
.dm-product__body a:not(.dm-product__title a){position:relative;z-index:3}
.dm-product .add_to_cart_button,
.dm-product .added_to_cart,
.dm-product form.cart,
.dm-product .button.product_type_variable,
.dm-product .button{position:relative;z-index:3}
.dm-product:hover{box-shadow:0 4px 18px rgba(63,53,38,.10);transform:translateY(-2px);transition:.18s ease}
.dm-product:hover .dm-product__title{color:var(--dm-teal-dark)}
/* Botón "Agotado/Avísame" del catálogo: ámbar, igual que el aviso de la ficha. */
.dm-product.outofstock .button{
  background:linear-gradient(180deg,#f7b13a,#f3a01f)!important;color:#fff!important;
  border:0!important;box-shadow:0 2px 8px rgba(243,160,31,.30)
}
.dm-product.outofstock .button:hover{filter:brightness(.97);transform:none}

@media(max-width:760px){
  .single-product .product_title{font-size:1.45rem;gap:10px}
  .single-product .product_title .dm-title-brand{font-size:.7rem;padding:5px 11px}
}

/* ============================================================
   18. AJUSTES — ficha, tabs, búsqueda en vivo, filtros, galería
   ============================================================ */

/* Ocultar SKU/Categoría/Marca al final de la ficha (la marca ya va en el título). */
.single-product .summary .product_meta{display:none}

/* La imagen llevaba doble borde (gallery + img). Dejar solo el card exterior. */
.single-product div.product div.images img,
.single-product .woocommerce-product-gallery img{border:0!important;border-radius:0;background:transparent}
.single-product .woocommerce-product-gallery{padding:18px}

/* Precio grande de la ficha:
 *  - Contenedor en color "Desde" (muted) por defecto.
 *  - El IMPORTE (.woocommerce-Price-amount) en VERDE (teal-dark).
 *  - El €/kg (small) en GRIS CLARO.
 *  - El prefijo "Desde" (.dm-from) mantiene su tono muted propio. */
.single-product .summary p.price,
.single-product .summary span.price,
.single-product .summary .price{color:var(--dm-ink-soft);font-weight:800;font-size:1.9rem;line-height:1.1}
.single-product .summary .price .woocommerce-Price-amount,
.single-product .summary .price .woocommerce-Price-amount *{color:var(--dm-teal-dark)!important}
.single-product .summary .price small,
.single-product .summary .price small *,
.single-product .summary .price small .woocommerce-Price-amount,
.single-product .summary .price small .woocommerce-Price-amount *{color:#9a9a9a!important}
.single-product .summary .price small{font-size:16px!important}
.single-product .summary .price small::before,
.single-product .summary .price small::after{color:#9a9a9a!important;opacity:1}

/* Pestañas — diseño de pills/segmented control en lugar de lista plana. */
.woocommerce div.product .woocommerce-tabs ul.tabs{
  display:flex;gap:6px;list-style:none;margin:0 0 24px;padding:6px;
  background:var(--dm-soft);border-radius:999px;border:0;flex-wrap:wrap;
  align-items:stretch;justify-content:flex-start
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after{display:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  background:transparent;border:0;border-radius:999px;margin:0;padding:0;display:flex
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  display:flex;align-items:center;padding:11px 22px;font-weight:600;font-size:.92rem;
  color:var(--dm-ink-soft);border:0;border-radius:999px;transition:.13s ease;line-height:1
}
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover a{background:#fff;color:var(--dm-ink)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{
  background:var(--dm-teal);color:#fff;box-shadow:0 1px 3px rgba(0,176,160,.3)
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active:hover a{background:var(--dm-teal);color:#fff}
.woocommerce-Tabs-panel{padding:6px 4px}

/* Pestañas de producto como acordeón en móvil (lo construye theme.js) */
.dm-acc{margin:4px 0 0;border-top:1px solid var(--dm-border)}
.dm-acc__item{border-bottom:1px solid var(--dm-border)}
.dm-acc__head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:none;border:0;padding:16px 2px;font-weight:700;font-size:1rem;color:var(--dm-ink);
  cursor:pointer;text-align:left;font-family:inherit;line-height:1.3}
.dm-acc__chev{flex:none;width:9px;height:9px;border-right:2px solid var(--dm-ink-soft);
  border-bottom:2px solid var(--dm-ink-soft);transform:rotate(45deg);margin-top:-3px;transition:transform .15s ease}
.dm-acc__item.is-open .dm-acc__head{color:var(--dm-teal-dark)}
.dm-acc__item.is-open .dm-acc__chev{transform:rotate(-135deg);margin-top:3px;border-color:var(--dm-teal-dark)}
.dm-acc__panel{display:none!important;padding:2px 2px 20px}
.dm-acc__item.is-open .dm-acc__panel{display:block!important}

/* Ocultar €/kg SOLO en cards de categoría — en la ficha sigue visible. */
.dm-product .price small,
ul.products li.product .price small{display:none!important}

/* Árbol de subcategorías multinivel en el sidebar (1er widget). */
.dm-filter--subcats .dm-cattree__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.dm-filter--subcats .dm-cattree__item{margin:0}
.dm-filter--subcats .dm-cattree__link{
  display:block;padding:8px 12px;color:var(--dm-ink-soft);font-size:.9rem;
  border-radius:var(--dm-radius-sm);font-weight:500;transition:.13s ease
}
.dm-filter--subcats .dm-cattree__link:hover{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.dm-filter--subcats .dm-cattree__link.is-current{color:#1a1a1a;font-weight:800;background:none}
.dm-filter--subcats .dm-cattree__link.is-current:hover{background:var(--dm-teal-soft);color:#1a1a1a}

.dm-filter--subcats .dm-cattree__list .dm-cattree__list{margin:2px 0 4px 9px;padding-left:8px;border-left:1px solid var(--dm-border)}
.dm-filter--subcats .dm-cattree__item--has>details{margin:0}
.dm-filter--subcats .dm-cattree__row{display:flex;align-items:center;gap:2px;cursor:pointer;list-style:none}
.dm-filter--subcats .dm-cattree__row::-webkit-details-marker{display:none}
.dm-filter--subcats .dm-cattree__row::marker{content:""}
.dm-filter--subcats .dm-cattree__row .dm-cattree__link{flex:1;min-width:0}
.dm-filter--subcats .dm-cattree__caret{flex:none;position:relative;width:30px;height:34px;border-radius:var(--dm-radius-sm)}
.dm-filter--subcats .dm-cattree__caret:hover{background:var(--dm-teal-soft)}
.dm-filter--subcats .dm-cattree__caret::before{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;
  border-right:2px solid var(--dm-ink-soft);border-bottom:2px solid var(--dm-ink-soft);
  transform:translate(-50%,-72%) rotate(45deg);transition:transform .15s ease}
.dm-filter--subcats details[open]>.dm-cattree__row .dm-cattree__caret::before{transform:translate(-50%,-28%) rotate(-135deg)}

/* Resultados de búsqueda en vivo bajo el input. */
.dm-search{position:relative}
.dm-search__results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:300;
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  box-shadow:0 8px 24px rgba(0,0,0,.10);max-height:78vh;overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-4px);transition:.13s ease;padding:6px
}
.dm-search__results.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.dm-search__hit{
  display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:var(--dm-radius-sm);
  text-decoration:none;color:inherit;transition:background .12s ease
}
.dm-search__hit:hover,.dm-search__hit:focus{background:var(--dm-teal-soft)}
.dm-search__hit img,.dm-search__noimg{
  width:48px;height:48px;border-radius:var(--dm-radius-sm);object-fit:contain;background:var(--dm-soft);flex:none
}
.dm-search__hit-body{display:flex;flex-direction:column;min-width:0;flex:1;gap:1px}
.dm-search__hit-brand{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--dm-muted);font-weight:700}
.dm-search__hit-title{font-size:.9rem;font-weight:600;color:var(--dm-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dm-search__hit-price{font-size:.86rem;font-weight:700;color:var(--dm-teal-dark)}
.dm-search__all{
  display:block;padding:11px 12px;text-align:center;font-weight:700;font-size:.88rem;
  color:var(--dm-teal-dark);border-top:1px solid var(--dm-border);margin-top:4px;
  text-decoration:none;border-radius:0 0 var(--dm-radius-sm) var(--dm-radius-sm)
}
.dm-search__all:hover{background:var(--dm-teal-soft);color:var(--dm-ink)}
.dm-search__empty{padding:18px;text-align:center;color:var(--dm-muted);font-size:.9rem}

/* Spinner mientras el fetch está en curso */
.dm-search__loading{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:22px 18px;color:var(--dm-muted);font-size:.92rem;font-weight:500
}
.dm-spinner{
  width:18px;height:18px;flex:none;
  border:2px solid var(--dm-teal-soft);border-top-color:var(--dm-teal);
  border-radius:50%;
  animation:dm-spin .65s linear infinite
}
@keyframes dm-spin{to{transform:rotate(360deg)}}

/* Galería de producto: miniaturas a la IZQUIERDA en columna. */
.single-product .woocommerce-product-gallery{display:flex!important;align-items:flex-start;gap:14px;flex-direction:row-reverse}
.single-product .woocommerce-product-gallery__wrapper{flex:1;min-width:0;margin:0}
.single-product .flex-control-thumbs{
  display:flex;flex-direction:column;flex-wrap:nowrap;flex:none;width:84px;gap:8px;margin:0;padding:0;list-style:none
}
.single-product .flex-control-thumbs li{width:84px;height:84px;margin:0;list-style:none}
.single-product .flex-control-thumbs li::marker{content:none}
.single-product .flex-control-thumbs img{
  width:100%;height:100%;border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  object-fit:contain;background:#fff;cursor:pointer;transition:.13s ease;padding:4px
}
.single-product .flex-control-thumbs img:hover,
.single-product .flex-control-thumbs img.flex-active{border-color:var(--dm-teal);box-shadow:0 0 0 2px var(--dm-teal-soft)}

@media(max-width:860px){
  .single-product .woocommerce-product-gallery{flex-direction:column}
  .single-product .flex-control-thumbs{flex-direction:row;flex-wrap:wrap;width:auto}
  .single-product .flex-control-thumbs li{width:64px;height:64px}
  .woocommerce div.product .woocommerce-tabs ul.tabs{padding:4px;gap:4px}
  .woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:9px 14px;font-size:.86rem}
}

/* ============================================================
   19. MINI-CART DRAWER + BARRA ENVÍO + FIX QTY + FIX CART PAGE
   ============================================================ */

/* Cantidad + botón "Añadir al carrito" alineados a misma altura en ficha. */
.woocommerce div.product form.cart{display:flex;gap:12px;align-items:stretch;margin:22px 0;flex-wrap:wrap}
.woocommerce div.product form.cart .quantity{display:flex;align-items:stretch;margin:0}
.woocommerce div.product form.cart .quantity input.qty{
  height:auto;min-height:44px;width:80px;padding:.55em .6em;font-size:1rem;
  border:1px solid var(--dm-border);border-radius:var(--dm-radius-sm);
  text-align:center;font-family:inherit;font-weight:700;line-height:1.2
}
.woocommerce div.product form.cart .button,
.woocommerce div.product form.cart .single_add_to_cart_button{
  min-height:44px;padding:.55em 1.8em;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;line-height:1.2
}

/* Página de carrito — restaurar ancho de contenido y padding lateral.
 * Las páginas .dm-page de Carrito/Checkout/Mi cuenta estaban a max-width:none
 * y padding:0 horizontal — quedaban pegadas a los bordes. */
.woocommerce-cart .dm-page,
.woocommerce-checkout .dm-page,
.woocommerce-account .dm-page{
  max-width:var(--dm-wrap);margin:0 auto;padding:14px 20px 40px
}
.woocommerce-cart .dm-page>h1,
.woocommerce-checkout .dm-page>h1,
.woocommerce-account .dm-page>h1{font-size:1.6rem;margin:6px 0 4px}
.woocommerce-cart .dm-page>h1::after,
.woocommerce-checkout .dm-page>h1::after,
.woocommerce-account .dm-page>h1::after{width:36px;height:3px;margin:8px auto 0}

/* ── Drawer mini-cart (slide desde la derecha) ──
 * z-index muy alto para ganarle al botón flotante de WhatsApp del plugin
 * click-to-chat (usa z-index:99.999.999). 2.147.483.647 = INT32 MAX. */
.dm-minicart__overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:2147483646;display:none}
.dm-minicart__overlay.is-open{display:block}

.dm-minicart{
  position:fixed;top:0;right:0;bottom:0;width:min(94vw,420px);background:#fff;
  z-index:2147483647;box-shadow:-8px 0 28px rgba(0,0,0,.14);
  transform:translateX(105%);transition:transform .25s ease;
  display:flex;flex-direction:column;
}
.dm-minicart.is-open{transform:translateX(0)}
/* Mientras el drawer está abierto ocultamos el botón flotante de WhatsApp
 * para que no compita con los CTAs Ver carrito / Realizar pedido. */
body:has(.dm-minicart.is-open) .ht-ctc-chat,
body:has(.dm-minicart.is-open) #ht-ctc-chat,
body:has(.dm-minicart.is-open) .ctc-no-number-message{display:none!important}
.dm-minicart__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid var(--dm-border);flex:none
}
.dm-minicart__title{margin:0;font-size:1.15rem;color:var(--dm-ink);font-weight:700}
.dm-minicart__close{background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--dm-ink);padding:0 4px}
.dm-minicart__close:hover{color:var(--dm-teal-dark)}
.dm-minicart__body{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column}
.dm-minicart__body>.widget_shopping_cart_content{display:contents}

/* Barra de envío gratuito */
.dm-shipbar{margin:0 0 16px;padding:14px 16px;background:var(--dm-teal-soft);border-radius:var(--dm-radius);font-size:.88rem}
.dm-shipbar__msg{margin:0 0 10px;color:var(--dm-ink)}
.dm-shipbar__msg strong{color:var(--dm-teal-dark);font-weight:800}
.dm-shipbar__msg--ok{color:var(--dm-ok);font-weight:700;text-align:center;margin-bottom:0}
.dm-shipbar__track{height:8px;background:#fff;border-radius:999px;overflow:hidden}
.dm-shipbar__fill{height:100%;background:linear-gradient(90deg,var(--dm-teal-dark),var(--dm-teal));transition:width .35s ease;border-radius:999px;min-width:6px}

/* Items dentro del mini-cart */
.woocommerce-mini-cart{list-style:none;margin:0 0 8px;padding:0}
.woocommerce-mini-cart-item.mini_cart_item{
  display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:start;
  padding:14px 0;border-bottom:1px solid var(--dm-border);position:relative
}
.woocommerce-mini-cart-item .dm-mini-thumb,
.woocommerce-mini-cart-item .dm-mini-thumb img{width:64px;height:64px;object-fit:contain;display:block}
.woocommerce-mini-cart-item .dm-mini-thumb{
  border:1px solid var(--dm-border);border-radius:6px;background:#fff;overflow:hidden;flex:none
}
.woocommerce-mini-cart-item .dm-mini-info{
  font-size:.9rem;font-weight:600;color:var(--dm-ink);text-decoration:none;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.woocommerce-mini-cart-item .dm-mini-info:hover{color:var(--dm-teal-dark)}
.woocommerce-mini-cart-item .quantity{display:block;color:var(--dm-muted);font-size:.82rem;margin-top:5px;grid-column:2}
.woocommerce-mini-cart-item .remove,
.woocommerce-mini-cart-item .remove_from_cart_button{
  position:absolute;top:14px;right:0;width:24px;height:24px;border-radius:50%;
  background:var(--dm-soft);color:var(--dm-ink)!important;display:flex;align-items:center;justify-content:center;
  text-decoration:none;font-size:1.1rem;line-height:1;font-weight:700;transition:.13s ease
}
.woocommerce-mini-cart-item .remove:hover{background:var(--dm-sale);color:#fff!important}
.woocommerce-mini-cart-item .dm-mini-info{padding-right:30px}

.woocommerce-mini-cart__total{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;border-top:2px solid var(--dm-border);font-size:1rem;margin:10px 0 0
}
.woocommerce-mini-cart__total strong{font-weight:800;color:var(--dm-ink)}
.woocommerce-mini-cart__total .amount{color:var(--dm-ink);font-weight:800;font-size:1.15rem}

/* Botonera abajo: Ver carrito (ghost) + Realizar pedido (teal) */
.dm-mini-buttons{display:flex;flex-direction:column;gap:10px;padding:6px 0 0;margin:0}
.dm-mini-btn{
  display:block;text-align:center;padding:.95em 1.4em;font-size:.96rem;font-weight:700;
  border-radius:var(--dm-radius-sm);text-decoration:none;border:0;cursor:pointer;
  line-height:1.2;transition:.13s ease
}
.dm-mini-btn--ghost{background:#fff;color:var(--dm-ink);border:1px solid var(--dm-border)}
.dm-mini-btn--ghost:hover{border-color:var(--dm-teal);color:var(--dm-teal-dark);background:var(--dm-teal-soft)}
.dm-mini-btn--primary{background:var(--dm-teal);color:#fff}
.dm-mini-btn--primary:hover{background:var(--dm-teal-dark);color:#fff}

.woocommerce-mini-cart__empty-message{
  text-align:center;color:var(--dm-muted);padding:30px 6px;font-size:.94rem;flex:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center
}

/* ============================================================
   20. CARRITO — rediseño con grid (image→…→×) + cupón pill + total
   ============================================================ */

.dm-cart{background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);overflow:hidden}
.dm-cart__head,
.dm-cart__row{
  display:grid;
  grid-template-columns: 96px minmax(0,1fr) 110px 130px 110px 42px;
  align-items:center;
  gap:18px;
  padding:16px 22px;
}
.dm-cart__head{
  background:var(--dm-soft);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--dm-ink-soft);font-weight:700;border-bottom:1px solid var(--dm-border)
}
.dm-cart__col-thumb,.dm-cart__col-rm{visibility:hidden}
.dm-cart__row{border-bottom:1px solid var(--dm-border)}
.dm-cart__row:last-of-type{border-bottom:0}

.dm-cart__thumb{display:flex;align-items:center;justify-content:center}
.dm-cart__thumb a,.dm-cart__thumb{width:80px;height:80px}
.dm-cart__thumb img{max-width:none!important;width:80px!important;height:80px!important;object-fit:contain;background:#fff;border:1px solid var(--dm-border);border-radius:8px;display:block;padding:4px}

.dm-cart__name{display:flex;flex-direction:column;gap:3px;min-width:0;line-height:1.35}
.dm-cart__brand{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dm-muted);font-weight:700}
.dm-cart__name a.dm-cart__title,
.dm-cart__name a{color:var(--dm-ink);font-weight:600;font-size:.95rem;text-decoration:none}
.dm-cart__name a:hover{color:var(--dm-teal-dark)}

.dm-cart__price,.dm-cart__sub{font-weight:700;color:var(--dm-ink);font-size:.98rem}
.dm-cart__price del{color:var(--dm-muted);font-weight:400;font-size:.85rem;display:block}
.dm-cart__sub{color:var(--dm-ink);font-weight:800}

.dm-cart__qty .quantity{display:flex;align-items:center}
.dm-cart__qty input.qty{
  width:88px;height:42px;padding:.4em .5em;border:1px solid var(--dm-border);
  border-radius:8px;text-align:center;font-family:inherit;font-weight:700;font-size:1rem;color:var(--dm-ink);
  background:#fff
}
.dm-cart__qty input.qty:focus{outline:0;border-color:var(--dm-teal);box-shadow:0 0 0 3px var(--dm-teal-soft)}

/* Input cantidad con botones − / + (producto y carrito) */
.quantity:has(.dm-qty-btn){
  display:inline-flex;align-items:stretch;border:1px solid var(--dm-border);
  border-radius:var(--dm-radius-sm);overflow:hidden;background:#fff;width:auto
}
.quantity:has(.dm-qty-btn) input.qty{
  width:54px;height:42px;border:0;border-radius:0;padding:0;margin:0;
  text-align:center;background:transparent;font-weight:700;color:var(--dm-ink);
  -moz-appearance:textfield;box-shadow:none
}
.quantity:has(.dm-qty-btn) input.qty::-webkit-outer-spin-button,
.quantity:has(.dm-qty-btn) input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.quantity:has(.dm-qty-btn) input.qty:focus{outline:0;background:var(--dm-teal-soft)}
.dm-qty-btn{
  width:38px;height:42px;border:0;background:#f6f7f7;cursor:pointer;
  font-size:1.25rem;line-height:1;color:var(--dm-ink);font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;padding:0;
  user-select:none;-webkit-user-select:none;font-family:inherit
}
.dm-qty-btn:hover{background:var(--dm-teal-soft);color:var(--dm-teal-dark)}
.dm-qty-btn:active{background:var(--dm-teal);color:#fff}
.dm-qty-btn:disabled{opacity:.4;cursor:not-allowed}
.dm-qty-btn--minus{border-right:1px solid var(--dm-border);order:0}
.dm-qty-btn--plus{border-left:1px solid var(--dm-border);order:2}
.quantity:has(.dm-qty-btn) input.qty,
.quantity:has(.dm-qty-btn) input[name="quantity"]{order:1}

/* Auto-actualización del carrito: ocultamos el botón "Actualizar carrito" y
 * mostramos un sutil estado de carga mientras se procesa la actualización. */
.woocommerce-cart-form button[name="update_cart"],
.woocommerce-cart-form input[name="update_cart"]{display:none!important}
body.dm-cart-updating .woocommerce-cart-form,
body.dm-cart-updating .cart_totals,
body.dm-cart-updating .dm-cart-totals{opacity:.55;pointer-events:none;transition:opacity .2s ease}

/* Filtros AJAX: atenuar la cuadrícula de productos mientras carga */
body.dm-filters-loading .dm-shop__main{opacity:.55;pointer-events:none;transition:opacity .2s ease}

.dm-cart__remove{display:flex;justify-content:flex-end}
.dm-cart__remove a.remove,
.dm-cart .remove_from_cart_button{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:var(--dm-soft);color:var(--dm-ink-soft)!important;
  font-size:1.4rem;text-decoration:none!important;line-height:1;font-weight:700;
  transition:.13s ease
}
.dm-cart__remove a.remove:hover{background:var(--dm-sale);color:#fff!important;transform:scale(1.05)}

/* Fila de acciones (cupón + actualizar carrito) */
.dm-cart-actions{
  display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;
  padding:18px 22px;margin-top:18px;
  background:linear-gradient(180deg,#fff,var(--dm-soft));
  border:1px solid var(--dm-border);border-radius:var(--dm-radius)
}

/* Cupón en formato "pill" — input + botón teal embebidos en una píldora */
.dm-cart-coupon{
  display:flex;align-items:center;gap:6px;flex:1;min-width:280px;max-width:520px;
  background:#fff;border:2px solid var(--dm-border);border-radius:999px;
  padding:5px;transition:.13s ease
}
.dm-cart-coupon:focus-within{border-color:var(--dm-teal);box-shadow:0 0 0 4px var(--dm-teal-soft)}
.dm-cart-coupon input{
  flex:1;min-width:0;padding:.55em 1em;border:0;background:transparent;outline:0;
  font-family:inherit;font-size:.92rem;color:var(--dm-ink)
}
.dm-cart-coupon input::placeholder{color:var(--dm-muted)}
.dm-cart-coupon .dm-coupon-btn,
.dm-cart-coupon button{
  border-radius:999px!important;padding:.55em 1.6em!important;font-size:.86rem!important;font-weight:700!important;
  background:var(--dm-teal)!important;color:#fff!important;border:0!important;cursor:pointer;
  line-height:1.2;flex:none;transition:.13s ease
}
.dm-cart-coupon .dm-coupon-btn:hover,
.dm-cart-coupon button:hover{background:var(--dm-teal-dark)!important}

/* Actualizar carrito como botón ghost */
.dm-update-btn{
  padding:.7em 1.4em!important;font-size:.86rem!important;font-weight:700!important;
  background:#fff!important;color:var(--dm-ink)!important;
  border:1px solid var(--dm-border)!important;border-radius:var(--dm-radius-sm)!important;
  cursor:pointer;transition:.13s ease
}
.dm-update-btn:hover{border-color:var(--dm-teal)!important;color:var(--dm-teal-dark)!important;background:var(--dm-teal-soft)!important}
.dm-update-btn[disabled]{opacity:.55;cursor:not-allowed}

/* Móvil: cada fila como tarjeta */
@media(max-width:760px){
  .dm-cart__head{display:none}
  .dm-cart__row{
    grid-template-columns: 72px 1fr 42px;
    grid-template-rows: auto auto auto;
    gap:8px 12px;row-gap:8px
  }
  .dm-cart__thumb{grid-column:1;grid-row:1/4;align-self:start}
  .dm-cart__thumb img,.dm-cart__thumb a{width:72px!important;height:72px!important}
  .dm-cart__name{grid-column:2;grid-row:1}
  .dm-cart__price{grid-column:2;grid-row:2;color:var(--dm-muted);font-weight:500;font-size:.85rem}
  .dm-cart__price::before{content:attr(data-title)": "}
  .dm-cart__qty{grid-column:2;grid-row:3;justify-self:start}
  .dm-cart__sub{grid-column:2;grid-row:3;justify-self:end;align-self:center}
  .dm-cart__remove{grid-column:3;grid-row:1;align-self:start}
  .dm-cart-actions{flex-direction:column;align-items:stretch}
  .dm-cart-coupon{max-width:none}
  .dm-update-btn{align-self:flex-end}
}

/* ── Totales del carrito — más pulido ── */
.woocommerce-cart .cart_totals{
  background:#fff;border:1px solid var(--dm-border);border-radius:var(--dm-radius);
  padding:26px 28px;box-shadow:0 1px 3px rgba(0,0,0,.03)
}
.woocommerce-cart .cart_totals h2{
  font-size:1.05rem;margin:0 0 18px;padding-bottom:14px;
  border-bottom:2px solid var(--dm-teal-soft);
  display:flex;align-items:center;gap:10px;color:var(--dm-ink);font-weight:700;text-transform:none;letter-spacing:0
}
.woocommerce-cart .cart_totals h2::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--dm-teal)}
.woocommerce-cart .cart_totals table{width:100%;border:0;margin:0 0 18px;background:none}
.woocommerce-cart .cart_totals table tr{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--dm-border);background:none!important}
.woocommerce-cart .cart_totals table tr:last-child{border-bottom:0}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td{
  border:0!important;padding:0!important;background:none!important;font-size:.92rem;color:var(--dm-ink-soft);
  text-transform:none;letter-spacing:0;font-weight:600
}
.woocommerce-cart .cart_totals table td{color:var(--dm-ink);font-weight:700;text-align:right}
.woocommerce-cart .cart_totals table .order-total{
  padding:14px 16px;background:var(--dm-teal-soft);border-radius:var(--dm-radius);border:0;margin-top:6px;
  display:flex;align-items:baseline
}
.woocommerce-cart .cart_totals table .order-total th{color:var(--dm-ink);font-size:1.05rem;font-weight:800}
.woocommerce-cart .cart_totals table .order-total td{color:var(--dm-teal-dark);font-size:1.4rem;font-weight:800;line-height:1.15}
.woocommerce-cart .cart_totals table .order-total td .amount{color:var(--dm-teal-dark)}
.woocommerce-cart .cart_totals .includes_tax,
.woocommerce-checkout #order_review .includes_tax,
.woocommerce-checkout .includes_tax{display:block;font-size:.78rem;color:var(--dm-muted);font-weight:500;margin-top:4px;line-height:1.3}
.woocommerce-cart .wc-proceed-to-checkout{margin:0;padding:0}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button{
  display:block;text-align:center;width:100%;padding:.95em 1.4em;font-size:1rem;font-weight:700;
  border-radius:var(--dm-radius-sm);background:var(--dm-teal);color:#fff!important;border:0
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover{background:var(--dm-teal-dark)}

@media(max-width:860px){
  .woocommerce-cart .cart_totals{padding:22px 22px}
}

/* ============================================================
   21. Banner de entrega bajo el botón de la ficha
   ============================================================ */
/* form.cart es flex; flex-basis:100% + order:99 fuerzan el banner a su
 * propia línea DEBAJO del botón "Añadir al carrito". */
.dm-delivery{
  display:flex;align-items:center;gap:10px;
  flex-basis:100%;order:99;
  margin:14px 0 6px;padding:10px 16px 10px 14px;
  background:#fff;border:1px solid #f3c050;
  border-radius:var(--dm-radius-sm);color:var(--dm-ink);font-size:.94rem;
  line-height:1.3;width:fit-content;max-width:100%
}
.dm-delivery__ico{flex:none;stroke:#c47a00}
.dm-delivery__msg{color:var(--dm-ink)}
.dm-delivery__msg strong{color:#a05c00;font-weight:800}
/* variante compacta en las tarjetas del listado.
 * order:0 + margin-top:auto agrupa el aviso de envío con el botón al fondo de
 * la tarjeta (envío ENCIMA del botón). Así el botón "Comprar"/"Agotado" queda
 * siempre alineado abajo, tengan o no aviso de envío (los agotados no lo
 * muestran). El botón que va justo debajo pierde su margin-top:auto. */
.dm-delivery--loop{
  order:0;width:100%;max-width:none;gap:7px;margin:auto 0 8px;padding:7px 10px;
  font-size:.78rem;line-height:1.25;background:#fff;border-color:#f3c050
}
.dm-delivery--loop .dm-delivery__ico{width:16px;height:16px}
.dm-delivery--loop ~ .button{margin-top:0 !important}

/* ============================================================
   22. Variaciones como radio buttons (sustituye al plugin)
   ============================================================ */

/* Tabla → bloques verticales, ya no es una "tabla" visualmente. */
table.variations,table.variations tbody,table.variations tr,
table.variations th,table.variations td{
  display:block;width:100%;padding:0;border:0;background:none;margin:0
}
table.variations tr{margin-bottom:18px}
table.variations th.label{padding:0 0 8px}
table.variations th.label label{
  display:inline-block;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--dm-ink-soft);font-weight:700;margin:0
}

/* Select original oculto (accesible pero invisible) — WC sigue leyéndolo. */
table.variations td.value select{
  position:absolute!important;width:1px!important;height:1px!important;
  opacity:0!important;pointer-events:none!important;clip:rect(0,0,0,0)!important;overflow:hidden
}

/* Grupo de radios estilo pill */
/* Lista vertical, una fila por opción: [○] etiqueta ........ precio */
.dm-vradios{display:flex;flex-direction:column;gap:6px;margin:2px 0 4px;width:100%}
.dm-vradio{
  position:relative;cursor:pointer;user-select:none;
  display:flex;align-items:center;gap:14px;
  padding:13px 18px;
  background:var(--dm-soft);border:1px solid transparent;
  border-radius:var(--dm-radius-sm);
  color:var(--dm-ink);font-weight:600;font-size:.94rem;line-height:1.3;
  transition:background .13s ease,border-color .13s ease
}
.dm-vradio input[type="radio"]{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  width:18px;height:18px;border:2px solid #c0c0c0;border-radius:50%;
  margin:0;padding:0;flex:none;cursor:pointer;position:relative;
  background:#fff;transition:.13s ease
}
.dm-vradio input[type="radio"]:checked{border-color:var(--dm-teal)}
.dm-vradio input[type="radio"]:checked::after{
  content:"";position:absolute;inset:3px;border-radius:50%;background:var(--dm-teal)
}
.dm-vradio__t{flex:none;color:var(--dm-ink-soft);font-weight:500}
/* La regla global .summary .price{font-size:1.9rem} de la ficha se mete
 * dentro del radio porque price_html trae un <span class="price">. Forzamos
 * tamaños propios dentro de .dm-vradio__price:
 *   - Precio principal: mayor, negro
 *   - €/kg: menor, gris claro y entre paréntesis */
.dm-vradio__price{margin-left:auto;text-align:right;white-space:nowrap;line-height:1.2}
.dm-vradio__price .price,
.dm-vradio__price > .woocommerce-Price-amount,
.dm-vradio__price > .price > .woocommerce-Price-amount,
.dm-vradio__price > .price > .woocommerce-Price-amount *{
  font-size:1rem!important;font-weight:700!important;color:var(--dm-ink)!important;line-height:1.2!important
}
.dm-vradio__price small,
.dm-vradio__price small *{
  font-size:.74rem!important;font-weight:500!important;color:#9a9a9a!important;
  display:inline!important;margin-left:4px
}
.dm-vradio__price small::before{content:"("!important;opacity:1;margin-right:1px;color:#9a9a9a}
.dm-vradio__price small::after{content:")"!important;opacity:1;margin-left:1px;color:#9a9a9a}
.dm-vradio__price br{display:none}

.dm-vradio:hover{background:var(--dm-teal-soft)}
.dm-vradio.is-active,
.dm-vradio:has(input:checked){
  background:var(--dm-teal-soft);border-color:var(--dm-teal)
}
.dm-vradio.is-active .dm-vradio__t,
.dm-vradio:has(input:checked) .dm-vradio__t{color:var(--dm-ink);font-weight:700}

.dm-vradio.is-disabled,
.dm-vradio:has(input:disabled){
  opacity:.5;cursor:not-allowed;text-decoration:line-through;text-decoration-thickness:1px
}
.dm-vradio.is-disabled:hover{background:var(--dm-soft)}

/* Ocultar "Limpiar" — el cliente puede tocar otro radio para cambiar.
 * Ocultar el bloque .woocommerce-variation que WC muestra debajo del form
 * con el precio repetido: el precio TOP ya se actualiza automáticamente. */
.reset_variations{display:none!important}
.woocommerce-variation,
.woocommerce-variation-price,
.woocommerce-variation-availability{display:none!important}

/* Asegurar que qty siempre va a la izquierda del botón Comprar (flex order) */
.woocommerce div.product form.cart .quantity{order:1}
.woocommerce div.product form.cart .single_add_to_cart_button{order:2;flex:1;min-width:200px}
.woocommerce div.product form.cart .dm-delivery{order:99}

/* En productos variables el qty + botón viven dentro de
 * .woocommerce-variation-add-to-cart, no directamente en form.cart.
 * Forzamos misma fila: qty izquierda, botón Comprar a la derecha. */
.woocommerce-variation-add-to-cart{
  display:flex;align-items:stretch;gap:12px;flex-wrap:wrap;margin:14px 0
}
.woocommerce-variation-add-to-cart .quantity{flex:none;order:1;margin:0}
.woocommerce-variation-add-to-cart .quantity input.qty{
  width:80px;height:48px;padding:.55em;border:1px solid var(--dm-border);
  border-radius:var(--dm-radius-sm);text-align:center;font-weight:700;font-size:1rem
}
.woocommerce-variation-add-to-cart .single_add_to_cart_button{
  order:2;flex:1;min-width:200px;height:48px;padding:.55em 1.8em;font-size:1rem;
  display:inline-flex;align-items:center;justify-content:center
}
.woocommerce-variation-add-to-cart input[name="quantity"]{order:1}

/* ===================================================================
   Valoraciones / estrellas WooCommerce
   El tema desregistra el CSS base de WooCommerce (ver functions.php),
   que incluye la fuente "star" y las reglas de estrellas. Las reponemos
   aquí para que se vean tanto las estrellas de la valoración media
   (bajo el título y en el listado de reseñas) como el selector del
   formulario "Tu puntuación".
   =================================================================== */
@font-face{
  font-family:'star';
  src:url('/wp-content/plugins/woocommerce/assets/fonts/star.woff') format('woff'),
      url('/wp-content/plugins/woocommerce/assets/fonts/star.ttf') format('truetype');
  font-weight:400;font-style:normal;font-display:block;
}

/* valoración media (solo aparece si el producto tiene reseñas) */
.woocommerce-product-rating{display:flex;align-items:center;gap:10px;margin:6px 0 16px;line-height:1}
.woocommerce-product-rating .woocommerce-review-link{color:inherit;font-size:.9rem;text-decoration:none}
.woocommerce-product-rating .woocommerce-review-link:hover{text-decoration:underline}

.star-rating{
  overflow:hidden;position:relative;height:1.25em;line-height:1.25;
  font-size:1.15em;width:5.4em;font-family:'star';font-weight:400;
}
.star-rating::before{content:"\73\73\73\73\73";color:#d8d4d8;float:left;top:0;left:0;position:absolute}
.star-rating span{overflow:hidden;float:left;top:0;left:0;position:absolute;padding-top:1.5em}
.star-rating span::before{content:"\53\53\53\53\53";top:0;left:0;position:absolute;color:#f5a623}

/* selector de puntuación del formulario de reseña (lo genera el JS de WC) */
.comment-form-rating label{display:block;margin:0 0 6px;font-weight:600}
p.stars{display:inline-block;margin:0 0 14px;line-height:1}
p.stars a{
  position:relative;height:1.5em;width:1.5em;text-indent:-999em;display:inline-block;
  text-decoration:none;margin-right:3px;font-weight:400;
}
p.stars a::before{
  display:block;position:absolute;top:0;left:0;width:1.5em;height:1.5em;line-height:1.5;
  font-family:'star';content:"\73";color:#d8d4d8;text-indent:0;font-size:1em;
}
p.stars a:hover ~ a::before{content:"\73";color:#d8d4d8}
p.stars:hover a::before{content:"\53";color:#f5a623}
p.stars a.active::before{content:"\53";color:#f5a623}
p.stars a.active ~ a::before{content:"\73";color:#d8d4d8}
p.stars.selected a.active::before{content:"\53";color:#f5a623}
p.stars.selected a.active ~ a::before{content:"\73";color:#d8d4d8}
p.stars.selected a:not(.active)::before{content:"\53";color:#f5a623}
.woocommerce-variation-add-to-cart .dm-delivery{order:99;flex-basis:100%}

/* ===================================================================
   Aviso de disponibilidad (Back In Stock) — botón + modal
   El JS mueve el formulario del plugin "cwginstock" dentro del modal y
   coloca este botón en su lugar. Colores naranja/ámbar.
   =================================================================== */
.dm-stock-notify-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  min-height:50px;padding:.75em 1.4em;margin:6px 0;
  background:linear-gradient(180deg,#f7b13a,#f3a01f);color:#fff;border:0;
  border-radius:var(--dm-radius);font-size:1rem;font-weight:700;line-height:1.15;
  cursor:pointer;box-shadow:0 3px 10px rgba(243,160,31,.35);
  transition:transform .13s ease,box-shadow .13s ease,filter .13s ease;
}
.dm-stock-notify-btn:hover{filter:brightness(.97);transform:translateY(-1px);box-shadow:0 6px 16px rgba(243,160,31,.45)}
.dm-stock-notify-btn:active{transform:translateY(0)}
.dm-stock-notify-btn strong{font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.dm-stock-notify-btn svg{flex:none}

/* overlay + tarjeta */
.dm-stock-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;
  padding:20px;background:rgba(22,22,28,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.dm-stock-modal.is-open{display:flex}
.dm-stock-modal__card{position:relative;width:100%;max-width:430px;background:#fff;border-radius:18px;
  padding:30px 28px 26px;box-shadow:0 24px 60px rgba(0,0,0,.28);text-align:center;
  animation:dmStockIn .18s ease}
@keyframes dmStockIn{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.dm-stock-modal__close{position:absolute;top:10px;right:12px;width:36px;height:36px;border:0;background:transparent;
  font-size:26px;line-height:1;color:#b3b0b8;cursor:pointer;border-radius:9px;transition:.13s}
.dm-stock-modal__close:hover{background:#f3f3f5;color:#555}
.dm-stock-modal__icon{width:56px;height:56px;margin:2px auto 12px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(243,160,31,.14);color:#e8951a}
.dm-stock-modal__icon svg{width:26px;height:26px}
.dm-stock-modal__title{margin:0 0 6px;font-size:1.3rem;font-weight:800;color:var(--dm-ink)}
.dm-stock-modal__lead{margin:0 0 20px;font-size:.92rem;color:var(--dm-muted);line-height:1.45}

/* reset del panel bootstrap del plugin dentro del modal + estilo limpio */
.dm-stock-form,.dm-stock-form .panel,.dm-stock-form .panel-body,.dm-stock-form .panel-heading,
.dm-stock-form .row,.dm-stock-form [class^="col-"]{
  background:none!important;border:0!important;box-shadow:none!important;margin:0!important;padding:0!important;width:100%!important}
.dm-stock-form .cwgstock_name,.dm-stock-form .cwgstock_email{
  width:100%!important;text-align:left!important;box-sizing:border-box;padding:12px 14px;margin:0 0 10px!important;
  border:1px solid var(--dm-border)!important;border-radius:10px!important;font-size:1rem;background:#fff!important}
.dm-stock-form .cwgstock_name:focus,.dm-stock-form .cwgstock_email:focus{
  outline:none;border-color:var(--dm-teal)!important;box-shadow:0 0 0 3px var(--dm-teal-soft)}
.dm-stock-form .cwgstock_button{
  width:100%!important;padding:13px 16px;margin-top:4px;background:linear-gradient(180deg,#f7b13a,#f3a01f)!important;
  color:#fff!important;border:0!important;border-radius:10px!important;font-weight:800;font-size:1rem;cursor:pointer;
  transition:filter .13s ease}
.dm-stock-form .cwgstock_button:hover{filter:brightness(.97)}
.dm-stock-form .cwgstock_output{margin-top:12px;font-size:.92rem;line-height:1.4}
@media(max-width:480px){.dm-stock-modal__card{padding:26px 20px 22px}}
