/*
Theme Name: Concanmex
Theme URI: https://concanmex.com
Author: Concanmex Inc
Author URI: https://concanmex.com
Description: Tema minimalista y claro hecho a medida para Concanmex Inc — tienda de electrónica y electrodomésticos. Compatible con WooCommerce, tipografía moderna y mucho aire.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hex-orbit
Tags: e-commerce, woocommerce, minimal, clean, custom-menu, featured-images, responsive
WC requires at least: 7.0
WC tested up to: 10.8
*/

/* =========================================================
   1. Design tokens
   ========================================================= */
:root{
  --bg:#ffffff;
  --bg-soft:#f5f6f8;
  --bg-soft-2:#fafbfc;
  --ink:#0b0c0e;
  --ink-2:#3c424c;
  --muted:#737a86;
  --line:#e8eaef;
  --line-2:#f0f2f5;
  --accent:#2f6bff;
  --accent-ink:#1f50d6;
  --accent-soft:#eef3ff;
  --success:#0f9d58;
  --danger:#e0322a;
  --warning:#b7791f;

  --radius:16px;
  --radius-sm:10px;
  --radius-xs:8px;

  --shadow-xs:0 1px 2px rgba(16,24,40,.05);
  --shadow-sm:0 2px 8px rgba(16,24,40,.06);
  --shadow:0 10px 34px rgba(16,24,40,.09);
  --shadow-lg:0 24px 60px rgba(16,24,40,.14);

  --container:1180px;
  --container-wide:1320px;
  --gap:24px;

  --font:'Inter','Inter var',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --header-h:72px;

  --transition:.22s cubic-bezier(.4,0,.2,1);
}

/* =========================================================
   2. Reset / base
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:'cv02','cv03','cv04','cv11';
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
h1,h2,h3,h4,h5,h6{margin:0 0 .5em;line-height:1.15;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.3rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
ul,ol{margin:0 0 1rem;padding-left:1.2rem}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* =========================================================
   3. Layout helpers
   ========================================================= */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
.container-wide{max-width:var(--container-wide)}
.section{padding-block:clamp(48px,7vw,96px)}
.section-sm{padding-block:clamp(32px,4vw,56px)}
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(28px,4vw,48px)}
.section-head p{color:var(--muted);font-size:1.05rem;margin:0}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.text-muted{color:var(--muted)}
.center{text-align:center}

/* =========================================================
   4. Buttons
   ========================================================= */
.btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:600;font-size:.95rem;line-height:1;
  padding:14px 24px;border-radius:999px;border:1px solid transparent;
  background:var(--ink);color:#fff;cursor:pointer;
  transition:transform var(--transition),background var(--transition),box-shadow var(--transition),color var(--transition);
  text-align:center;white-space:nowrap;
}
.btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover{
  background:#23262b;color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)
}
.btn-accent,.woocommerce a.button.alt,.woocommerce button.button.alt{background:var(--accent)}
.btn-accent:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--accent-ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--bg-soft);color:var(--ink);border-color:var(--ink)}
.btn-lg{padding:17px 34px;font-size:1.02rem}
.btn-block{display:flex;width:100%}

/* =========================================================
   5. Header
   ========================================================= */
.announce-bar{background:var(--ink);color:#fff;text-align:center;font-size:.84rem;letter-spacing:.01em;padding:9px 16px}
.announce-bar strong{color:#fff}
.announce-bar a{color:#fff;text-decoration:underline;text-underline-offset:3px}

.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.18rem;letter-spacing:-.03em;color:var(--ink);flex-shrink:0;justify-self:start}
.brand:hover{color:var(--ink)}
.brand .brand-mark{width:30px;height:30px;flex:0 0 auto}
.brand img.custom-logo{max-height:38px;width:auto}

.primary-nav{display:flex;align-items:center;gap:4px;justify-self:center}
.primary-nav ul{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.primary-nav a{display:inline-block;padding:9px 12px;border-radius:999px;font-weight:500;font-size:.95rem;color:var(--ink-2);white-space:nowrap}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--ink);background:var(--bg-soft)}
/* Dropdowns (desktop) */
.primary-nav li{position:relative}
.primary-nav .menu-item-has-children>a{display:inline-flex;align-items:center;gap:5px}
.primary-nav .menu-item-has-children>a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform var(--transition);opacity:.6}
.primary-nav .menu-item-has-children:hover>a::after,.primary-nav .menu-item-has-children.open>a::after{transform:rotate(225deg) translateY(0);opacity:1}
.primary-nav .sub-menu{position:absolute;top:100%;left:0;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;margin:0;list-style:none;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity var(--transition),transform var(--transition),visibility var(--transition);z-index:70}
.primary-nav .menu-item-has-children:hover>.sub-menu,.primary-nav .menu-item-has-children.open>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.primary-nav .sub-menu li{position:static}
.primary-nav .sub-menu a{display:block;padding:10px 13px;border-radius:9px;font-size:.92rem;color:var(--ink-2);white-space:nowrap}
.primary-nav .sub-menu a:hover{background:var(--bg-soft);color:var(--ink)}

.header-actions{display:flex;align-items:center;gap:6px;justify-self:end}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;color:var(--ink);background:transparent;border:none;cursor:pointer;position:relative;transition:background var(--transition)}
.icon-btn:hover{background:var(--bg-soft);color:var(--ink)}
.icon-btn svg{width:21px;height:21px}
.cart-count{position:absolute;top:4px;right:3px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);color:#fff;font-size:.66rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.cart-count:empty,.cart-count.is-zero{display:none}

.menu-toggle{display:none}

/* Overlay de búsqueda */
.search-overlay{position:fixed;top:0;left:0;right:0;z-index:200;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity var(--transition),visibility var(--transition)}
.search-overlay.open{transform:translateY(0);opacity:1;visibility:visible}
.search-overlay .container{display:flex;align-items:center;min-height:84px}
.search-overlay__form{display:flex;align-items:center;gap:14px;width:100%}
.search-overlay__form>svg{width:24px;height:24px;color:var(--muted);flex:0 0 auto}
.search-overlay__form input{flex:1;min-width:0;border:none;outline:none;font-size:clamp(1.1rem,2vw,1.4rem);font-family:inherit;color:var(--ink);background:transparent;padding:10px 0}
.search-overlay__form input::placeholder{color:var(--muted)}

/* mobile drawer */
.mobile-nav{position:fixed;inset:0 0 0 auto;width:min(86vw,340px);background:#fff;z-index:120;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);padding:22px;overflow-y:auto;display:flex;flex-direction:column}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav ul{list-style:none;margin:18px 0 0;padding:0}
.mobile-nav li{border-bottom:1px solid var(--line-2)}
.mobile-nav a{display:block;padding:15px 4px;font-size:1.05rem;font-weight:500}
/* Acordeón móvil */
.mobile-nav .menu-item-has-children>a{display:flex;align-items:center;justify-content:space-between}
.mobile-nav .menu-item-has-children>a::after{content:"";width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform var(--transition);opacity:.5;flex:0 0 auto;margin-right:6px}
.mobile-nav .menu-item-has-children.open>a::after{transform:rotate(225deg)}
.mobile-nav .sub-menu{list-style:none;margin:0;padding:0 0 6px 10px;max-height:0;overflow:hidden;transition:max-height .28s ease}
.mobile-nav .menu-item-has-children.open>.sub-menu{max-height:600px}
.mobile-nav .sub-menu li{border-bottom:none}
.mobile-nav .sub-menu a{padding:11px 4px;font-size:.98rem;font-weight:400;color:var(--ink-2)}
.mobile-nav-head{display:flex;align-items:center;justify-content:space-between}
.nav-overlay{position:fixed;inset:0;background:rgba(11,12,14,.45);z-index:110;opacity:0;visibility:hidden;transition:opacity var(--transition)}
.nav-overlay.open{opacity:1;visibility:visible}

/* =========================================================
   6. Hero
   ========================================================= */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--bg-soft-2),#fff)}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-block:clamp(56px,8vw,110px)}
.hero-copy h1{margin-bottom:18px}
.hero-copy .lead{font-size:1.18rem;color:var(--ink-2);max-width:34ch;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-trust div{font-size:.85rem;color:var(--muted)}
.hero-trust strong{display:block;font-size:1.5rem;color:var(--ink);letter-spacing:-.03em}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:340px}
.hero-orbit{width:100%;max-width:460px;aspect-ratio:1;position:relative}
.hero-card{position:absolute;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px;display:flex;align-items:center;gap:12px;font-size:.9rem;font-weight:600}
.hero-card .dot{width:38px;height:38px;border-radius:11px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.hero-card.c1{top:8%;left:-4%}
.hero-card.c2{bottom:14%;right:-6%}
.hero-card.c3{bottom:-2%;left:14%}

/* =========================================================
   7. Feature strip
   ========================================================= */
.feature-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-block:34px}
.feature{display:flex;align-items:center;gap:14px}
.feature .fi{width:44px;height:44px;border-radius:12px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;color:var(--ink);flex:0 0 auto}
.feature .fi svg{width:22px;height:22px}
.feature h4{margin:0;font-size:.97rem}
.feature p{margin:0;font-size:.83rem;color:var(--muted)}

/* =========================================================
   8. Product grid (custom + WooCommerce)
   ========================================================= */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;list-style:none;margin:0;padding:0}
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(4,1fr);gap:26px;margin:0!important;padding:0!important;list-style:none!important}
/* Neutraliza el clearfix de WooCommerce: en grid, ::before/::after crean celdas fantasma */
.woocommerce ul.products::before,
.woocommerce ul.products::after{content:none!important;display:none!important}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{width:auto!important;margin:0!important;float:none!important;text-align:left}

/* --- Tarjeta de producto --- */
.product-card,
.woocommerce ul.products li.product{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)
}
.woocommerce ul.products li.product:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}

/* Imagen del producto sobre blanco (sin fondo gris) */
.woocommerce ul.products li.product a img{
  margin:0!important;width:100%;aspect-ratio:1;object-fit:contain;
  background:#fff;border-radius:0;padding:20px;
  transition:transform .45s cubic-bezier(.4,0,.2,1);
}
.woocommerce ul.products li.product:hover a img{transform:scale(1.04)}

/* Título y precio */
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  padding:0 18px!important;margin:14px 0 0!important;font-size:.92rem!important;font-weight:500;
  letter-spacing:-.005em;color:var(--ink);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.55em
}
.woocommerce ul.products li.product .price{padding:0 18px;color:var(--ink)!important;font-weight:700;font-size:1.02rem;margin:7px 0 0;display:flex;align-items:baseline;gap:8px}
.woocommerce ul.products li.product .price del{color:var(--muted)!important;font-weight:500;font-size:.85rem;opacity:1;margin:0;order:2}
.woocommerce ul.products li.product .price ins{text-decoration:none;order:1}
.woocommerce ul.products li.product .star-rating{margin:8px 18px 0;font-size:.76em}

/* Add to cart: contorno minimal que se rellena al hover; alineado al fondo */
.woocommerce ul.products li.product .button{
  margin:12px 18px 18px!important;margin-top:auto!important;border-radius:10px;
  padding:9px 14px;font-size:.8rem;font-weight:500;
  background:var(--bg-soft);color:var(--ink);border:1px solid var(--line);
}
.woocommerce ul.products li.product .button:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:none;box-shadow:none}
.woocommerce ul.products li.product .added_to_cart{margin:0 18px 18px;text-align:center;font-weight:600;color:var(--accent)}
/* El botón "Add to cart" está siempre visible; la card mantiene su efecto hover. */

/* Badge minimalista (porcentaje de descuento / Nuevo) */
.woocommerce span.onsale,.product-card .badge{
  position:absolute;z-index:3;min-height:auto;min-width:auto;
  background:rgba(11,12,14,.92);color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.01em;
  padding:5px 9px;border-radius:8px;margin:0;line-height:1
}
/* Posición forzada dentro de la tarjeta (gana a la regla de WooCommerce y evita el recorte) */
.woocommerce ul.products li.product span.onsale,
.woocommerce ul.products li.product .onsale{top:12px!important;left:12px!important;right:auto!important;bottom:auto!important}
.product-card .badge.new{background:var(--accent)}

/* =========================================================
   9. Category cards
   ========================================================= */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cat-card{display:block;border-radius:18px;overflow:hidden;background:#fff;border:1px solid var(--line);color:var(--ink);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;color:var(--ink)}
.cat-card .cat-thumb{display:flex;align-items:center;justify-content:center;aspect-ratio:16/10;background:var(--bg-soft);padding:22px}
.cat-card .cat-thumb img{width:auto;height:auto;max-width:76%;max-height:80%;object-fit:contain;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.cat-card:hover .cat-thumb img{transform:scale(1.06)}
.cat-card .cat-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px}
.cat-card .cat-name{font-weight:600;font-size:1.02rem;letter-spacing:-.01em}
.cat-card .cat-count{font-size:.82rem;color:var(--muted);white-space:nowrap}

/* =========================================================
   10. CTA band + newsletter
   ========================================================= */
.cta-band{background:var(--ink);color:#fff;border-radius:24px;padding:clamp(36px,5vw,64px);text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.75);max-width:50ch;margin-inline:auto}
.newsletter-form{display:flex;gap:10px;max-width:440px;margin:24px auto 0}
.newsletter-form input{flex:1;padding:14px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-size:.95rem}
.newsletter-form input::placeholder{color:rgba(255,255,255,.55)}
.newsletter-form .btn{background:#fff;color:var(--ink)}
.newsletter-form .btn:hover{background:#e9ebee;color:var(--ink)}

/* =========================================================
   11. Footer
   ========================================================= */
.site-footer{background:var(--bg-soft);border-top:1px solid var(--line);margin-top:0}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-block:clamp(44px,5vw,72px)}
.footer-brand .brand{margin-bottom:14px}
.footer-brand p{color:var(--muted);font-size:.92rem;max-width:34ch}
.footer-col h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:16px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--ink-2);font-size:.93rem}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--line);padding-block:22px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-bottom p{margin:0;color:var(--muted);font-size:.85rem}
.footer-legal{display:flex;flex-wrap:wrap;gap:18px}
.footer-legal a{color:var(--ink-2);font-size:.85rem}
.footer-legal a:hover{color:var(--accent)}
.pay-icons{display:flex;gap:8px;align-items:center}
.pay-icons span{font-size:.72rem;font-weight:700;letter-spacing:.03em;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:6px;padding:4px 8px}
.social{display:flex;gap:8px}
.social a{width:36px;height:36px;border-radius:999px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink)}
.social a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.social svg{width:17px;height:17px}

/* =========================================================
   12. WooCommerce general
   ========================================================= */
.woocommerce-breadcrumb{color:var(--muted);font-size:.86rem;margin-bottom:22px}
.woocommerce-breadcrumb a{color:var(--muted)}
.woocommerce-breadcrumb a:hover{color:var(--accent)}
.shop-wrap{padding-block:clamp(32px,4vw,56px)}
.woocommerce .woocommerce-result-count{color:var(--muted);font-size:.9rem}
.woocommerce .woocommerce-ordering select{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;font-family:inherit}

/* Paginación */
.woocommerce nav.woocommerce-pagination{margin-top:clamp(40px,5vw,60px);text-align:center;border:none}
.woocommerce nav.woocommerce-pagination ul{display:inline-flex;flex-wrap:wrap;justify-content:center;gap:8px;border:none!important;margin:0;padding:0}
.woocommerce nav.woocommerce-pagination ul li{border:none!important;margin:0;overflow:visible;display:flex}
.woocommerce nav.woocommerce-pagination ul li a.page-numbers,
.woocommerce nav.woocommerce-pagination ul li span.page-numbers{
  display:flex;align-items:center;justify-content:center;
  min-width:44px;height:44px;padding:0 13px;border-radius:12px;
  border:1px solid var(--line)!important;background:#fff;color:var(--ink);
  font-weight:600;font-size:.92rem;line-height:1;transition:background var(--transition),border-color var(--transition),color var(--transition)
}
.woocommerce nav.woocommerce-pagination ul li a.page-numbers:hover{background:var(--bg-soft);border-color:var(--ink-2);color:var(--ink)}
.woocommerce nav.woocommerce-pagination ul li span.page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink)!important}
.woocommerce nav.woocommerce-pagination ul li span.page-numbers.dots{border:none!important;background:transparent;min-width:24px;color:var(--muted)}
.page-title-band{padding-block:clamp(28px,4vw,52px) 0;text-align:center}
.page-title-band h1{margin-bottom:6px}
.page-title-band p{color:var(--muted)}

/* Layout tienda con filtros */
.shop-layout{display:grid;grid-template-columns:250px 1fr;gap:36px;align-items:start}
.shop-main{min-width:0}
.shop-main ul.products{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))!important}
.shop-main.is-loading{position:relative}
.shop-main.is-loading ul.products,.shop-main.is-loading .woocommerce-info{opacity:.4;transition:opacity .2s;pointer-events:none}
.shop-filters{position:sticky;top:90px}
.filters-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.filters-head h3{margin:0;font-size:1.1rem}
.filters-clear{font-size:.82rem;color:var(--accent);font-weight:600}
.filter-search{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:10px;padding:0 12px;margin:14px 0 4px}
.filter-search svg{width:17px;height:17px;color:var(--muted);flex:0 0 auto}
.filter-search input{flex:1;min-width:0;border:none;outline:none;background:transparent;font-family:inherit;font-size:.92rem;padding:11px 0;color:var(--ink)}
.filter-search input::placeholder{color:var(--muted)}
.filter-group{padding:20px 0;border-top:1px solid var(--line)}
.filter-group h4{margin:0 0 12px;font-size:.78rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted)}
.filter-group h4.filter-group-spacer{margin-top:22px}
.filter-cats{list-style:none;margin:0;padding:0}
.filter-cats a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 11px;border-radius:9px;color:var(--ink-2);font-size:.92rem}
.filter-cats a:hover{background:var(--bg-soft);color:var(--ink)}
.filter-cats a.is-active{background:var(--ink);color:#fff}
.filter-cats a.is-active .c-count{color:rgba(255,255,255,.65)}
.filter-cats .c-count{font-size:.78rem;color:var(--muted);font-variant-numeric:tabular-nums}
.price-presets{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:1px}
.price-presets a{display:block;padding:7px 11px;border-radius:8px;font-size:.9rem;color:var(--ink-2)}
.price-presets a:hover{background:var(--bg-soft);color:var(--ink)}
.price-presets a.is-active{color:var(--accent);font-weight:600;background:var(--accent-soft)}
.price-inputs{display:flex;align-items:center;gap:8px}
.price-inputs input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:.9rem}
.price-inputs span{color:var(--muted)}
.filter-check{display:flex;align-items:center;gap:10px;padding:7px 2px;font-size:.92rem;color:var(--ink-2);cursor:pointer}
.filter-check input{width:17px;height:17px;accent-color:var(--ink);cursor:pointer;flex:0 0 auto}
.filter-check span:first-of-type{flex:1}
.filter-brands{max-height:236px;overflow-y:auto;margin-right:-6px;padding-right:4px}
.filter-brands .filter-check{padding:6px 2px}
.filter-brands .c-count{font-size:.78rem;color:var(--muted);font-variant-numeric:tabular-nums}
.filter-brands::-webkit-scrollbar{width:6px}
.filter-brands::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}
.filter-form .btn{margin-top:18px}
.filters-toggle{display:none;align-items:center;gap:8px;margin-bottom:20px;padding:11px 18px;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:600;font-size:.9rem;cursor:pointer}
.filters-toggle svg{width:18px;height:18px}
.filters-toggle:hover{background:var(--bg-soft)}

@media(max-width:860px){
  .shop-layout{grid-template-columns:1fr}
  .filters-toggle{display:inline-flex}
  .shop-filters{position:static;display:none;border:1px solid var(--line);border-radius:16px;padding:20px 22px;margin-bottom:24px}
  .shop-filters.open{display:block}
}

/* Single product */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);margin-top:8px;align-items:start}
.woocommerce div.product .woocommerce-product-gallery{margin:0!important;float:none!important;width:100%!important;position:sticky;top:92px}
.woocommerce div.product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper{width:100%;margin:0}
/* Imagen enmarcada en un tile (contain, nunca estirada) */
.woocommerce div.product .woocommerce-product-gallery__image{
  background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:8%
}
.woocommerce div.product .woocommerce-product-gallery__image a{display:flex;width:100%;height:100%;align-items:center;justify-content:center}
.woocommerce div.product .woocommerce-product-gallery img{
  width:auto!important;max-width:100%;max-height:100%;height:auto;object-fit:contain;border-radius:0;margin:0
}
.woocommerce div.product .woocommerce-product-gallery__trigger{top:1rem;right:1rem;z-index:3}

.woocommerce div.product .summary{margin:0!important;float:none!important;width:auto!important}
.woocommerce div.product .product_title{font-size:clamp(1.8rem,3vw,2.4rem);margin-bottom:12px;letter-spacing:-.02em;line-height:1.1}
.woocommerce div.product .woocommerce-product-details__short-description{color:var(--ink-2);font-size:1.02rem;line-height:1.6;margin:0 0 6px}

/* Precio */
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink);font-size:1.75rem;font-weight:700;display:flex;align-items:baseline;flex-wrap:wrap;gap:12px;margin:14px 0}
.woocommerce div.product p.price del,.woocommerce div.product span.price del{color:var(--muted);font-weight:500;font-size:1.1rem;opacity:1;order:2}
.woocommerce div.product p.price ins,.woocommerce div.product span.price ins{text-decoration:none;order:1}

/* Stock */
.woocommerce div.product .stock.in-stock{color:var(--success);font-size:.88rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;margin:0 0 20px}
.woocommerce div.product .stock.in-stock::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--success)}
.woocommerce div.product .stock.out-of-stock{color:var(--danger);font-weight:600;margin:0 0 20px}

/* Cantidad + Add to cart */
.woocommerce div.product form.cart{margin:4px 0 0;display:flex;align-items:stretch;gap:12px}
.woocommerce .quantity{display:flex}
.woocommerce .quantity .qty{width:78px;height:54px;padding:0 10px;border:1px solid var(--line);border-radius:12px;text-align:center;font-family:inherit;font-size:1rem}
.woocommerce div.product form.cart .button{height:54px;display:inline-flex;align-items:center;justify-content:center;padding:0 32px;border-radius:12px;background:var(--ink);border:1px solid var(--ink);color:#fff;font-size:.95rem}
.woocommerce div.product form.cart .button:hover{background:#23262b;border-color:#23262b;color:#fff}

/* Fila de confianza */
.po-trust{list-style:none;margin:24px 0 0;padding:22px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:13px}
.po-trust li{display:flex;align-items:center;gap:12px;font-size:.92rem;color:var(--ink-2)}
.po-trust svg{width:20px;height:20px;color:var(--ink);flex:0 0 auto}

/* Meta */
.woocommerce div.product .product_meta{margin-top:22px;font-size:.85rem;color:var(--muted)}
.woocommerce div.product .product_meta>span{display:block;margin-bottom:5px}
.woocommerce div.product .product_meta a{color:var(--ink-2)}

/* Relacionados / upsells */
.woocommerce div.product .related,.woocommerce div.product .upsells{grid-column:1/-1;margin-top:clamp(44px,6vw,72px);border-top:1px solid var(--line);padding-top:clamp(32px,4vw,48px)}
.woocommerce div.product .related>h2,.woocommerce div.product .upsells>h2{font-size:clamp(1.4rem,2.5vw,1.9rem);letter-spacing:-.02em;margin-bottom:30px}
.woocommerce div.product .related ul.products,.woocommerce div.product .upsells ul.products{grid-template-columns:repeat(4,1fr)!important}
.woocommerce div.product .woocommerce-tabs{grid-column:1/-1;margin-top:24px}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;border-bottom:1px solid var(--line)}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:none;border:none;border-radius:0;margin:0 18px 0 0;padding:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:14px 0;font-weight:600;color:var(--muted)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--ink);box-shadow:inset 0 -2px 0 var(--ink)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{border:none}

/* Cart & checkout */
.woocommerce table.shop_table{border-radius:var(--radius);border-color:var(--line);overflow:hidden}
.woocommerce table.shop_table th{font-weight:600}
.woocommerce .cart-collaterals .cart_totals,.woocommerce-checkout #order_review{border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select,.woocommerce-page form .form-row input.input-text,#add_payment_method .form-row input.input-text{border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;font-family:inherit}
.woocommerce #respond input#submit.alt,.woocommerce a.button.alt,.woocommerce button.button.alt{}

/* notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-radius:var(--radius-sm);border-top:none;padding:16px 18px 16px 46px}
.woocommerce-message{border-left:4px solid var(--success);background:#f1faf4}
.woocommerce-info{border-left:4px solid var(--accent);background:var(--accent-soft)}
.woocommerce-error{border-left:4px solid var(--danger);background:#fdf2f1}
.woocommerce-message::before{color:var(--success)}
.woocommerce-info::before{color:var(--accent)}

/* =========================================================
   My Account (dashboard)
   ========================================================= */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation){display:grid;grid-template-columns:250px 1fr;gap:36px;align-items:start}
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) .woocommerce-notices-wrapper{grid-column:1/-1}
.woocommerce-account .woocommerce-MyAccount-navigation{grid-column:1;width:auto!important;float:none!important;position:sticky;top:90px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px}
.woocommerce-account .woocommerce-MyAccount-content{grid-column:2;width:auto!important;float:none!important}
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;margin:0;padding:0}
.woocommerce-account .woocommerce-MyAccount-navigation li{margin:0;border:none}
.woocommerce-account .woocommerce-MyAccount-navigation li a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;color:var(--ink-2);font-weight:500;font-size:.95rem;transition:background var(--transition),color var(--transition)}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{background:var(--bg-soft);color:var(--ink)}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{background:var(--ink);color:#fff}
.woocommerce-account .woocommerce-MyAccount-navigation .acc-ico{display:flex;flex:0 0 auto}
.woocommerce-account .woocommerce-MyAccount-navigation .acc-ico svg{width:19px;height:19px}
.woocommerce-account .woocommerce-MyAccount-navigation-link--customer-logout a{color:var(--danger)}
.woocommerce-account .woocommerce-MyAccount-navigation-link--customer-logout.is-active a{color:#fff}

.woocommerce-account .woocommerce-MyAccount-content{min-width:0}
.woocommerce-account .woocommerce-MyAccount-content p{color:var(--ink-2);line-height:1.7}
.woocommerce-account .woocommerce-MyAccount-content a:not(.button){color:var(--accent)}
.woocommerce-account .woocommerce-MyAccount-content h2,.woocommerce-account .woocommerce-MyAccount-content h3{margin:0 0 16px;letter-spacing:-.01em}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:6px}
.woocommerce-account .woocommerce-Addresses::before,
.woocommerce-account .woocommerce-Addresses::after{content:none!important;display:none!important}
.woocommerce-account .woocommerce-Addresses .u-column1,
.woocommerce-account .woocommerce-Addresses .u-column2{width:auto!important;float:none!important;margin:0!important}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address{border:1px solid var(--line);border-radius:14px;padding:22px}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address .title h2,.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address .title h3{margin:0;font-size:1.05rem}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address address{font-style:normal;color:var(--ink-2);line-height:1.7}
.woocommerce-account .woocommerce-orders-table__cell-order-actions a.button,.woocommerce-account .woocommerce-MyAccount-content .button{font-size:.85rem}

@media(max-width:860px){
  .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation){grid-template-columns:1fr}
  .woocommerce-account .woocommerce-MyAccount-navigation{position:static}
  .woocommerce-account .woocommerce-MyAccount-navigation ul{display:flex;flex-wrap:wrap;gap:6px}
  .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses{grid-template-columns:1fr}
}

/* =========================================================
   13. Content pages
   ========================================================= */
.page-content{padding-block:clamp(40px,5vw,72px)}
.entry-content{max-width:760px;margin-inline:auto}
/* Cart / Checkout / Account: usan todo el ancho del contenedor (no la columna de lectura) */
.wc-page-content{max-width:none;width:100%}
.wc-page-content .wc-block-checkout,
.wc-page-content .wp-block-woocommerce-checkout,
.wc-page-content .wp-block-woocommerce-cart,
.wc-page-content .wc-block-cart{max-width:none!important;width:100%!important}
.entry-content img{border-radius:var(--radius);margin-block:1.4em}
.post-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow var(--transition)}
.post-card:hover{box-shadow:var(--shadow)}

/* =========================================================
   14. Responsive
   ========================================================= */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .feature-grid{grid-template-columns:repeat(2,1fr);gap:20px 28px}
  .products-grid,.woocommerce ul.products{grid-template-columns:repeat(3,1fr)!important}
}
@media(max-width:860px){
  .primary-nav{display:none}
  .menu-toggle{display:inline-flex}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-visual{order:-1;min-height:280px}
  .cat-grid{grid-template-columns:1fr 1fr}
  .woocommerce div.product{grid-template-columns:1fr}
}
@media(max-width:600px){
  .hide-on-mobile{display:none!important}
}
@media(max-width:640px){
  .products-grid,.woocommerce ul.products{grid-template-columns:repeat(2,1fr)!important;gap:16px}
  .feature-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .cat-grid{grid-template-columns:1fr}
  .hero-trust{gap:18px}
  .newsletter-form{flex-direction:column}
  .newsletter-form .btn{width:100%}
}
@media(max-width:420px){
  .footer-top{grid-template-columns:1fr}
}
@media(max-width:360px){
  .products-grid,.woocommerce ul.products{grid-template-columns:1fr!important}
}
